aboutsummaryrefslogtreecommitdiffstats
path: root/lib/parsetools/src/yeccscan.erl
diff options
context:
space:
mode:
authorErlang/OTP <[email protected]>2009-11-20 14:54:40 +0000
committerErlang/OTP <[email protected]>2009-11-20 14:54:40 +0000
commit84adefa331c4159d432d22840663c38f155cd4c1 (patch)
treebff9a9c66adda4df2106dfd0e5c053ab182a12bd /lib/parsetools/src/yeccscan.erl
downloadotp-84adefa331c4159d432d22840663c38f155cd4c1.tar.gz
otp-84adefa331c4159d432d22840663c38f155cd4c1.tar.bz2
otp-84adefa331c4159d432d22840663c38f155cd4c1.zip
The R13B03 release.OTP_R13B03
Diffstat (limited to 'lib/parsetools/src/yeccscan.erl')
-rw-r--r--lib/parsetools/src/yeccscan.erl62
1 files changed, 62 insertions, 0 deletions
diff --git a/lib/parsetools/src/yeccscan.erl b/lib/parsetools/src/yeccscan.erl
new file mode 100644
index 0000000000..d7ec3ba8d3
--- /dev/null
+++ b/lib/parsetools/src/yeccscan.erl
@@ -0,0 +1,62 @@
+%%
+%% %CopyrightBegin%
+%%
+%% Copyright Ericsson AB 1996-2009. All Rights Reserved.
+%%
+%% 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 online 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.
+%%
+%% %CopyrightEnd%
+%%
+
+-module(yeccscan).
+-export([scan/1, scan/3]).
+
+scan(Inport) ->
+ scan(Inport, '', 1).
+
+scan(Inport, Prompt, Line1) ->
+ case catch io:scan_erl_form(Inport, Prompt, Line1) of
+ {eof, Line2} ->
+ {eof, Line2};
+ {ok, Tokens, Line2} ->
+ case Tokens of
+ [] ->
+ scan(Inport, Prompt, Line2);
+ _ ->
+ {ok, lex(Tokens), Line2}
+ end;
+ {error, Descriptor, Line2} ->
+ {error, Descriptor, Line2};
+ {'EXIT', Why} ->
+ io:format('yeccscan: Error scanning input line ~w~n', [Line1]),
+ exit(Why)
+ end.
+
+lex([]) ->
+ [];
+lex([Token | Tokens]) ->
+ case Token of
+ {'dot', Line} ->
+ [{'dot', Line} | lex(Tokens)];
+ {':', Line} ->
+ [{':', Line} | lex(Tokens)];
+ {'->', Line} ->
+ [{'->', Line} | lex(Tokens)];
+ {Category, Line, Symbol} ->
+ [{Category, Line, Symbol} | lex(Tokens)];
+ {Other, Line} ->
+ Cat = case erl_scan:reserved_word(Other) of
+ true -> reserved_word;
+ false -> reserved_symbol
+ end,
+ [{Cat, Line, Other} | lex(Tokens)]
+ end.