Skip to content

Project at ENSEIRB-MATMECA to create oceans and portholes, featuring network communication

Notifications You must be signed in to change notification settings

Pravez/Octopoulpe

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Octopoulpe - Oceans

Projet de réseaux réalisé à l'ENSEIRB-MATMECA réalisé par :

  • Laurie-Anne Parant
  • Louise Mouret
  • Paul Breton
  • Paul Gaulier
  • Nicolas Vidal

Les sources que vous pourrez trouver ici se découpent en deux projets :

  • Poseidon : Projet du serveur de l'Aquarium, écrit en C
  • Aquarium : Projet de la vue de l'aquarium, écrit en Java et utilisant la bibliothèque JavaFX.

Configuration pour bon fonctionnement

Pour compiler le code en tant que tel vous allez avoir besoin de CMake. Pour compiler le java, vous devez posséder l'extension Java de CMake (normalement packagée par défaut dans votre installation de CMake). Nous utilisons la bibliothèque readline en C, mais qui est normalement inclue de base dans toute distribution linux. Nous utilisons du côté de la vue la bibliothèque graphique JavaFX, qui est désormais packée dans le SDK de Java 1.8 (SDK d'Oracle). (Voir version open source OpenJFX que vous devriez peut être également posséder).

Résumé

Pour simplifier au plus le système de build, nous avons mis à disposition un script qui réalise toutes les commandes nécessaires à la compilation et exécution des programmes. Vous pouvez donc utiliser le script situé à la racine du projet principal, nommé Oceans.sh. Il est muni d'un menu d'aide appellable via l'option -h ou --help.

Si vous souhaitez préparer le répertoire de build, et compiler toutes les sources, utilisez : ./Oceans.sh -p -c. Si vous souhaitez lancer un des deux programmes produits, utilisez : ./Oceans.sh -r [EXEC] où EXEC est soit Server, soit Aquarium.

Quelques détails d'utilisation

Le projet est préparé à la production, c'est à dire que lorsque vous le lancerez il ne disposera d'aucun aquarium en place. C'est pourquoi, avant de tenter une quelconque authentification avec un quelconque client (commande hello), il vaudra mieux charger un aquarium côté serveur pour éviter au client de se faire refuser, et donc de terminer son programme.

Nous vous mettons à disposition un aquarium préfait (fichier aquarium.save), qui est automatiquement déplacé au bon endroit avant l'exécution pour que vous n'ayez pas à vous en occuper. La seule chose à faire est de charger, au lancement du programme, l'aquarium en question (sachant que vous pourriez charger un quelconque autre aquarium). Il vous suffit donc d'exécuter la commande : load aquarium.save.

DETAIL A NE PAS RATER

Lors de l'exécution chez certains d'entre nous le programme s'arrêtait brusquement sur des instructions de la bibliothèque Readline avec le programme recevant un SIGABRT. Ce problème est arrivé quelques fois mais reste trop peu compréhensible, et est certainement lié à GNU Readline. Lancer l'exécution une nouvelle fois "règle" le problème, que nous n'avons pas réussi à expliquer.

Poseidon

Comme pour tout projet réalisé avec cmake, créez un répertoire build/ à la racine principale du projet. Exécutez la commande cmake ../. Entrez dans build/ et entrez la commande make all. Il ne vous reste plus qu'à exécuter build/Poseidon/src/Server pour lancer le serveur principal ! Attention, le fichier controller.cfg doit obligatoirement se trouver dans le même répertoire que l'exécutable du serveur. (géré automatiquement par CMake)

Aquarium

Si malheureusement CMake refuse de compiler correctement, vous pourrez trouver à la racine du projet Aquarium/, un script qui vous permettra tout de même de compiler et d'exécuter le programme en Java (même s'il est tout de même plus "agréable" d'utiliser le CMake). Attention, le répertoire Images/ doit se trouver au même niveau que les .class de java. De plus, le repertoire resources/ doit se trouver au même endroit que le classpath global (pas besoin de s'en soucier dans le cadre par défaut, tout est normalement géré).

A propos des tests

Nous avons réalisé des tests sur le serveur uniquement, permettant de vérifier le bon fonctionnement d'après notre implémentation du protocole de communication entre les clients et le serveur, et le bon parsage des données en entrée d'un fichier .cfg donné. Pour lancer ces tests, utilisez le script Oceans.sh via l'option -t ou --test. Si vous souhaitez exécuter à la main, ces exécutables se situent dans le répertoire tst/ de la solution (et donc dans un répertoire du même nom dans le build).