source: Sophya/trunk/SophyaLib/BuildMgr/README@ 3405

Last change on this file since 3405 was 3401, checked in by ansari, 18 years ago

Modifs mineures dans BuildMgr/README - Reza 23/11/2007

File size: 7.5 KB
RevLine 
[3029]1======================== BuildMgr Module ======================
2== Code Management scripts / top level makefile for SOPHYA ====
3===============================================================
[3357]4 (C) LAL-IN2P3/CNRS 1998-2007
5 (C) DAPNIA/CEA 1998-2007
[3036]6===============================================================
[3029]7
8### README file for SOPHYA Build makefiles and scripts (BuildMgr) ####
9See http://www.sophya.org and the SOPHYA overview manual for more information
10
11
[3084]12====================================
[3029]13A/ Software build and installation :
14====================================
15
161/ Configuration:
17csh> cd BuildMgr/
18csh> ./configure -h
19# configure with c-fitsio, installed in /usr/local/include and /usr/local/lib,
20# with g++ as cxx compiler. The target installation directory is $HOME/SObjs/
21# To get c-fitsio : http://heasarc.gsfc.nasa.gov/docs/software/fitsio/fitsio.html
22
23
24# Create the target installation directory (if not already existing)
25csh> mkdir ~/SObjs
26# Define the SOPHYABASE environment variable
27csh> setenv $SOPHYABASE ~/SObjs/
28# run the configure script
29csh> ./configure -sbase $SOPHYABASE -scxx g++ -extp /usr/local
[3180]30 -noext fftw -noext lapack -noext astro
[3029]31
322/ compile and build the libraries
33csh> make libs extlibs slb slbext
34# Or if you want to compile also PI (need Motif or Lesstif)
35csh> make all slball
36
373/ Compile some test and utility programs
38csh> make basetests prgutil
39# To compile piapp
40csh> make piapp
41
[3030]424/ You can clean the .o files, if you are not going to recompile after
43changing or update source files
44csh> make cleanobj
45
465/ List of Makefile targets
47 > libs extlibs PI = all
48 > slb slbext slbpi = slball (OR = slballinone)
49 > clean cleanobj
50 > tests prgutil prgmap progpi = prgall
51 > basetests piapp (ou progpi) pmixer
52
536/ Currently tested on the following platform/compilers
[3029]54-------------------------------------------------------------------------
55Linux 2.4 , 2.6 g++ 3.x 4.0 (GNU g++ compiler)
[3401]56MacOSX/Darwin 10.3/10.4 g++ 3.3,4.0 (Apple/GNU compiler)
[3029]57Linux 2.4 icc 9.0 (Intel compiler)
58HP/Compaq/DEC OSF 5.x cxx 6.x (native Tru64/OSF compiler)
59SGI IRIX64 CC 7.30 (IRIX-64 native compiler)
[3401]60IBM AIX (5.3) xlC 8.0 (AIX native compiler)
[3029]61-------------------------------------------------------------------------
62
[3084]63============================
64B/ Code management scripts :
65============================
[3029]66
[2720]671/ configure : c-shell script configuration
[3084]68 ./configure -sbase /tmp/sbase/ -scxx cxx -extp /usr/local/extlibs
[2720]69
702/ mkmflib : c-shell script for creation of library module Makefile / smakefile
71 ./mkmflib -sbase /tmp/sbase SUtils
72
[2739]733/ mkmfprog : c-shell script for creation of programs module Makefile / smakefile
74 ./mkmfprog -sbase /tmp/sbase SUtils
75
764/ domkmf : c-shell script : calls mkmflib for all modules
[2720]77 ./domkmf -sbase /tmp/sbase
78
[3029]795/ chk_cvs.csh : Compares/updates modules using CVS
80 Usage: chk_cvs.csh [-a] [-all] [-nos] [-u] [r]
81 chk_cvs.csh -h for help
[2720]82
[3029]836/ Makefile/smakefile : Top level makefile for library and program modules
84
857/ Configuration files used to generate sophyamake.inc
86 - Linux_g++_make.inc: Linux with g++ compiler
87 - OSF1_cxx_make.inc: HP/Compaq/Digital Tru64 with native cxx compiler
88 - Darwin_g++_make.inc: Apple/MacOSX with the native GNU compiler
89 - IRIX64_CC_make.inc: SGI IRIX-64 system and native CC compiler
90 - AIX_xlC_make.inc : IBM AIX system and compiler xlC
91 - Linux_icc_make.inc : Linux with Intel compiler
92
93
[3084]94==========================================
95C/ List of modules SOPHYA and PI modules :
96==========================================
[3029]97
98* BuildMgr/ Scripts for code management and makefiles
99* BaseTools/ General architecture support classes
100* TArray/ Template numerical arrays, vectors and matrices
101* HiStats/ Histogram-ming and data set handling classes
102* NTools/ Some standard numerical analysis tools
103* SUtils/ Utility classes and functions
104* SysTools/ Interface to various services provided by the operating system
105* SkyMap/ Local and full sky maps
106* SkyT/ Spectral emission and detector frequency response modelling
107* Samba/ Miscellaneous classes (TOD analysis, Spherical Harmonics, ...)
108
109Modules using external library
110* FitsIOServer/ FITS format file I/O (interface with cfitsio library)
111* LinAlg/ Interface with Lapack linear algebra package
112* IFFTW/ Interface with FFTW package
113* XAstroPack/ Interface with astronomy library (XEphem)
114 The XEphem library code is in the SOPHYA module XephemAstroLib
115
116* XephemAstroLib/ The code of the external XEphem astronomy library, extracted from XEphem
117
118Modules with main programs
119* Tests/ Simple test programs
120
121* PMixer/ skymixer and utility main programs
122
123* PrgUtil/ Utility main programs
124
125* PrgMap/ Utility main programs for sky map manipulation
126
127PI/piapp GUI and interactive analysis framework
128
129* PI/ GUI class library and application framework
130* PIGcont/ PI contour drawer
131* PIext/ specific GUI objects for SOPHYA classes and piapp framework
132* ProgPI/ interactive analysis tool using SOPHYA, PI PIGCont and PIext
133
[3084]134
135================================================
136D/ How to use Sophya libraries and/or programs :
137================================================
138
1391./ Set the Sophya environment variable :
140 that is the repository where the libraries and the programs stand,
141 for example:
142 > setenv SOPHYABASE /home/.../SophyaWork
143
144 ..Remark:
145 The choice of the name is up to you, but if you want
146 to use versions on different operating systems (or compilators)
147 the "SOPHYABASE" repository must be different, for example:
148 > setenv SOPHYABASE /home/.../SophyaWork_Linux_gcc2.95
149 > setenv SOPHYABASE /home/.../SophyaWork_Linux_gcc4
150 > setenv SOPHYABASE /home/.../SophyaWork_OSF1_cxx
151 > setenv SOPHYABASE /home/.../SophyaWork_OSF1_gcc
152 > ...
153
154 So you will find:
155 ..shared libraries in: $SOPHYABASE/slb
156 ..archived libraries in: $SOPHYABASE/lib
157 (you will probably prefer to use the shared versions of the libraries)
158 ..programs in: $SOPHYABASE/exe
159 ..include files in: $SOPHYABASE/include
160 (you will only need it if you write code using sophya libraries)
161 ..object files in: $SOPHYABASE/obj
162 (you probably should not have to use it)
163
1642./ Using Sophya shared libraries:
165 As you would do for any software,
166 add the repository name of Sophya shared libraries to LD_LIBRARY_PATH
167 > setenv LD_LIBRARY_PATH ${LD_LIBRARY_PATH}:${SOPHYABASE}/slb
168
1693./ Using Sophya programs:
170 As you would do for any software,
171 add the repository name of Sophya programs to PATH
172 > setenv PATH ${PATH}:${SOPHYABASE}/exe
173 then recomputed the internal hash table for executables
174 > rehash
175
1764./ Using external libraries which are wrapped in Sophya external modules:
177 Sophya is presently using the archived version of the external libraries
178 so nothing special have to be done.
179
1805./ Making your own programs:
181 If you are writing code using Sophya you may like to
182 "include $(SOPHYABASE)/include/sophyamake.inc"
183 in your own Makefile.
184 That will provide you with default variables for the libraries repositories
185 and names as well as standard compilation and link options for
186 various current OS and compilators.
187 (please see: > more $SOPHYABASE/include/sophyamake.inc )
188 That is JUST AN HELP that Sophya provides, you may prefer
189 to deal YOURSELF with libraires path/names and compiler/linker options.
Note: See TracBrowser for help on using the repository browser.