Einen Syntax Checker programmieren

TimoH.

Mitglied
Hallo ihr,

ich habe mir vorgenommen einen Syntax Checker zu schreiben.
Er soll ein übergebenes Skript-Dokument auf syntaktische Fehler überprüfen.
Folgenede Dinge will ich berücksichtigen.
  • Einlesen von nativen Funktionen, welche in einer externen Datei sind
  • Funktion/Variable vorhanden
  • Ist der übergebene Wert korrekt (integer wirklich integer?)
  • Ausgabe von Fehlern
  • Anwendung via. Konsole also ohne GUI schnickschnack

Angefangen habe ich zunächst mit dem Part zum Einscannen von den nativen Funktionen etc., das ist aber nicht wirklich performant...
Hier mal die Methode zum Einlesen der nativen Funktionen/variabeln ...
Java:
private ArrayList<String> zeilen = new ArrayList<String>();
private void scanCommon(String dateiPfad) {
        BufferedReader br = null;
        try {
            File file = new File(dateiPfad);
            if (!file.exists()) {
                return;
            }
            br = new BufferedReader(new FileReader(file));
            String line = null;
            try {
                while ((line = br.readLine()) != null) {
                    if (!line.equals("") || !line.isEmpty()) {
                        if (line.indexOf("//") != -1) {
                            line = line.substring(0, line.indexOf("//"));
                        }
                        if (!line.replaceAll(" ", "").isEmpty() || !line.replaceAll(" ", "").equals("")) {
                            zeilen.add(line);
                        }
                    }
                }
            } catch (IOException ex) {
            }
            int lineNr = 0;
            for (String t : zeilen) {
                new JassValue().scan(t,lineNr++);
            }
        } catch (FileNotFoundException ex) {
        } finally {
            try {
                br.close();
                zeilen.clear();
            } catch (IOException ex) {
            }
        }
    }

Für jede native Funktion bzw. Variable für ein JassValue Objekt erzeugt
(JassValue)
Java:
public class JassValue{
    private static HashMap<String,JassValue> valueMap = new HashMap<String,JassValue>();
    private static HashMap<String,JassValue> typeMap = new HashMap<String,JassValue>();
    private static ArrayList<String> typeListe = new ArrayList<String>();
    private static ArrayList<String> ignoreListe = new ArrayList<String>();
    private static ArrayList<String> valueNameListe = new ArrayList<String>();
    private String name = "";
    private ArrayList<String> parametar = new ArrayList<String>();
    private String returnValue = "nothing";
    private boolean firstUse = true;

    public JassValue(String name,boolean standardType){
        this.name = name;
    }

    public JassValue() {
    }

    public boolean scan(String headLine,int lineNr){
        if(firstUse){
          setupArrayList();
          firstUse = false;
        }
        boolean takes = false, returns = false,type = false,consVar = false, first = false;
        boolean globalTakes = false;
        String returnString = "";
        StringTokenizer st = new StringTokenizer(headLine);
        while(st.hasMoreTokens()){
            String s = st.nextToken();
            if(globalTakes){
                returnString = headLine.substring(headLine.indexOf("=")+1).trim();
                globalTakes = false;
                if(returnString.indexOf("(") != -1){
                    String temp = returnString.substring(0, returnString.indexOf("("));
                }
            }
            if(returns){
                returnValue = s;
            }
            if(s.equals("returns")){
                takes = false;
                returns = true;
            }
            if(s.equals("=")){
                globalTakes = true;
            }
            if(takes){
                if(!s.equals(",") && valueNameListe.indexOf(s) != -1){
                    parametar.add(s);
                }
            }
            if (consVar) {
                if (typeMap.containsKey(s)) {
                    returnValue = s;
                }
                consVar = false;
            }
            if(s.equals("takes"))takes = true;
            if(s.equals("constant"))consVar = true;
            if(s.equals("type"))type = true;
            if(typeMap.containsKey(s) && headLine.indexOf("=") != -1 && headLine.indexOf("constant") == -1){
                returnValue = s;
            }
            if (!takes && !returns) {
                if (typeListe.indexOf(s) == -1 && ignoreListe.indexOf(s) == -1
                        && valueNameListe.indexOf(s) == -1 && s.length() >= 4
                        && s.indexOf("(") == -1 && s.indexOf(",") == -1 && !s.isEmpty()
                        && !s.equals("") && !s.equals(" ")) {
                    name = s;
                    first = true;
                    valueNameListe.add(name);
                    if(type){
                        typeMap.put(name,this);
                    }else{
                        valueMap.put(name,this);
                    }
                }
            }
        }
        return first;
    }

    public ArrayList<String> getParametar(){
        return parametar;
    }

    public String getName(){
        return name;
    }

