Metafor

ULiege - Aerospace & Mechanical Engineering

User Tools

Site Tools


devel:compillinux

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
devel:compillinux [2016/03/30 15:23] – external edit 127.0.0.1devel:compillinux [2019/03/23 07:14] (current) boman
Line 10: Line 10:
  
  
-==== Compilation de Metafor sous Linux (by hand) ====+==== Compilation de Metafor sous Linux (à la main) ====
  
-La compilation de Metafor se fait en 3 étapes :  +La compilation de Metafor se fait en 3 étapes:  
-  * la récupération des sources +  * la récupération des sources, 
-  * la génération des Makefiles +  * la génération des Makefiles, 
-  * la compilation proprement-dite+  * la compilation proprement-dite.
  
-=== Récupération des sources Metafor sous Linux ===+=== Récupération des sources Metafor ===
  
-La récupération des souces Metafor sous Linux se fait en ligne de commande :  +Considérons que l'on se trouve dans un répertoire à partir duquel on dispose de suffisamment d'espace (~1Gb): disons ''~/Dev/Meta''. Sachant que: 
-  * considérons que l'on se trouve dans un répertoire à partir duquel on dispose de suffisament d'espace (~1Gb) : disons ''~/Dev/Meta'' +    * les répositories se trouvent sur ''blueberry'' dans le répertoire ''~metafor/SVN'', 
-  * sachant que : +    * ''oo_meta'': repository des sources Metafor, 
-    * les répository se trouvent sur ''clifton'' dans le répertoire ~metafor/SVN +    * ''oo_nda'': repository des NDA Metafor, 
-    * ''oo_meta''répository des sources Metafor +    * l'accès aux repository se fait par ''ssh'', 
-    * ''oo_nda''répository des NDA Metafor  +la récupération des sources se fait via les commandes (remplacer ''userName'' par votre identifiant):
-    * l'accès aux répository se fait par ''ssh'' +
-  la récupération des sources se fait via les commandes (remplacer userName par votre identifiant)+
  
-''%%svn co svn+ssh://userName@clifton.ltas.ulg.ac.be/home/metafor/SVN/oo_meta/trunk oo_meta%%'' \\ +''%%svn co svn+ssh://userName@blueberry.ltas.ulg.ac.be/home/metafor/SVN/oo_meta/trunk oo_meta%%'' \\ 
-''%%svn co svn+ssh://userName@clifton.ltas.ulg.ac.be/home/metafor/SVN/oo_nda/trunk oo_nda%%''+''%%svn co svn+ssh://userName@blueberry.ltas.ulg.ac.be/home/metafor/SVN/oo_nda/trunk oo_nda%%''
  
-  * Il en résulte 2 répertoires :+Il en résulte 2 répertoires:
     * ''~/Dev/Meta/oo_meta''     * ''~/Dev/Meta/oo_meta''
     * ''~/Dev/Meta/oo_nda''     * ''~/Dev/Meta/oo_nda''
 +
 +A côté de ces 2 ensembles de sources, il est nécessaire de récupérer les sources de ''linuxbin'' (scripts tels que la batterie de tests stockés sur github) et ''parasolid'' (interface avec la bibliothèque CAO Parasolid stockée chez nous). Ces deux modules utilisent le système [[https://git-scm.com/|git]] au lieu de SVN. 
 +
 +  git clone https://github.com/ulgltas/linuxbin.git
 +  git clone git@gitlab.uliege.be:am-dept/MN2L/parasolid.git
 +
  
 === Génération des Makefiles === === Génération des Makefiles ===
-En plus des deux répertoires de sources, il nécessaire de générer un répertoire dans lequel Metafor sera compilé. Nomons le "MetaBin" (son nom importe peu, son positionnement à coté des sources est lui indispensable).+ 
 +En plus des répertoires de sources, il nécessaire de générer un répertoire dans lequel Metafor sera compilé. Nommons-le "MetaBin" (son nom importe peu, son positionnement à coté des sources estluiindispensable).
  
 La génération des Makefiles se fait via [[http://www.cmake.org/|CMake]] dans le répertoire de compilation  La génération des Makefiles se fait via [[http://www.cmake.org/|CMake]] dans le répertoire de compilation 
-  * ''~/Dev/Meta/MetaBin'' +''~/Dev/Meta/MetaBin''. 
-  * la génération des makefiles se fait via la commande :  + 
-    * ''cmake -C ../oo_meta/CMake/configMachine.cmake ../oo_meta'' : pour générer un exécutable release (defaut) +La génération des makefiles se fait via la commande:  
-    * ''cmake -C ../oo_meta/CMake/configMachine.cmake  -D CMAKE_BUILD_TYPE=Debug ../oo_meta'' : pour générer un exécutable debug +    * ''cmake -C ../oo_meta/CMake/configMachine.cmake ../oo_meta'' : pour générer un exécutable Release (defaut) 
-  où ''configMachine'' est remplacé par le nom de la machine éventuellement d'un choix d'options prédéfini dans le fichier. Exemple :  +    * ''cmake -C ../oo_meta/CMake/configMachine.cmake  -D CMAKE_BUILD_TYPE=Debug ../oo_meta'' : pour générer un exécutable Debug. 
-    * ''blueberry.cmake'' : compilation par défaut sur ''blueberry'' (compilateur intel ''icc''+où ''configMachine'' est remplacé par le nom de la machine éventuellement d'un choix d'options prédéfini dans le fichier.  
-    * ''blueberry-gcc.cmake'' : compilation sur ''blueberry'' avec le compilateur GNU ''gcc'' + 
-    * ''thorgal.cmake'' : compilation par défaut sur ''thorgal'' (''gcc''+Exemples:  
-    * ''thorgal-icc.cmake'' : compilation par défaut sur ''thorgal'' (''gcc''+    * ''blueberry.cmake'': compilation par défaut sur ''blueberry'' (compilateur intel ''icc''
-    * ''fabulous.cmake'' : configuration par défaut sur ''fabulous'' (''icc''+    * ''blueberry-gcc.cmake'': compilation sur ''blueberry'' avec le compilateur GNU ''gcc'' 
-    * ''fabulous-gcc.cmake'' : configuration sur ''fabulous'' avec le compilateur GNU (''gcc'')+    * ''thorgal.cmake'': compilation par défaut sur ''thorgal'' (''gcc''
 +    * ''thorgal-icc.cmake'': compilation par défaut sur ''thorgal'' (''gcc''
 +    * ''fabulous.cmake'': configuration par défaut sur ''fabulous'' (''icc''
 +    * ''fabulous-gcc.cmake'': configuration sur ''fabulous'' avec le compilateur GNU (''gcc'')
     * ...      * ... 
-  * Le nom seul de la machine donnant la configuration par défaut (utilisée par la batterie de test).+Le nom seul de la machine donnant la configuration par défaut (utilisée par la batterie de test).
  
  
 === Compilation === === Compilation ===
  
-La compilation se fait à partir du répertoire de génération +La compilation se fait à partir du répertoire de génération (dans notre exemple ''~/Dev/Meta/MetaBin''via la commande: 
-  * dans notre exemple ''~/Dev/Meta/MetaBin'' +    * ''make'': pour une compilation sur 1 coeur 
-  * via la commande : +    * ''make -j n'': pour une compilation sur n coeurs 
-    * ''make'' : pour une compilation sur 1 coeur +
-    * ''make -j n'' : pour une compilation sur n coeurs +
  
  
  
devel/compillinux.1459344184.txt.gz · Last modified: 2016/08/20 07:20 (external edit)

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki