亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? compiler.cpp

?? SSD6 練習4的原版正確答案
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// work well for user type-in)
//
bool Compiler::compile_file(FILE *file, bool interactive)
{
	interactive_mode = interactive;
	inf = file; // so that get_token() will read from file
	if (!semantics.reset()) return false;
    error_flag = false;
    token = tokens;
    unget_count = 0;
    token->typ = TOKEN_OTHER;
    istack_top = 0;
    indentation[0] = 0;
    dedent_count = 0;
	newline_flag = false;
	line_number = 1;
    while (!machine->exit_flag && parse_decl()) ;
	return !error_flag;
}


bool Compiler::compile(char *filename)
{
    FILE *f = fopen(filename, "r");
	bool result;
    if (f) {
		result = compile_file(f, false);
		fclose(f);
	} else {
        char msg[128];
        strcpy(msg, "Compiler: can't open ");
        strcat(msg, filename);
        report_error(msg);
		result = false;
    }
	return result;
}


bool Compiler::parse_decl()
{
    if (get_token()) {
        return parse_decl_2();
    }
    return false;
}


bool Compiler::parse_decl_2()
{
    if (token->typ == TOKEN_ID) {
        if (streql(token->str, "def")) {
            return parse_method();
        } else if (streql(token->str, "var")) {
            return parse_var();
        } else if (streql(token->str, "class")) {
            return parse_class();
        } else {
            // assume we have an immediate statement
            // create a method for it
            semantics.method_start();
            semantics.method_name_is("<immediate command>");
            semantics.begin_formals();
            semantics.end_of_formals();
            if (parse_stmt_2() && semantics.method_end()) {
                // execute the method now
                Symbol_ptr s_imcd = Symbol::create("<immediate command>", machine);
                machine->global_function(s_imcd);
                if (machine->error_flag) return false;
                machine->call();
                return !machine->error_flag;
            }
            return false; // allow immediate stmt in place of decl
        }
    } else if (token->typ == TOKEN_NEWLINE) {
        return true;
    }
    return false;
}


bool Compiler::parse_id(char *msg)
{
    if (get_token() && token->typ == TOKEN_ID) return true;
    expected_id(msg);
    return false;
}


bool Compiler::parse_method()
{
    if (get_token()) {
        if (token->typ == TOKEN_ID &&
            semantics.method_start() &&
            semantics.method_name_is(token->str)) {
            if (parse_formals() &&
				parse_colon() &&
                parse_stmt_list() && 
                semantics.method_end()) {
                return true;
            }
        }
    }
    return false;
}

bool Compiler::parse_formals()
{
    semantics.begin_formals();
    if (!get_token() || !streql(token->str, "(")) {
        expected_open_paren();
        return false;
    }
    if (!parse_token()) return false;
    bool more = true;
    bool first = true; // allow ')' only on first time through loop
    while (more) {
        if (token->typ == TOKEN_ID) {
            bool ok = true;
            if ((streql(token->str, "optional") && 
                 (ok = semantics.set_formal_type(FORMAL_OPTIONAL))) ||
                (streql(token->str, "keyword") &&
                 (ok = semantics.set_formal_type(FORMAL_KEYWORD))) ||
                (streql(token->str, "rest") &&
                 (ok = semantics.set_formal_type(FORMAL_REST))) ||
                (streql(token->str, "dictionary") &&
                 (ok = semantics.set_formal_type(FORMAL_DICTIONARY))) ||
                (streql(token->str, "required") &&
                 (ok = semantics.set_formal_type(FORMAL_REQUIRED)))) {
                if (!parse_id("formal parameter")) return false;
            }
            // if a set_formal_type failed, return now:
            if (!ok) return false;
            if (!semantics.formal_is(token->str)) return false;
            // look for default value specification:
            if (get_token()) {
                if (streql(token->str, "=")) {
                    if (!parse_default_value()) return false;
                } else unget_token();
            } else unget_token();
            // look for comma
            if (get_token()) {
                more = streql(token->str, ",");
                if (more) {
                    if (!parse_token()) return false;
                }
            } else { // no token!
                expected_close_paren();
                return false;
            }
        } else if (first && streql(token->str, ")")) {
            more = false;
        } else break;
        first = false;
    }
    if (streql(token->str, ")")) {
        return semantics.end_of_formals();
    } else {
        expected_close_paren_or_formal();
        return false();
    }
}


