-
Notifications
You must be signed in to change notification settings - Fork 94
/
Copy pathasyparser.h
35 lines (27 loc) · 1.11 KB
/
asyparser.h
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
/*****
* asyparser.h
* Tom Prince 2004/01/10
*
*****/
#pragma once
#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