summaryrefslogtreecommitdiff
path: root/src/util/language.h
diff options
context:
space:
mode:
authorMorgan Deters <mdeters@gmail.com>2010-11-15 22:57:14 +0000
committerMorgan Deters <mdeters@gmail.com>2010-11-15 22:57:14 +0000
commit5e5956d492ab18b5b4d4bb51117ac760867a525d (patch)
tree0c151baa58810722288ad986dfa13123de273739 /src/util/language.h
parentec4e1bdba56565d6372cb19ded12c9cadc506870 (diff)
Pretty-printer infrastructure created (in src/printer) and SMT-LIBv2 printer
implemented. This new infrastructure removes support for pretty-printing (even in the AST language) an Expr with reference count 0. Previously, this was supported in a few places internally to the expr package, for example in NodeBuilder. (Now, a NodeBuilder cannot be prettyprinted, you must extract the Node before printing it.)
Diffstat (limited to 'src/util/language.h')
-rw-r--r--src/util/language.h24
1 files changed, 14 insertions, 10 deletions
diff --git a/src/util/language.h b/src/util/language.h
index 5446357c4..fdd2a382d 100644
--- a/src/util/language.h
+++ b/src/util/language.h
@@ -37,7 +37,7 @@ enum Language {
/** Auto-detect the language */
LANG_AUTO = -1,
- // COMMON INPUT AND OUTPUT LANGUAGES HAVE ENUM VALUES IN [0,999]
+ // COMMON INPUT AND OUTPUT LANGUAGES HAVE ENUM VALUES IN [0,9]
// AND SHOULD CORRESPOND IN PLACEMENT WITH OUTPUTLANGUAGE
//
// EVEN IF A LANGUAGE ISN'T CURRENTLY SUPPORTED AS AN INPUT OR
@@ -49,15 +49,20 @@ enum Language {
/** The SMTLIB v2 input language */
LANG_SMTLIB_V2,
/** The CVC4 input language */
- LANG_CVC4
+ LANG_CVC4,
- // START INPUT-ONLY LANGUAGES AT ENUM VALUE 1000
+ // START INPUT-ONLY LANGUAGES AT ENUM VALUE 10
// THESE ARE IN PRINCIPLE NOT POSSIBLE OUTPUT LANGUAGES
+ /** LANG_MAX is > any valid InputLanguage id */
+ LANG_MAX
};/* enum Language */
inline std::ostream& operator<<(std::ostream& out, Language lang) {
switch(lang) {
+ case LANG_AUTO:
+ out << "LANG_AUTO";
+ break;
case LANG_SMTLIB:
out << "LANG_SMTLIB";
break;
@@ -67,9 +72,6 @@ inline std::ostream& operator<<(std::ostream& out, Language lang) {
case LANG_CVC4:
out << "LANG_CVC4";
break;
- case LANG_AUTO:
- out << "LANG_AUTO";
- break;
default:
out << "undefined_input_language";
}
@@ -83,7 +85,7 @@ namespace output {
enum Language {
// SPECIAL "NON-LANGUAGE" LANGUAGES HAVE ENUM VALUE < 0
- // COMMON INPUT AND OUTPUT LANGUAGES HAVE ENUM VALUES IN [0,999]
+ // COMMON INPUT AND OUTPUT LANGUAGES HAVE ENUM VALUES IN [0,9]
// AND SHOULD CORRESPOND IN PLACEMENT WITH INPUTLANGUAGE
//
// EVEN IF A LANGUAGE ISN'T CURRENTLY SUPPORTED AS AN INPUT OR
@@ -97,12 +99,14 @@ enum Language {
/** The CVC4 output language */
LANG_CVC4 = input::LANG_CVC4,
- // START OUTPUT-ONLY LANGUAGES AT ENUM VALUE 1000
+ // START OUTPUT-ONLY LANGUAGES AT ENUM VALUE 10
// THESE ARE IN PRINCIPLE NOT POSSIBLE INPUT LANGUAGES
/** The AST output language */
- LANG_AST = 1000
+ LANG_AST = 10,
+ /** LANG_MAX is > any valid OutputLanguage id */
+ LANG_MAX
};/* enum Language */
inline std::ostream& operator<<(std::ostream& out, Language lang) {
@@ -117,7 +121,7 @@ inline std::ostream& operator<<(std::ostream& out, Language lang) {
out << "LANG_CVC4";
break;
case LANG_AST:
- out << "LANG_AUTO";
+ out << "LANG_AST";
break;
default:
out << "undefined_output_language";
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback