File: parser.h

package info (click to toggle)
asymptote 2.85%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 43,264 kB
  • sloc: cpp: 210,491; ansic: 98,376; python: 14,568; javascript: 6,629; sh: 4,301; perl: 1,566; lisp: 1,505; makefile: 764; yacc: 554; lex: 446; xml: 182; objc: 177
file content (38 lines) | stat: -rw-r--r-- 1,171 bytes parent folder | download | duplicates (2)
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
/*****
 * parser.h
 * Tom Prince 2004/01/10
 *
 *****/

#ifndef PARSER_H
#define PARSER_H

#include "common.h"
#include "absyn.h"

namespace parser {

// Opens and parses the file returning the abstract syntax tree.
// If there is an unrecoverable parse error, returns null.
absyntax::file *parseFile(const string& filename,
                          const char *nameOfAction);

// Opens and parses the URL returning the abstract syntax tree.
// If there is an unrecoverable parse error, returns null.
absyntax::file *parseURL(const string& filename,
                         const char *nameOfAction);

// Parses string and returns the abstract syntax tree.  Any error in lexing or
// parsing will be reported and a handled_error thrown.  If the string is
// "extendable", then a parse error simply due to running out of input will not
// throw an exception, but will return null.
absyntax::file *parseString(const string& code,
                            const string& filename,
                            bool extendable=false);

bool isURL(const string& filename);
bool readURL(stringstream& buf, const string& filename);

} // namespace parser

#endif // PARSER_H