trick/trick_source/sim_services/MemoryManager/ADefParseContext.cpp

84 lines
2.2 KiB
C++
Raw Permalink Normal View History

/**
2015-02-26 15:02:31 +00:00
@page ADEF_Syntax Allocation Declaration Syntax
An allocation declaration string is used to declare type information for a chunk of memory.
They are taken as parameters by the Memory Managers's declare_var and declare_ext_var member
functions as well as "C" interface calls TMM_declare_var_s and TMM_declare_ext_var_s.
An allocation declaration is an intrinsic type or a user-defined-type followed by a declarator.
A declarator is zero or more asterisks (pointers), followed by an optional variable name,
followed by zero or more bracketed integers (a dimension list).
An intrinsic type is one of the "built-in" types, like "char", "int", "double", etc.
A user defined type is a typedef-struct name or a class name, including if necessary, scope resolution operators ( i.e., "::").
Example Allocation Declaration strings:
- "double"
- "double[3]"
- "double*[3]"
- "char[3][4]"
- "int narf"
- "int *baz[3]"
- "VEHICLE truck"
- "FOO::BAR zortz[2][5]"
2015-02-26 15:02:31 +00:00
\b Syntax of an Allocation Declaration String:
@verbatim
<alloc-declaration> ::= <intrinsic-type> <declarator>
| <user-defined-type> <declarator>
<declarator> ::= <pointers> <opt-name> <dim-list>
<opt-name> ::= nil
| NAME
<pointers> ::= nil
| pointers '*'
<user-defined-type> ::= NAME
| <user-defined-type> ":" ":" NAME
<dim-list> ::= nil
| <dim-list> "[" INTEGER "]"
intrinsic_type ::= "char"
| "short"
| "int"
| "long"
| "float"
| "double"
| "long long"
| "wchar_t"
| "unsigned char"
| "unsigned short"
| "unsigned int"
| "unsigned long"
| "unsigned long long"
NAME ::= [_a-zA-Z][_a-zA-Z0-9:]*
@endverbatim
*/
#include <stdio.h>
#include <stdlib.h>
#include "trick/ADefParseContext.hh"
2015-02-26 15:02:31 +00:00
/**
Constructor
2015-02-26 15:02:31 +00:00
*/
Trick::ADefParseContext::ADefParseContext( std::istream* in_is ) {
init_scanner();
this->is = in_is;
}
/**
Destructor
2015-02-26 15:02:31 +00:00
*/
Trick::ADefParseContext::~ADefParseContext() {
destroy_scanner();
}