IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

Compilateur C/C++ en Java


Sujet :

Java

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 22
    Points : 16
    Points
    16
    Par défaut Compilateur C/C++ en Java
    Bonjour a tous,

    Dans le cadre d'un projet, qui comprend un IDE un peu spécial, développé en Java, j'aurais besoin de compiler du code C/C++ généré par cet IDE.
    J'ai pense a appeler (exec) un compilateur présent sur la machine d'exécution mais l'IDE est suppose s'exécuter sur de nombreuses plateformes et ajouter un compilateur a l'installation de l'IDE pour chaque risque d'être assez contraignant...
    J'ai donc pense qu'il existait peut-etre un compilateur C-C++ (open-source) ecrit en Java qui pourrait etre inclus directement dans le code de l'IDE mais mes recherches n'ont rien donne.

    Avez-vous deja entendu parler de ca ou d'un projet similaire ?
    Ou bien d'apres-vous quelle est la meilleure solution a mon probleme ?

    merci d'avance

  2. #2
    Expert confirmé
    Avatar de GLDavid
    Homme Profil pro
    Service Delivery Manager
    Inscrit en
    Janvier 2003
    Messages
    2 852
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Service Delivery Manager
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Janvier 2003
    Messages : 2 852
    Points : 4 759
    Points
    4 759
    Par défaut
    Bonjour

    Un compilo C écrit en Java? Connais pas et tu auras du malà trouver.
    En revanche, si la compatibilité est obligatoire, tu as 2 options:
    1) Fournir un compilateur comme GCC sous UNIX ou MINGW (GCC) sous Windows. un coup de Google te permettra d'obtenir les exécutables.
    2) En supposant que le poste client ait déjà un compilo C, faire une interface de configuration de ton IDE.
    Notes que les deux options ne sont pas distinctes et peuvent être jointes.

    @++
    GLDavid
    Consultez la FAQ Perl ainsi que mes cours de Perl.
    N'oubliez pas les balises code ni le tag

    Je ne répond à aucune question technique par MP.

  3. #3
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    a noter qu'en général un code C++ pour linux ne compilera pas sous windows, et inversément, les bibliothèques et APIs n'étant pas les mêmes

    Un compilateur C++ en java, t'aura beaucoup de mal à trouver parce que
    1) ca n'a pas de sens de devoir installer java pour compiler du C
    2) le compilateur doit faire de toutes façons une sorite différente suivant l'OS hôte, ce qui limite l'intérête de java.

    Regarde plutot à intégrer ton projet dans l'IDE eclipse CDT, qui fournis déjà tout ce qu'il faut pour la compilation C++

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 22
    Points : 16
    Points
    16
    Par défaut
    Merci pour vos réponses!

    Cela confirme ce que je pensais, je vais donc inclure les deux versions de GCC et lancer la compilation dans un process different.
    Pour ce qui est de la configuration du compilo, elle sera toujours la meme donc pas de soucis, idem pour le code généré qui compilera sur n'importe quelle archi sans problèmes.
    Je reste tout de même étonné qu'un projet de compilateur C/C++ n'est jamais été réalisé en Java, cela m'aurais bien facilite la tache...

  5. #5
    Expert confirmé Avatar de fregolo52
    Homme Profil pro
    Développeur C
    Inscrit en
    Août 2004
    Messages
    2 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur C

    Informations forums :
    Inscription : Août 2004
    Messages : 2 364
    Points : 5 378
    Points
    5 378
    Par défaut
    Citation Envoyé par dyslesia Voir le message
    Je reste tout de même étonné qu'un projet de compilateur C/C++ n'est jamais été réalisé en Java, cela m'aurais bien facilite la tache...
    Peut-être parce que c'est ridicule de créer un compilateur en langage machine avec un compilateur en langage interprété !!

  6. #6
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Pour faire un compilateur C/C++ en java, il faudrait maitriser à la fois java et C, alors que pour faire un compilateur C en C, il ne faut maitriser que C. De la même manière pour faire un compilateur java en java .....

  7. #7
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 218
    Points : 1 088
    Points
    1 088
    Par défaut
    Sinon, pour manipuler des langages différents via une interface commune, j'aurais été voir du côté de CORBA. (Je ne suis jamais allé très loin dans le sujet, donc je ne te serais pas d'une grande aide)

  8. #8
    En attente de confirmation mail
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Octobre 2010
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2010
    Messages : 501
    Points : 1 060
    Points
    1 060
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    Pour faire un compilateur C/C++ en java, il faudrait maitriser à la fois java et C, alors que pour faire un compilateur C en C, il ne faut maitriser que C. De la même manière pour faire un compilateur java en java .....
    Ce qui (soit dit en passant) n'est pas vrai dans l'autre sens.
    Comme le bytecode java n'est pas exécutable par les processeurs, on est obligé d'utiliser un autre langage pour implémenter une JVM (en générale C/C++).
    Il y a donc bel et bien des personnes qui maitrisent très bien le Java et le C/C++.

    Par ailleurs, pour développer un compilateur C++, il faut avoir également de très bonnes connaissances en assembleur.
    un tel projet nécessite donc une triple expertise: Java, C++, assembleur.

  9. #9
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    C'est relatif, il y a une différence entre java (le language) et la JVM (un processeur virtuel implémentant un bytecode particulier). Dire qu'il faut un expertise en java pour faire une JVM (au sens du processeur virtuel), c'est un peux comme dire qu'il faut un expertise en Scala et Python pour faire la même chose (après tout, les compilateur scala et Jython génèrent du code pour la jvm :p)

  10. #10
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Nudger Voir le message
    Ce qui (soit dit en passant) n'est pas vrai dans l'autre sens.
    Comme le bytecode java n'est pas exécutable par les processeurs, on est obligé d'utiliser un autre langage pour implémenter une JVM (en générale C/C++).
    Il y a donc bel et bien des personnes qui maitrisent très bien le Java et le C/C++.

    Par ailleurs, pour développer un compilateur C++, il faut avoir également de très bonnes connaissances en assembleur.
    un tel projet nécessite donc une triple expertise: Java, C++, assembleur.
    je ne suis pas entièrement d'accord. Il existe des VM qui s'exécutent elles-mêmes, en Java par exemple Jikes RVM, pypy pour python et d'autres encore, pour ruby par exemple. La VM se bootstrape et s'exécute elle même ensuite (il suffit d'un mini-lanceur dans un langage compilé en natif pour la platforme visée).
    De plus comme l'a dit tchize_, pour implémenter une JVM il faut surtout connaître la spec du bytecode Java, ce qui est largement réalisable.
    On pourrait voir un intérêt à implémenter un compilo C/C++ en Java, notamment au niveau de la portabilité du compilateur qui ferait aussi de la cross-compilation, ce n'est pas si absurde (et il existe sûrement plein de personnes largement capables de faire ça, même si il faut bien connaître plusieurs langages...). Ce qui fait que ça n'existe pas est sûrement plus dû à l'ampleur de la tâche à accomplir qu'au fait que personne n'en soit techniquement capable.

    Bref la question de base n'est pas absurde, loin de là, mais hélas non ça n'existe pas, même eclipse ne s'y est pas risqué et utilise un compilateur externe pour le CDT.

  11. #11
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    De toute facon, le coeur du probleme reste d'avoir des sources communes pour une appli linux et windows. Et comme ca a deja été dit plusieurs fois, c'est pas si simple (headers différents, librairies - donc makefiles differents, ...).
    Bref, deja, trouver un outil pour faire un programme compatible linux/windows n'est deja pas simple (j'en connais pas personnelement) mais realiser un compilateur en plus...

    Pour avoir deja fait des programmes qui tournent sur les 2 OS (et encore, c'est des projets perso et pas tres compliqués), ca donne du code flagué dans tous les sens (meme en regroupant tout dans une couche "drivers").

    Bref, le projet peut etre interessant sur le principe mais ce serait bien que dyslesia precise ce qu'il veut faire parce que ca ressemble quand meme beaucoup à une fausse bonne idée...

  12. #12
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Pour faire des applis multi os, faut se baser uniquement sur les API multi OS (QT, GTK, ...) et leurs typedefs

  13. #13
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 22
    Points : 16
    Points
    16
    Par défaut
    Je vois que le sujet est partit dans une autre direction!

    Personnellement je rejoins George7, je ne trouvais pas l'idée absurde mais certes, l'intérêt d'un tel projet au point de vu de son ampleur reste discutable...
    Notamment pour mon projet, je recherchais la facilite!
    Après discussion avec mon groupe, nous avons décidé de faire différemment et faire compiler le code généré directement sur la plateforme cible, par un autre composant de notre appli.

    Sinon oui le moyen le plus simple pour realiser dans appli multi os est de se baser totalement sur certaines librairies, ou alors réaliser nombres d'abstractions pour le les parties non multi-os comme le reseau, threads, etc...

Discussions similaires

  1. [Compilation]Compilateur Java
    Par gurv4n dans le forum Général Java
    Réponses: 4
    Dernier message: 09/01/2008, 21h31
  2. intégrerer un compilateur pascal dans un applet java
    Par antinira dans le forum Applets
    Réponses: 5
    Dernier message: 18/04/2006, 08h05
  3. [Java 5 - Annotations] Compilateur d'annotations
    Par petitpr dans le forum Langage
    Réponses: 2
    Dernier message: 20/03/2006, 15h39
  4. [Compilateur]compilateur java sous debian
    Par Burinho dans le forum Général Java
    Réponses: 23
    Dernier message: 03/11/2005, 20h54
  5. Compilateurs Java
    Par anzar dans le forum Build
    Réponses: 2
    Dernier message: 12/06/2003, 22h13

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo