Introducción al desarrollo de intérpretes y lenguajes de programación

1

Aprende a desarrollar lenguajes de programación con intérpretes

2

Desarrolla LPP o Lenguaje de Programación Platzi

Construcción del lexer o tokenizador

3

¿Qué es análisis léxico? Funcionamiento del lexer y tokens

4

Estructura y definición de tokens en Python

5

Lectura de caracteres y tokens

6

Tokens ilegales, operadores de un solo carácter y delimitadores

7

Reconocimiento y diferenciación entre letras y números

8

Declaración y ejecución de funciones

9

Extensión del lexer: condicionales, operaciones y booleanos

10

Operadores de dos caracteres

11

Primera versión del REPL con tokens

Construcción del parser o analizador sintáctico

12

¿Qué es un parser y AST?

13

Estructura y definición de nodos del AST en Python

14

Parseo del programa o nodo principal

15

Parseo de assignment statements

16

Parseo de let statements

17

Parseo de errores

18

Parseo del return statement

19

Técnicas de parsing y pratt parsing

20

Pruebas del AST

21

Implementación del pratt parser

22

Parseo de Identifiers: testing

23

Parseo de Identifiers: implementación

24

Parseo de enteros

25

Prefix operators: negación y negativos

26

Infix operators y orden de las operaciones: testing

27

Infix operators y orden de las operaciones: implementación

28

Parseo de booleanos

29

Desafío: testing de infix operators y booleanos

30

Parseo de expresiones agrupadas

31

Parseo de condicionales: testing y AST

32

Parseo de condicionales: implementación

33

Parseo de declaración de funciones: testing

34

Parseo de declaración de funciones: AST e implementación

35

Parseo de llamadas a funciones: testing y AST

36

Parseo de llamadas a funciones: implementación

37

Completando los TODOs o pendientes del lexer

38

Segunda versión del REPL con AST

Evaluación o análisis semántico

39

Significado de símbolos

40

Estrategias de evaluación para intérpretes de software

41

Representación de objetos

42

Evaluación de expresiones: enteros

43

Evaluación de expresiones: booleanos y nulos

44

Evaluación de expresiones: prefix

45

Evaluación de expresiones: infix

46

Evaluación de condicionales

47

Evaluación del return statement

48

Manejo de errores

49

Ambiente

50

Bindings

51

Evaluación de funciones

52

Llamadas a funciones

Mejora del intérprete

53

Implementación de strings

54

Operaciones con strings

55

Built-in functions: objeto y tests

56

Built-in functions: evaluación

Siguientes pasos

57

Retos para expandir tu intérprete

58

Continúa con el Curso de Creación de Compiladores de Software

No tienes acceso a esta clase

¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera

Evaluación de condicionales

46/58
Recursos

Aportes 3

Preguntas 0

Ordenar por:

¿Quieres ver más aportes, preguntas y respuestas de la comunidad?

Me encanta que podemos empezar a ponernos creativos con esto jaja
.

.
Por cierto, me di cuenta que en este pedazo de código:

def _evaluate_statements(statements: List[ast.Statement]) -> Optional[Object]:

    result: Optional[Object] = None

    for statement in statements:

        result = evaluate(statement)

    return result

No importa cuántos statements pasemos, solamente vamos a tomar el valor del último, porque a cada rato se está sobreescribiendo el valor de result, así que actualmente el LPP no puede ejecutar más de un statement 🤔

##Una optimización de código.
En este punto, podemos cambiar nuestra función _evaluate_bang_operator_expression para que simplemente devuelva lo contrario de _is_truthy.
.
En mi caso quedó así:

def _evaluate_bang_operator_expression(right: Object) -> Object:
    return FALSE if _is_truthy(right) else TRUE

.
De esta forma, así, si en algún momento decidimos cambiar la forma en que se qué es verdadero y qué es falso, no tendremos que cambiarlo en ambos lugares. Remember the principle: Don’t repeat your self.

Lo que veo en este caso es que nuestros If no soportar múltiples condiciones ni tenemos el token And y Or en nuestro lenguaje. Me he puesto a pensar como hacerlo pero todavía no lo he implementado.