⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 yeccparser.erl

📁 OTP是开放电信平台的简称
💻 ERL
📖 第 1 页 / 共 2 页
字号:
-module(yeccparser).-export([parse/1, parse_and_scan/1, format_error/1]).-file("yeccgramm.yrl", 59).-record(symbol, {line, name}).symbol(Symbol) ->    #symbol{line = line_of(Symbol), name = value_of(Symbol)}.value_of(Token) ->    element(3, Token).line_of(Token) ->    element(2, Token).-file("./yeccpre.hrl", 0).%% ``The contents of this file are subject to the Erlang Public License,%% Version 1.1, (the "License"); you may not use this file except in%% compliance with the License. You should have received a copy of the%% Erlang Public License along with this software. If not, it can be%% retrieved via the world wide web at http://www.erlang.org/.%% %% Software distributed under the License is distributed on an "AS IS"%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See%% the License for the specific language governing rights and limitations%% under the License.%% %% The Initial Developer of the Original Code is Ericsson Utvecklings AB.%% Portions created by Ericsson are Copyright 1999, Ericsson Utvecklings%% AB. All Rights Reserved.''%% %%     $Id $%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% The parser generator will insert appropriate declarations before this line.%parse(Tokens) ->    yeccpars0(Tokens, false).parse_and_scan({F, A}) -> % Fun or {M, F}    yeccpars0([], {F, A});parse_and_scan({M, F, A}) ->    yeccpars0([], {{M, F}, A}).format_error(Message) ->    case io_lib:deep_char_list(Message) of	true ->	    Message;	_ ->	    io_lib:write(Message)    end.% To be used in grammar files to throw an error message to the parser% toplevel. Doesn't have to be exported!-compile({nowarn_unused_function,{return_error,2}}).return_error(Line, Message) ->    throw({error, {Line, ?MODULE, Message}}).yeccpars0(Tokens, MFA) ->    try yeccpars1(Tokens, MFA, 0, [], [])    catch         throw: {error, {_Line, ?MODULE, _M}} = Error ->                    Error % probably from return_error/1    end.% Don't change yeccpars1/6 too much, it is called recursively by yeccpars2/8!yeccpars1([Token | Tokens], Tokenizer, State, States, Vstack) ->    yeccpars2(State, element(1, Token), States, Vstack, Token, Tokens,	      Tokenizer);yeccpars1([], {F, A}, State, States, Vstack) ->    case apply(F, A) of        {ok, Tokens, _Endline} ->	    yeccpars1(Tokens, {F, A}, State, States, Vstack);        {eof, _Endline} ->            yeccpars1([], false, State, States, Vstack);        {error, Descriptor, _Endline} ->            {error, Descriptor}    end;yeccpars1([], false, State, States, Vstack) ->    yeccpars2(State, '$end', States, Vstack, {'$end', 999999}, [], false).% For internal use only.yeccerror(Token) ->    {error,     {element(2, Token), ?MODULE,      ["syntax error before: ", yecctoken2string(Token)]}}.yecctoken2string({atom, _, A}) -> io_lib:write(A);yecctoken2string({integer,_,N}) -> io_lib:write(N);yecctoken2string({float,_,F}) -> io_lib:write(F);yecctoken2string({char,_,C}) -> io_lib:write_char(C);yecctoken2string({var,_,V}) -> io_lib:format('~s', [V]);yecctoken2string({string,_,S}) -> io_lib:write_string(S);yecctoken2string({reserved_symbol, _, A}) -> io_lib:format('~w', [A]);yecctoken2string({_Cat, _, Val}) -> io_lib:format('~w', [Val]);yecctoken2string({'dot', _}) -> io_lib:format('~w', ['.']);yecctoken2string({'$end', _}) ->    [];yecctoken2string({Other, _}) when is_atom(Other) ->    io_lib:format('~w', [Other]);yecctoken2string(Other) ->    io_lib:write(Other).%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%-file("yeccparser.erl", 110).yeccpars2(0, atom, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 6, [0 | __Ss], [__T | __Stack]);yeccpars2(0, integer, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 7, [0 | __Ss], [__T | __Stack]);yeccpars2(0, reserved_word, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 8, [0 | __Ss], [__T | __Stack]);yeccpars2(0, var, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 9, [0 | __Ss], [__T | __Stack]);yeccpars2(0, _, _, _, __T, _, _) -> yeccerror(__T);yeccpars2(1, atom, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 6, [1 | __Ss], [__T | __Stack]);yeccpars2(1, integer, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 7, [1 | __Ss], [__T | __Stack]);yeccpars2(1, reserved_word, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 8, [1 | __Ss], [__T | __Stack]);yeccpars2(1, var, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 9, [1 | __Ss], [__T | __Stack]);yeccpars2(1, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars2(yeccgoto(head, hd(__Ss)), __Cat, __Ss, __Stack, __T, __Ts, __Tzr);yeccpars2(2, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars2(yeccgoto(grammar, hd(__Ss)), __Cat, __Ss, __Stack, __T, __Ts, __Tzr);yeccpars2(3, '->', __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 10, [3 | __Ss], [__T | __Stack]);yeccpars2(3, _, _, _, __T, _, _) -> yeccerror(__T);yeccpars2(4, '$end', _, __Stack, _, _, _) -> {ok, hd(__Stack)};yeccpars2(4, _, _, _, __T, _, _) -> yeccerror(__T);yeccpars2(5, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars2(yeccgoto(grammar, hd(__Ss)), __Cat, __Ss, __Stack, __T, __Ts, __Tzr);yeccpars2(6, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_6_(__Stack), yeccpars2(yeccgoto(symbol, hd(__Ss)), __Cat, __Ss, __NewStack, __T, __Ts, __Tzr);yeccpars2(7, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_7_(__Stack), yeccpars2(yeccgoto(symbol, hd(__Ss)), __Cat, __Ss, __NewStack, __T, __Ts, __Tzr);yeccpars2(8, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_8_(__Stack), yeccpars2(yeccgoto(symbol, hd(__Ss)), __Cat, __Ss, __NewStack, __T, __Ts, __Tzr);yeccpars2(9, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_9_(__Stack), yeccpars2(yeccgoto(symbol, hd(__Ss)), __Cat, __Ss, __NewStack, __T, __Ts, __Tzr);yeccpars2(10, atom, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 6, [10 | __Ss], [__T | __Stack]);yeccpars2(10, integer, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 7, [10 | __Ss], [__T | __Stack]);yeccpars2(10, reserved_word, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 8, [10 | __Ss], [__T | __Stack]);yeccpars2(10, var, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 9, [10 | __Ss], [__T | __Stack]);yeccpars2(10, _, _, _, __T, _, _) -> yeccerror(__T);yeccpars2(11, ':', __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 15, [11 | __Ss], [__T | __Stack]);yeccpars2(11, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_11_(__Stack), yeccpars2(14, __Cat, [11 | __Ss], __NewStack, __T, __Ts, __Tzr);yeccpars2(12, atom, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 6, [12 | __Ss], [__T | __Stack]);yeccpars2(12, integer, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 7, [12 | __Ss], [__T | __Stack]);yeccpars2(12, reserved_word, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 8, [12 | __Ss], [__T | __Stack]);yeccpars2(12, var, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 9, [12 | __Ss], [__T | __Stack]);yeccpars2(12, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_12_(__Stack), yeccpars2(yeccgoto(symbols, hd(__Ss)), __Cat, __Ss, __NewStack, __T, __Ts, __Tzr);yeccpars2(13, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_13_(__Stack), __Nss = lists:nthtail(1, __Ss), yeccpars2(yeccgoto(symbols, hd(__Nss)), __Cat, __Nss, __NewStack, __T, __Ts, __Tzr);yeccpars2(14, dot, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 29, [14 | __Ss], [__T | __Stack]);yeccpars2(14, _, _, _, __T, _, _) -> yeccerror(__T);yeccpars2(15, '->', __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 18, [15 | __Ss], [__T | __Stack]);yeccpars2(15, ':', __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 19, [15 | __Ss], [__T | __Stack]);yeccpars2(15, atom, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 20, [15 | __Ss], [__T | __Stack]);yeccpars2(15, char, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 21, [15 | __Ss], [__T | __Stack]);yeccpars2(15, float, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 22, [15 | __Ss], [__T | __Stack]);yeccpars2(15, integer, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 23, [15 | __Ss], [__T | __Stack]);yeccpars2(15, reserved_symbol, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 24, [15 | __Ss], [__T | __Stack]);yeccpars2(15, reserved_word, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 25, [15 | __Ss], [__T | __Stack]);yeccpars2(15, string, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 26, [15 | __Ss], [__T | __Stack]);yeccpars2(15, var, __Ss, __Stack, __T, __Ts, __Tzr) -> yeccpars1(__Ts, __Tzr, 27, [15 | __Ss], [__T | __Stack]);yeccpars2(15, _, _, _, __T, _, _) -> yeccerror(__T);yeccpars2(16, __Cat, __Ss, __Stack, __T, __Ts, __Tzr) -> __NewStack = yeccpars2_16_(__Stack), __Nss = lists:nthtail(1, __Ss), yeccpars2(yeccgoto(attached_code, hd(__Nss)), __Cat, __Nss, __NewStack, __T, __Ts, __Tzr);yeccpars2(17, '->', __Ss, __Stack, __T, __Ts, __Tzr) ->

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -