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

Langage Java Discussion :

Une requête un peu spéciale (Interpréteur en java)


Sujet :

Langage Java

  1. #1
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Août 2016
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Aveyron (Midi Pyrénées)

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

    Informations forums :
    Inscription : Août 2016
    Messages : 9
    Points : 0
    Points
    0
    Par défaut Une requête un peu spéciale (Interpréteur en java)
    Bonjour, Je travaille actuellement sur un langage de programmation basique pour l'un de mes logiciels et je n'arrive pas à créer un interpréteur pour celui-ci.
    Voici la synthaxe:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    // les types sont: num, string, bool, list:type, map:type,type
    func load(a :string,b :num) {
        System.print("random: "+Math.random(0,Math.random(0,100))+Math.random(0,100)+" ")
        var v = Math.random(0,Math.random(0,100)+$Math.random(0,100))
        if (v+2/8<19+Math.random(0,20)+b) {
            System.print("good"+a)
        } else {
            System.print("bad"+a)
        }
    }
    Merci de m'aider à interpréter tout cela SANS COMPILATION.
    Je bloque sur la lecture des fonctions dans les strings et le else.
    Cordialement ccgauche.

  2. #2
    Membre éprouvé
    Avatar de Cafeinoman
    Homme Profil pro
    Couteau suisse d'une PME
    Inscrit en
    Octobre 2012
    Messages
    628
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Couteau suisse d'une PME

    Informations forums :
    Inscription : Octobre 2012
    Messages : 628
    Points : 1 256
    Points
    1 256
    Par défaut
    Sans plus d'infos c'est compliqué. A supposer que tu utilise des tokens pour delimiter tes blocs de codes, quand tu trouve le token if, tu crées un function qui prend ce quil y a entre parenthèses en entrée, qui teste le resultat, et qui retourne ce qu'il y a dans le bloc de code situé entre les accolades si c'est vrai, ou celui qui est dans le bloc suivant, délimité par le else et ses accolades, si c'est faux. Tu execute ensuite le bloc de code retourné, ou rien s'il n'y a pas de code (pas de else par exemple).
    «Dieu ne joue pas aux dés.» - Albert Einstein. Et pan! 30 ans de retard dans la théorie quantique!
    «Tout n'est pas politique, mais la politique s'intéresse à tout.» - Nicolas Machiavel. Et surtout à ceux qui ne s'y intéressent pas.

  3. #3
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  4. #4
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Août 2016
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Aveyron (Midi Pyrénées)

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

    Informations forums :
    Inscription : Août 2016
    Messages : 9
    Points : 0
    Points
    0
    Par défaut
    Merci mais je préfère le faire par moi même.
    Cordialement, ccgauche.

  5. #5
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Par défaut
    Dans ce cas il va peut-être falloir passer par JLex entres autres.
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  6. #6
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Août 2016
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Aveyron (Midi Pyrénées)

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

    Informations forums :
    Inscription : Août 2016
    Messages : 9
    Points : 0
    Points
    0
    Par défaut
    Citation Envoyé par bouye Voir le message
    Dans ce cas il va peut-être falloir passer par JLex entres autres.
    Pourriez vous m'expliquer comment Jlex fonctionne.
    Merci d'avance.

  7. #7
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Par défaut
    JLex est un analyseur syntaxique qui permet de reconnaître des expressions. Typiquement dans le monde UNIX et C, Lex (resp Flex) est utilisé avec l'outils de génération Yacc (resp GNU Bison) et traditionnellement ces deux outils sont généralement associés pour créer des compilateurs de compilateur. JLex et Cup sont les équivalent Java de ces deux outils.

    Le but ici serait quand même d’éviter de coder a mano le parsing de ton langage de script (parce que bon, tu n'es pas rendu si tu t'y lances car implémenter un parseur a partir d'une grammaire n'est pas forcement quelque chose d'aisé) mais d'utiliser un de ces outils pour générer le squelette des classes qui te permettront de lire ce code et de l’exécuter. Le but avec JLex est d’écrire un fichier de règles (apparemment dans un format similaire a celui de Flex d’après l'exemple fourni sur le site indiqué) qui seront invoquées lorsque des tokens sont reconnus au moment de l’analyse lexicale.

    EDIT - voir aussi JFlex apparemment un port plus récent de Flex qui peut aussi fonctionner avec Cup.
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  8. #8
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Août 2016
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Aveyron (Midi Pyrénées)

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

    Informations forums :
    Inscription : Août 2016
    Messages : 9
    Points : 0
    Points
    0
    Par défaut
    Citation Envoyé par bouye Voir le message
    JLex est un analyseur syntaxique qui permet de reconnaître des expressions. Typiquement dans le monde UNIX et C, Lex (resp Flex) est utilisé avec l'outils de génération Yacc (resp GNU Bison) et traditionnellement ces deux outils sont généralement associés pour créer des compilateurs de compilateur. JLex et Cup sont les équivalent Java de ces deux outils.

    Le but ici serait quand même d’éviter de coder a mano le parsing de ton langage de script (parce que bon, tu n'es pas rendu si tu t'y lances car implémenter un parseur a partir d'une grammaire n'est pas forcement quelque chose d'aisé) mais d'utiliser un de ces outils pour générer le squelette des classes qui te permettront de lire ce code et de l’exécuter. Le but avec JLex est d’écrire un fichier de règles (apparemment dans un format similaire a celui de Flex d’après l'exemple fourni sur le site indiqué) qui seront invoquées lorsque des tokens sont reconnus au moment de l’analyse lexicale.

    EDIT - voir aussi JFlex apparemment un port plus récent de Flex qui peut aussi fonctionner avec Cup.
    Je n'arrive pas à comprendre le système de JFlex ainsi que celui de JLex Il me faudrais un exemple pour pouvoir comprendre à quoi sert chaque chose (un code dans un langage inventé puis comment est le fichier JFlex

  9. #9
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Août 2016
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Aveyron (Midi Pyrénées)

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

    Informations forums :
    Inscription : Août 2016
    Messages : 9
    Points : 0
    Points
    0
    Par défaut
    Citation Envoyé par bouye Voir le message
    JLex est un analyseur syntaxique qui permet de reconnaître des expressions. Typiquement dans le monde UNIX et C, Lex (resp Flex) est utilisé avec l'outils de génération Yacc (resp GNU Bison) et traditionnellement ces deux outils sont généralement associés pour créer des compilateurs de compilateur. JLex et Cup sont les équivalent Java de ces deux outils.

    Le but ici serait quand même d’éviter de coder a mano le parsing de ton langage de script (parce que bon, tu n'es pas rendu si tu t'y lances car implémenter un parseur a partir d'une grammaire n'est pas forcement quelque chose d'aisé) mais d'utiliser un de ces outils pour générer le squelette des classes qui te permettront de lire ce code et de l’exécuter. Le but avec JLex est d’écrire un fichier de règles (apparemment dans un format similaire a celui de Flex d’après l'exemple fourni sur le site indiqué) qui seront invoquées lorsque des tokens sont reconnus au moment de l’analyse lexicale.

    EDIT - voir aussi JFlex apparemment un port plus récent de Flex qui peut aussi fonctionner avec Cup.
    J'ai finalement créé un parser moi même en java c'est très efficace mon quand même pour l'aide.
    Cordialement ccgauche.

    Pour ceux qui voudront l'interpréteur sera disponible quand j'aurais tout fini.

  10. #10
    Nouveau Candidat au Club
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Août 2016
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Aveyron (Midi Pyrénées)

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

    Informations forums :
    Inscription : Août 2016
    Messages : 9
    Points : 0
    Points
    0
    Par défaut
    Pourriez vous m'aider pour passer d'une liste de String avec des if , else , while à un arbre.
    Je ne trouve pas d'algorithme pour cela
    Merci d'avance ccgauche.

  11. #11
    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
    Citation Envoyé par ccgauche Voir le message
    Pourriez vous m'aider pour passer d'une liste de String avec des if , else , while à un arbre.
    Je ne trouve pas d'algorithme pour cela
    Merci d'avance ccgauche.
    Ben Bouye t'as donné des références pour ça. Il n'y a pas vraiment d'algorithme magique tout fait si tu ne veux pas utiliser ce genre d'outil, c'est à toi de gérer les token au fur et à mesure qu'il arrivent et de les organiser.

  12. #12
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  13. #13
    Membre chevronné
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Points : 1 855
    Points
    1 855
    Par défaut
    ça fait un bon bout de temps que je ne me casse plus la tête pour faire des interpréteurs spécifiques.
    même si ce n'est pas une solution universelle qui répond à tous les besoins je suis passé aux D.S.L (domain specific languages) permis par Groovy.
    gain de temps et finalement ça permet suffisamment de choses (ma dernière réalisation importante était un formalisme de configuration pour des mécaniques très complexes, formalisme très souple et extensible - j'ai aussi réalisé un langage de tests de code Java ... mais ça ça a fait un bide total! -)
    J'ai des principes: je peux toujours trouver une bonne raison pour les contredire .... mais j'ai des principes!
    (mon excellent bouquin sur Java : https://eska-publishing.com/fr/livre...822407076.html)

Discussions similaires

  1. Une application un peu spéciale
    Par Bircher dans le forum AWT/Swing
    Réponses: 3
    Dernier message: 18/07/2008, 10h40
  2. requête un peu spéciale
    Par jako 29 dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 31/03/2008, 11h49
  3. Construction d'une requête un peu complexe
    Par dauphin34000 dans le forum SQL
    Réponses: 9
    Dernier message: 24/05/2007, 11h43
  4. Création d'une requête un peu complexe
    Par vpicchi dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 17/01/2007, 21h52

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