Hola, soy nuevo en el desarrollo de compiladores, y me pregunto cómo será AST. Tengo una pequeña sección de código, y uso Clang para generar el AST. No obtengo mucha información de eso. Desde su aspecto, el árbol de sintaxis es exactamente el mismo que el de la fuente, a excepción de una estructura que se agrega a casi cualquier muestra con la que realice la prueba.Clang: ¿Cómo se ve AST (árbol de sintaxis abstracta)?
Fuente:
class A {
public:
int *a, *b, *c;
int i;
void sum() {
a = new int[5];
b = new int[5];
c = new int[5];
for (i = 0; i < 5; i++) {
a[i] = i;
b[i] = i;
}
for (i = 0; i < 5; i++) {
c[i] = a[i] + b[i];
}
delete[] a; delete[] b; delete[] c;
}
};
class B : public A {
};
int main() {
B bclass;
bclass.sum();
return 0;
}
comando para generar AST:
clang++ -cc1 -ast-print ~/sum.cpp
salida de AST:
struct __va_list_tag {
unsigned int gp_offset;
unsigned int fp_offset;
void *overflow_arg_area;
void *reg_save_area;
};
typedef struct __va_list_tag __va_list_tag;
class A {
public:
int *a;
int *b;
int *c;
int i;
void sum() {
this->a = new int [5];
this->b = new int [5];
this->c = new int [5];
for (this->i = 0; this->i < 5; this->i++) {
this->a[this->i] = this->i;
this->b[this->i] = this->i;
}
for (this->i = 0; this->i < 5; this->i++) {
this->c[this->i] = this->a[this->i] + this->b[this->i];
}
delete [] this->a;
delete [] this->b;
delete [] this->c;
}
};
class B : public A {
};
int main() {
B bclass;
bclass.sum();
return 0;
}
Gracias
Sólo una nota: es posible que desee probar -to-volcar en lugar de -ast-print; esa representación podría estar más cerca de lo que estás buscando. – servn
Si la pregunta es qué aspecto tiene una AST, y no qué aspecto tiene la AST de Clang, puede encontrar esta respuesta útil: http://stackoverflow.com/questions/6376662/how-a-ast-for-an-object -orientado-programación-lenguaje-se-buscar-como/6378997 # 6378997 –