Exemple de p-code LSD010

Code LSD010 analysé


Code c (P2_4.t) (13 lignes) :
  1. integer foo()
  2. {
  3.   {
  4.     integer a;
  5.   }
  6.   a = 7;
  7.   return(a);
  8. }
  9. void main()
  10. {
  11.   { }
  12.   write(foo());
  13. }

 

Affichage console de l'analyse

steph@astate:/mnt/steph_docs/FUNDP/lsd010$ source/lsd10

;
;
; LSD010 Compiler [SSHD09]
;
;
;****************************************************************************************
; Creating Symbols Table
; Using Test file...true
; Parsing tests/P2_4.t file...
; Calling yyparse()
; End of yyparse execution;
;
; Warning : 'Print tree not requested (use DEB_I level minimum to print it)' On lsd10.y, Line 647
; -------------------------------------------------------------
;
; Warning : 'Print Symbols table not requested (use DEB_I level minimum to print it)' On lsd10.y, Line 618
; -------------------------------------------------------------
;
; 1st AST walk: filling symbols table...
; 2nd AST walk: checking types and constraints...
; Generating AST Graph from last compilation into astLSD10.dot file ... (graphVizHelper.c, col 202)
; ...OK Graph printed
; Generating image from dot file : dot -Tjpg -olsd10_Img201062034437.jpg astLSD10.dot
; Generating p-code...
;
; Open lsd10.pm p-code file...OK
; Start program
ssp 0
mst 0
cup 0 @fct_main_0
ujp @program_end
; Start of foo function
define @fct_foo_0
ssp 6
ujp @fct_body_foo_0
define @fct_body_foo_0
lda i 0 0
; ---Start affectation
; Generate address for a variable
lda i 0 5
; ---Generate value for 7 integer constant
ldc i 7
sto i
; End of affectation
; ---a id
; Generate address for a variable
lda i 0 5
ind i
; Return
sto i
retf
retf
; End of foo function
; Start of main function
define @fct_main_0
ssp 5
ujp @fct_body_main_0
define @fct_body_main_0
lda i 0 0
; ---Start write operation
; ---foo function call
mst 0
cup 0 @fct_foo_0
prin
; ---End of write operation
retf
; End of main function
define @program_end
stp
; End of program
;
; ...OK P-code generated;
; Cleaning memory...
; ...OK Memory cleaned
;
;
; Parsing started at Sun Jun 20 03:44:38 2010
; 13 lines 91 chars parsed in 0.1 seconds
; Verbose set on "Minimum excution messages" level
; That's All Folks!
OK

steph@astate:/mnt/steph_docs/FUNDP/lsd010$

 

AST généré

AST pour le p-code demandé

 

P-code LSD010


Code P-code (lsd10.pm) (44 lignes) :
  1. ; Start program
  2. ssp 0
  3. mst 0
  4. cup 0 @fct_main_0
  5. ujp @program_end
  6. ; Start of foo function
  7. define @fct_foo_0
  8. ssp 6
  9. ujp @fct_body_foo_0
  10. define @fct_body_foo_0
  11. lda i 0 0
  12. ; ---Start affectation
  13. ; Generate address for a variable
  14. lda i 0 5
  15. ; ---Generate value for 7 integer constant
  16. ; End of affectation
  17. ; ---a id
  18. ; Generate address for a variable
  19. lda i 0 5
  20. ind i
  21. ; Return
  22. ; End of foo function
  23. ; Start of main function
  24. define @fct_main_0
  25. ssp 5
  26. ujp @fct_body_main_0
  27. define @fct_body_main_0
  28. lda i 0 0
  29. ; ---Start write operation
  30. ; ---foo function call
  31. mst 0
  32. cup 0 @fct_foo_0
  33. ; ---End of write operation
  34. ; End of main function
  35. define @program_end
  36. ; End of program

 

Document créé le 31/07/10 04:33, dernière modification le 23/03/18 10:27
Source du document imprimé : https://www.gaudry.be/langages-pcode-lsd.html

L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.

Notes

  1. a,b,c LSD010 : Langage Simple et Didactique Il existe une un certain nombre d'interprétations de l'acronyme LSD (Langage Symbolique Didactique, Langage Sans Difficulté, Langage Simple et Didactique). LSD010 est la version 2010 de la suite LSD80, LSD_02, LSD03, LSD04, LSD05, LSD06, LSD07, LSD08, et LSD09.

  2.  Abstract Syntaxic Tree : correspond à « arbre syntaxique abstrait” en français

  3.  AST : “Abstract Syntaxic Tree” (en français, « arbre syntaxique abstrait »)

 

Références

  1. livre Langue du document: fr IHDCB332 - Théorie des langages : Syntaxe et sémantique : PY Schobbens, Syntaxe et sémantique (Janvier 2010)

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.