int Compiler::hex_to_int(char h)
{
	if (isdigit(h)) return h - '0';
	else if (isxdigit(h)) return tolower(h) - 'a' + 10;
	expected_hex_constant();
	return 0;
}


int Compiler::oct_to_int(char o)
{
	if ((o >= '0') && (o <= '7')) return o - '0';
	expected_oct_constant();
	return 0;
}


int Compiler::dec_to_int(char d)
{
	if (isdigit(d)) return d - '0';
	expected_number_constant();
	return 0;
}


int64 Compiler::string_to_int(char *s)
{
	int64 result = 0;
	int sign = 1;
	if (!s || *s == 0) return result;
	if (*s == '-') {
		if (*s++ == 0) return result;
		sign = -1;
	} 
	if (s[0] == '0' && (s[1] == 'x' || s[1] == 'X')) { // hexadecimal
		for (int i = 2; s[i] && !error_flag; i++) {
			result = (result << 4) + hex_to_int(s[i]);
		}
		result *= sign;
	} else if (s[0] == '0') { // octal
		for (int i = 1; s[i] && !error_flag; i++) {
			result = (result << 3) + oct_to_int(s[i]);
		}
		result *= sign;
	} else {
		// since negative numbers can be larger (in magnitude) than positive
		// we'll compute decimal numbers in the negative form and then apply
		// the sign.
		for (int i = 0; s[i] && !error_flag; i++) {
			result = (result * 10) - dec_to_int(s[i]);
		}
		result *= -sign;
	}
	return result;
}


bool Compiler::parse_default_value()
{
    if (!parse_token()) return false;
    // assume value is in one token
    if (token->typ == TOKEN_LONG) {
		int64 val = string_to_int(token->str);
		if (error_flag) return false;
        return semantics.default_value(
            FLong::create(val, machine));
	} else if (token->typ == TOKEN_DOUBLE) {
		// make sure there is a + or - after e:
		char *pos = strpbrk(token->str, "eE");
		if (pos && pos[1] != '+' && pos[1] != '-') {
			// open up some space:
			memmove(pos + 2, pos + 1, strlen(pos + 1));
			pos[1] = '+';
		}
        return semantics.default_value(
            FDouble::create(atof(token->str), machine));
	} else if (token->typ == TOKEN_STRING) {
        return semantics.default_value(
            FString::create(token->str + 1, machine));
    } else if (token->typ == TOKEN_SYMBOL) {
        return semantics.default_value(
            Symbol::create(token->str + 1, machine));
	} else return false;
}


bool Compiler::parse_stmt()
{
    if (get_token()) {
        return parse_stmt_2();
    }
    expected_statement();
    return false;
}


// parse_stmt_2 -- parse stmt, assumes first token already gotten
//
bool Compiler::parse_stmt_2()
{
    if (streql(token->str, "class") || streql(token->str, "var") ||
        streql(token->str, "def")) {
        return parse_decl_2();
    } else if (streql(token->str, "if")) {
        return parse_if();
    } else if (streql(token->str, "while")) {
        return parse_while();
    } else if (streql(token->str, "for")) {
        return parse_for();
    } else if (streql(token->str, "return")) {
        return parse_return();
	} else if (streql(token->str, "print")) {
		return parse_print();
    } else if (streql(token->str, "load")) {
        return parse_load();
    } else if (token->typ == TOKEN_ID) {
        char id[STRING_MAX];
        strcpy(id, token->str);
        if (!parse_id_expr(id)) return false;
        if (get_token()) {
            if (streql(token->str, "=")) {
                return parse_assign();
            } else if (token->typ == TOKEN_NEWLINE) {
                semantics.end_id_expr();
                return true;
            }
        }
        expected_newline();
    } else {
        expected_statement();
    }
    return false;
}