    public void setReturnValue(String value){
        returnValue = value;
    }

    public String getReturnValue(){
        return returnValue;
    }

    public boolean noParametar(){
        return parametar.isEmpty();
    }

    private void setupArrayList() {
        typeListe.add("constant");
        typeListe.add("native");
        typeListe.add("type");
        valueNameListe.add("handle");
        valueNameListe.add("integer");
        valueNameListe.add("real");
        valueNameListe.add("boolean");
        valueNameListe.add("string");
        valueNameListe.add("code");
        typeMap.put("handle",new JassValue("handle",true));
        typeMap.put("integer",new JassValue("integer",true));
        typeMap.put("string",new JassValue("string",true));
        typeMap.put("real",new JassValue("real",true));
        typeMap.put("boolean",new JassValue("boolean",true));
        typeMap.put("code",new JassValue("code",true));
        ignoreListe.add("handle");
        ignoreListe.add("extends");
        ignoreListe.add("takes");
        ignoreListe.add("returns");
        ignoreListe.add("string");
        ignoreListe.add("integer");
        ignoreListe.add("boolean");
        ignoreListe.add("globals");
        ignoreListe.add("endglobals");
        ignoreListe.add("=");
    }

    public static HashMap<String,JassValue> getValueMap(){
        return valueMap;
    }

    public static HashMap<String,JassValue> getTypeMap(){
        return typeMap;
    }

    public int compareTo(JassValue o) {
        return o.getName().toLowerCase().compareTo(this.name.toLowerCase())*-1;
    }
}

Ich denke die nativen Funktionen und so brauche ich eventuell garnicht so einzuscannen, habe aber keine Idee, wie ich das sonst realisieren soll.

Das gleich passiert bei dem Dokument, welches vom User eingescannt wird. Alle Funktionen etc. werden als JassValue Objekte eingelesen um später zu überprüfen ob diese vorhanden sind.
Das ist ja leider aber nur der Anfang ... auf Dinge wie das Überprüfen ob der richtige Typ übergeben wurde oder Fehler in der Schreibweise habe ich noch garnicht geachtet.

Meine Fragen nun:
- Gibt es eventuell Tutorials zum schreiben von Syntax Checkern.
- Habt ihr eventuell Tips, wie ich das ganze besser angehen könnte.
- Ist mein Ansatz total falsch? ;)

Über jegliche Hilfe wäre ich sehr glücklich
(Das ganze mache ich in meiner Freizeit , zum üben und weil es spaß macht. Also ist es auch nicht so schlimm wenn keiner weiter weiß :D)

MFG
Timo
 

FArt

Top Contributor
Syntaxchecker? Dazu passt z.B. nicht "ist der übergebene Wert korrekt", das geht über eine rein syntaktische Prüfung hinaus. Wird eine formale Sprache gescannt? Dann musst du die Sprache beschreiben und z.B. einen AST aufbauchen. Natürlich nicht per Hand...

Du brauchs eine Scanner und einen Parser... hier gibt es ordentliche Unterstützung: ANTLR Parser Generator.

Viel Vergnügen.
 

0x7F800000

Top Contributor
- Ist mein Ansatz total falsch? ;)
ouuyeah... manoman... Ganz kleine Parser ohne jeglichen Plan zu schreiben klappt manchmal besser, als in den dicken Compilerbau-büchern suggeriert wird, aber wenn du da irgendwelche funktions-definitionen und sogar typüberprüfungen haben willst, wirst du das so höchstwahrscheinlich nicht schaffen. Oder selbst wenn du das schaffen solltest, wird das designtechnisch furchtbar, undebuggbar und absolut unwartbar. Solche Riesenteile bastelt man einfach nicht aus unendlich verschachtelten for-schleifen und if-abfragen, so eine "r34l pr0gr4mm3r"-Nummer kannst du imho vergessen, und stattdessen gleich ANTLR nehmen. Ist nicht böse gemeint, aber du solltest das Problem wirklich nicht unterschätzen, sonst verschwendest du nur unendlich viel Zeit, ohne dass am ende was rauskommt.
 
Zuletzt bearbeitet:

TimoH.

