Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pravez/octopoulpe
Project at ENSEIRB-MATMECA to create oceans and portholes, featuring network communication
https://github.com/pravez/octopoulpe
c cmake java javafx readline sockets
Last synced: 7 days ago
JSON representation
Project at ENSEIRB-MATMECA to create oceans and portholes, featuring network communication
- Host: GitHub
- URL: https://github.com/pravez/octopoulpe
- Owner: Pravez
- Created: 2017-02-28T15:30:14.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-05-11T10:03:25.000Z (over 7 years ago)
- Last Synced: 2024-11-11T05:16:44.063Z (2 months ago)
- Topics: c, cmake, java, javafx, readline, sockets
- Language: C
- Homepage:
- Size: 43.2 MB
- Stars: 0
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Octopoulpe - Oceans
Projet de réseaux réalisé à l'ENSEIRB-MATMECA réalisé par :
- Laurie-Anne Parant
- Louise Mouret
- Paul Breton
- Paul Gaulier
- Nicolas VidalLes 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).