Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is the process of creating an interpreted language? [duplicate]

I want to create a very simple experimental programming language. What are some resources can i check out to get an overview of the process of creating an interpreted language. I will be using c++ to build and compile the interpreter.

like image 974
Babiker Avatar asked May 27 '10 17:05

Babiker


People also ask

How do you create an interpreted language?

To create an interpreter first you need to create a lexer to get the tokens of your input program. Next you create a parser that takes those tokens and, by following the rules of a formal grammar, returns an AST of your input program. Finally, the interpreter takes that AST and interprets it in some way.

Which two languages are interpreted languages?

Example of Interpreted language – JavaScript, Perl, Python, BASIC, etc.

What is a interpreted programming language?

An interpreted language such as Python is one where the source code is converted to machine code and then executed each time the program runs.

How does an interpreter process a program?

As the name suggests, an interpreter transforms or interprets a high-level programming code into code that can be understood by the machine (machine code) or into an intermediate language that can be easily executed as well. The interpreter reads each statement of code and then converts or executes it directly.


2 Answers

You need to implement both a parser and an interpreter.

There is a great free text book called "Programming Languages: Application and Interpretation" that uses scheme to build increasingly more complex interpreters. It also serves as a great introduction to programming language features.

Check it out here: http://www.cs.brown.edu/~sk/Publications/Books/ProgLangs/

If Scheme isn't your cup of tea it may be worth looking into.

like image 149
Ben Avatar answered Oct 19 '22 23:10

Ben


A few steps:

First, build the lexer and parser. This is really easy to do with common tools such as lex and yacc, or using a more modern framework such as Antlr (which is what I recommend). These tools will generate source code for your target language that you can then compile and include in your project.

The lexer and parser will build the internal representation of the source file. There are a few different ways of approaching this:

  1. In the bytecode model, the source file is compiled into a low-level internal language, for which you write a bytecode interpreter that directly executes the operations. This is the way that Perl and the .NET languages work, for example.
  2. In the object tree model, the source file is compiled into an object tree where every object knows how to execute itself. Once parsing is completed, you just call Exec() on the root object (which in turn calls Exec() on its children, etc.). This is basically the method that I use for my interpreted domain-specific language Phonix.
like image 32
JSBձոգչ Avatar answered Oct 20 '22 01:10

JSBձոգչ