bool Compiler::parse_if()
{
    // at this point, IF has already been parsed
    if (parse_expr()) {
        semantics.if_true();
        if (parse_colon() && parse_stmt_list()) {
			long elif_count = 0;
			while (get_token() && streql(token->str, "elif")) {
				semantics.if_else();
				if (parse_expr()) {
					semantics.if_true();
					if (parse_colon() && parse_stmt_list()) {
						elif_count++;
						trace("elif_count %d\n", elif_count);
					} else return false;
				} else return false;
			}
            if (streql(token->str, "else")) {
                semantics.if_else();
                if (parse_colon() && parse_stmt_list()) {
					// if_end called for each elif and for else
					while (elif_count >= 0) {
						semantics.if_end();
						elif_count--;
					}
					return true;
				} else return false;
            } else {
                unget_token();
				while (elif_count >= 0) {
					semantics.if_end();
					elif_count--;
				}
                return true;
            }
        }
    }
    return false;
}


bool Compiler::parse_while()
{
    return semantics.while_begin() && 
        parse_expr() && parse_colon() &&
        semantics.while_true() && 
        parse_stmt_list() && 
        semantics.while_end();
}


bool Compiler::parse_for()
{
	if (!parse_token()) return false;
	if (token->typ != TOKEN_ID) {
		expected_id(token->str);
		return false;
	}
	if (!semantics.for_var(token->str)) return false;
	if (!parse_token()) return false;
	else if (streql(token->str, "=")) {
		if (!parse_expr() || !semantics.for_init())
			return false;
		if (!get_token() || !streql(token->str, "to")) {
			expected_to();
			return false;
		}
		if (!(parse_expr() && semantics.for_to()))
			return false;
		if (!parse_token()) return false;
		if (streql(token->str, "by")) {
			if (!parse_expr() || !semantics.for_by(true))
				return false;
		} else {
			unget_token();
			if (!semantics.for_by(false)) return false;
		}
		if (!parse_colon() || !parse_stmt_list() || 
			!semantics.for_end_range())
			return false;
	} else if (streql(token->str, "in")) {
		if (!parse_expr() || !semantics.for_array() ||
			!parse_colon() || !parse_stmt_list() ||
			!semantics.for_end_elements())
			return false;
	} else {
		expected_equal_or_in();
		return false;
	}
	return true;
}


bool Compiler::parse_indent()
{
	if (get_token() && token->typ == TOKEN_INDENT) {
		return true;
	}
	expected_indent();
	return false;
}


bool Compiler::parse_newline()
{
    if (get_token() && token->typ == TOKEN_NEWLINE) {
        return true;
    }
    expected_newline();
    return false;
}


bool Compiler::parse_return()
{
    if (get_token() && token->typ == TOKEN_NEWLINE) {
		return semantics.return_null();
	}
    unget_token();
	return parse_expr() && parse_newline() && semantics.return_end();
}


bool Compiler::parse_load()
{
	return parse_expr() && parse_newline() && semantics.load_end();
}


bool Compiler::parse_print()
{
    bool print_endl = true;
    while (true) {
        // look for an expression
        if (!parse_token()) return false;
        if (token->typ == TOKEN_NEWLINE) {
            if (print_endl) return semantics.print_end();
            else return true;
        } else if (unget_token() && parse_expr()) {
            semantics.print_expr();
        } else return false; // no expression found
        print_endl = false;
        // look for a separator
        if (!parse_token()) return false;
        if (token->typ == TOKEN_NEWLINE) {
            return semantics.print_end();
        } else if (streql(token->str, ",")) {
            semantics.print_comma();
        } else if (streql(token->str, ";")) {
            // nothing
        } else expected_comma();
    }
}

