Skip to content

Latest commit

 

History

History
250 lines (170 loc) · 6.27 KB

INSTALL.md

File metadata and controls

250 lines (170 loc) · 6.27 KB

CLASP - Installation and Use

CLASP is a classic-form C library (with a C++ API), insofar as it has implementation files in its src directory and header files in its include/CLASP directory. Thus, once "installed", one must simply include CLASP/CLASP.h (or one of the utility headers), and compile-in or link-in the implementation. There are several ways to do this:

Table of Contents

CMake

The primary choice for installation is by use of CMake.

  1. Obtain the latest distribution of CLASP, from https://github.com/synesissoftware/CLASP/, e.g.

    $ mkdir -p ~/open-source
    $ cd ~/open-source
    $ git clone https://github.com/synesissoftware/CLASP/
  2. Prepare the CMake configuration, via the prepare_cmake.sh script, as in:

    $ cd ~/open-source/CLASP
    $ ./prepare_cmake.sh

    NOTE: if you intend only to build the library then you can eschew building of examples (-E) and tests (-T) and use the command:

    $ cd ~/open-source/CLASP
    $ ./prepare_cmake.sh -E -T

    In this case, you do not need to have installed STLSoft; otherwise, you will.

  3. Run a build of the generated CMake-derived build files via the build_cmake.sh script, as in:

    $ ./build_cmake.sh

    (NOTE: if you provide the flag --run-make (=== -m) in step 3 then you do not need this step.)

  4. As a check, execute the built test program files via the build_run_all_unit_tests.sh script, as in:

    $ ./run_all_unit_tests.sh
  5. Install the library on the host, via cmake, as in:

    $ sudo cmake --install ${SIS_CMAKE_BUILD_DIR:-./_build} --config Release
  6. Then to use the library, it is a simple matter as follows:

    1. Assuming a simplest possible program to verify the installation:

      // main.cpp
      #include <clasp/clasp.h>
      #include <stdio.h>
      #include <stdlib.h>
      
      int main(int argc, char* argv[])
      {
        ((void)&argc);
        ((void)&argv);
      
        clasp_countSpecifications(NULL);
      
        printf("using CLASP (minimally)\n");
      
        return EXIT_SUCCESS;
      }
    2. Compile your project against CLASP:

      Due to the installation step (Step 6 above) there is no requirement for an explicit include directory for CLASP:

      $ g++ -c -std=c++11 -D UNIX main.cpp
    3. Link your project against CLASP:

      Due to the installation step (Step 6 above) there is no requirement for an explicit library directory for CLASP:

      $ g++ main.o -lclasp
    4. Test your project:

      Then you can run, as in:

      $ ./a.out
      using CLASP (minimally)
      $

Custom makefile

Before support for CMake was provided, the recommended approach was to use one of the custom makefiles provided with the project, as follows:

  1. Obtain the latest distribution of CLASP, from https://github.com/synesissoftware/CLASP/, as in:

    $ mkdir -p ~/open-source
    $ cd ~/open-source
    $ git clone https://github.com/synesissoftware/CLASP/
  2. Determine the custom makefile appropriate for your compiler:

    For example, if running on UNIX and using GCC v4.2.1 then the requisite makefile will reside in build/gcc42.unix.

    $ ls -al build/gcc42.unix/makefile
  3. Execute a test build, passing the target clean:

    # from within build/gcc42.unix
    $ make clean

    You should see output such as the following:

    cleaning Core libraries ...
    cleaning CLASP libraries ...
    cleaning Test:Component programs ...
    cleaning Test:Scratch programs ...
    cleaning Test:Unit programs ...
    
  4. Build the CLASP library configurations, using the target build:

    # from within build/gcc42.unix
    $ make build
    . . .
    $
  5. Then to use the library, it was customary practice to make available the CLASP header files and built files as follows:

    1. Assuming a simplest possible program to verify the installation:

      // main.cpp
      #include <clasp/clasp.h>
      #include <stdio.h>
      #include <stdlib.h>
      
      int main(int argc, char* argv[])
      {
        ((void)&argc);
        ((void)&argv);
      
        clasp_countSpecifications(NULL);
      
        printf("using CLASP (minimally)\n");
      
        return EXIT_SUCCESS;
      }
    2. Create an environment variable CLASP_ROOT with the value of the root directory of the CLASP project, as in:

      $ export CLASP_ROOT=~/open-source/CLASP
    3. Compile your project against CLASP:

      This requires explicit use of the environment variable CLASP_ROOT (and the environment variable STLSOFT discussed above).

      $ g++ -c -I ${CLASP_ROOT}/include -std=c++11 main.cpp
    4. Link your project against CLASP:

      Given the above main step to build the library, examining the lib directory:

      $ ls -al lib

      should show a bunch of files, including:

      . . .
      -rw-r--r--   1 mwan  staff   110K 30 Nov 12:24 libclasp.0.core.gcc42.a
      -rw-r--r--   1 mwan  staff   262K 30 Nov 12:24 libclasp.0.core.gcc42.debug.a
      -rw-r--r--   1 mwan  staff   110K 30 Nov 12:24 libclasp.0.core.gcc42.mt.a
      -rw-r--r--   1 mwan  staff   262K 30 Nov 12:24 libclasp.0.core.gcc42.mt.debug.a
      

      The best choice is libclasp.0.core.gcc42.a, which is the archive for Release configuration and compiled without _REENTRANT as we don't care about multithreaded program support in this example.

      So, we link to CLASP via:

      $ g++ main.o -L ${CLASP_ROOT}/lib -lclasp.0.core.gcc42
    5. Test your project:

      Run the resulting program with the argument --verbosity=4 as in:

      $ ./a.out
      using CLASP (minimally)
      $