Skip to content

Environnement de TP pour OCaml et Coq avec GNU Emacs (UE TAPFA = Types Abstraits et Programmation Fonctionnelle Avancée)

License

Notifications You must be signed in to change notification settings

erikmd/tapfa-init.el

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Environnement de TP pour OCaml+Coq (avec Emacs)

Ce tutoriel vise à guider l'installation de :

sous GNU/Linux, macOS et Windows 10+ (64 bits).

Installation sous GNU/Linux Ubuntu LTS ou Debian Stable

(Ces composants sont déjà installés sur les PC de l'UPS, sauter alors ces étapes.)

  1. Installer emacs (version >= 25.1) et rlwrap (optionnel mais recommandé) :

    sudo apt-get update
    sudo apt-get install emacs rlwrap
    
  2. Installer les dépendances d'opam :

    sudo apt-get install build-essential bubblewrap unzip tar curl git m4 rsync ca-certificates
    
  3. Installer opam 2.x, soit la version disponible le gestionnaire de paquets Debian/Ubuntu :

    sudo apt-get install opam
    

    soit la toute dernière version (avec le script d'installation officiel) :

    curl -fL https://github.com/ocaml/opam/raw/master/shell/install.sh > ./install.sh
    sh ./install.sh
    
  4. Configurer opam puis installer merlin :

    opam init --auto-setup --bare
    opam switch create 4.12.1 ocaml-base-compiler.4.12.1
    eval $(opam env)
    opam update
    opam install merlin
    

    Ne pas exécuter opam user-setup install.

  5. Optionnel : installer utop (pour un toplevel en ligne de commande plus riche que rlwrap ocaml)

    opam install utop
    
  6. Optionnel : installer coq :

    opam repo add --all-switches --set-default coq-released https://coq.inria.fr/opam/released
    opam pin add -n -y -k version coq 8.17.1
    opam install -j 2 coq
    

Installation des modes Emacs pour OCaml et Coq

(Reprendre à cette étape si vous travaillez sur un PC de l'UPS.)

Pour installer automatiquement les modes tuareg, merlin-eldoc, merlin-iedit, company, ProofGeneral, company-coq et magit :

  1. Téléchargez et placez le fichier .emacs fourni à la racine de votre homedir (~/) :

    cd                    # pour revenir à la racine du homedir (~/)
    mv -f .emacs .emacs~  # pour sauvegarder votre fichier au cas où
    # si la ligne précédente renvoie une erreur, ne pas en tenir compte
    curl -fL https://github.com/erikmd/tapfa-init.el/raw/master/.emacs > ~/.emacs
    

    Note : Si vous n'utilisez pas curl mais la fonctionnalité de téléchargement de votre navigateur, veillez à ce que celui-ci n'enlève pas le point au début du fichier (.emacs, pas emacs).

  2. Lancer Emacs :

    emacs &
    

    L'installation des modes Emacs pour OCaml et Coq devrait se lancer automatiquement et durer environ 2'30.

    Note pour les utilisateurs de Debian : si vous avez Emacs 26.1 (la version packagée dans Debian 10), vous pourriez avoir le message d'erreur "Buffer ' *http elpa.gnu.org:443*' has a running process; kill it?" ou bien "Failed to download 'melpa' archive during the package refresh step". C'est un bug connu (debbug #34341) qui a été corrigé dans Emacs 26.3 et 27.1. En gardant Emacs 26.1, un contournement simple consiste à décommenter la ligne (setq gnutls-algorithm-priority "NORMAL:-VERS-TLS1.3") dans votre fichier .emacs (enlever les ;; devant cette ligne) et redémarrer emacs.

    En cas d'un autre type de souci durant l'installation, faites M-x package-install-selected-packages RET (M-x désignant Alt+X et RET la touche Entrée) et redémarrez emacs.

  3. Vous pouvez alors créer ou ouvrir un fichier OCaml en tapant C-x C-f tp1.ml RET (C-x désignant Ctrl+X).

    Tester alors l'installation en effectuant les deux choses suivantes :

    • Écrire une erreur de type (let n = 1 + true) et taper sur C-x C-s pour sauvegarder. Assurez-vous que l'IDE a bien mis en surbrillance l'erreur de type (et si vous placez le curseur dessus (ou tapez C-c C-x), vous devriez voir le message d'erreur complet : This expression has type bool but an expression was expected of type int).

    • Corriger l'expression précédemment tapée (let n = 1 + 2) puis taper sur C-c C-e pour évaluer l'expression courante dans un toplevel (si l'IDE affiche OCaml REPL to run: la première fois, valider avec RET = touche Entrée).

Installation sous macOS
  1. Installer Emacs Plus avec Homebrew:

    brew tap d12frosted/emacs-plus
    brew install emacs-plus
    

    Avant cela (si vous aviez précédemment installé Emacs Cask), désinstallez Emacs avec brew uninstall emacs. En effet, Emacs Plus est similaire à Emacs Cask mais comporte plusieurs patches spécifiques à MacOS, et est directement compilé à partir des sources, ce qui accroît les performances (en étant de-facto adapté à l'architecture de votre Mac, par exemple, Apple M1).

  2. Installer opam 2.x avec Homebrew :

    brew install opam
    
  3. Configurer opam puis installer merlin :

    opam init --auto-setup --bare
    opam switch create 4.12.1 ocaml-base-compiler.4.12.1
    eval $(opam env)
    opam update
    opam install merlin
    

    Ne pas exécuter opam user-setup install.

  4. Optionnel : installer utop (pour un toplevel en ligne de commande plus riche que rlwrap ocaml)

    opam install utop
    
  5. Optionnel : installer coq :

    opam repo add --all-switches --set-default coq-released https://coq.inria.fr/opam/released
    opam pin add -n -y -k version coq 8.17.1
    opam install -j 2 coq
    

Installation des modes Emacs pour OCaml et Coq

Pour installer automatiquement les modes tuareg, merlin-eldoc, merlin-iedit, company, ProofGeneral, company-coq et magit :

  1. Téléchargez et placez le fichier .emacs fourni à la racine de votre homedir (~/) :

    cd                    # pour revenir à la racine du homedir (~/)
    mv -f .emacs .emacs~  # pour sauvegarder votre fichier
    # si la ligne précédente renvoie une erreur, ne pas en tenir compte
    curl -fL https://github.com/erikmd/tapfa-init.el/raw/master/.emacs > ~/.emacs
    

    Note : Si vous n'utilisez pas curl mais la fonctionnalité de téléchargement de votre navigateur, veillez à ce que celui-ci n'enlève pas le point au début du fichier (.emacs, pas emacs).

  2. Lancer Emacs :

    emacs &
    

    L'installation des modes Emacs pour OCaml et Coq devrait se lancer automatiquement en arrière-plan et durer environ 2'30.

    En cas de souci, faites M-x package-install-selected-packages RET (M-x désignant Alt+X et RET la touche Entrée) et redémarrez emacs.

  3. Vous pouvez alors créer ou ouvrir un fichier OCaml en tapant C-x C-f tp1.ml RET (C-x désignant Ctrl+X).

    Tester alors l'installation en effectuant les deux choses suivantes :

    • Écrire une erreur de type (let n = 1 + true) et taper sur C-x C-s pour sauvegarder. Assurez-vous que l'IDE a bien mis en surbrillance l'erreur de type (et si vous placez le curseur dessus (ou tapez C-c C-x), vous devriez voir le message d'erreur complet : This expression has type bool but an expression was expected of type int).

    • Corriger l'expression précédemment tapée (let n = 1 + 2) puis taper sur C-c C-e pour évaluer l'expression courante dans un toplevel (si l'IDE affiche OCaml REPL to run: la première fois, valider avec RET = touche Entrée).

  4. Et si vous avez installé learn-ocaml-client, pour utiliser le mode learn-ocaml, vous pouvez taper M-x learn-ocaml-mode RET.

Installation sous Windows 10 (64 bits) avec WSL

Note: Les lignes barrées ci-dessous ne doivent pas être exécutées (il s'agit des étapes de l'ancienne version du tutoriel qui nécessitait emacs-modified for windows et wsl-alias, et qui était moins robuste que la dernière version du tutoriel utilisant emacs natif pour Linux).

  1. Installer GNU Emacs 28 à partir de https://emacs-modified.gitlab.io/windows/

  2. Installer WSL pour Windows 10+ : https://aka.ms/wslstore

  3. Installer une distribution GNU/Linux (par exemple, Ubuntu-22.04) en suivant les instructions de https://aka.ms/wslstore.

  4. Ouvrir un terminal WSL (par ex. en tapant le nom de la distribution dans le Menu Démarrer), répondez aux questions éventuelles et assurez-vous que vous avez un compte utilisateur Linux "normal" (pas root).

  5. Mettre à jour l'index des paquets :

    sudo apt-get update
    
  6. Installer les dépendances d'opam :

    sudo apt-get install build-essential bubblewrap unzip tar curl git m4 rsync ca-certificates
    
  7. Installer opam 2.x, soit la version disponible le gestionnaire de paquets Debian/Ubuntu :

    sudo apt-get install opam
    

    soit la toute dernière version (avec le script d'installation officiel) :

    curl -fL https://github.com/ocaml/opam/raw/master/shell/install.sh > ./install.sh
    sh ./install.sh
    
  8. Configurer opam et installer merlin : (--disable-sandboxing est requis) :

    opam init --disable-sandboxing --auto-setup --bare
    opam switch create 4.12.1 ocaml-base-compiler.4.12.1
    eval $(opam env)
    opam update
    opam install merlin
    

    (Les commandes précédentes doivent être copiées ligne à ligne !)

    Ne pas exécuter opam user-setup install.

  9. Optionnel : installer coq :

    opam repo add --all-switches --set-default coq-released https://coq.inria.fr/opam/released
    opam pin add -n -y -k version coq 8.17.1
    opam install -j 2 coq
    
  10. Optionnel : installer utop (pour un toplevel en ligne de commande plus riche que rlwrap ocaml)

    opam install utop
    
  11. Installer wsl-alias :

    curl -fOL https://github.com/leongrdic/wsl-alias/raw/master/install.sh bash ./install.sh

    et valider les questions posées.

  12. Ajouter comme indiqué, le chemin suivant à votre PATH Windows : %userprofile%\wsl-alias (vous pouvez vous inspirer de la page https://stackoverflow.com/a/44272417).

  13. Ouvrir un terminal cmd.exe (a.k.a. MS-DOS, pas WSL) et taper les commandes suivantes :

    b wsl-alias add opam opam
    b wsl-alias add ocaml "opam exec -- ocaml"
    b wsl-alias add ocamlc "opam exec -- ocamlc"
    b wsl-alias add ocamlmerlin "opam exec -- ocamlmerlin"
    b wsl-alias add learn-ocaml-client "wrapper-learn-ocaml-client"
    b wsl-alias add utop "opam exec -- utop"
    b wsl-alias add coqtop "opam exec -- coqtop"
    b wsl-alias add coqidetop "opam exec -- coqidetop"
    b wsl-alias add coqc "opam exec -- coqc"
    b wsl-alias list # pour vérifier
    b # sans argument, pour passer en mode WSL

    (Les commandes précédentes doivent être copiées ligne à ligne !)

    Vérifier que vous êtes bien dans le répertoire /mnt/c/Users/VOTRELOGIN = dossier personnel Windows.

  14. Dans la ligne de commande WSL, télécharger le fichier .emacs fourni :

    cd ~/
    mv -f .emacs .emacs.bak  # pour sauvegarder votre fichier au cas où
    # si la ligne précédente renvoie une erreur, ne pas en tenir compte
    
    curl -fL https://github.com/erikmd/tapfa-init.el/raw/master/.emacs > ~/.emacs # même config que Linux
    
  15. Toujours dans la ligne de commande WSL, éditer le fichier ~/.wsl-alias/env.sh en tapant :

    nano ~/.wsl-alias/env.sh

    Ajouter à la fin de ce fichier (qui doit déjà exister) :

    wrapper-learn-ocaml-client() {
    declare -a args
    args=()
    for arg; do
    args[${#args[@]}]="$(sed -e 's|htt/mnt/p\\\?|http://|; s|http/mnt/s\\\?|https://|' <<< "$arg")"
    done
    exec opam exec -- learn-ocaml-client "${args[@]}"
    }

    Sauver avec Ctrl+O Entrée et quitter avec Ctrl+X.

  16. Lancer Emacs à partir de Windows.

  17. Installer Emacs dans WSL, puis lancer Emacs à partir de WSL :

    sudo apt-get update && sudo apt-get install emacs
    eval $(opam env)
    emacs
    

    L'installation des modes Emacs pour OCaml et Coq (tuareg, merlin, company, ProofGeneral, company-coq et magit) devrait se lancer automatiquement et durer environ 2'30.

    En cas de souci, faites M-x package-install-selected-packages RET (M-x désignant Alt+X et RET la touche Entrée) et redémarrez emacs.

  18. Vous pouvez alors créer ou ouvrir un fichier OCaml en tapant C-x C-f tp1.ml RET (C-x désignant Ctrl+X).

    Tester alors l'installation en effectuant les deux choses suivantes :

    • Écrire une erreur de type (let n = 1 + true) et taper sur C-x C-s pour sauvegarder. Assurez-vous que l'IDE a bien mis en surbrillance l'erreur de type (et si vous placez le curseur dessus (ou tapez C-c C-x), vous devriez voir le message d'erreur complet : This expression has type bool but an expression was expected of type int).

    • Corriger l'expression précédemment tapée (let n = 1 + 2) puis taper sur C-c C-e pour évaluer l'expression courante dans un toplevel (si l'IDE affiche OCaml REPL to run: la première fois, valider avec RET = touche Entrée).

Exemples

Copies d'écran d'Emacs+Tuareg+Merlin+OPSW :

Thème spacemacs-light

spacemacs-light

Thème spacemacs-dark

spacemacs-dark

Remarques

La configuration .emacs fournie incorpore un menu cliquable (?) permettant d'afficher les raccourcis Emacs de base, et de changer le paramétrage initial (dark mode, etc.)

En cas de problème avec cette configuration, ouvrez une issue ou envoyez-moi un e-mail.

Ce tutoriel d'installation propose d'installer coq version 8.17.1, mais vous pouvez aussi installer la dernière version stable de Coq, donnée au début du badge suivant : coq latest version

About

Environnement de TP pour OCaml et Coq avec GNU Emacs (UE TAPFA = Types Abstraits et Programmation Fonctionnelle Avancée)

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published