bool Compiler::parse_stmt_list()
{
	if (!parse_token()) return false;
	if (token->typ != TOKEN_NEWLINE) {
		return parse_stmt_2(); // just one statement after a colon
	} 
	if (!parse_indent()) return false;
	while (true) {
		if (get_token()) {
			if (token->typ == TOKEN_DEDENT) {
				return true;
			} else if (parse_stmt_2()) {
				// continue parsing stmts
			} else break;
		} else {
			expected_statement();
			break;
		}
	}
	return false;
}


bool Compiler::parse_assign()
{
    // expr and "=" have already been parsed
    return semantics.rval2lval() && 
           parse_expr() && 
           parse_newline() && 
           semantics.assign_end();
}


/*
bool Compiler::parse_assign_id(char *id)
{
	return parse_expr() && parse_newline() && semantics.assign_id(id);
}
*/


bool Compiler::parse_expr()
{
    if (parse_conj()) {
        return parse_disjunctions();
    }
    return false;
}


bool Compiler::parse_conj()
{
    if (parse_relation()) {
        return parse_conjunctions();
    }
    return false;
}


bool Compiler::parse_relation()
{
    if (parse_sum()) {
        if (parse_relop()) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一级日本不卡的影视| av色综合久久天堂av综合| 国产高清久久久| 欧美色手机在线观看| 国产欧美精品在线观看| 日本不卡免费在线视频| 99国产精品久| 欧美韩日一区二区三区四区| 午夜成人免费电影| 色哟哟国产精品| 欧美激情艳妇裸体舞| 精品一区二区久久久| 欧美日韩亚州综合| 亚洲国产另类av| 91极品美女在线| 亚洲欧美韩国综合色| 国产精品亚洲人在线观看| 欧美成人一区二区| 免费久久精品视频| 91精品在线一区二区| 亚洲福利国产精品| 在线看日韩精品电影| 亚洲欧美日韩精品久久久久| 国v精品久久久网| 久久久久久久免费视频了| 日本欧美在线观看| 91麻豆精品国产91久久久久 | 婷婷久久综合九色综合伊人色| 丁香六月久久综合狠狠色| 精品国产91亚洲一区二区三区婷婷 | 欧美另类videos死尸| 亚洲天堂久久久久久久| 91视频在线观看免费| 亚洲欧洲精品天堂一级| 不卡一卡二卡三乱码免费网站| 国产日韩欧美综合在线| 国产91色综合久久免费分享| 2022国产精品视频| 成人免费视频播放| 亚洲欧美激情一区二区| 在线免费亚洲电影| 亚洲大尺度视频在线观看| 91超碰这里只有精品国产| 日韩高清电影一区| 精品国产99国产精品| 成人午夜在线播放| 亚洲欧美一区二区三区国产精品 | 国产亚洲婷婷免费| 成人美女视频在线观看18| 国产精品天天摸av网| jlzzjlzz亚洲女人18| 亚洲一区影音先锋| 7799精品视频| 国产宾馆实践打屁股91| 亚洲精品中文在线| 91精品午夜视频| 国产成人精品影视| 亚洲日本护士毛茸茸| 欧美日韩国产系列| 国产美女精品人人做人人爽| 亚洲视频电影在线| 制服丝袜亚洲精品中文字幕| 国产精品一区二区你懂的| **网站欧美大片在线观看| 欧美一区二区三区小说| 成人国产精品视频| 丝袜亚洲精品中文字幕一区| 久久久.com| 欧美三级乱人伦电影| 国产精品白丝av| 偷窥少妇高潮呻吟av久久免费| 久久精品日产第一区二区三区高清版 | 欧美女孩性生活视频| 国产麻豆欧美日韩一区| 亚洲午夜免费电影| 日本一区二区成人| 欧美一区二区三区四区五区| 99re这里只有精品首页| 精品一区二区三区视频在线观看| 自拍偷拍欧美精品| 国产午夜精品久久久久久免费视 | 欧美mv和日韩mv的网站| 97久久久精品综合88久久| 美女视频一区二区三区| 亚洲欧美日韩国产中文在线| 久久亚洲精精品中文字幕早川悠里| 色婷婷综合久久| 成人综合在线观看| 韩国在线一区二区| 天堂蜜桃91精品| 亚洲美女视频一区| 国产精品久久夜| 久久亚洲欧美国产精品乐播| 欧美美女bb生活片| 成人av影视在线观看| 久久成人免费网| 天天免费综合色| 亚洲va欧美va天堂v国产综合| 中文字幕佐山爱一区二区免费| 日韩欧美成人激情| 欧美精品乱码久久久久久按摩 | 欧美肥妇bbw| 日本福利一区二区| 色综合久久88色综合天天| 北岛玲一区二区三区四区| 福利一区二区在线观看| 国产黄人亚洲片| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲精品视频在线| 中文字幕亚洲精品在线观看| 国产欧美日韩激情| 国产精品天天看| 国产精品视频在线看| 国产午夜久久久久| 中文幕一区二区三区久久蜜桃| 国产喷白浆一区二区三区| 久久青草国产手机看片福利盒子 | 美女网站色91| 久久国产成人午夜av影院| 久久99精品久久久久久动态图 | 99久久综合精品| 99久久精品情趣| 色综合中文字幕国产| 国产91精品露脸国语对白| 高清在线不卡av| 色综合中文字幕国产| 91网站在线观看视频| 色久综合一二码| 欧美日韩精品三区| 精品免费国产二区三区| 国产日韩视频一区二区三区| 亚洲欧洲一区二区在线播放| 亚洲精品国产一区二区精华液| 亚洲成人精品一区| 美女一区二区久久| 成人黄色av电影| 色哟哟国产精品免费观看| 欧美高清你懂得| 久久综合久久久久88| 亚洲人成小说网站色在线| 亚洲午夜激情网站| 麻豆91免费观看| www.久久久久久久久| 欧美伦理影视网| 国产日产精品1区| 亚洲电影激情视频网站| 久久www免费人成看片高清| 成人精品国产福利| 欧美剧情片在线观看| 久久精品视频在线看| 亚洲综合成人在线| 国产在线精品一区二区三区不卡| 91麻豆蜜桃一区二区三区| 欧美大片在线观看| 亚洲女同女同女同女同女同69| 日韩**一区毛片| 成人91在线观看| 欧美va亚洲va国产综合| 亚洲裸体xxx| 国产在线精品不卡| 欧美三级中文字幕在线观看| 国产视频一区二区在线| 午夜视频在线观看一区| 成人一区在线看| 精品免费视频.| 亚洲成a天堂v人片| 福利91精品一区二区三区| 欧美精品三级日韩久久| 亚洲欧美一区二区不卡| 国产不卡在线视频| 欧美电影免费观看高清完整版在线观看 | 亚洲一二三四区| 高清不卡一区二区在线| 日韩精品中文字幕在线不卡尤物 | 欧美人与z0zoxxxx视频| 亚洲色图在线播放| 国产精品456| 欧美videos中文字幕| 日韩精彩视频在线观看| 91一区一区三区| 国产精品福利影院| 大胆亚洲人体视频| 国产日产欧美一区| 国产成人亚洲综合色影视| 欧美videofree性高清杂交| 日韩精品成人一区二区三区 | 日韩一二三区不卡| 午夜久久久久久久久| 欧美色男人天堂| 亚洲免费观看视频| 91蜜桃免费观看视频| 国产精品久久久久婷婷| 成人小视频在线| 国产精品久久久久影院亚瑟| 国产成人av电影在线播放| 日本一区二区三区电影| 国产91精品免费| 亚洲欧洲成人av每日更新| av一区二区三区| 亚洲视频中文字幕|