Installing and Using GNUstep and Objective-C on Linux
One of the great things about Linux is the shear number of different distributions available to choose from. This is the result of the power of open source software combined with vibrant communities of dedicated developers who believe passionately about this powerful and flexible operating system. It also gives the end user the opportunity to find a Linux distribution that best suits their needs (and, perhaps, just a few headaches during the decision process).
Unfortunately, this diversity can prove to be a considerable obstacle to an author of a book trying to write a chapter on how to install a particular software package on Linux. The sheer diversity of the Linux marketplace makes providing instructions for every available Linux distribution beyond the scape of this book such as this. Instead this chapter will look at one distribution for which pre-built packages are available (Ubuntu Linux) and then provide an overview of how to build the necessary packages from sources on a platform for which pre-built packages are not available (Red Hat Enterprise Linux). It is anticipated that these steps should ultimately provide a path to Objective-C development on the majority of Linux distributions on the market today.
Package Requirements
The basics of Objective-C are supported by the GNU compiler collection. In order to utilize the full power of Objective-C together with the Cocoa /openStep environments, and to work with many of the examples covered in this book, it is necessary to install gcc, the gcc Objective-C support package and the GNUstep environment.
Installing GNUstep on Ubuntu
Fortunately for Ubuntu users, all the GNUstep and gcc Objective-C packages are available and ready to install from the Ubuntu repositories. To install GNUstep, therefore, open a Terminal window on your Ubuntu desktop (Applications->Accessories->Terminal) and enter the following command (together with your password when prompted):
sudo apt-get install gnustep
The apt-get utility will gather together a list of all the packages required for a successful GNUstep runtime installation and ask for confirmation that the installation is to proceed. Once confirmation is provided, the packages will be downloaded and installed onto the system.
The next step is to install the GNUstep development packages. This is achieved using the following command:
sudo apt-get install gnustep-devel
Once again apt-get will list the packages required and seek confirmation before performing the installation process.
Once the installation is complete, it can be tested by opening your favorite editor (if you don't have a favorite try GEdit by selecting Applications->Accessories->Text Editor) and entering some Objective-C code:
#import <Foundation/Foundation.h> int main (int argc, const char * argv[]) { NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init]; NSLog (@"hello world"); [pool drain]; return 0; }
Objective-C source files have a .m file name extension, so save the file as hello.m in a suitable folder such that you will be able to locate the file in the next section.
Compiling Objective-C Code
Before an Objective-C program can be run it must first be compiled. Complication is a process whereby the human readable Objective-C code in the source file (in our case hello.m) is converted to the machine code understood by the CPU. Prior to performing this compilation, however, the GNUstep environment must first be set up. Thankfully, a shell script is provided to perform this task for us and may be executed as follows:
. /usr/share/GNUstep/Makefiles/GNUstep.sh
Note that this setup script will need to be executed each time you start a new Terminal window with the intention of compiling Objective-C. For this reason, you may find it advantageous to add it to the .bashrc file in your home directory so that it gets executed automatically. Failure to execute this script prior to compiling Objective-C code in a Terminal window will result in the compiler reporting errors similar to the following:
error: cannot find interface declaration for ‘NXConstantString’
From within a Terminal window change directory to the where you saved the hello.m source file and execute the following command to compile it:
gcc `gnustep-config --objc-flags` -lgnustep-base hello.m -o hello
If all goes well, the compilation should complete silently and the test application is ready to run. If, on the other hand, you see an error message similar to the following then an additional package needs to be installed on your system:
gcc: error trying to exec 'cc1obj': execvp: No such file or directory
The missing package is called gobjc and may be installed from a Terminal window using the following command:
sudo apt-get install gobjc
Once the installation is complete, attempt to compile the test application again. Assuming a successful compilation is achieved, the program may be executed as follows:
./hello
Executing the program will result in output similar to the following:
2009-09-15 10:48:39.772 prog1[12906] hello world