Mitglied
Naja, das habe ich mir fast gedacht, dass das alles ein kleinwenig komplexer ist, als gedacht.
Danke für den Link, ich werde mich mal mit ANTLR auseinander setzen, eventuell kommt dabei ja was brauchbares raus.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Suche einen ganz einfachen Editor (syntax Highlighting+comp) Java Basics - Anfänger-Themen 7
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
S Timer vs ExecutorService: jeden Sonntag um 14.00 Uhr einen Task starten..? Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
X wie bekomme ich durch Eingabeaufforderung definierte double in einen Befehl, welcher 3 erwartete double braucht? Java Basics - Anfänger-Themen 3
P Gibt es einen anderen Weg um "{}" in IntelliJ zu schreiben? Java Basics - Anfänger-Themen 5
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
F Hat es noch einen Sinn, alte Versionen zu lernen Java Basics - Anfänger-Themen 45
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
N Kann man einen Iterator nur einmal verwenden Java Basics - Anfänger-Themen 5
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
F Wie kann ich eine Funktion schreiben, die nur in bestimmten Fällen einen Wert zurückgibt? Java Basics - Anfänger-Themen 5
berserkerdq2 Brauche ich while != -1, wenn ich immer einen BufferedReader verwende? Java Basics - Anfänger-Themen 8
berserkerdq2 Habe ein Spiel entwickelt, dass immer in der 4 Runde einen cast-Fehler erhält Java Basics - Anfänger-Themen 3
N Gibt es hierfür einen Shortcut Java Basics - Anfänger-Themen 5
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
K Wie verneine ich einen Regex? Java Basics - Anfänger-Themen 2
berserkerdq2 Wie würde man einen regulären Ausdruck in Java schreiben, der prüft, dass zwei bestimtme Zahlen nicht nebeneinadner sind? Java Basics - Anfänger-Themen 3
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
O Ich ahbe einen char und diesen soll ich bei .matches prüfen, also ob der char in meiner Zeichenkette vorhanden ist, wie mache ich das? Java Basics - Anfänger-Themen 9
W Unterschiede bei Zugriff auf Objekt und Klassenvariablen über einen Getter? Java Basics - Anfänger-Themen 2
D Einen boolischen Wert aus einer Methode in einer anderen Klasse aufrufen? Java Basics - Anfänger-Themen 11
C Potenzberechnung über switch case. Taschenrechner mit Eingabe über einen grafischen Dialog Java Basics - Anfänger-Themen 22
Poppigescorn Mithilfe einer Arrayliste einen Notenspiegel ausgeben Java Basics - Anfänger-Themen 12
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
L GUI- wie cancel ich einen Timer? Java Basics - Anfänger-Themen 10
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
LetsSebi Methode, die einen arry von objekten speichert in einer datei Java Basics - Anfänger-Themen 6
Devin Wo kann man einen Java Lehrplan finden? Java Basics - Anfänger-Themen 5
J Ist es möglich einen int Array wirklich leer zu initialisieren oder zu füllen? Java Basics - Anfänger-Themen 21
P Welche Zeile in Tadople gibt einen compiler error? Java Basics - Anfänger-Themen 5
S First Time Mave: Wie ergänze ich einen Source-Folder? Java Basics - Anfänger-Themen 10
M Pfadprobleme - Zugriff auf einen Ordner im Workspace Java Basics - Anfänger-Themen 17
J Eine Position im String durch einen Integer - Wert teilen Java Basics - Anfänger-Themen 5
P Methode die eigentlich einen Scanner benötigt mit toString() Java Basics - Anfänger-Themen 5
S Erste Schritte Button einen Wert zuweisen & diesen ausgeben Java Basics - Anfänger-Themen 2
M Auf einen Array innerhalb eines Objekts zugreifen Java Basics - Anfänger-Themen 5
V_Fynn03 Erste Schritte Einen Wert in ein TextField einfügen aus einer anderen Klasse Java Basics - Anfänger-Themen 3
J Hat jemand einen Lösungsansatz für diese Aufgabe? Java Basics - Anfänger-Themen 1
F Hilfe für einen Anfänger! Java Basics - Anfänger-Themen 4
O Ziehen im Array um einen Schritt in eine einzige beliebige Richtung Java Basics - Anfänger-Themen 5
N Wie kann ich einen String wieder zusammensetzen und ausgeben lassen? Java Basics - Anfänger-Themen 9
T Fehlermeldung beim Versuch, einen String einzulesen Java Basics - Anfänger-Themen 4
J Wie kann ich z.B. einem int-Wert einen String-Wert zuweisen? Java Basics - Anfänger-Themen 2
steven789hjk543 Kann man mit Java und Eclipse einen Virus programmieren? Java Basics - Anfänger-Themen 13
D Eingabe einscannen, ohne vorher einen Datentypen anzugeben? Java Basics - Anfänger-Themen 1
T Einen Stern malen Java Basics - Anfänger-Themen 32
T Einen Stern malen Java Basics - Anfänger-Themen 2
L Files verschieben in einen Ordner Java Basics - Anfänger-Themen 87
A Mit JComboBox Ergebnis einen Integer aus einer anderen Klasse aufrufen. Java Basics - Anfänger-Themen 2
J Mit for Schleife einen String Rückwärts befüllen Java Basics - Anfänger-Themen 9
J Einen Buttonklick in Label anzeigen Java Basics - Anfänger-Themen 6
S Gibt es einen guten kostenlosen Online-kurs Java Basics - Anfänger-Themen 2
W Wie programmiere ich einen Potenzrechner? Java Basics - Anfänger-Themen 5
B ArrayList besitzt einen Wert zu wenig Java Basics - Anfänger-Themen 16
B Prüfen, ob es schon einen Termin gibt in einem Zeitraum Java Basics - Anfänger-Themen 5
B Wie instanzisiert man einen Cursor richtig? Java Basics - Anfänger-Themen 3
S Interface (WindowBuilder) Panels in einen Frame einfügen Java Basics - Anfänger-Themen 10
J Aufruf einer Methode über einen String Java Basics - Anfänger-Themen 11
C Wie erstellt man einen Timer/Delay? Java Basics - Anfänger-Themen 1
C Wie kann ich einen User Input mit einer If-Anweisung verbinden? Java Basics - Anfänger-Themen 5
J Guten tag, Ich hoffe ihr habt einen schönen Sonntag und könnt mir helfen Java Basics - Anfänger-Themen 2
D Methoden 2 TextWatcher auf einen EditText Java Basics - Anfänger-Themen 4
I Datentypen input.nextCharAt(0) wirft einen Fehler Java Basics - Anfänger-Themen 3
C In einer Methode einen Array zurückgeben Java Basics - Anfänger-Themen 2
S Bestehendes Java Programm, einen festen Wert ändern Java Basics - Anfänger-Themen 17
F Variablen If else: Einer Variable einen Wert hinzufügen oder so? Java Basics - Anfänger-Themen 6
R Übergeben eines Array Strings an einen Spinner Java Basics - Anfänger-Themen 4
Bluedaishi Einen Betrag X auf X Tage verteilen Java Basics - Anfänger-Themen 14
D Einen Wert unter einen ActionListener weitergeben Java Basics - Anfänger-Themen 1
J In Java einen Ton erzeugen Java Basics - Anfänger-Themen 8
C Variablen von einem JFrame in einen anderen übertragen Java Basics - Anfänger-Themen 3
V Arrays die einen Termin speichen Java Basics - Anfänger-Themen 5
G Wie gebe ich einen Dateipfad in RandomAccessFile an? Java Basics - Anfänger-Themen 2
R Wie kann ich einen Objekt zu Instanzvariable speichern ? Java Basics - Anfänger-Themen 10
F In LinkedList einen Wert ersetzen oder neu einfügen Java Basics - Anfänger-Themen 7
S Das Anführungszeichen(") Zeichen in einen String setzen Java Basics - Anfänger-Themen 1
P Einen String mittig zeichnen? Java Basics - Anfänger-Themen 1
J Erste Schritte Wie kann ich einen String in eine If einbauen :)? Java Basics - Anfänger-Themen 12
G Wie kann ich einem StringBuilder einen int Wert formatiert hinzufügen? Java Basics - Anfänger-Themen 8
P Einen Ordner mit Dateien hochladen [FTP] Java Basics - Anfänger-Themen 2
OlafHD Einen String an eine Klasse übergeben Java Basics - Anfänger-Themen 2
OlafHD Gibt es einen Laufbalken? Java Basics - Anfänger-Themen 2
Silvascus Inhalt eines externen Textdokuments an einen String übergeben Java Basics - Anfänger-Themen 2
B OOP Über einen AVL-Baum iterieren (NullPointer) Java Basics - Anfänger-Themen 5
G Erste Schritte Wie kann ich einen zurückgegebenen Wert ausgeben Java Basics - Anfänger-Themen 4
W Wie kann man diesen Code in einen Code umwandeln, der folgendes können sollte? Java Basics - Anfänger-Themen 1
J App auf einen Webserver laden Java Basics - Anfänger-Themen 14
E Was ergibt trim() auf einen leeren String Java Basics - Anfänger-Themen 3
B Schleife über einen Container Java Basics - Anfänger-Themen 7
X Quelltext einen Tic Tac Toe Spiels erklären Java Basics - Anfänger-Themen 4
M Panel erstellen, welches ein Control erhält. Ausgabe soll über einen Stream erfolgen. Java Basics - Anfänger-Themen 0
D Klassen Gesucht: Einfache Beispiel-Klasse für einen Datentyp Java Basics - Anfänger-Themen 7
B Wer kennt einen Link für vollständiges, leichtverständliches "Game of Life"? Java Basics - Anfänger-Themen 1
A Hat jemand einen ratschlag, wie java beim replaceALL eine geschweifte klammer erkennt ? Java Basics - Anfänger-Themen 5
L Mit rekursiven Aufrufen einen Stack emulieren Java Basics - Anfänger-Themen 1
N Benötige eine Alternative für einen GOTO Befehl Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben