Difference between revisions of "GNUstep under Ubuntu Linux"

From GNUstepWiki
Jump to navigation Jump to search
(Updated for CMake)
m (Update intro and explain compilation at bottom of page.)
(34 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 +
Objective-C under Ubuntu Linux
 +
 +
== Compiling manually ==
 +
 +
The compilation instructions below are divided into two steps.
 +
The first step compiles the *base* (non-graphical) parts of GNUStep, including setting up the Objective-C compiler.
 +
The second step compiles the graphical parts of GNUStep. 
 +
 +
Some notes:
 +
 +
* We use clang and libobjc2 for all the new features like ARC, Blocks, etc.
 +
* Tested on fresh installs of (and likely with a more completed installation of):
 +
* Ubuntu 12.10 Server.
 +
* Ubuntu 13.10 Desktop.
 +
* Ubuntu 12.04 LTS Desktop, see bottom of the page for important info.
 +
 +
After installing everything below, you could install EtoileOS: see [[EtoileOS under Ubuntu Linux]].
 +
 
<pre>
 
<pre>
# Objective C 2.0 installation
+
sudo apt-get install aptitude
# On fresh install of Ubuntu 12.10 Server
+
# Dependencies
# Patryk Laurent (http://pakl.net/)
+
sudo aptitude -y install build-essential git subversion ninja cmake
# Dec 27, 2012
+
# Dependencies for GNUStep Base
 
+
sudo aptitude -y install libffi-dev libxml2-dev libgnutls-dev libicu-dev
sudo aptitude install build-essential git subversion ninja cmake
+
# Dependencies for libdispatch
 +
sudo aptitude -y install libblocksruntime-dev libkqueue-dev libpthread-workqueue-dev autoconf libtool
  
 +
cd ~
 +
git clone git://github.com/nickhutchinson/libdispatch.git
 +
svn co http://svn.gna.org/svn/gnustep/modules/core
 +
svn co http://svn.gna.org/svn/gnustep/libs/libobjc2/trunk libobjc2
 
svn co http://llvm.org/svn/llvm-project/llvm/trunk llvm
 
svn co http://llvm.org/svn/llvm-project/llvm/trunk llvm
 
cd llvm/tools
 
cd llvm/tools
 
svn co http://llvm.org/svn/llvm-project/cfe/trunk clang
 
svn co http://llvm.org/svn/llvm-project/cfe/trunk clang
cd .. # Back to llvm directory
 
./configure --enable-optimized
 
make -j4  # Go off to prepare cup of coffee here.
 
  
export PATH=$PATH:~/llvm/Release+Asserts/bin # Add to .bashrc
+
cd ~/llvm
export CC=clang  # Add to .bashrc
+
mkdir build
 +
cd build
 +
cmake ..
 +
make -j8  # 8=your number of build CPUs
 +
 
 +
echo "export PATH=\$PATH:~/llvm/build/bin" >> ~/.bashrc
 +
echo "export CC=clang" >> ~/.bashrc
 +
echo "export CXX=clang++" >> ~/.bashrc
 +
source ~/.bashrc
 
clang -v
 
clang -v
 +
clang++ -v
  
svn co http://svn.gna.org/svn/gnustep/modules/core
+
cd ~/libobjc2
svn co http://svn.gna.org/svn/gnustep/libs/libobjc2/trunk libobjc2
 
cd core/make
 
./configure --enable-debug-by-default --with-layout=gnustep
 
make && sudo -E make install
 
. /usr/GNUstep/System/Library/Makefiles/GNUstep.sh # Add to .bashrc
 
 
 
sudo aptitude install gobjc  # Otherwise we get "cc1obj not found
 
cd ../../libobjc2
 
 
mkdir build
 
mkdir build
 
cd build
 
cd build
 
cmake ..
 
cmake ..
make
+
make -j8
 +
sudo -E make install
 +
 
 +
cd ~/core/make
 +
./configure --enable-debug-by-default --with-layout=gnustep --enable-objc-nonfragile-abi
 +
make && sudo -E make install
 +
echo ". /usr/GNUstep/System/Library/Makefiles/GNUstep.sh" >> ~/.bashrc
 +
source ~/.bashrc
 +
 
 +
sudo /sbin/ldconfig
 +
 
 +
cd ~/core/base/
 +
./configure
 +
make -j8
 +
sudo -E make install
 +
 
 +
cd ~/libdispatch
 +
sh autogen.sh
 +
./configure CFLAGS="-I/usr/include/kqueue" LDFLAGS="-lkqueue -lpthread_workqueue -pthread -lm"
 +
make -j8
 
sudo -E make install
 
sudo -E make install
 +
sudo ldconfig
 +
 +
# ----------------------------------------------------------------------------------------
 +
# TEST COMPILING SOME CODE FROM THE INTERNET
 +
# ----------------------------------------------------------------------------------------
 +
 +
You can compile the following code with:
 +
 +
clang `gnustep-config --objc-flags` `gnustep-config --objc-libs` -fobjc-runtime=gnustep -fblocks -fobjc-arc -lobjc  blocktest.m
 +
 +
clang `gnustep-config --objc-flags` `gnustep-config --objc-libs` -fobjc-runtime=gnustep -fblocks -lobjc -ldispatch -lgnustep-base  Fraction.m helloGCD_objc.m
 +
 +
  
 
cat > blocktest.m << EOF
 
cat > blocktest.m << EOF
Line 45: Line 98:
 
EOF
 
EOF
  
clang `gnustep-config --objc-flags` `gnustep-config --objc-libs` -fobj-arc -fobjc-nonfragile-abi -fblocks  -lobjc blocktest.m  
+
cat > helloGCD_objc.m << EOF
 +
 
 +
#include <dispatch/dispatch.h>
 +
#import <stdio.h>
 +
#import "Fraction.h"
 +
 
 +
int main( int argc, const char *argv[] ) {
 +
  dispatch_queue_t queue = dispatch_queue_create(NULL, NULL);
 +
  Fraction *frac = [[Fraction alloc] init];
 +
 
 +
  [frac setNumerator: 1];
 +
  [frac setDenominator: 3];
 +
 
 +
  // print it
 +
  dispatch_sync(queue, ^{
 +
    printf( "The fraction is: " );
 +
    [frac print];
 +
    printf( "\n" );
 +
  });
 +
  dispatch_release(queue);
 +
 
 +
  return 0;
 +
}
 +
 
 +
EOF
 +
 
 +
cat > Fraction.h << EOF
 +
 
 +
#import <Foundation/NSObject.h>
 +
 
 +
@interface Fraction: NSObject {
 +
  int numerator;
 +
  int denominator;
 +
}
 +
 
 +
-(void) print;
 +
-(void) setNumerator: (int) n;
 +
-(void) setDenominator: (int) d;
 +
-(int) numerator;
 +
-(int) denominator;
 +
@end
 +
 
 +
EOF
 +
 
 +
 
 +
cat > Fraction.m << EOF
 +
#import "Fraction.h"
 +
#import <stdio.h>
 +
 
 +
@implementation Fraction
 +
-(void) print {
 +
  printf( "%i/%i", numerator, denominator );
 +
}
 +
 
 +
-(void) setNumerator: (int) n {
 +
  numerator = n;
 +
}
 +
 
 +
-(void) setDenominator: (int) d {
 +
  denominator = d;
 +
}
 +
 
 +
-(int) denominator {
 +
  return denominator;
 +
}
 +
 
 +
-(int) numerator {
 +
  return numerator;
 +
}
 +
@end
 +
 
 +
EOF
 +
 
 +
 
 +
# ------------------------------------------------------
 +
# STEP 2:  INSTALLING GUI AND BACK
 +
# (i.e., if you're running Ubuntu Desktop)
 +
# ------------------------------------------------------
 +
 
 +
sudo aptitude install -y libjpeg-dev libtiff-dev libffi-dev
 +
sudo aptitude install -y libcairo-dev libx11-dev:i386 libxt-dev
 +
 
 +
cd ~/core/gui
 +
./configure
 +
make -j8
 +
sudo -E make install
 +
 
 +
cd ~/core/back
 +
./configure
 +
make -j8
 +
sudo -E make install
 +
 
 +
You can compile the following code with:
 +
 
 +
clang `gnustep-config --objc-flags` `gnustep-config --objc-libs` -fobjc-runtime=gnustep -fblocks -lobjc -fobjc-arc -ldispatch -lgnustep-base -lgnustep-gui guitest.m
 +
 
 +
 
 +
 
 +
cat > guitest.m << EOF
 +
#import <AppKit/AppKit.h>
 +
 
 +
int main()
 +
{
 +
NSApplication *app;  // Without these 2 lines, seg fault may occur
 +
app = [NSApplication sharedApplication];
 +
 
 +
NSAlert * alert = [[NSAlert alloc] init];
 +
[alert setMessageText:@"Hello alert"];
 +
[alert addButtonWithTitle:@"All done"];
 +
[alert runModal];
 +
}
 +
EOF
 +
 
 +
 
 
</pre>
 
</pre>
 +
 +
 +
* General Note: When compiling your own code, it is generally good to tell clang both the family and version of the runtime: -fobjc-runtime=gnustep-1.7
 +
(The current version number can be had by looking at the latest ANNOUNCE filename in http://svn.gna.org/svn/gnustep/libs/libobjc2/trunk/ (e.g., ANNOUNCE.1.7))
 +
 +
 +
<b>Ubuntu 12.04 Help</b>
 +
 +
On Ubuntu 12.04, the default installed version of CMake is 2.8.7 but you need 2.8.8 or later to compile LLVM.  And the default installed version of GCC and G++ is 4.6 but you need 4.8 or later to compile LLVM.
 +
 +
For CMake, the solution is to download and compile CMake yourself.  Use the existing CMake 2.8.7 and then replace it:
 +
 +
# Download the latest CMake version from the CMake web site (http://www.cmake.org/cmake/resources/software.html), and uncompress it in a folder.
 +
# Create a _build directory in the CMake sources folder.
 +
# From the _build directory, run the following commands to build and install CMake from sources:
 +
 +
<pre>
 +
cmake .. -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr
 +
make
 +
cpack -G DEB
 +
sudo apt-get remove cmake cmake-data
 +
sudo dpkg -i cmake*.deb
 +
</pre>
 +
 +
To get GCC and G++ 4.8, do the following:
 +
 +
<pre>
 +
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
 +
sudo apt-get update
 +
sudo apt-get install gcc-4.8 g++-4.8
 +
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.8 50
 +
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.8 50
 +
</pre>
 +
 +
You should be good to go.

Revision as of 16:12, 5 June 2014

Objective-C under Ubuntu Linux

Compiling manually

The compilation instructions below are divided into two steps. The first step compiles the *base* (non-graphical) parts of GNUStep, including setting up the Objective-C compiler. The second step compiles the graphical parts of GNUStep.

Some notes:

  • We use clang and libobjc2 for all the new features like ARC, Blocks, etc.
  • Tested on fresh installs of (and likely with a more completed installation of):
  • Ubuntu 12.10 Server.
  • Ubuntu 13.10 Desktop.
  • Ubuntu 12.04 LTS Desktop, see bottom of the page for important info.

After installing everything below, you could install EtoileOS: see EtoileOS under Ubuntu Linux.

sudo apt-get install aptitude
# Dependencies
sudo aptitude -y install build-essential git subversion ninja cmake
# Dependencies for GNUStep Base
sudo aptitude -y install libffi-dev libxml2-dev libgnutls-dev libicu-dev 
# Dependencies for libdispatch
sudo aptitude -y install libblocksruntime-dev libkqueue-dev libpthread-workqueue-dev autoconf libtool

cd ~
git clone git://github.com/nickhutchinson/libdispatch.git
svn co http://svn.gna.org/svn/gnustep/modules/core
svn co http://svn.gna.org/svn/gnustep/libs/libobjc2/trunk libobjc2
svn co http://llvm.org/svn/llvm-project/llvm/trunk llvm
cd llvm/tools
svn co http://llvm.org/svn/llvm-project/cfe/trunk clang

cd ~/llvm
mkdir build
cd build
cmake ..
make -j8   # 8=your number of build CPUs

echo "export PATH=\$PATH:~/llvm/build/bin" >> ~/.bashrc
echo "export CC=clang"  >> ~/.bashrc
echo "export CXX=clang++" >> ~/.bashrc
source ~/.bashrc
clang -v
clang++ -v

cd ~/libobjc2
mkdir build
cd build
cmake ..
make -j8
sudo -E make install

cd ~/core/make
./configure --enable-debug-by-default --with-layout=gnustep --enable-objc-nonfragile-abi
make && sudo -E make install
echo ". /usr/GNUstep/System/Library/Makefiles/GNUstep.sh" >> ~/.bashrc
source ~/.bashrc

sudo /sbin/ldconfig

cd ~/core/base/
./configure
make -j8
sudo -E make install

cd ~/libdispatch
sh autogen.sh
./configure CFLAGS="-I/usr/include/kqueue" LDFLAGS="-lkqueue -lpthread_workqueue -pthread -lm"
make -j8
sudo -E make install
sudo ldconfig

# ----------------------------------------------------------------------------------------
# TEST COMPILING SOME CODE FROM THE INTERNET
# ----------------------------------------------------------------------------------------

You can compile the following code with:

clang `gnustep-config --objc-flags` `gnustep-config --objc-libs` -fobjc-runtime=gnustep -fblocks -fobjc-arc -lobjc  blocktest.m 

clang `gnustep-config --objc-flags` `gnustep-config --objc-libs` -fobjc-runtime=gnustep -fblocks -lobjc -ldispatch -lgnustep-base  Fraction.m helloGCD_objc.m



cat > blocktest.m << EOF
#include <stdio.h>

int main() {
    void (^hello)(void) = ^(void) {
        printf("Hello, block!\n");
    };
    hello();
    return 0;
}
EOF

cat > helloGCD_objc.m << EOF

#include <dispatch/dispatch.h>
#import <stdio.h>
#import "Fraction.h"

int main( int argc, const char *argv[] ) {
   dispatch_queue_t queue = dispatch_queue_create(NULL, NULL); 
   Fraction *frac = [[Fraction alloc] init];

   [frac setNumerator: 1];
   [frac setDenominator: 3];

   // print it
   dispatch_sync(queue, ^{
     printf( "The fraction is: " );
     [frac print];
     printf( "\n" );
   });
   dispatch_release(queue);

   return 0;
}

EOF

cat > Fraction.h << EOF

#import <Foundation/NSObject.h>

@interface Fraction: NSObject {
   int numerator;
   int denominator;
}

-(void) print;
-(void) setNumerator: (int) n;
-(void) setDenominator: (int) d;
-(int) numerator;
-(int) denominator;
@end

EOF


cat > Fraction.m << EOF
#import "Fraction.h"
#import <stdio.h>

@implementation Fraction
-(void) print {
   printf( "%i/%i", numerator, denominator );
}

-(void) setNumerator: (int) n {
   numerator = n;
}

-(void) setDenominator: (int) d {
   denominator = d;
}

-(int) denominator {
   return denominator;
}

-(int) numerator {
   return numerator;
}
@end

EOF


# ------------------------------------------------------
# STEP 2:  INSTALLING GUI AND BACK
# (i.e., if you're running Ubuntu Desktop)
# ------------------------------------------------------

sudo aptitude install -y libjpeg-dev libtiff-dev libffi-dev
sudo aptitude install -y libcairo-dev libx11-dev:i386 libxt-dev

cd ~/core/gui
./configure
make -j8
sudo -E make install

cd ~/core/back
./configure
make -j8
sudo -E make install

You can compile the following code with:

clang `gnustep-config --objc-flags` `gnustep-config --objc-libs`  -fobjc-runtime=gnustep -fblocks -lobjc -fobjc-arc -ldispatch -lgnustep-base -lgnustep-gui  guitest.m



cat > guitest.m << EOF
#import <AppKit/AppKit.h>

int main()
{
NSApplication *app;  // Without these 2 lines, seg fault may occur
app = [NSApplication sharedApplication];

NSAlert * alert = [[NSAlert alloc] init];
[alert setMessageText:@"Hello alert"];
[alert addButtonWithTitle:@"All done"];
[alert runModal];
}
EOF



  • General Note: When compiling your own code, it is generally good to tell clang both the family and version of the runtime: -fobjc-runtime=gnustep-1.7

(The current version number can be had by looking at the latest ANNOUNCE filename in http://svn.gna.org/svn/gnustep/libs/libobjc2/trunk/ (e.g., ANNOUNCE.1.7))


Ubuntu 12.04 Help

On Ubuntu 12.04, the default installed version of CMake is 2.8.7 but you need 2.8.8 or later to compile LLVM. And the default installed version of GCC and G++ is 4.6 but you need 4.8 or later to compile LLVM.

For CMake, the solution is to download and compile CMake yourself. Use the existing CMake 2.8.7 and then replace it:

  1. Download the latest CMake version from the CMake web site (http://www.cmake.org/cmake/resources/software.html), and uncompress it in a folder.
  2. Create a _build directory in the CMake sources folder.
  3. From the _build directory, run the following commands to build and install CMake from sources:
cmake .. -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr
make
cpack -G DEB
sudo apt-get remove cmake cmake-data
sudo dpkg -i cmake*.deb

To get GCC and G++ 4.8, do the following:

sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install gcc-4.8 g++-4.8
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.8 50
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.8 50

You should be good to go.