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/08/20 07:20] bomandevel: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 sources 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 suffisamment 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 ''blueberry'' 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@blueberry.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@blueberry.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) et ''parasolid'' (interface avec la bibliothèque CAO Parasolid). Ces deux modules utilisent le système [[https://git-scm.com/|git]] au lieu de SVN. + 
 +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 https://github.com/ulgltas/linuxbin.git
-  git clone userName@blueberry.ltas.ulg.ac.be:/home/metafor/GIT/parasolid.git+  git clone git@gitlab.uliege.be:am-dept/MN2L/parasolid.git
  
  
Line 45: Line 44:
  
 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: + 
 +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)     * ''cmake -C ../oo_meta/CMake/configMachine.cmake ../oo_meta'' : pour générer un exécutable Release (defaut)
-    * ''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  -D CMAKE_BUILD_TYPE=Debug ../oo_meta'' : pour générer un exécutable Debug. 
-  où ''configMachine'' est remplacé par le nom de la machine éventuellement d'un choix d'options prédéfini dans le fichier. Exemple+où ''configMachine'' est remplacé par le nom de la machine éventuellement d'un choix d'options prédéfini dans le fichier.  
 + 
 +Exemples
     * ''blueberry.cmake'': compilation par défaut sur ''blueberry'' (compilateur intel ''icc'')     * ''blueberry.cmake'': compilation par défaut sur ''blueberry'' (compilateur intel ''icc'')
     * ''blueberry-gcc.cmake'': compilation sur ''blueberry'' avec le compilateur GNU ''gcc''     * ''blueberry-gcc.cmake'': compilation sur ''blueberry'' avec le compilateur GNU ''gcc''
Line 57: Line 59:
     * ''fabulous-gcc.cmake'': configuration sur ''fabulous'' avec le compilateur GNU (''gcc'')     * ''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'' +
-  * via la commande:+
     * ''make'': pour une compilation sur 1 coeur     * ''make'': pour une compilation sur 1 coeur
     * ''make -j n'': pour une compilation sur n coeurs      * ''make -j n'': pour une compilation sur n coeurs 
devel/compillinux.1471670404.txt.gz · Last modified: 2016/08/20 07:20 by boman

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki