Die einfache Antwort lautet "Nein".
Jede Art von Verallgemeinerung aus Beispielen leidet unter der grundlegenden Tatsache, dass es sich um Schätzung handelt. Du könntest schätzen, dass die Sprache ein 'if'-Token hat. Es gibt keine Garantie, dass dies der Fall ist, oder dass es if heißt oder dass es eine Semantik hat, die du verstehst. Du wirst kein automatisiertes Tool bekommen, um die Grammatik für dich abzuleiten.
Am besten ist es, alle verfügbaren Dokumente zur Beschreibung der Sprache zu nehmen und dann eine Grammatik zu schätzen. Dann baust du einen Parser für die Grammatik und validierst sie anhand einer möglichst großen Code-Basis und überarbeitest sie. Das habe ich schon dutzende Male mit einer Vielzahl von Sprachen gemacht (siehe mein Bio).
Es ist schmerzhaft, aber oft kommst du an einen ziemlich nützlichen Ort. Die gute Nachricht ist, dass dein Parser nichts analysieren muss, was die Benutzer nicht schreiben können. Die schlechte Nachricht ist, dass sie Dinge schreiben werden, basierend auf einem obskuren Beispiel, das du noch nie gesehen hast, oder mit einem Tippfehler, der zufällig funktioniert. (Selbst der Sprachdesigner hat es nicht beabsichtigt, aber das ist dem Benutzer egal; sein Programm funktioniert und dein Compiler nicht. Dein Problem per Definition).
Was du nie herausfinden wirst, ist, ob der Anbieter der Sprache bestimmte Funktionen hat, die er einfach nicht dokumentiert hat und niemand anderem gezeigt hat. Sei ständig darauf vorbereitet, überrascht zu werden, auch lange nachdem du fertig bist :-{
Das beste Tool, das du meiner Meinung nach für diesen Prozess verwenden kannst, ist ein GLR Parser-Generator; das ist das, was meine Firma verwendet. Diese werden jede kontextfreie Sprache (die du vorschlagen könntest) parsen, ohne sich sehr darum bemühen zu müssen, die Grammatik so zu verbiegen, dass sie zu den anderen gängigen Einschränkungen von rekursivem Abstieg, LL(k)- oder LR(k)-Parsen passt. Das Leben ist schon schwer genug, um die Grammatik zu erraten, geschweige denn zu erraten, wie man sie verbiegt, um sie korrekt vom Parser-Generator schlucken zu lassen.
Du hast auch das Problem, einmal du die Grammatik richtig hast, einen Übersetzer zu bauen. Du könntest diese SO-Antwort hilfreich finden: Welche Arten von Mustern könnte ich im Code erzwingen, um die Übersetzung in eine andere Programmiersprache zu erleichtern?