File: annotator.cc

package info (click to toggle)
aspectc%2B%2B 1.0pre4~svn.20080711-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 104,504 kB
  • ctags: 363,975
  • sloc: cpp: 1,645,814; ansic: 16,601; sh: 2,175; makefile: 1,043
file content (105 lines) | stat: -rw-r--r-- 3,939 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#include "Transformer.h"
#include <Puma/CProject.h>
#include <Puma/CTranslationUnit.h>
#include <Puma/CCParser.h>
//#include <Puma/CPrintVisitor.h>
//#include <Puma/CCSemVisitor.h>
//#include <Puma/PrePrintVisitor.h>
//#include <Puma/PreTree.h>
#include <iostream>


int main(int argc, char** argv) {
  // This is the error stream object used throughout
  // the whole system, it supports several error 
  // severities and auto-formatted error location
  // output.
  Puma::ErrorStream err;

  // The project handles all file related task like
  // finding, opening, writing, and closing files.
  // The special CProject additionally is able to
  // scan files and strings, i.e. it provides an easy
  // to use interface to the lexical analyzer (scanner).
  Puma::CProject project(err, argc, argv);
  // Set the initial source/destination path pair. If 
  // a file shall be written using the project it is
  // first checked if this file is located in one of
  // source paths known to the project. If not, the file
  // is not written. This mechanism is necessary to 
  // avoid system headers to be overwritten (except for
  // the case that the corresponding system include 
  // path is added as a source path).
  project.addPath(".", ".");
  
  // Check the arguments, need an input file.
  if (argc != 2) {
    std::cout << "Usage: " << argv[0] << " FILE" << std::endl;
    return 1;
  }

  // Scan the input file. The result is a token list
  // representation of the input file.
  Puma::Unit* unit = project.scanFile(argv[1]);
  if (! unit) {
    std::cerr << "Aborted: Unable to scan input file" << std::endl;
    return 1;
  }

  // After the input file was successfully scanned, it is 
  // now tried to parse it. The result is the so-called 
  // translation unit encapsulating the preprocessor, 
  // syntax, and semantic trees.
  Puma::CCParser parser;
  Puma::CTranslationUnit* tu = parser.parse(*unit, project);

  if (tu->tree()) {
    // During the parsing of the input file only those 
    // semantic analyses are performed that are necessary
    // to build the correct syntax tree and to recognize
    // the correct types. Expression evaluation and so on
    // is performed in an additional sematic analysis. It
    // is optional and not needed for this application.
    //Puma::CCSemVisitor semantics(err);
    //semantics.run(tu->tree());

    // The generated syntax tree is an attributed syntax
    // tree referring to both tokens and semantic information.
    // It can be traversed using a corresponding tree visitor.
    // Formatted printing of the tree is performed by the 
    // CPrintVisitor tree visitor.
    //CPrintVisitor cprinter;
    //cprinter.print(tu->tree(), std::cout);

    // The collected semantic information also is organized 
    // as a tree reflecting the scope structure of the parsed 
    // code. The interface to the semantic tree is the class 
    // CSemDatabase. It can also be used to print this tree.
    //tu->db().Dump(std::cout, 10);
    
    // Now transform the "if" statements so that a comment
    // exists before every "if" statement.
    Transformer transformer(err);
    transformer.transform(tu->tree());
    
    // At last the transformed unit has to be saved as file
    // again. This is also realized using the project class.
    // The original file shall be renamed to filename.bak
    // before the transformed version of this file is written.
    project.saveMode(Puma::SaveMode::RENAME_OLD, ".bak");
    project.save(unit);
  }
  if (tu->cpp_tree()) {
    // Beside the syntax and semantic trees there is also 
    // a separate tree for the preprocessor directives.
    // This tree can be printed using the PrePrintVisitor.
    //Puma::PrePrintVisitor preprinter;
    //tu->cpp_tree()->accept(preprinter);
  }
  
  // Clean up.
  delete tu;

  // Return 1 if errors or fatal errors occurred.
  return err.severity() > Puma::sev_warning ? 1 : 0;
}