From ac0c3c551b1fdba61d492d7aaedc557e82b494f4 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= <essen@dev-extend.eu>
Date: Mon, 12 Dec 2011 10:02:34 +0100
Subject: [PATCH] Initial release layout

Moved files around to generate releases later on, but also to
separate the code into many different applications each with their
own purpose (patch server, game server, data storage, script compiler,
files library, and so on).
---
 {c_src => apps/egs/c_src}/egs_prs_drv.c       |    0
 {c_src => apps/egs/c_src}/prs.c               |    0
 {include => apps/egs/include}/records.hrl     |    0
 apps/egs/priv/egs_drv.so                      |  Bin 0 -> 18398 bytes
 apps/egs/rebar.config                         |    4 +
 {src => apps/egs/src}/egs.app.src             |    0
 {src => apps/egs/src}/egs.erl                 |    0
 {src => apps/egs/src}/egs_accounts.erl        |    0
 {src => apps/egs/src}/egs_app.erl             |    0
 {src => apps/egs/src}/egs_char_select.erl     |    0
 {src => apps/egs/src}/egs_conf.erl            |    0
 {src => apps/egs/src}/egs_counters_db.erl     |    0
 {src => apps/egs/src}/egs_files.erl           |    0
 {src => apps/egs/src}/egs_game.erl            |    0
 {src => apps/egs/src}/egs_game_protocol.erl   |    6 +-
 {src => apps/egs/src}/egs_items_db.erl        |    0
 {src => apps/egs/src}/egs_login.erl           |    0
 {src => apps/egs/src}/egs_login_protocol.erl  |    6 +-
 {src => apps/egs/src}/egs_network.erl         |    0
 {src => apps/egs/src}/egs_npc_db.erl          |    0
 {src => apps/egs/src}/egs_patch_files_db.erl  |    0
 {src => apps/egs/src}/egs_patch_protocol.erl  |    6 +-
 {src => apps/egs/src}/egs_proto.erl           |    0
 {src => apps/egs/src}/egs_prs.erl             |    0
 {src => apps/egs/src}/egs_quests.erl          |    0
 {src => apps/egs/src}/egs_quests_db.erl       |    0
 {src => apps/egs/src}/egs_quests_sup.erl      |    0
 {src => apps/egs/src}/egs_script_compiler.erl |    0
 apps/egs/src/egs_script_lexer.erl             | 1076 +++++++++++++
 {src => apps/egs/src}/egs_script_lexer.xrl    |    0
 apps/egs/src/egs_script_parser.erl            | 1330 +++++++++++++++++
 {src => apps/egs/src}/egs_script_parser.yrl   |    0
 {src => apps/egs/src}/egs_seasons.erl         |    0
 {src => apps/egs/src}/egs_shops_db.erl        |    0
 {src => apps/egs/src}/egs_sup.erl             |    0
 {src => apps/egs/src}/egs_universes.erl       |    0
 {src => apps/egs/src}/egs_users.erl           |    0
 {src => apps/egs/src}/egs_zones.erl           |    0
 {src => apps/egs/src}/egs_zones_sup.erl       |    0
 .../egs/src}/objects/egs_obj_chair.erl        |    0
 .../egs/src}/objects/egs_obj_door.erl         |    0
 .../egs/src}/objects/egs_obj_entrance.erl     |    0
 .../egs/src}/objects/egs_obj_exit.erl         |    0
 .../src}/objects/egs_obj_invisible_block.erl  |    0
 .../egs/src}/objects/egs_obj_label.erl        |    0
 {src => apps/egs/src}/objects/egs_obj_npc.erl |    0
 .../egs/src}/objects/egs_obj_pp_cube.erl      |    0
 .../egs/src}/objects/egs_obj_sensor.erl       |    0
 .../egs/src}/objects/egs_obj_static_model.erl |    0
 .../egs/src}/objects/egs_obj_type_counter.erl |    0
 .../egs/src}/objects/egs_obj_uni_cube.erl     |    0
 {src => apps/egs/src}/psu/psu_appearance.erl  |    0
 {src => apps/egs/src}/psu/psu_characters.erl  |    0
 {src => apps/egs/src}/psu/psu_party.erl       |    0
 data/lobby/.gitignore                         |    1 -
 data/missions/.gitignore                      |    1 -
 data/rooms/.gitignore                         |    1 -
 data/tutorial/.gitignore                      |    1 -
 rebar.config                                  |    5 +-
 start.sh                                      |    2 +-
 60 files changed, 2422 insertions(+), 17 deletions(-)
 rename {c_src => apps/egs/c_src}/egs_prs_drv.c (100%)
 rename {c_src => apps/egs/c_src}/prs.c (100%)
 rename {include => apps/egs/include}/records.hrl (100%)
 create mode 100755 apps/egs/priv/egs_drv.so
 create mode 100644 apps/egs/rebar.config
 rename {src => apps/egs/src}/egs.app.src (100%)
 rename {src => apps/egs/src}/egs.erl (100%)
 rename {src => apps/egs/src}/egs_accounts.erl (100%)
 rename {src => apps/egs/src}/egs_app.erl (100%)
 rename {src => apps/egs/src}/egs_char_select.erl (100%)
 rename {src => apps/egs/src}/egs_conf.erl (100%)
 rename {src => apps/egs/src}/egs_counters_db.erl (100%)
 rename {src => apps/egs/src}/egs_files.erl (100%)
 rename {src => apps/egs/src}/egs_game.erl (100%)
 rename {src => apps/egs/src}/egs_game_protocol.erl (92%)
 rename {src => apps/egs/src}/egs_items_db.erl (100%)
 rename {src => apps/egs/src}/egs_login.erl (100%)
 rename {src => apps/egs/src}/egs_login_protocol.erl (88%)
 rename {src => apps/egs/src}/egs_network.erl (100%)
 rename {src => apps/egs/src}/egs_npc_db.erl (100%)
 rename {src => apps/egs/src}/egs_patch_files_db.erl (100%)
 rename {src => apps/egs/src}/egs_patch_protocol.erl (98%)
 rename {src => apps/egs/src}/egs_proto.erl (100%)
 rename {src => apps/egs/src}/egs_prs.erl (100%)
 rename {src => apps/egs/src}/egs_quests.erl (100%)
 rename {src => apps/egs/src}/egs_quests_db.erl (100%)
 rename {src => apps/egs/src}/egs_quests_sup.erl (100%)
 rename {src => apps/egs/src}/egs_script_compiler.erl (100%)
 create mode 100644 apps/egs/src/egs_script_lexer.erl
 rename {src => apps/egs/src}/egs_script_lexer.xrl (100%)
 create mode 100644 apps/egs/src/egs_script_parser.erl
 rename {src => apps/egs/src}/egs_script_parser.yrl (100%)
 rename {src => apps/egs/src}/egs_seasons.erl (100%)
 rename {src => apps/egs/src}/egs_shops_db.erl (100%)
 rename {src => apps/egs/src}/egs_sup.erl (100%)
 rename {src => apps/egs/src}/egs_universes.erl (100%)
 rename {src => apps/egs/src}/egs_users.erl (100%)
 rename {src => apps/egs/src}/egs_zones.erl (100%)
 rename {src => apps/egs/src}/egs_zones_sup.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_chair.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_door.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_entrance.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_exit.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_invisible_block.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_label.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_npc.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_pp_cube.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_sensor.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_static_model.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_type_counter.erl (100%)
 rename {src => apps/egs/src}/objects/egs_obj_uni_cube.erl (100%)
 rename {src => apps/egs/src}/psu/psu_appearance.erl (100%)
 rename {src => apps/egs/src}/psu/psu_characters.erl (100%)
 rename {src => apps/egs/src}/psu/psu_party.erl (100%)
 delete mode 100644 data/lobby/.gitignore
 delete mode 100644 data/missions/.gitignore
 delete mode 100644 data/rooms/.gitignore
 delete mode 100644 data/tutorial/.gitignore

diff --git a/c_src/egs_prs_drv.c b/apps/egs/c_src/egs_prs_drv.c
similarity index 100%
rename from c_src/egs_prs_drv.c
rename to apps/egs/c_src/egs_prs_drv.c
diff --git a/c_src/prs.c b/apps/egs/c_src/prs.c
similarity index 100%
rename from c_src/prs.c
rename to apps/egs/c_src/prs.c
diff --git a/include/records.hrl b/apps/egs/include/records.hrl
similarity index 100%
rename from include/records.hrl
rename to apps/egs/include/records.hrl
diff --git a/apps/egs/priv/egs_drv.so b/apps/egs/priv/egs_drv.so
new file mode 100755
index 0000000000000000000000000000000000000000..383ae8376b52743af173c53a9664137b1b5cf2bc
GIT binary patch
literal 18398
zcmcIs3w%`7nLl?Xj~fz_fdEDj90e?_Wx^X&&|n-K6fouCqT+9uB$H$`nThj)R3foK
zWz15O)+*c5UF^Co?Y0(M%a0b<2DOUaZj1F%*0pWwtBKle6l^I{v;Xg$^WC{~GqnDG
zyFD=X`@aA8IFEbox#!+<Zg%)ruXGuP;N%vU3zE9Z6jGxVM;B-Yq(&?iML13uUTIsH
zRgL2AuTl_G0Ut_~M-hH|w0=*O7ZS;edfZYJUQOB01(^K$wO_xsXWC1Fk(ioF6a}F4
zW86t+Xgj84OR4V7WFztSPn6;)x>v!1Df@j2epJqno9yMB04J*U)oVA3x1OB#+OA*j
z?Of2Y?z)-Z+j(S3YT#cf<~aPO5rcFNeq->Xyi4#a$L~D+O7S}vzY6>)jaNiaRf_SO
zgkPn`&PJv{K~3$^22(Yq?m_3B%0cJEnI;3EI#3%>ea7O)bp&fA@~2o7gUWPFJY3c#
zJX6e>M#=XJ3a$bq^;9P+1I405Wv6;m*(fh6r#*2w32Qw6+x~Z6_<i|8w|Bw!cfVIY
zY1-e{Zn<K~+T*uvI`6Lae?G5nXXhP<U;o_p+b{Xyowfd#-d*~;_kZwa(_<fe;nuEu
zUU{p(qOzgmlWPLgZC8Ljr!4QrS*W5$x21mo&uwReW&iiu0nN_@&4=#;o-Yoy!-e=c
z(<K1%+23#$yzMObEx4Yz-`MlG<}CIbq<xt<S38~7PE?lh=mjnMI^tL%ZC|N7VvANh
zChbSJ=cU^IO6oXB0Y$_R=y>#$hjnMK(fDUz?-B2f?4RP*h$1U>oO^Yg`?U54pcLnu
z)ZvgGR78AM$2sJPQ?28CM>lq_w!i%>`Ht826Se(ZZNCGQ^1WTR!y~Yx^eBFW@73j@
z>xj}%@guxe*Eb|lAwJUh8ycUd@r!i6ew{C!Z<&I@=C)Wgm`H}=$zV_fn<CMO2nHLr
zg@_HcMm`-D!E4gNb>ZenA{ma?wuTaka6*Kmk)~i<=+<zsKGYbBH!C2L2-d?Z-l4^4
zqCMP@%)vsft+571+T)2}L#(Ym9!}_x@o<iTEgKb=vPBV-f?V5ENw`Oo@mMP&=EZ{1
zSR#}Tk222zQTt@1A=ns7hNNM0I7uy%gISqU3nf~lT|Bh4z9XrECt70hWJ9dILuy)M
z(Pm4KOk23Ep{-rCM(P`UiI{J(2!>^T!C-wNq1qo%v{78WdexP+!TG-VzD0bJ6y<T2
zsPQrWkr&zBhI6k^yGTur;1=N$pV$4%tNSyL%`DeA@U*^e>m2xM-62~X_zrEq&4F{=
zE(h+{{d<=K->mUo2cFRQ9tZwejqh{d_i*_qd#PFEeaV_yK;C4-`5sPoTWq-fe%_^V
zx@YluA^Tl6oZFo6UK>7z0G;;Oa6J@B%|08hr(zP{Z^LQq=XAh^^F5Muhitfgp4M-}
z?e#ip!}SzPW^v4hQ=K^-x8XF`;51;v?f2qA8_s=>e1>hfK7}&WDH~368Y}7ZOJ$)s
z4=2-x)0~Kt$A;T)(N#9wJ{JmfziSQ#aghw3rb8iO1-hR$pBh<oX@yse%v^?J#rZYh
zNS1f4p@9*kne$1et83_(l>d%o>LNq^QofL6>Uu*5q&%5q>T*N-q&%KvI#olxQXWGx
zouZ*GDZ5CfY7ezb`E)sCYRaK4QhuLgYLcNkDZfoJHN{YklwTv6nqX+IlwTp4y4a9c
z%0D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
RE$F`^Kv`y&D%Iae_+Qi>jGh1h

literal 0
HcmV?d00001

diff --git a/apps/egs/rebar.config b/apps/egs/rebar.config
new file mode 100644
index 0000000..6d687c8
--- /dev/null
+++ b/apps/egs/rebar.config
@@ -0,0 +1,4 @@
+{deps, [
+	{ex_reloader, ".*", {git, "git://github.com/extend/ex_reloader.git", "HEAD"}},
+	{cowboy, ".*", {git, "git://github.com/extend/cowboy.git", "HEAD"}}
+]}.
diff --git a/src/egs.app.src b/apps/egs/src/egs.app.src
similarity index 100%
rename from src/egs.app.src
rename to apps/egs/src/egs.app.src
diff --git a/src/egs.erl b/apps/egs/src/egs.erl
similarity index 100%
rename from src/egs.erl
rename to apps/egs/src/egs.erl
diff --git a/src/egs_accounts.erl b/apps/egs/src/egs_accounts.erl
similarity index 100%
rename from src/egs_accounts.erl
rename to apps/egs/src/egs_accounts.erl
diff --git a/src/egs_app.erl b/apps/egs/src/egs_app.erl
similarity index 100%
rename from src/egs_app.erl
rename to apps/egs/src/egs_app.erl
diff --git a/src/egs_char_select.erl b/apps/egs/src/egs_char_select.erl
similarity index 100%
rename from src/egs_char_select.erl
rename to apps/egs/src/egs_char_select.erl
diff --git a/src/egs_conf.erl b/apps/egs/src/egs_conf.erl
similarity index 100%
rename from src/egs_conf.erl
rename to apps/egs/src/egs_conf.erl
diff --git a/src/egs_counters_db.erl b/apps/egs/src/egs_counters_db.erl
similarity index 100%
rename from src/egs_counters_db.erl
rename to apps/egs/src/egs_counters_db.erl
diff --git a/src/egs_files.erl b/apps/egs/src/egs_files.erl
similarity index 100%
rename from src/egs_files.erl
rename to apps/egs/src/egs_files.erl
diff --git a/src/egs_game.erl b/apps/egs/src/egs_game.erl
similarity index 100%
rename from src/egs_game.erl
rename to apps/egs/src/egs_game.erl
diff --git a/src/egs_game_protocol.erl b/apps/egs/src/egs_game_protocol.erl
similarity index 92%
rename from src/egs_game_protocol.erl
rename to apps/egs/src/egs_game_protocol.erl
index 081e230..9e4c0aa 100644
--- a/src/egs_game_protocol.erl
+++ b/apps/egs/src/egs_game_protocol.erl
@@ -18,12 +18,12 @@
 %%	along with EGS.  If not, see <http://www.gnu.org/licenses/>.
 
 -module(egs_game_protocol).
--export([start_link/3, init/2]).
+-export([start_link/4, init/2]).
 
 -include("include/records.hrl").
 
--spec start_link(ssl:sslsocket(), module(), []) -> {ok, pid()}.
-start_link(Socket, Transport, []) ->
+-spec start_link(pid(), ssl:sslsocket(), module(), []) -> {ok, pid()}.
+start_link(_ListenerPid, Socket, Transport, []) ->
 	Pid = spawn_link(?MODULE, init, [Socket, Transport]),
 	{ok, Pid}.
 
diff --git a/src/egs_items_db.erl b/apps/egs/src/egs_items_db.erl
similarity index 100%
rename from src/egs_items_db.erl
rename to apps/egs/src/egs_items_db.erl
diff --git a/src/egs_login.erl b/apps/egs/src/egs_login.erl
similarity index 100%
rename from src/egs_login.erl
rename to apps/egs/src/egs_login.erl
diff --git a/src/egs_login_protocol.erl b/apps/egs/src/egs_login_protocol.erl
similarity index 88%
rename from src/egs_login_protocol.erl
rename to apps/egs/src/egs_login_protocol.erl
index 5a2bc05..2a21ccc 100644
--- a/src/egs_login_protocol.erl
+++ b/apps/egs/src/egs_login_protocol.erl
@@ -18,12 +18,12 @@
 %%	along with EGS.  If not, see <http://www.gnu.org/licenses/>.
 
 -module(egs_login_protocol).
--export([start_link/3, init/2]).
+-export([start_link/4, init/2]).
 
 -include("include/records.hrl").
 
--spec start_link(ssl:sslsocket(), module(), []) -> {ok, pid()}.
-start_link(Socket, Transport, []) ->
+-spec start_link(pid(), ssl:sslsocket(), module(), []) -> {ok, pid()}.
+start_link(_ListenerPid, Socket, Transport, []) ->
 	Pid = spawn_link(?MODULE, init, [Socket, Transport]),
 	{ok, Pid}.
 
diff --git a/src/egs_network.erl b/apps/egs/src/egs_network.erl
similarity index 100%
rename from src/egs_network.erl
rename to apps/egs/src/egs_network.erl
diff --git a/src/egs_npc_db.erl b/apps/egs/src/egs_npc_db.erl
similarity index 100%
rename from src/egs_npc_db.erl
rename to apps/egs/src/egs_npc_db.erl
diff --git a/src/egs_patch_files_db.erl b/apps/egs/src/egs_patch_files_db.erl
similarity index 100%
rename from src/egs_patch_files_db.erl
rename to apps/egs/src/egs_patch_files_db.erl
diff --git a/src/egs_patch_protocol.erl b/apps/egs/src/egs_patch_protocol.erl
similarity index 98%
rename from src/egs_patch_protocol.erl
rename to apps/egs/src/egs_patch_protocol.erl
index fa17267..9df46d6 100644
--- a/src/egs_patch_protocol.erl
+++ b/apps/egs/src/egs_patch_protocol.erl
@@ -18,7 +18,7 @@
 %%	along with EGS.  If not, see <http://www.gnu.org/licenses/>.
 
 -module(egs_patch_protocol).
--export([start_link/3, init/2]).
+-export([start_link/4, init/2]).
 
 -define(TIMEOUT, 5000).
 
@@ -33,8 +33,8 @@
 -type cmd() :: 0..16#14.
 -type cmd_size() :: 0..16#ffffffff.
 
--spec start_link(inet:socket(), module(), []) -> {ok, pid()}.
-start_link(Socket, Transport, []) ->
+-spec start_link(pid(), inet:socket(), module(), []) -> {ok, pid()}.
+start_link(_ListenerPid, Socket, Transport, []) ->
 	Pid = spawn_link(?MODULE, init, [Socket, Transport]),
 	{ok, Pid}.
 
diff --git a/src/egs_proto.erl b/apps/egs/src/egs_proto.erl
similarity index 100%
rename from src/egs_proto.erl
rename to apps/egs/src/egs_proto.erl
diff --git a/src/egs_prs.erl b/apps/egs/src/egs_prs.erl
similarity index 100%
rename from src/egs_prs.erl
rename to apps/egs/src/egs_prs.erl
diff --git a/src/egs_quests.erl b/apps/egs/src/egs_quests.erl
similarity index 100%
rename from src/egs_quests.erl
rename to apps/egs/src/egs_quests.erl
diff --git a/src/egs_quests_db.erl b/apps/egs/src/egs_quests_db.erl
similarity index 100%
rename from src/egs_quests_db.erl
rename to apps/egs/src/egs_quests_db.erl
diff --git a/src/egs_quests_sup.erl b/apps/egs/src/egs_quests_sup.erl
similarity index 100%
rename from src/egs_quests_sup.erl
rename to apps/egs/src/egs_quests_sup.erl
diff --git a/src/egs_script_compiler.erl b/apps/egs/src/egs_script_compiler.erl
similarity index 100%
rename from src/egs_script_compiler.erl
rename to apps/egs/src/egs_script_compiler.erl
diff --git a/apps/egs/src/egs_script_lexer.erl b/apps/egs/src/egs_script_lexer.erl
new file mode 100644
index 0000000..348488f
--- /dev/null
+++ b/apps/egs/src/egs_script_lexer.erl
@@ -0,0 +1,1076 @@
+-file("/usr/lib/erlang/lib/parsetools-2.0.6/include/leexinc.hrl", 0).
+%% The source of this file is part of leex distribution, as such it
+%% has the same Copyright as the other files in the leex
+%% distribution. The Copyright is defined in the accompanying file
+%% COPYRIGHT. However, the resultant scanner generated by leex is the
+%% property of the creator of the scanner and is not covered by that
+%% Copyright.
+
+-module(egs_script_lexer).
+
+-export([string/1,string/2,token/2,token/3,tokens/2,tokens/3]).
+-export([format_error/1]).
+
+%% User code. This is placed here to allow extra attributes.
+-file("src/egs_script_lexer.xrl", 46).
+
+%% Reserved words.
+reserved_word("debug")    -> debug;
+%% Definitions.
+reserved_word("event")    -> event_def;
+reserved_word("function") -> function_def;
+reserved_word("num_var")  -> num_var;
+reserved_word("str_var")  -> str_var;
+%% Low level opcodes.
+reserved_word("abs")      -> abs;
+reserved_word("add")      -> add;
+reserved_word("band")     -> 'band';
+reserved_word("bor")      -> 'bor';
+reserved_word("bxor")     -> 'bxor';
+reserved_word("dec")      -> dec;
+reserved_word("div")      -> 'div';
+reserved_word("inc")      -> inc;
+reserved_word("is_eq")    -> is_eq;
+reserved_word("is_gt")    -> is_gt;
+reserved_word("is_gteq")  -> is_gteq;
+reserved_word("is_lt")    -> is_lt;
+reserved_word("is_lteq")  -> is_lteq;
+reserved_word("is_neq")   -> is_neq;
+reserved_word("jmp")      -> jmp;
+reserved_word("jnz")      -> jnz;
+reserved_word("jz")       -> jz;
+reserved_word("land")     -> land;
+reserved_word("lor")      -> lor;
+reserved_word("lshift")   -> lshift;
+reserved_word("mod")      -> mod;
+reserved_word("mul")      -> mul;
+reserved_word("neg")      -> neg;
+reserved_word("nop")      -> nop;
+reserved_word("num_get")  -> num_get;
+reserved_word("num_set")  -> num_set;
+reserved_word("push")     -> push;
+reserved_word("restore")  -> restore;
+reserved_word("return")   -> return;
+reserved_word("rshift")   -> rshift;
+reserved_word("save")     -> save;
+reserved_word("savep")    -> savep;
+reserved_word("str_get")  -> str_get;
+reserved_word("str_set")  -> str_set;
+reserved_word("sub")      -> sub;
+%% Case statement.
+reserved_word("case")     -> 'case';
+reserved_word("default")  -> default;
+reserved_word("end")      -> 'end';
+%% Otherwise isn't a reserved word.
+reserved_word(_)          -> false.
+
+%% Syscalls.
+syscall("mes.fukidasi_pc")                  -> {100,  sync};
+syscall("mes.fukidasi_apc")                 -> {101,  sync};
+syscall("mes.fukidasi_npc")                 -> {102,  sync};
+syscall("mes.fukidasi_pc_type")             -> {103,  sync};
+syscall("mes.fukidasi_apc_type")            -> {104,  sync};
+syscall("mes.fukidasi_npc_type")            -> {105,  sync};
+syscall("mes.fukidasi_custom")              -> {106,  sync};
+syscall("mes.erase_fukidasi")               -> {107, async};
+syscall("mes.chat_pc")                      -> {108, async};
+syscall("mes.cut_in_chat")                  -> {109, async};
+syscall("mes.cut_in_chat_custom")           -> {110, async};
+syscall("mes.system_win")                   -> {111,  sync};
+syscall("mes.custom_win")                   -> {112,  sync};
+syscall("mes.scroll_win")                   -> {113,  sync};
+syscall("mes.win_move")                     -> {114, async};
+syscall("mes.erase_system_win")             -> {115, async};
+syscall("mes.select_win")                   -> {116,  sync};
+syscall("mes.select_win_set")               -> {117,  sync};
+syscall("mes.select_win_single")            -> {118,  sync};
+syscall("mes.select_win_custom")            -> {119,  sync};
+syscall("mes.select_win_fukidasi")          -> {120,  sync};
+syscall("mes.select_win_b")                 -> {121,  sync};
+syscall("mes.select_win_set_b")             -> {122,  sync};
+syscall("mes.select_win_single_b")          -> {123,  sync};
+syscall("mes.select_win_custom_b")          -> {124,  sync};
+syscall("mes.select_win_fukidasi_b")        -> {125,  sync};
+syscall("mes.erase_select_win")             -> {126,  sync};
+syscall("mes.message_end")                  -> {127, async};
+syscall("mes.set_name_npc")                 -> {128, async};
+syscall("mes.set_color_npc")                -> {129, async};
+syscall("mes.line_window")                  -> {130, async};
+syscall("adv.cut_in")                       -> {131, async};
+syscall("adv.cut_in_custom")                -> {132, async};
+syscall("adv.window_disable")               -> {133, async};
+syscall("adv.window_enable")                -> {134, async};
+syscall("adv.fukidasi_disable")             -> {135, async};
+syscall("adv.fukidasi_enable")              -> {136, async};
+syscall("adv.player_disable")               -> {137, async};
+syscall("adv.player_enable")                -> {138, async};
+syscall("adv.chat_on")                      -> {139, async};
+syscall("adv.chat_off")                     -> {140, async};
+syscall("adv.mainmenu_disable")             -> {141, async};
+syscall("adv.mainmenu_enable")              -> {142, async};
+syscall("unit_flag.on")                     -> {143, async};
+syscall("unit_flag.off")                    -> {144, async};
+syscall("unit_flag.reverse")                -> {145, async};
+syscall("unit_flag.delay_on")               -> {146, async};
+syscall("unit_flag.delay_off")              -> {147, async};
+syscall("unit_flag.delay_reverse")          -> {148, async};
+syscall("unit_flag.chk")                    -> {149, async};
+syscall("player.get_my_id")                 -> {150, async};
+syscall("player.set_pos")                   -> {151, async};
+syscall("player.change_unit")               -> {152, async};
+syscall("player.turn")                      -> {153, async};
+syscall("player.walk")                      -> {154, async};
+syscall("player.run")                       -> {155, async};
+syscall("player.pad_off")                   -> {158, async};
+syscall("player.pad_on")                    -> {159, async};
+syscall("player.get_pos")                   -> {160, async};
+syscall("player.get_ang")                   -> {161, async};
+syscall("player.turn_coord")                -> {162, async};
+syscall("player.turn_member")               -> {163, async};
+syscall("plymotion.item_take_off")          -> {173, async};
+syscall("plymotion.set_pack")               -> {174,  sync};
+syscall("plymotion.release_pack")           -> {176, async};
+syscall("plymotion.set_loop")               -> {177, async};
+syscall("plymotion.play_one_shot")          -> {178,  sync};
+syscall("plymotion.cancel_one_shot")        -> {179, async};
+syscall("plymotion.restart_one_shot")       -> {180, async};
+syscall("apc.create")                       -> {183,  sync};
+syscall("apc.delete")                       -> {184, async};
+syscall("apc.delete_inx")                   -> {185, async};
+syscall("apc.team_into")                    -> {186, async};
+syscall("apc.team_remove")                  -> {187, async};
+syscall("apc.set_pos")                      -> {188, async};
+syscall("apc.turn")                         -> {189, async};
+syscall("apc.walk")                         -> {190, async};
+syscall("apc.run")                          -> {191, async};
+syscall("apc.think_off")                    -> {194, async};
+syscall("apc.think_on")                     -> {195, async};
+syscall("apc.get_pos")                      -> {196, async};
+syscall("apc.get_ang")                      -> {197, async};
+syscall("apc.reserve")                      -> {205, async};
+syscall("apc.reserve_cancel")               -> {206, async};
+syscall("apc.is_reserve")                   -> {207, async};
+syscall("apc.create_lv")                    -> {208,  sync};
+syscall("apc.reserve_lv")                   -> {209, async};
+syscall("apc.target_guard")                 -> {210, async};
+syscall("apc.target_guard_pid")             -> {211, async};
+syscall("apc.target_guard_aid")             -> {212, async};
+syscall("apc.cancel_target_guard")          -> {213, async};
+syscall("apc.set_move_out_party")           -> {214, async};
+syscall("apc.apc_set_ban")                  -> {215, async};
+syscall("apc.get_aid_from_pid")             -> {216, async};
+syscall("apc.is_apc2")                      -> {217, async};
+syscall("apc.is_alive")                     -> {218, async};
+syscall("camera.set")                       -> {219, async};
+syscall("camera.move")                      -> {220, async};
+syscall("camera.release")                   -> {221, async};
+syscall("camera.get_pos")                   -> {222, async};
+syscall("camera.cam_rot")                   -> {223, async};
+syscall("camera.target_rot")                -> {224, async};
+syscall("camera.dist_move")                 -> {225, async};
+syscall("camera.get_cam_angle")             -> {226, async};
+syscall("camera.get_target_angle")          -> {227, async};
+syscall("camera.get_dist")                  -> {228, async};
+syscall("camera.set_quake")                 -> {229, async};
+syscall("camera.stop_quake")                -> {230, async};
+syscall("direction.fade_in")                -> {232, async};
+syscall("direction.fade_out")               -> {233, async};
+syscall("direction.fade_out_rgba")          -> {234, async};
+syscall("direction.cinema_on")              -> {235, async};
+syscall("direction.cinema_off")             -> {236, async};
+syscall("direction.vib")                    -> {237, async};
+syscall("wait.abort_cancel")                -> {238, async};
+syscall("temp.exit_game")                   -> {239, async};
+syscall("movie.play_prm")                   -> {240,  sync};
+syscall("movie.play_rtm")                   -> {242,  sync};
+syscall("movie.play_event")                 -> {245,  sync};
+syscall("movie.play_sub_title")             -> {246,  sync};
+syscall("movie.telop")                      -> {247,  sync};
+syscall("sound.play_se")                    -> {251, async};
+syscall("sound.play_bgm")                   -> {253, async}; %% Unofficial name.
+syscall("sound.stop_bgm")                   -> {256, async};
+syscall("render.scene_off")                 -> {257, async};
+syscall("render.scene_on")                  -> {258, async};
+syscall("render.npc_all_off")               -> {259, async};
+syscall("render.npc_all_on")                -> {260, async};
+syscall("render.npc_off")                   -> {261, async};
+syscall("render.npc_on")                    -> {262, async};
+syscall("render.player_off")                -> {263, async};
+syscall("render.player_on")                 -> {264, async};
+syscall("render.enemy_off")                 -> {265, async};
+syscall("render.enemy_on")                  -> {266, async};
+syscall("render.obj_off")                   -> {267, async};
+syscall("render.obj_on")                    -> {268, async};
+syscall("seq.get_quest")                    -> {271, async};
+syscall("seq.is_online")                    -> {272, async};
+syscall("seq.save_qst")                     -> {273,  sync};
+syscall("seq.get_area")                     -> {274, async};
+syscall("seq.get_zone")                     -> {275, async};
+syscall("seq.get_unit")                     -> {276, async};
+syscall("seq.get_item")                     -> {280,  sync};
+syscall("work.accountwork_get")             -> {282,  sync};
+syscall("work.accountwork_set")             -> {283,  sync};
+syscall("work.chrwork_get")                 -> {284,  sync};
+syscall("work.chrwork_set")                 -> {285,  sync};
+syscall("work.chrflag_get")                 -> {286,  sync};
+syscall("work.chrflag_set")                 -> {287,  sync};
+syscall("work.partyflag_on")                -> {288,  sync};
+syscall("work.partyflag_off")               -> {289,  sync};
+syscall("work.qstwork_get")                 -> {290, async};
+syscall("work.qstwork_get_member")          -> {291, async};
+syscall("work.qstwork_set")                 -> {292, async};
+syscall("work.partyflag_get")               -> {297, async};
+syscall("work.partywork_get")               -> {298, async};
+syscall("work.partywork_set")               -> {299, async};
+syscall("work.zone_cndflag_get")            -> {300, async};
+syscall("work.zone_cndflag_on")             -> {301, async};
+syscall("work.zone_cndflag_off")            -> {302, async};
+syscall("work.zone_sendwork_get")           -> {303, async};
+syscall("work.zone_sendwork_set")           -> {304, async};
+syscall("work.party_rand_get")              -> {305,  sync};
+syscall("party.get_member")                 -> {306, async};
+syscall("party.get_leader")                 -> {307, async};
+syscall("party.chk_exist")                  -> {308, async};
+syscall("party.sync_wait")                  -> {309,  sync};
+syscall("party.join_on")                    -> {310, async};
+syscall("party.join_off")                   -> {311, async};
+syscall("party.get_enemy_kill")             -> {312, async};
+syscall("ptcl.create")                      -> {315, async};
+syscall("ptcl.move")                        -> {316, async};
+syscall("ptcl.delete")                      -> {317, async};
+syscall("col.create")                       -> {318, async};
+syscall("col.create_lock_on")               -> {319, async};
+syscall("col.create_attack")                -> {320, async};
+syscall("col.move")                         -> {321, async};
+syscall("col.scale")                        -> {322, async};
+syscall("col.delete")                       -> {323, async};
+syscall("npc.talk_on")                      -> {324, async};
+syscall("npc.talk_off")                     -> {325, async};
+syscall("npc.think_on")                     -> {326, async};
+syscall("npc.think_off")                    -> {327, async};
+syscall("npc.set_pos")                      -> {328, async};
+syscall("npc.turn")                         -> {329, async};
+syscall("npc.gaze")                         -> {330, async};
+syscall("npc.walk")                         -> {331, async};
+syscall("npc.run")                          -> {332, async};
+syscall("npc.walk_path")                    -> {335, async};
+syscall("npc.run_path")                     -> {336, async};
+syscall("npc.get_pos")                      -> {338, async};
+syscall("npc.get_ang")                      -> {339, async};
+syscall("npc.cng_motion")                   -> {340, async};
+syscall("npc.cancel_motion")                -> {341, async};
+syscall("npc.get_motion")                   -> {342, async};
+syscall("npc.coli_end")                     -> {343, async};
+syscall("obj.coli_end")                     -> {347, async}; %% Unofficial name.
+syscall("status.get_posflag")               -> {354, async};
+syscall("lobby.start")                      -> {356,  sync};
+syscall("lobby.end")                        -> {357, async};
+syscall("lobby.select_planet")              -> {358,  sync};
+syscall("camera.def_cng")                   -> {359, async};
+syscall("camera.def_remove")                -> {360, async};
+syscall("camera.def_move_back")             -> {361, async};
+syscall("camera.def_set_back")              -> {362, async};
+syscall("camera.def_set_quake")             -> {364, async};
+syscall("camera.def_stop_qake")             -> {365, async};
+syscall("calc.get_rot")                     -> {373, async};
+syscall("sjis.fukidasi_pc")                 -> {389,  sync};
+syscall("sjis.fukidasi_apc")                -> {390,  sync};
+syscall("sjis.fukidasi_npc")                -> {391,  sync};
+syscall("sjis.fukidasi_pc_type")            -> {392,  sync};
+syscall("sjis.fukidasi_apc_type")           -> {393,  sync};
+syscall("sjis.fukidasi_npc_type")           -> {394,  sync};
+syscall("sjis.fukidasi_custom")             -> {395,  sync};
+syscall("sjis.chat_pc")                     -> {396, async};
+syscall("sjis.cut_in_chat")                 -> {397, async};
+syscall("sjis.cut_in_chat_custom")          -> {398, async};
+syscall("sjis.system_win")                  -> {399,  sync};
+syscall("sjis.custom_win")                  -> {400,  sync};
+syscall("sjis.scroll_win")                  -> {401,  sync};
+syscall("sjis.select_win")                  -> {402,  sync};
+syscall("sjis.select_win_set")              -> {403,  sync};
+syscall("sjis.select_win_single")           -> {404,  sync};
+syscall("sjis.select_win_custom")           -> {405,  sync};
+syscall("sjis.select_win_fukidasi")         -> {406,  sync};
+syscall("sjis.select_win_b")                -> {407,  sync};
+syscall("sjis.select_win_set_b")            -> {408,  sync};
+syscall("sjis.select_win_single_b")         -> {409,  sync};
+syscall("sjis.select_win_custom_b")         -> {410,  sync};
+syscall("sjis.select_win_fukidasi_b")       -> {411,  sync};
+syscall("sjis.line_window")                 -> {412, async};
+syscall("temp.line")                        -> {413, async};
+syscall("temp.sline")                       -> {414, async};
+syscall(_)                                  -> false.
+
+%% Functions.
+function("adv.cut_in_load")                 -> {"q.adv.cut_in_load",              async};
+function("adv.cut_in_noise")                -> {"q.adv.cut_in_noise",             async};
+function("adv.cut_in_release")              -> {"q.adv.cut_in_release",           async};
+function("adv.cut_in_stop")                 -> {"q.adv.cut_in_stop",              async};
+%% @todo apc.apc_sp_exec
+%% @todo q.apc.create_ex
+function("apc.get_reserve_aid_all")         -> {"apc.get_reserve_aid_all",        async};
+function("apc.get_reserve_count")           -> {"apc.get_reserve_count",          async};
+function("apc.guildcard_disable")           -> {"apc.guildcard_disable",          async};
+function("apc.guildcard_enable")            -> {"apc.guildcard_enable",           async};
+function("apc.impossible_join_pt")          -> {"apc.impossible_join_pt",         async};
+function("apc.is_set_ban")                  -> {"apc.is_set_ban",                 async};
+%% @todo apc.move
+%% @todo apc.move_xz
+function("apc.possible_join_pt")            -> {"apc.possible_join_pt",           async};
+%% @todo apc.set_goal_out_party
+function("apc.set_sp_ban")                  -> {"apc.set_sp_ban",                 async};
+function("apc.set_talk_ban")                -> {"apc.set_talk_ban",               async};
+function("counter.create_dc_map")           -> {"counter.create_dc_map",          async};
+function("counter.delete_dc_map")           -> {"counter.delete_dc_map",          async};
+function("counter.set_arrow_pos")           -> {"counter.set_arrow_pos",          async};
+function("counter.set_lookon_pos")          -> {"counter.set_lookon_pos",         async};
+function("direction.fade_out_nowloading")   -> {"direction.fade_out_nowloading",  async};
+function("font.set_party_member_id")        -> {"font.set_party_member_id",       async};
+function("item.exchange")                   -> {"q.seq.exchange_item",             sync};
+function("item.get_num")                    -> {"q.seq.get_item_num",              sync};
+function("item.get_slot_num_req")           -> {"q.item.get_slot_num_req",         sync};
+function("item.get_slot_num_ret")           -> {"q.item.get_slot_num_ret",        async};
+%% @todo item.set_ability
+function("mes.mes_broadcast_clear")         -> {"mes.mes_broadcast_clear",        async};
+%% @todo mes.mes_broadcast_clear_all
+function("mes.mes_broadcast_set")           -> {"mes.mes_broadcast_set",          async};
+function("mes.line_window_time")            -> {"q.mes.line_window_line_time",    async};
+function("mes.select_win_number")           -> {"q.mes.select_win_number",         sync};
+function("movie.text_prm_delay")            -> {"movie.text_prm_delay",           async};
+function("myroom.check_data_load")          -> {"myroom.check_data_load",         async};
+function("myroom.disable_obj_ex")           -> {"myroom.disable_obj_ex",          async};
+function("myroom.get_move_planet")          -> {"myroom.get_move_planet",         async};
+function("myroom.get_probo_ang")            -> {"myroom.get_probo_ang",           async};
+function("myroom.get_probo_pos")            -> {"myroom.get_probo_pos",           async};
+function("myroom.get_probo_rank")           -> {"myroom.get_probo_rank",          async};
+function("myroom.news_enable")              -> {"myroom.news_enable",             async};
+%% @todo myroom.get_probo_type
+function("npc.gaze_cancel")                 -> {"npc.gaze_cancel",                async};
+%% @todo npc.get_head_y
+function("npc.is_load_comp")                -> {"npc.is_load_comp",               async};
+%% @todo q.npc.run_fast
+%% @todo npc.run_xz_fast
+%% @todo q.npc.walk_fast
+%% @todo npc.walk_xz_fast
+%% @todo obj.chair_disable
+%% @todo obj.chair_enable
+function("obj.get_eventflag")               -> {"obj.get_eventflag",              async};
+function("obj.set_caption")                 -> {"obj.set_caption",                async};
+function("obj.vehicle_resetpos")            -> {"obj.vehicle_resetpos",           async};
+function("player.display")                  -> {"player.display",                 async};
+function("player.disp_off_except_party")    -> {"player.disp_off_except_party",   async};
+function("player.disp_on_except_party")     -> {"player.disp_on_except_party",    async};
+function("player.face_set")                 -> {"player.face_set",                async};
+%% @todo player.gaze_body
+%% @todo player.get_action
+function("player.get_level")                -> {"player.get_level",               async};
+function("player.get_my_pmid")              -> {"q.player.get_my_pmid",           async};
+function("player.get_occupation")           -> {"player.get_occupation",          async};
+function("player.get_off_vehicle")          -> {"player.get_off_vehicle",         async};
+%% @todo player.get_on_vehicle
+function("player.get_race")                 -> {"player.get_race",                async};
+function("player.get_sex")                  -> {"player.get_sex",                 async};
+function("player.hide")                     -> {"player.hide",                    async};
+function("player.is_dead")                  -> {"player.is_dead",                 async};
+%% @todo player.is_equipping_item
+function("player.is_in_sp")                 -> {"player.is_in_sp",                async};
+function("player.is_on_vehicle")            -> {"player.is_on_vehicle",           async};
+%% @todo player.move
+%% @todo player.move_xz
+%% @todo player.set_vehicle_breakpos
+function("player.sp_cancel")                -> {"player.sp_cancel",               async};
+%% @todo player.turn_round
+%% @todo player.turn_round_coord_xz
+function("plymotion.can_i_set_event_pack")  -> {"plymotion.can_i_set_event_pack", async};
+%% @todo plymotion.get_pack
+function("plymotion.is_ready")              -> {"plymotion.is_ready",             async};
+function("plymotion.item_re_equip")         -> {"plymotion.item_re_equip",        async};
+%% @todo radar.display
+%% @todo radar.fullclose
+function("radar.fullopen")                  -> {"radar.fullopen",                 async};
+%% @todo radar.hide
+function("seq.endroll_play")                -> {"q.seq.endroll_play",              sync};
+%% @todo seq.get_death_count
+%% @todo seq.get_death_count_apc
+function("seq.get_destroy_enemy_count")     -> {"seq.get_destroy_enemy_count",    async};
+function("seq.get_elapsed_time")            -> {"seq.get_elapsed_time",           async};
+function("seq.get_judgement")               -> {"seq.get_judgement",              async};
+function("seq.get_mission_step")            -> {"seq.get_mission_step",           async};
+function("seq.get_rank")                    -> {"seq.get_rank",                   async};
+%% @todo seq.get_remaining_time
+%% @todo seq.get_setdata_inx
+%% @todo seq.goto_title
+function("seq.has_finished_result")         -> {"seq.has_finished_result",        async};
+function("seq.open_ex_mode")                -> {"seq.open_ex_mode",               async};
+function("seq.preview_network")             -> {"q.seq.preview_network",           sync};
+function("seq.preview_play")                -> {"q.seq.preview_play",              sync};
+function("seq.result")                      -> {"q.seq.result",                   async};
+function("seq.save_menu")                   -> {"q.seq.save_menu",                 sync};
+%% @todo seq.set_chapter_no
+function("seq.set_ex_chapter_no")           -> {"seq.set_ex_chapter_no",          async};
+%% @todo seq.set_story_end_flag
+function("seq.staffroll_play")              -> {"q.seq.staffroll_play",            sync};
+%% @todo q.seq.unify_counter
+function("shop.open")                       -> {"shop.open",                      async};
+%% @todo shop.req_load_data
+function("sjis.line_window_time")           -> {"q.sjis.line_window_time",        async};
+function("sound.check_jingle")              -> {"sound.check_jingle",             async};
+%% @todo sound.get_player_pack
+function("sound.load_enemy_pack")           -> {"sound.load_enemy_pack",          async};
+%% @todo sound.load_enemy_port_pack
+function("sound.load_event_pack")           -> {"sound.load_event_pack",          async};
+function("sound.load_player_pack")          -> {"sound.load_player_pack",         async};
+%% @todo sound.pause_adx_voice
+function("sound.pause_bgm")                 -> {"sound.pause_bgm",                async};
+function("sound.play_jingle")               -> {"sound.play_jingle",              async};
+function("sound.play_se3d_loop_stop")       -> {"sound.play_se3d_loop_stop",      async};
+function("sound.play_se3d_loop_vol")        -> {"sound.play_se3d_loop_vol",       async};
+function("sound.play_player")               -> {"q.sound.play_player",             sync};
+function("sound.play_se3d")                 -> {"q.sound.play_se3d",               sync};
+%% @todo sound.play_se3d_loop
+function("sound.play_se3d_vol")             -> {"q.sound.play_se3d_vol",           sync};
+function("sound.play_technique")            -> {"sound.play_technique",           async};
+function("sound.play_vehicle")              -> {"sound.play_vehicle",             async};
+function("sound.stop_adx_voice")            -> {"sound.stop_adx_voice",           async};
+function("system.frame_adjust")             -> {"system.frame_adjust",            async};
+%% @todo system.frame_default
+function("system.frame_get")                -> {"system.frame_get",               async};
+%% @todo system.frame_set
+function("system.get_episode")              -> {"system.get_episode",             async};
+%% @todo system.get_language
+function("system.get_platform")             -> {"system.get_platform",            async};
+function("system.get_resolution")           -> {"system.get_resolution",          async};
+function("work.get_stamp_bonus")            -> {"q.work.get_stamp_bonus",          sync};
+function("work.get_stamp_num")              -> {"q.work.get_stamp_num",            sync};
+function("work.get_stamp_quest")            -> {"q.work.get_stamp_quest",          sync};
+%% @todo q.work.on_accountwork_get
+function("work.partyworknum_get")           -> {"q.work.partyworknum_get",        async};
+function("work.partyworknum_set")           -> {"q.work.partyworknum_set",        async};
+%% @todo q.work.stamp_command
+function(Name)                              -> {Name,                             local}.
+
+%% Strings.
+string_gen([$\\|Cs]) ->
+	string_escape(Cs);
+string_gen([C|Cs]) ->
+	[C|string_gen(Cs)];
+string_gen([]) ->
+	[].
+
+string_escape([O1,O2,O3|S]) when O1 >= $0, O1 =< $7, O2 >= $0, O2 =< $7, O3 >= $0, O3 =< $7 ->
+	[(O1*8 + O2)*8 + O3 - 73*$0|string_gen(S)];
+string_escape([$^,C|Cs]) ->
+	[C band 31|string_gen(Cs)];
+string_escape([C|Cs]) when C >= $\000, C =< $\s ->
+	string_gen(Cs);
+string_escape([C|Cs]) ->
+	[escape_char(C)|string_gen(Cs)].
+
+escape_char($n) -> $\n; %% \n = LF
+escape_char($r) -> $\r; %% \r = CR
+escape_char($t) -> $\t; %% \t = TAB
+escape_char($v) -> $\v; %% \v = VT
+escape_char($b) -> $\b; %% \b = BS
+escape_char($f) -> $\f; %% \f = FF
+escape_char($e) -> $\e; %% \e = ESC
+escape_char($s) -> $\s; %% \s = SPC
+escape_char($d) -> $\d; %% \d = DEL
+escape_char(C) -> C.
+
+-file("/usr/lib/erlang/lib/parsetools-2.0.6/include/leexinc.hrl", 14).
+
+format_error({illegal,S}) -> ["illegal characters ",io_lib:write_string(S)];
+format_error({user,S}) -> S.
+
+string(String) -> string(String, 1).
+
+string(String, Line) -> string(String, Line, String, []).
+
+%% string(InChars, Line, TokenChars, Tokens) ->
+%% {ok,Tokens,Line} | {error,ErrorInfo,Line}.
+%% Note the line number going into yystate, L0, is line of token
+%% start while line number returned is line of token end. We want line
+%% of token start.
+
+string([], L, [], Ts) ->                     % No partial tokens!
+    {ok,yyrev(Ts),L};
+string(Ics0, L0, Tcs, Ts) ->
+    case yystate(yystate(), Ics0, L0, 0, reject, 0) of
+        {A,Alen,Ics1,L1} ->                  % Accepting end state
+            string_cont(Ics1, L1, yyaction(A, Alen, Tcs, L0), Ts);
+        {A,Alen,Ics1,L1,_S1} ->              % Accepting transistion state
+            string_cont(Ics1, L1, yyaction(A, Alen, Tcs, L0), Ts);
+        {reject,_Alen,Tlen,_Ics1,L1,_S1} ->  % After a non-accepting state
+            {error,{L0,?MODULE,{illegal,yypre(Tcs, Tlen+1)}},L1};
+        {A,Alen,_Tlen,_Ics1,L1,_S1} ->
+            string_cont(yysuf(Tcs, Alen), L1, yyaction(A, Alen, Tcs, L0), Ts)
+    end.
+
+%% string_cont(RestChars, Line, Token, Tokens)
+%% Test for and remove the end token wrapper. Push back characters
+%% are prepended to RestChars.
+
+string_cont(Rest, Line, {token,T}, Ts) ->
+    string(Rest, Line, Rest, [T|Ts]);
+string_cont(Rest, Line, {token,T,Push}, Ts) ->
+    NewRest = Push ++ Rest,
+    string(NewRest, Line, NewRest, [T|Ts]);
+string_cont(Rest, Line, {end_token,T}, Ts) ->
+    string(Rest, Line, Rest, [T|Ts]);
+string_cont(Rest, Line, {end_token,T,Push}, Ts) ->
+    NewRest = Push ++ Rest,
+    string(NewRest, Line, NewRest, [T|Ts]);
+string_cont(Rest, Line, skip_token, Ts) ->
+    string(Rest, Line, Rest, Ts);
+string_cont(Rest, Line, {skip_token,Push}, Ts) ->
+    NewRest = Push ++ Rest,
+    string(NewRest, Line, NewRest, Ts);
+string_cont(_Rest, Line, {error,S}, _Ts) ->
+    {error,{Line,?MODULE,{user,S}},Line}.
+
+%% token(Continuation, Chars) ->
+%% token(Continuation, Chars, Line) ->
+%% {more,Continuation} | {done,ReturnVal,RestChars}.
+%% Must be careful when re-entering to append the latest characters to the
+%% after characters in an accept. The continuation is:
+%% {token,State,CurrLine,TokenChars,TokenLen,TokenLine,AccAction,AccLen}
+
+token(Cont, Chars) -> token(Cont, Chars, 1).
+
+token([], Chars, Line) ->
+    token(yystate(), Chars, Line, Chars, 0, Line, reject, 0);
+token({token,State,Line,Tcs,Tlen,Tline,Action,Alen}, Chars, _) ->
+    token(State, Chars, Line, Tcs ++ Chars, Tlen, Tline, Action, Alen).
+
+%% token(State, InChars, Line, TokenChars, TokenLen, TokenLine,
+%% AcceptAction, AcceptLen) ->
+%% {more,Continuation} | {done,ReturnVal,RestChars}.
+%% The argument order is chosen to be more efficient.
+
+token(S0, Ics0, L0, Tcs, Tlen0, Tline, A0, Alen0) ->
+    case yystate(S0, Ics0, L0, Tlen0, A0, Alen0) of
+        %% Accepting end state, we have a token.
+        {A1,Alen1,Ics1,L1} ->
+            token_cont(Ics1, L1, yyaction(A1, Alen1, Tcs, Tline));
+        %% Accepting transition state, can take more chars.
+        {A1,Alen1,[],L1,S1} ->                  % Need more chars to check
+            {more,{token,S1,L1,Tcs,Alen1,Tline,A1,Alen1}};
+        {A1,Alen1,Ics1,L1,_S1} ->               % Take what we got
+            token_cont(Ics1, L1, yyaction(A1, Alen1, Tcs, Tline));
+        %% After a non-accepting state, maybe reach accept state later.
+        {A1,Alen1,Tlen1,[],L1,S1} ->            % Need more chars to check
+            {more,{token,S1,L1,Tcs,Tlen1,Tline,A1,Alen1}};
+        {reject,_Alen1,Tlen1,eof,L1,_S1} ->     % No token match
+            %% Check for partial token which is error.
+            Ret = if Tlen1 > 0 -> {error,{Tline,?MODULE,
+                                          %% Skip eof tail in Tcs.
+                                          {illegal,yypre(Tcs, Tlen1)}},L1};
+                     true -> {eof,L1}
+                  end,
+            {done,Ret,eof};
+        {reject,_Alen1,Tlen1,Ics1,L1,_S1} ->    % No token match
+            Error = {Tline,?MODULE,{illegal,yypre(Tcs, Tlen1+1)}},
+            {done,{error,Error,L1},Ics1};
+        {A1,Alen1,_Tlen1,_Ics1,L1,_S1} ->       % Use last accept match
+            token_cont(yysuf(Tcs, Alen1), L1, yyaction(A1, Alen1, Tcs, Tline))
+    end.
+
+%% token_cont(RestChars, Line, Token)
+%% If we have a token or error then return done, else if we have a
+%% skip_token then continue.
+
+token_cont(Rest, Line, {token,T}) ->
+    {done,{ok,T,Line},Rest};
+token_cont(Rest, Line, {token,T,Push}) ->
+    NewRest = Push ++ Rest,
+    {done,{ok,T,Line},NewRest};
+token_cont(Rest, Line, {end_token,T}) ->
+    {done,{ok,T,Line},Rest};
+token_cont(Rest, Line, {end_token,T,Push}) ->
+    NewRest = Push ++ Rest,
+    {done,{ok,T,Line},NewRest};
+token_cont(Rest, Line, skip_token) ->
+    token(yystate(), Rest, Line, Rest, 0, Line, reject, 0);
+token_cont(Rest, Line, {skip_token,Push}) ->
+    NewRest = Push ++ Rest,
+    token(yystate(), NewRest, Line, NewRest, 0, Line, reject, 0);
+token_cont(Rest, Line, {error,S}) ->
+    {done,{error,{Line,?MODULE,{user,S}},Line},Rest}.
+
+%% tokens(Continuation, Chars, Line) ->
+%% {more,Continuation} | {done,ReturnVal,RestChars}.
+%% Must be careful when re-entering to append the latest characters to the
+%% after characters in an accept. The continuation is:
+%% {tokens,State,CurrLine,TokenChars,TokenLen,TokenLine,Tokens,AccAction,AccLen}
+%% {skip_tokens,State,CurrLine,TokenChars,TokenLen,TokenLine,Error,AccAction,AccLen}
+
+tokens(Cont, Chars) -> tokens(Cont, Chars, 1).
+
+tokens([], Chars, Line) ->
+    tokens(yystate(), Chars, Line, Chars, 0, Line, [], reject, 0);
+tokens({tokens,State,Line,Tcs,Tlen,Tline,Ts,Action,Alen}, Chars, _) ->
+    tokens(State, Chars, Line, Tcs ++ Chars, Tlen, Tline, Ts, Action, Alen);
+tokens({skip_tokens,State,Line,Tcs,Tlen,Tline,Error,Action,Alen}, Chars, _) ->
+    skip_tokens(State, Chars, Line, Tcs ++ Chars, Tlen, Tline, Error, Action, Alen).
+
+%% tokens(State, InChars, Line, TokenChars, TokenLen, TokenLine, Tokens,
+%% AcceptAction, AcceptLen) ->
+%% {more,Continuation} | {done,ReturnVal,RestChars}.
+
+tokens(S0, Ics0, L0, Tcs, Tlen0, Tline, Ts, A0, Alen0) ->
+    case yystate(S0, Ics0, L0, Tlen0, A0, Alen0) of
+        %% Accepting end state, we have a token.
+        {A1,Alen1,Ics1,L1} ->
+            tokens_cont(Ics1, L1, yyaction(A1, Alen1, Tcs, Tline), Ts);
+        %% Accepting transition state, can take more chars.
+        {A1,Alen1,[],L1,S1} ->                  % Need more chars to check
+            {more,{tokens,S1,L1,Tcs,Alen1,Tline,Ts,A1,Alen1}};
+        {A1,Alen1,Ics1,L1,_S1} ->               % Take what we got
+            tokens_cont(Ics1, L1, yyaction(A1, Alen1, Tcs, Tline), Ts);
+        %% After a non-accepting state, maybe reach accept state later.
+        {A1,Alen1,Tlen1,[],L1,S1} ->            % Need more chars to check
+            {more,{tokens,S1,L1,Tcs,Tlen1,Tline,Ts,A1,Alen1}};
+        {reject,_Alen1,Tlen1,eof,L1,_S1} ->     % No token match
+            %% Check for partial token which is error, no need to skip here.
+            Ret = if Tlen1 > 0 -> {error,{Tline,?MODULE,
+                                          %% Skip eof tail in Tcs.
+                                          {illegal,yypre(Tcs, Tlen1)}},L1};
+                     Ts == [] -> {eof,L1};
+                     true -> {ok,yyrev(Ts),L1}
+                  end,
+            {done,Ret,eof};
+        {reject,_Alen1,Tlen1,_Ics1,L1,_S1} ->
+            %% Skip rest of tokens.
+            Error = {L1,?MODULE,{illegal,yypre(Tcs, Tlen1+1)}},
+            skip_tokens(yysuf(Tcs, Tlen1+1), L1, Error);
+        {A1,Alen1,_Tlen1,_Ics1,L1,_S1} ->
+            Token = yyaction(A1, Alen1, Tcs, Tline),
+            tokens_cont(yysuf(Tcs, Alen1), L1, Token, Ts)
+    end.
+
+%% tokens_cont(RestChars, Line, Token, Tokens)
+%% If we have an end_token or error then return done, else if we have
+%% a token then save it and continue, else if we have a skip_token
+%% just continue.
+
+tokens_cont(Rest, Line, {token,T}, Ts) ->
+    tokens(yystate(), Rest, Line, Rest, 0, Line, [T|Ts], reject, 0);
+tokens_cont(Rest, Line, {token,T,Push}, Ts) ->
+    NewRest = Push ++ Rest,
+    tokens(yystate(), NewRest, Line, NewRest, 0, Line, [T|Ts], reject, 0);
+tokens_cont(Rest, Line, {end_token,T}, Ts) ->
+    {done,{ok,yyrev(Ts, [T]),Line},Rest};
+tokens_cont(Rest, Line, {end_token,T,Push}, Ts) ->
+    NewRest = Push ++ Rest,
+    {done,{ok,yyrev(Ts, [T]),Line},NewRest};
+tokens_cont(Rest, Line, skip_token, Ts) ->
+    tokens(yystate(), Rest, Line, Rest, 0, Line, Ts, reject, 0);
+tokens_cont(Rest, Line, {skip_token,Push}, Ts) ->
+    NewRest = Push ++ Rest,
+    tokens(yystate(), NewRest, Line, NewRest, 0, Line, Ts, reject, 0);
+tokens_cont(Rest, Line, {error,S}, _Ts) ->
+    skip_tokens(Rest, Line, {Line,?MODULE,{user,S}}).
+
+%%skip_tokens(InChars, Line, Error) -> {done,{error,Error,Line},Ics}.
+%% Skip tokens until an end token, junk everything and return the error.
+
+skip_tokens(Ics, Line, Error) ->
+    skip_tokens(yystate(), Ics, Line, Ics, 0, Line, Error, reject, 0).
+
+%% skip_tokens(State, InChars, Line, TokenChars, TokenLen, TokenLine, Tokens,
+%% AcceptAction, AcceptLen) ->
+%% {more,Continuation} | {done,ReturnVal,RestChars}.
+
+skip_tokens(S0, Ics0, L0, Tcs, Tlen0, Tline, Error, A0, Alen0) ->
+    case yystate(S0, Ics0, L0, Tlen0, A0, Alen0) of
+        {A1,Alen1,Ics1,L1} ->                  % Accepting end state
+            skip_cont(Ics1, L1, yyaction(A1, Alen1, Tcs, Tline), Error);
+        {A1,Alen1,[],L1,S1} ->                 % After an accepting state
+            {more,{skip_tokens,S1,L1,Tcs,Alen1,Tline,Error,A1,Alen1}};
+        {A1,Alen1,Ics1,L1,_S1} ->
+            skip_cont(Ics1, L1, yyaction(A1, Alen1, Tcs, Tline), Error);
+        {A1,Alen1,Tlen1,[],L1,S1} ->           % After a non-accepting state
+            {more,{skip_tokens,S1,L1,Tcs,Tlen1,Tline,Error,A1,Alen1}};
+        {reject,_Alen1,_Tlen1,eof,L1,_S1} ->
+            {done,{error,Error,L1},eof};
+        {reject,_Alen1,Tlen1,_Ics1,L1,_S1} ->
+            skip_tokens(yysuf(Tcs, Tlen1+1), L1, Error);
+        {A1,Alen1,_Tlen1,_Ics1,L1,_S1} ->
+            Token = yyaction(A1, Alen1, Tcs, Tline),
+            skip_cont(yysuf(Tcs, Alen1), L1, Token, Error)
+    end.
+
+%% skip_cont(RestChars, Line, Token, Error)
+%% Skip tokens until we have an end_token or error then return done
+%% with the original rror.
+
+skip_cont(Rest, Line, {token,_T}, Error) ->
+    skip_tokens(yystate(), Rest, Line, Rest, 0, Line, Error, reject, 0);
+skip_cont(Rest, Line, {token,_T,Push}, Error) ->
+    NewRest = Push ++ Rest,
+    skip_tokens(yystate(), NewRest, Line, NewRest, 0, Line, Error, reject, 0);
+skip_cont(Rest, Line, {end_token,_T}, Error) ->
+    {done,{error,Error,Line},Rest};
+skip_cont(Rest, Line, {end_token,_T,Push}, Error) ->
+    NewRest = Push ++ Rest,
+    {done,{error,Error,Line},NewRest};
+skip_cont(Rest, Line, skip_token, Error) ->
+    skip_tokens(yystate(), Rest, Line, Rest, 0, Line, Error, reject, 0);
+skip_cont(Rest, Line, {skip_token,Push}, Error) ->
+    NewRest = Push ++ Rest,
+    skip_tokens(yystate(), NewRest, Line, NewRest, 0, Line, Error, reject, 0);
+skip_cont(Rest, Line, {error,_S}, Error) ->
+    skip_tokens(yystate(), Rest, Line, Rest, 0, Line, Error, reject, 0).
+
+yyrev(List) -> lists:reverse(List).
+yyrev(List, Tail) -> lists:reverse(List, Tail).
+yypre(List, N) -> lists:sublist(List, N).
+yysuf(List, N) -> lists:nthtail(N, List).
+
+%% yystate() -> InitialState.
+%% yystate(State, InChars, Line, CurrTokLen, AcceptAction, AcceptLen) ->
+%% {Action, AcceptLen, RestChars, Line} |
+%% {Action, AcceptLen, RestChars, Line, State} |
+%% {reject, AcceptLen, CurrTokLen, RestChars, Line, State} |
+%% {Action, AcceptLen, CurrTokLen, RestChars, Line, State}.
+%% Generated state transition functions. The non-accepting end state
+%% return signal either an unrecognised character or end of current
+%% input.
+
+-file("src/egs_script_lexer.erl", 739).
+yystate() -> 21.
+
+yystate(24, Ics, Line, Tlen, _, _) ->
+    {4,Tlen,Ics,Line};
+yystate(23, [37|Ics], Line, Tlen, _, _) ->
+    yystate(0, Ics, Line, Tlen+1, 7, Tlen);
+yystate(23, [10|Ics], Line, Tlen, _, _) ->
+    yystate(23, Ics, Line+1, Tlen+1, 7, Tlen);
+yystate(23, [C|Ics], Line, Tlen, _, _) when C >= 0, C =< 9 ->
+    yystate(23, Ics, Line, Tlen+1, 7, Tlen);
+yystate(23, [C|Ics], Line, Tlen, _, _) when C >= 11, C =< 32 ->
+    yystate(23, Ics, Line, Tlen+1, 7, Tlen);
+yystate(23, Ics, Line, Tlen, _, _) ->
+    {7,Tlen,Ics,Line,23};
+yystate(22, [62|Ics], Line, Tlen, Action, Alen) ->
+    yystate(24, Ics, Line, Tlen+1, Action, Alen);
+yystate(22, [45|Ics], Line, Tlen, Action, Alen) ->
+    yystate(8, Ics, Line, Tlen+1, Action, Alen);
+yystate(22, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(20, Ics, Line, Tlen+1, Action, Alen);
+yystate(22, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,22};
+yystate(21, [125|Ics], Line, Tlen, Action, Alen) ->
+    yystate(4, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [123|Ics], Line, Tlen, Action, Alen) ->
+    yystate(4, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [95|Ics], Line, Tlen, Action, Alen) ->
+    yystate(17, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [59|Ics], Line, Tlen, Action, Alen) ->
+    yystate(4, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [46|Ics], Line, Tlen, Action, Alen) ->
+    yystate(10, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [45|Ics], Line, Tlen, Action, Alen) ->
+    yystate(22, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [44|Ics], Line, Tlen, Action, Alen) ->
+    yystate(4, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [37|Ics], Line, Tlen, Action, Alen) ->
+    yystate(0, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [34|Ics], Line, Tlen, Action, Alen) ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [10|Ics], Line, Tlen, Action, Alen) ->
+    yystate(23, Ics, Line+1, Tlen+1, Action, Alen);
+yystate(21, [C|Ics], Line, Tlen, Action, Alen) when C >= 0, C =< 9 ->
+    yystate(23, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [C|Ics], Line, Tlen, Action, Alen) when C >= 11, C =< 32 ->
+    yystate(23, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(1, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [C|Ics], Line, Tlen, Action, Alen) when C >= 65, C =< 90 ->
+    yystate(17, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, [C|Ics], Line, Tlen, Action, Alen) when C >= 97, C =< 122 ->
+    yystate(17, Ics, Line, Tlen+1, Action, Alen);
+yystate(21, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,21};
+yystate(20, [46|Ics], Line, Tlen, _, _) ->
+    yystate(16, Ics, Line, Tlen+1, 0, Tlen);
+yystate(20, [C|Ics], Line, Tlen, _, _) when C >= 48, C =< 57 ->
+    yystate(20, Ics, Line, Tlen+1, 0, Tlen);
+yystate(20, Ics, Line, Tlen, _, _) ->
+    {0,Tlen,Ics,Line,20};
+yystate(19, [92|Ics], Line, Tlen, Action, Alen) ->
+    yystate(7, Ics, Line, Tlen+1, Action, Alen);
+yystate(19, [34|Ics], Line, Tlen, Action, Alen) ->
+    yystate(15, Ics, Line, Tlen+1, Action, Alen);
+yystate(19, [10|Ics], Line, Tlen, Action, Alen) ->
+    yystate(19, Ics, Line+1, Tlen+1, Action, Alen);
+yystate(19, [C|Ics], Line, Tlen, Action, Alen) when C >= 0, C =< 9 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(19, [C|Ics], Line, Tlen, Action, Alen) when C >= 11, C =< 33 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(19, [C|Ics], Line, Tlen, Action, Alen) when C >= 35, C =< 91 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(19, [C|Ics], Line, Tlen, Action, Alen) when C >= 93 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(19, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,19};
+yystate(18, Ics, Line, Tlen, _, _) ->
+    {6,Tlen,Ics,Line};
+yystate(17, [95|Ics], Line, Tlen, Action, Alen) ->
+    yystate(13, Ics, Line, Tlen+1, Action, Alen);
+yystate(17, [46|Ics], Line, Tlen, Action, Alen) ->
+    yystate(9, Ics, Line, Tlen+1, Action, Alen);
+yystate(17, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(13, Ics, Line, Tlen+1, Action, Alen);
+yystate(17, [C|Ics], Line, Tlen, Action, Alen) when C >= 65, C =< 90 ->
+    yystate(13, Ics, Line, Tlen+1, Action, Alen);
+yystate(17, [C|Ics], Line, Tlen, Action, Alen) when C >= 97, C =< 122 ->
+    yystate(13, Ics, Line, Tlen+1, Action, Alen);
+yystate(17, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,17};
+yystate(16, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(12, Ics, Line, Tlen+1, Action, Alen);
+yystate(16, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,16};
+yystate(15, Ics, Line, Tlen, _, _) ->
+    {3,Tlen,Ics,Line};
+yystate(14, [C|Ics], Line, Tlen, _, _) when C >= 0, C =< 9 ->
+    yystate(14, Ics, Line, Tlen+1, 6, Tlen);
+yystate(14, [C|Ics], Line, Tlen, _, _) when C >= 11 ->
+    yystate(14, Ics, Line, Tlen+1, 6, Tlen);
+yystate(14, Ics, Line, Tlen, _, _) ->
+    {6,Tlen,Ics,Line,14};
+yystate(13, [95|Ics], Line, Tlen, _, _) ->
+    yystate(13, Ics, Line, Tlen+1, 2, Tlen);
+yystate(13, [46|Ics], Line, Tlen, _, _) ->
+    yystate(9, Ics, Line, Tlen+1, 2, Tlen);
+yystate(13, [C|Ics], Line, Tlen, _, _) when C >= 48, C =< 57 ->
+    yystate(13, Ics, Line, Tlen+1, 2, Tlen);
+yystate(13, [C|Ics], Line, Tlen, _, _) when C >= 65, C =< 90 ->
+    yystate(13, Ics, Line, Tlen+1, 2, Tlen);
+yystate(13, [C|Ics], Line, Tlen, _, _) when C >= 97, C =< 122 ->
+    yystate(13, Ics, Line, Tlen+1, 2, Tlen);
+yystate(13, Ics, Line, Tlen, _, _) ->
+    {2,Tlen,Ics,Line,13};
+yystate(12, [C|Ics], Line, Tlen, _, _) when C >= 48, C =< 57 ->
+    yystate(12, Ics, Line, Tlen+1, 1, Tlen);
+yystate(12, Ics, Line, Tlen, _, _) ->
+    {1,Tlen,Ics,Line,12};
+yystate(11, [92|Ics], Line, Tlen, _, _) ->
+    yystate(7, Ics, Line, Tlen+1, 3, Tlen);
+yystate(11, [34|Ics], Line, Tlen, _, _) ->
+    yystate(15, Ics, Line, Tlen+1, 3, Tlen);
+yystate(11, [10|Ics], Line, Tlen, _, _) ->
+    yystate(19, Ics, Line+1, Tlen+1, 3, Tlen);
+yystate(11, [C|Ics], Line, Tlen, _, _) when C >= 0, C =< 9 ->
+    yystate(19, Ics, Line, Tlen+1, 3, Tlen);
+yystate(11, [C|Ics], Line, Tlen, _, _) when C >= 11, C =< 33 ->
+    yystate(19, Ics, Line, Tlen+1, 3, Tlen);
+yystate(11, [C|Ics], Line, Tlen, _, _) when C >= 35, C =< 91 ->
+    yystate(19, Ics, Line, Tlen+1, 3, Tlen);
+yystate(11, [C|Ics], Line, Tlen, _, _) when C >= 93 ->
+    yystate(19, Ics, Line, Tlen+1, 3, Tlen);
+yystate(11, Ics, Line, Tlen, _, _) ->
+    {3,Tlen,Ics,Line,11};
+yystate(10, [37|Ics], Line, Tlen, Action, Alen) ->
+    yystate(14, Ics, Line, Tlen+1, Action, Alen);
+yystate(10, [10|Ics], Line, Tlen, Action, Alen) ->
+    yystate(18, Ics, Line+1, Tlen+1, Action, Alen);
+yystate(10, [C|Ics], Line, Tlen, Action, Alen) when C >= 0, C =< 9 ->
+    yystate(18, Ics, Line, Tlen+1, Action, Alen);
+yystate(10, [C|Ics], Line, Tlen, Action, Alen) when C >= 11, C =< 32 ->
+    yystate(18, Ics, Line, Tlen+1, Action, Alen);
+yystate(10, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,10};
+yystate(9, [95|Ics], Line, Tlen, Action, Alen) ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(9, [46|Ics], Line, Tlen, Action, Alen) ->
+    yystate(9, Ics, Line, Tlen+1, Action, Alen);
+yystate(9, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(9, [C|Ics], Line, Tlen, Action, Alen) when C >= 65, C =< 90 ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(9, [C|Ics], Line, Tlen, Action, Alen) when C >= 97, C =< 122 ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(9, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,9};
+yystate(8, [45|Ics], Line, Tlen, Action, Alen) ->
+    yystate(8, Ics, Line, Tlen+1, Action, Alen);
+yystate(8, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(20, Ics, Line, Tlen+1, Action, Alen);
+yystate(8, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,8};
+yystate(7, [94|Ics], Line, Tlen, Action, Alen) ->
+    yystate(3, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [93|Ics], Line, Tlen, Action, Alen) ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [92|Ics], Line, Tlen, Action, Alen) ->
+    yystate(7, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [34|Ics], Line, Tlen, Action, Alen) ->
+    yystate(11, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [10|Ics], Line, Tlen, Action, Alen) ->
+    yystate(19, Ics, Line+1, Tlen+1, Action, Alen);
+yystate(7, [C|Ics], Line, Tlen, Action, Alen) when C >= 0, C =< 9 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [C|Ics], Line, Tlen, Action, Alen) when C >= 11, C =< 33 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [C|Ics], Line, Tlen, Action, Alen) when C >= 35, C =< 91 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, [C|Ics], Line, Tlen, Action, Alen) when C >= 95 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(7, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,7};
+yystate(6, [95|Ics], Line, Tlen, _, _) ->
+    yystate(5, Ics, Line, Tlen+1, 1, Tlen);
+yystate(6, [C|Ics], Line, Tlen, _, _) when C >= 48, C =< 57 ->
+    yystate(6, Ics, Line, Tlen+1, 1, Tlen);
+yystate(6, [C|Ics], Line, Tlen, _, _) when C >= 65, C =< 90 ->
+    yystate(5, Ics, Line, Tlen+1, 1, Tlen);
+yystate(6, [C|Ics], Line, Tlen, _, _) when C >= 97, C =< 122 ->
+    yystate(5, Ics, Line, Tlen+1, 1, Tlen);
+yystate(6, Ics, Line, Tlen, _, _) ->
+    {1,Tlen,Ics,Line,6};
+yystate(5, [95|Ics], Line, Tlen, _, _) ->
+    yystate(5, Ics, Line, Tlen+1, 2, Tlen);
+yystate(5, [C|Ics], Line, Tlen, _, _) when C >= 48, C =< 57 ->
+    yystate(5, Ics, Line, Tlen+1, 2, Tlen);
+yystate(5, [C|Ics], Line, Tlen, _, _) when C >= 65, C =< 90 ->
+    yystate(5, Ics, Line, Tlen+1, 2, Tlen);
+yystate(5, [C|Ics], Line, Tlen, _, _) when C >= 97, C =< 122 ->
+    yystate(5, Ics, Line, Tlen+1, 2, Tlen);
+yystate(5, Ics, Line, Tlen, _, _) ->
+    {2,Tlen,Ics,Line,5};
+yystate(4, Ics, Line, Tlen, _, _) ->
+    {5,Tlen,Ics,Line};
+yystate(3, [92|Ics], Line, Tlen, Action, Alen) ->
+    yystate(7, Ics, Line, Tlen+1, Action, Alen);
+yystate(3, [34|Ics], Line, Tlen, Action, Alen) ->
+    yystate(11, Ics, Line, Tlen+1, Action, Alen);
+yystate(3, [10|Ics], Line, Tlen, Action, Alen) ->
+    yystate(19, Ics, Line+1, Tlen+1, Action, Alen);
+yystate(3, [C|Ics], Line, Tlen, Action, Alen) when C >= 0, C =< 9 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(3, [C|Ics], Line, Tlen, Action, Alen) when C >= 11, C =< 33 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(3, [C|Ics], Line, Tlen, Action, Alen) when C >= 35, C =< 91 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(3, [C|Ics], Line, Tlen, Action, Alen) when C >= 93 ->
+    yystate(19, Ics, Line, Tlen+1, Action, Alen);
+yystate(3, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,3};
+yystate(2, [95|Ics], Line, Tlen, Action, Alen) ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(2, [46|Ics], Line, Tlen, Action, Alen) ->
+    yystate(9, Ics, Line, Tlen+1, Action, Alen);
+yystate(2, [C|Ics], Line, Tlen, Action, Alen) when C >= 48, C =< 57 ->
+    yystate(6, Ics, Line, Tlen+1, Action, Alen);
+yystate(2, [C|Ics], Line, Tlen, Action, Alen) when C >= 65, C =< 90 ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(2, [C|Ics], Line, Tlen, Action, Alen) when C >= 97, C =< 122 ->
+    yystate(5, Ics, Line, Tlen+1, Action, Alen);
+yystate(2, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,2};
+yystate(1, [95|Ics], Line, Tlen, _, _) ->
+    yystate(13, Ics, Line, Tlen+1, 0, Tlen);
+yystate(1, [46|Ics], Line, Tlen, _, _) ->
+    yystate(2, Ics, Line, Tlen+1, 0, Tlen);
+yystate(1, [C|Ics], Line, Tlen, _, _) when C >= 48, C =< 57 ->
+    yystate(1, Ics, Line, Tlen+1, 0, Tlen);
+yystate(1, [C|Ics], Line, Tlen, _, _) when C >= 65, C =< 90 ->
+    yystate(13, Ics, Line, Tlen+1, 0, Tlen);
+yystate(1, [C|Ics], Line, Tlen, _, _) when C >= 97, C =< 122 ->
+    yystate(13, Ics, Line, Tlen+1, 0, Tlen);
+yystate(1, Ics, Line, Tlen, _, _) ->
+    {0,Tlen,Ics,Line,1};
+yystate(0, [37|Ics], Line, Tlen, _, _) ->
+    yystate(0, Ics, Line, Tlen+1, 7, Tlen);
+yystate(0, [10|Ics], Line, Tlen, _, _) ->
+    yystate(23, Ics, Line+1, Tlen+1, 7, Tlen);
+yystate(0, [C|Ics], Line, Tlen, _, _) when C >= 0, C =< 9 ->
+    yystate(0, Ics, Line, Tlen+1, 7, Tlen);
+yystate(0, [C|Ics], Line, Tlen, _, _) when C >= 11, C =< 32 ->
+    yystate(0, Ics, Line, Tlen+1, 7, Tlen);
+yystate(0, [C|Ics], Line, Tlen, _, _) when C >= 33, C =< 36 ->
+    yystate(0, Ics, Line, Tlen+1, 7, Tlen);
+yystate(0, [C|Ics], Line, Tlen, _, _) when C >= 38 ->
+    yystate(0, Ics, Line, Tlen+1, 7, Tlen);
+yystate(0, Ics, Line, Tlen, _, _) ->
+    {7,Tlen,Ics,Line,0};
+yystate(S, Ics, Line, Tlen, Action, Alen) ->
+    {Action,Alen,Tlen,Ics,Line,S}.
+
+%% yyaction(Action, TokenLength, TokenChars, TokenLine) ->
+%% {token,Token} | {end_token, Token} | skip_token | {error,String}.
+%% Generated action function.
+
+yyaction(0, TokenLen, YYtcs, TokenLine) ->
+    TokenChars = yypre(YYtcs, TokenLen),
+    yyaction_0(TokenChars, TokenLine);
+yyaction(1, TokenLen, YYtcs, TokenLine) ->
+    TokenChars = yypre(YYtcs, TokenLen),
+    yyaction_1(TokenChars, TokenLine);
+yyaction(2, TokenLen, YYtcs, TokenLine) ->
+    TokenChars = yypre(YYtcs, TokenLen),
+    yyaction_2(TokenChars, TokenLine);
+yyaction(3, TokenLen, YYtcs, TokenLine) ->
+    TokenChars = yypre(YYtcs, TokenLen),
+    yyaction_3(TokenChars, TokenLen, TokenLine);
+yyaction(4, _, _, TokenLine) ->
+    yyaction_4(TokenLine);
+yyaction(5, TokenLen, YYtcs, TokenLine) ->
+    TokenChars = yypre(YYtcs, TokenLen),
+    yyaction_5(TokenChars, TokenLine);
+yyaction(6, _, _, TokenLine) ->
+    yyaction_6(TokenLine);
+yyaction(7, _, _, _) ->
+    yyaction_7();
+yyaction(_, _, _, _) -> error.
+
+-compile({inline,yyaction_0/2}).
+-file("src/egs_script_lexer.xrl", 27).
+yyaction_0(TokenChars, TokenLine) ->
+     { token, { integer, TokenLine, list_to_integer (TokenChars) } } .
+
+-compile({inline,yyaction_1/2}).
+-file("src/egs_script_lexer.xrl", 28).
+yyaction_1(TokenChars, TokenLine) ->
+     { token, { float, TokenLine, list_to_float (TokenChars) } } .
+
+-compile({inline,yyaction_2/2}).
+-file("src/egs_script_lexer.xrl", 29).
+yyaction_2(TokenChars, TokenLine) ->
+     { token, case reserved_word (TokenChars) of
+     false -> case syscall (TokenChars) of
+     false -> { function, TokenLine, function (TokenChars) } ;
+     Syscall -> { syscall, TokenLine, Syscall }
+     end ;
+     KeyWord -> { KeyWord, TokenLine }
+     end } .
+
+-compile({inline,yyaction_3/3}).
+-file("src/egs_script_lexer.xrl", 37).
+yyaction_3(TokenChars, TokenLen, TokenLine) ->
+     S = lists : sublist (TokenChars, 2, TokenLen - 2),
+     { token, { string, TokenLine, string_gen (S) } } .
+
+-compile({inline,yyaction_4/1}).
+-file("src/egs_script_lexer.xrl", 39).
+yyaction_4(TokenLine) ->
+     { token, { '->', TokenLine } } .
+
+-compile({inline,yyaction_5/2}).
+-file("src/egs_script_lexer.xrl", 40).
+yyaction_5(TokenChars, TokenLine) ->
+     { token, { list_to_atom (TokenChars), TokenLine } } .
+
+-compile({inline,yyaction_6/1}).
+-file("src/egs_script_lexer.xrl", 41).
+yyaction_6(TokenLine) ->
+     { end_token, { dot, TokenLine } } .
+
+-compile({inline,yyaction_7/0}).
+-file("src/egs_script_lexer.xrl", 42).
+yyaction_7() ->
+     skip_token .
+
+-file("/usr/lib/erlang/lib/parsetools-2.0.6/include/leexinc.hrl", 282).
diff --git a/src/egs_script_lexer.xrl b/apps/egs/src/egs_script_lexer.xrl
similarity index 100%
rename from src/egs_script_lexer.xrl
rename to apps/egs/src/egs_script_lexer.xrl
diff --git a/apps/egs/src/egs_script_parser.erl b/apps/egs/src/egs_script_parser.erl
new file mode 100644
index 0000000..4b33e82
--- /dev/null
+++ b/apps/egs/src/egs_script_parser.erl
@@ -0,0 +1,1330 @@
+-module(egs_script_parser).
+-export([parse/1, parse_and_scan/1, format_error/1]).
+-file("src/egs_script_parser.yrl", 88).
+
+unwrap({_,_,V}) -> V.
+
+-file("/usr/lib/erlang/lib/parsetools-2.0.6/include/yeccpre.hrl", 0).
+%%
+%% %CopyrightBegin%
+%%
+%% Copyright Ericsson AB 1996-2010. 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%
+%%
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+% The parser generator will insert appropriate declarations before this line.%
+
+-type yecc_ret() :: {'error', _} | {'ok', _}.
+
+-spec parse(Tokens :: list()) -> yecc_ret().
+parse(Tokens) ->
+    yeccpars0(Tokens, {no_func, no_line}, 0, [], []).
+
+-spec parse_and_scan({function() | {atom(), atom()}, [_]}
+                     | {atom(), atom(), [_]}) -> yecc_ret().
+parse_and_scan({F, A}) -> % Fun or {M, F}
+    yeccpars0([], {{F, A}, no_line}, 0, [], []);
+parse_and_scan({M, F, A}) ->
+    yeccpars0([], {{{M, F}, A}, no_line}, 0, [], []).
+
+-spec format_error(any()) -> [char() | list()].
+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}).
+-spec return_error(integer(), any()) -> no_return().
+return_error(Line, Message) ->
+    throw({error, {Line, ?MODULE, Message}}).
+
+-define(CODE_VERSION, "1.4").
+
+yeccpars0(Tokens, Tzr, State, States, Vstack) ->
+    try yeccpars1(Tokens, Tzr, State, States, Vstack)
+    catch 
+        error: Error ->
+            Stacktrace = erlang:get_stacktrace(),
+            try yecc_error_type(Error, Stacktrace) of
+                Desc ->
+                    erlang:raise(error, {yecc_bug, ?CODE_VERSION, Desc},
+                                 Stacktrace)
+            catch _:_ -> erlang:raise(error, Error, Stacktrace)
+            end;
+        %% Probably thrown from return_error/2:
+        throw: {error, {_Line, ?MODULE, _M}} = Error ->
+            Error
+    end.
+
+yecc_error_type(function_clause, [{?MODULE,F,ArityOrArgs} | _]) ->
+    case atom_to_list(F) of
+        "yeccgoto_" ++ SymbolL ->
+            {ok,[{atom,_,Symbol}],_} = erl_scan:string(SymbolL),
+            State = case ArityOrArgs of
+                        [S,_,_,_,_,_,_] -> S;
+                        _ -> state_is_unknown
+                    end,
+            {Symbol, State, missing_in_goto_table}
+    end.
+
+yeccpars1([Token | Tokens], Tzr, State, States, Vstack) ->
+    yeccpars2(State, element(1, Token), States, Vstack, Token, Tokens, Tzr);
+yeccpars1([], {{F, A},_Line}, State, States, Vstack) ->
+    case apply(F, A) of
+        {ok, Tokens, Endline} ->
+            yeccpars1(Tokens, {{F, A}, Endline}, State, States, Vstack);
+        {eof, Endline} ->
+            yeccpars1([], {no_func, Endline}, State, States, Vstack);
+        {error, Descriptor, _Endline} ->
+            {error, Descriptor}
+    end;
+yeccpars1([], {no_func, no_line}, State, States, Vstack) ->
+    Line = 999999,
+    yeccpars2(State, '$end', States, Vstack, yecc_end(Line), [],
+              {no_func, Line});
+yeccpars1([], {no_func, Endline}, State, States, Vstack) ->
+    yeccpars2(State, '$end', States, Vstack, yecc_end(Endline), [],
+              {no_func, Endline}).
+
+%% yeccpars1/7 is called from generated code.
+%%
+%% When using the {includefile, Includefile} option, make sure that
+%% yeccpars1/7 can be found by parsing the file without following
+%% include directives. yecc will otherwise assume that an old
+%% yeccpre.hrl is included (one which defines yeccpars1/5).
+yeccpars1(State1, State, States, Vstack, Token0, [Token | Tokens], Tzr) ->
+    yeccpars2(State, element(1, Token), [State1 | States],
+              [Token0 | Vstack], Token, Tokens, Tzr);
+yeccpars1(State1, State, States, Vstack, Token0, [], {{_F,_A}, _Line}=Tzr) ->
+    yeccpars1([], Tzr, State, [State1 | States], [Token0 | Vstack]);
+yeccpars1(State1, State, States, Vstack, Token0, [], {no_func, no_line}) ->
+    Line = yecctoken_end_location(Token0),
+    yeccpars2(State, '$end', [State1 | States], [Token0 | Vstack],
+              yecc_end(Line), [], {no_func, Line});
+yeccpars1(State1, State, States, Vstack, Token0, [], {no_func, Line}) ->
+    yeccpars2(State, '$end', [State1 | States], [Token0 | Vstack],
+              yecc_end(Line), [], {no_func, Line}).
+
+%% For internal use only.
+yecc_end({Line,_Column}) ->
+    {'$end', Line};
+yecc_end(Line) ->
+    {'$end', Line}.
+
+yecctoken_end_location(Token) ->
+    try
+        {text, Str} = erl_scan:token_info(Token, text),
+        {line, Line} = erl_scan:token_info(Token, line),
+        Parts = re:split(Str, "\n"),
+        Dline = length(Parts) - 1,
+        Yline = Line + Dline,
+        case erl_scan:token_info(Token, column) of
+            {column, Column} ->
+                Col = byte_size(lists:last(Parts)),
+                {Yline, Col + if Dline =:= 0 -> Column; true -> 1 end};
+            undefined ->
+                Yline
+        end
+    catch _:_ ->
+        yecctoken_location(Token)
+    end.
+
+-compile({nowarn_unused_function, yeccerror/1}).
+yeccerror(Token) ->
+    Text = yecctoken_to_string(Token),
+    Location = yecctoken_location(Token),
+    {error, {Location, ?MODULE, ["syntax error before: ", Text]}}.
+
+-compile({nowarn_unused_function, yecctoken_to_string/1}).
+yecctoken_to_string(Token) ->
+    case catch erl_scan:token_info(Token, text) of
+        {text, Txt} -> Txt;
+        _ -> yecctoken2string(Token)
+    end.
+
+yecctoken_location(Token) ->
+    case catch erl_scan:token_info(Token, location) of
+        {location, Loc} -> Loc;
+        _ -> element(2, Token)
+    end.
+
+-compile({nowarn_unused_function, yecctoken2string/1}).
+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_unicode_string(S);
+yecctoken2string({reserved_symbol, _, A}) -> io_lib:write(A);
+yecctoken2string({_Cat, _, Val}) -> io_lib:format("~p",[Val]);
+yecctoken2string({dot, _}) -> "'.'";
+yecctoken2string({'$end', _}) ->
+    [];
+yecctoken2string({Other, _}) when is_atom(Other) ->
+    io_lib:write(Other);
+yecctoken2string(Other) ->
+    io_lib:write(Other).
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+
+
+-file("src/egs_script_parser.erl", 190).
+
+yeccpars2(0=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_0(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(1=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_1(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(2=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_2(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(3=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_3(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(4=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_4(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(5=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_5(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(6=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_6(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(7=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_7(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(8=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_8(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(9=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_9(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(10=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_10(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(11=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_11(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(12=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_12(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(13=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_13(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(14=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_14(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(15=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_15(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(16=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_16(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(17=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_17(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(18=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_18(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(19=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_19(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(20=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_20(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(21=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_21(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(22=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_22(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(23=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_23(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(24=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_24(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(25=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_25(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(26=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_26(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(27=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_27(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(28=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_28(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(29=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_29(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(30=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_30(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(31=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_31(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(32=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_32(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(33=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_33(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(34=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_34(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(35=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_35(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(36=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_36(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(37=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_37(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(38=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_38(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(39=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_39(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(40=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_40(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(41=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_41(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(42=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_42(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(43=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_43(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(44=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_44(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(45=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_45(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(46=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_46(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(47=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_47(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(48=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_48(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(49=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_49(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(50=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_50(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(51=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_51(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(52=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_52(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(53=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_53(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(54=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_54(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(55=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_55(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(56=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_56(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(57=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_57(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(58=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_58(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(59=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_59(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(60=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_60(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(61=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_61(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(62=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_62(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(63=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_63(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(64=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_64(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(65=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_65(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(66=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_66(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(67=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_67(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(68=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_13(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(69=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_69(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(70=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_70(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(71=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_71(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(72=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_72(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(73=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_73(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(74=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_13(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(75=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_75(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(76=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_76(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(77=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_13(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(78=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_78(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(79=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_79(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(80=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_80(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(81=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_13(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(82=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_82(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(83=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_83(S, Cat, Ss, Stack, T, Ts, Tzr);
+%% yeccpars2(84=S, Cat, Ss, Stack, T, Ts, Tzr) ->
+%%  yeccpars2_84(S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccpars2(Other, _, _, _, _, _, _) ->
+ erlang:error({yecc_bug,"1.4",{missing_state_in_action_table, Other}}).
+
+yeccpars2_0(S, event_def, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 3, Ss, Stack, T, Ts, Tzr);
+yeccpars2_0(S, function_def, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 4, Ss, Stack, T, Ts, Tzr);
+yeccpars2_0(S, num_var, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 5, Ss, Stack, T, Ts, Tzr);
+yeccpars2_0(S, str_var, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 6, Ss, Stack, T, Ts, Tzr);
+yeccpars2_0(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_0_(Stack),
+ yeccpars2_1(1, Cat, [0 | Ss], NewStack, T, Ts, Tzr).
+
+yeccpars2_1(_S, '$end', _Ss, Stack, _T, _Ts, _Tzr) ->
+ {ok, hd(Stack)};
+yeccpars2_1(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_2(S, event_def, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 3, Ss, Stack, T, Ts, Tzr);
+yeccpars2_2(S, function_def, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 4, Ss, Stack, T, Ts, Tzr);
+yeccpars2_2(S, num_var, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 5, Ss, Stack, T, Ts, Tzr);
+yeccpars2_2(S, str_var, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 6, Ss, Stack, T, Ts, Tzr);
+yeccpars2_2(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_2_(Stack),
+ yeccpars2_84(_S, Cat, [2 | Ss], NewStack, T, Ts, Tzr).
+
+yeccpars2_3(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 80, Ss, Stack, T, Ts, Tzr);
+yeccpars2_3(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_4(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 12, Ss, Stack, T, Ts, Tzr);
+yeccpars2_4(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_5(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 10, Ss, Stack, T, Ts, Tzr);
+yeccpars2_5(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_6(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 7, Ss, Stack, T, Ts, Tzr);
+yeccpars2_6(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_7(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 8, Ss, Stack, T, Ts, Tzr);
+yeccpars2_7(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_8(S, dot, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 9, Ss, Stack, T, Ts, Tzr);
+yeccpars2_8(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_9(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_,_|Nss] = Ss,
+ NewStack = yeccpars2_9_(Stack),
+ yeccgoto_declaration(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_10(S, dot, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 11, Ss, Stack, T, Ts, Tzr);
+yeccpars2_10(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_11(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_11_(Stack),
+ yeccgoto_declaration(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_12(S, '->', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 13, Ss, Stack, T, Ts, Tzr);
+yeccpars2_12(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_13(S, abs, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 16, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, add, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 17, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, 'band', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 18, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, 'bor', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 19, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, 'bxor', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 20, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, 'case', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 21, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, debug, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 22, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, dec, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 23, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, 'div', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 24, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 25, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, inc, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 26, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, is_eq, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 27, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, is_gt, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 28, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, is_gteq, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 29, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, is_lt, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 30, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, is_lteq, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 31, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, is_neq, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 32, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, jmp, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 33, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, jnz, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 34, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, jz, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 35, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, land, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 36, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, lor, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 37, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, lshift, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 38, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, mod, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 39, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, mul, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 40, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, neg, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 41, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, nop, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 42, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, num_get, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 43, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, num_set, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 44, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, push, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 45, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, restore, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 46, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, return, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 47, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, rshift, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 48, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, save, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 49, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, savep, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 50, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, str_get, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 51, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, str_set, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 52, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, sub, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 53, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(S, syscall, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 54, Ss, Stack, T, Ts, Tzr);
+yeccpars2_13(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_14(S, dot, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 79, Ss, Stack, T, Ts, Tzr);
+yeccpars2_14(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_15(S, ',', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 77, Ss, Stack, T, Ts, Tzr);
+yeccpars2_15(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_15_(Stack),
+ yeccgoto_instructions(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_16(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_16_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_17(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_17_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_18(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_18_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_19(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_19_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_20(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_20_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_21(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 67, Ss, Stack, T, Ts, Tzr);
+yeccpars2_21(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_22(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_22_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_23(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_23_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_24(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_24_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_25(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_25_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_26(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_26_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_27(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_27_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_28(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_28_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_29(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_29_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_30(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_30_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_31(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_31_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_32(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_32_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_33(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 64, Ss, Stack, T, Ts, Tzr);
+yeccpars2_33(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_34(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 63, Ss, Stack, T, Ts, Tzr);
+yeccpars2_34(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_35(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 62, Ss, Stack, T, Ts, Tzr);
+yeccpars2_35(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_36(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_36_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_37(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_37_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_38(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_38_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_39(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_39_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_40(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_40_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_41(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_41_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_42(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_42_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_43(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 61, Ss, Stack, T, Ts, Tzr);
+yeccpars2_43(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_44(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 60, Ss, Stack, T, Ts, Tzr);
+yeccpars2_44(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_45(S, float, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 57, Ss, Stack, T, Ts, Tzr);
+yeccpars2_45(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 58, Ss, Stack, T, Ts, Tzr);
+yeccpars2_45(S, string, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 59, Ss, Stack, T, Ts, Tzr);
+yeccpars2_45(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_46(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_46_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_47(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_47_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_48(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_48_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_49(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_49_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_50(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_50_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_51(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 56, Ss, Stack, T, Ts, Tzr);
+yeccpars2_51(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_52(S, function, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 55, Ss, Stack, T, Ts, Tzr);
+yeccpars2_52(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_53(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_53_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_54(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_54_(Stack),
+ yeccgoto_instruction(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_55(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_55_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_56(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_56_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_57(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_57_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_58(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_58_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_59(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_59_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_60(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_60_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_61(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_61_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_62(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_62_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_63(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_63_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_64(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_64_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_65(S, 'end', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 76, Ss, Stack, T, Ts, Tzr);
+yeccpars2_65(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_66(S, ';', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 70, Ss, Stack, T, Ts, Tzr);
+yeccpars2_66(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ NewStack = yeccpars2_66_(Stack),
+ yeccgoto_case_tests(hd(Ss), Cat, Ss, NewStack, T, Ts, Tzr).
+
+yeccpars2_67(S, '->', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 68, Ss, Stack, T, Ts, Tzr);
+yeccpars2_67(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+%% yeccpars2_68: see yeccpars2_13
+
+yeccpars2_69(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_69_(Stack),
+ yeccgoto_case_test(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_70(S, default, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 73, Ss, Stack, T, Ts, Tzr);
+yeccpars2_70(S, integer, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 67, Ss, Stack, T, Ts, Tzr);
+yeccpars2_70(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_71(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_71_(Stack),
+ yeccgoto_case_tests(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_72(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_72_(Stack),
+ yeccgoto_case_tests(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_73(S, '->', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 74, Ss, Stack, T, Ts, Tzr);
+yeccpars2_73(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+%% yeccpars2_74: see yeccpars2_13
+
+yeccpars2_75(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_75_(Stack),
+ yeccgoto_case_default(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_76(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_76_(Stack),
+ yeccgoto_instruction(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+%% yeccpars2_77: see yeccpars2_13
+
+yeccpars2_78(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_|Nss] = Ss,
+ NewStack = yeccpars2_78_(Stack),
+ yeccgoto_instructions(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_79(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_,_,_|Nss] = Ss,
+ NewStack = yeccpars2_79_(Stack),
+ yeccgoto_declaration(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_80(S, '->', Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 81, Ss, Stack, T, Ts, Tzr);
+yeccpars2_80(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+%% yeccpars2_81: see yeccpars2_13
+
+yeccpars2_82(S, dot, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars1(S, 83, Ss, Stack, T, Ts, Tzr);
+yeccpars2_82(_, _, _, _, T, _, _) ->
+ yeccerror(T).
+
+yeccpars2_83(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_,_,_,_|Nss] = Ss,
+ NewStack = yeccpars2_83_(Stack),
+ yeccgoto_declaration(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccpars2_84(_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ [_|Nss] = Ss,
+ NewStack = yeccpars2_84_(Stack),
+ yeccgoto_declarations(hd(Nss), Cat, Nss, NewStack, T, Ts, Tzr).
+
+yeccgoto_case_default(70=_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_72(_S, Cat, Ss, Stack, T, Ts, Tzr).
+
+yeccgoto_case_test(21, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_66(66, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_case_test(70, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_66(66, Cat, Ss, Stack, T, Ts, Tzr).
+
+yeccgoto_case_tests(21, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_65(65, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_case_tests(70=_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_71(_S, Cat, Ss, Stack, T, Ts, Tzr).
+
+yeccgoto_declaration(0, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_2(2, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_declaration(2, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_2(2, Cat, Ss, Stack, T, Ts, Tzr).
+
+yeccgoto_declarations(0, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_1(1, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_declarations(2=_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_84(_S, Cat, Ss, Stack, T, Ts, Tzr).
+
+yeccgoto_instruction(13, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_15(15, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instruction(68, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_15(15, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instruction(74, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_15(15, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instruction(77, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_15(15, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instruction(81, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_15(15, Cat, Ss, Stack, T, Ts, Tzr).
+
+yeccgoto_instructions(13, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_14(14, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instructions(68=_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_69(_S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instructions(74=_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_75(_S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instructions(77=_S, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_78(_S, Cat, Ss, Stack, T, Ts, Tzr);
+yeccgoto_instructions(81, Cat, Ss, Stack, T, Ts, Tzr) ->
+ yeccpars2_82(82, Cat, Ss, Stack, T, Ts, Tzr).
+
+-compile({inline,yeccpars2_0_/1}).
+-file("src/egs_script_parser.yrl", 25).
+yeccpars2_0_(__Stack0) ->
+ [begin
+   nil
+  end | __Stack0].
+
+-compile({inline,yeccpars2_2_/1}).
+-file("src/egs_script_parser.yrl", 25).
+yeccpars2_2_(__Stack0) ->
+ [begin
+   nil
+  end | __Stack0].
+
+-compile({inline,yeccpars2_9_/1}).
+-file("src/egs_script_parser.yrl", 30).
+yeccpars2_9_(__Stack0) ->
+ [__4,__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { str_var , unwrap ( __2 ) , unwrap ( __3 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_11_/1}).
+-file("src/egs_script_parser.yrl", 29).
+yeccpars2_11_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { num_var , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_15_/1}).
+-file("src/egs_script_parser.yrl", 33).
+yeccpars2_15_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   { __1 , nil }
+  end | __Stack].
+
+-compile({inline,yeccpars2_16_/1}).
+-file("src/egs_script_parser.yrl", 35).
+yeccpars2_16_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   abs
+  end | __Stack].
+
+-compile({inline,yeccpars2_17_/1}).
+-file("src/egs_script_parser.yrl", 36).
+yeccpars2_17_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   add
+  end | __Stack].
+
+-compile({inline,yeccpars2_18_/1}).
+-file("src/egs_script_parser.yrl", 37).
+yeccpars2_18_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   'band'
+  end | __Stack].
+
+-compile({inline,yeccpars2_19_/1}).
+-file("src/egs_script_parser.yrl", 38).
+yeccpars2_19_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   'bor'
+  end | __Stack].
+
+-compile({inline,yeccpars2_20_/1}).
+-file("src/egs_script_parser.yrl", 39).
+yeccpars2_20_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   'bxor'
+  end | __Stack].
+
+-compile({inline,yeccpars2_22_/1}).
+-file("src/egs_script_parser.yrl", 73).
+yeccpars2_22_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   debug
+  end | __Stack].
+
+-compile({inline,yeccpars2_23_/1}).
+-file("src/egs_script_parser.yrl", 40).
+yeccpars2_23_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   dec
+  end | __Stack].
+
+-compile({inline,yeccpars2_24_/1}).
+-file("src/egs_script_parser.yrl", 41).
+yeccpars2_24_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   'div'
+  end | __Stack].
+
+-compile({inline,yeccpars2_25_/1}).
+-file("src/egs_script_parser.yrl", 74).
+yeccpars2_25_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   { function , unwrap ( __1 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_26_/1}).
+-file("src/egs_script_parser.yrl", 42).
+yeccpars2_26_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   inc
+  end | __Stack].
+
+-compile({inline,yeccpars2_27_/1}).
+-file("src/egs_script_parser.yrl", 43).
+yeccpars2_27_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   is_eq
+  end | __Stack].
+
+-compile({inline,yeccpars2_28_/1}).
+-file("src/egs_script_parser.yrl", 44).
+yeccpars2_28_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   is_gt
+  end | __Stack].
+
+-compile({inline,yeccpars2_29_/1}).
+-file("src/egs_script_parser.yrl", 45).
+yeccpars2_29_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   is_gteq
+  end | __Stack].
+
+-compile({inline,yeccpars2_30_/1}).
+-file("src/egs_script_parser.yrl", 46).
+yeccpars2_30_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   is_lt
+  end | __Stack].
+
+-compile({inline,yeccpars2_31_/1}).
+-file("src/egs_script_parser.yrl", 47).
+yeccpars2_31_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   is_lteq
+  end | __Stack].
+
+-compile({inline,yeccpars2_32_/1}).
+-file("src/egs_script_parser.yrl", 48).
+yeccpars2_32_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   is_neq
+  end | __Stack].
+
+-compile({inline,yeccpars2_36_/1}).
+-file("src/egs_script_parser.yrl", 52).
+yeccpars2_36_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   land
+  end | __Stack].
+
+-compile({inline,yeccpars2_37_/1}).
+-file("src/egs_script_parser.yrl", 53).
+yeccpars2_37_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   lor
+  end | __Stack].
+
+-compile({inline,yeccpars2_38_/1}).
+-file("src/egs_script_parser.yrl", 54).
+yeccpars2_38_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   lshift
+  end | __Stack].
+
+-compile({inline,yeccpars2_39_/1}).
+-file("src/egs_script_parser.yrl", 55).
+yeccpars2_39_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   mod
+  end | __Stack].
+
+-compile({inline,yeccpars2_40_/1}).
+-file("src/egs_script_parser.yrl", 56).
+yeccpars2_40_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   mul
+  end | __Stack].
+
+-compile({inline,yeccpars2_41_/1}).
+-file("src/egs_script_parser.yrl", 57).
+yeccpars2_41_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   neg
+  end | __Stack].
+
+-compile({inline,yeccpars2_42_/1}).
+-file("src/egs_script_parser.yrl", 58).
+yeccpars2_42_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   nop
+  end | __Stack].
+
+-compile({inline,yeccpars2_46_/1}).
+-file("src/egs_script_parser.yrl", 64).
+yeccpars2_46_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   restore
+  end | __Stack].
+
+-compile({inline,yeccpars2_47_/1}).
+-file("src/egs_script_parser.yrl", 65).
+yeccpars2_47_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   return
+  end | __Stack].
+
+-compile({inline,yeccpars2_48_/1}).
+-file("src/egs_script_parser.yrl", 66).
+yeccpars2_48_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   rshift
+  end | __Stack].
+
+-compile({inline,yeccpars2_49_/1}).
+-file("src/egs_script_parser.yrl", 67).
+yeccpars2_49_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   save
+  end | __Stack].
+
+-compile({inline,yeccpars2_50_/1}).
+-file("src/egs_script_parser.yrl", 68).
+yeccpars2_50_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   savep
+  end | __Stack].
+
+-compile({inline,yeccpars2_53_/1}).
+-file("src/egs_script_parser.yrl", 71).
+yeccpars2_53_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   sub
+  end | __Stack].
+
+-compile({inline,yeccpars2_54_/1}).
+-file("src/egs_script_parser.yrl", 75).
+yeccpars2_54_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   { syscall , unwrap ( __1 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_55_/1}).
+-file("src/egs_script_parser.yrl", 70).
+yeccpars2_55_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { str_set , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_56_/1}).
+-file("src/egs_script_parser.yrl", 69).
+yeccpars2_56_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { str_get , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_57_/1}).
+-file("src/egs_script_parser.yrl", 62).
+yeccpars2_57_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { push , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_58_/1}).
+-file("src/egs_script_parser.yrl", 61).
+yeccpars2_58_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { push , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_59_/1}).
+-file("src/egs_script_parser.yrl", 63).
+yeccpars2_59_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { push , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_60_/1}).
+-file("src/egs_script_parser.yrl", 60).
+yeccpars2_60_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { num_set , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_61_/1}).
+-file("src/egs_script_parser.yrl", 59).
+yeccpars2_61_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { num_get , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_62_/1}).
+-file("src/egs_script_parser.yrl", 51).
+yeccpars2_62_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { jz , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_63_/1}).
+-file("src/egs_script_parser.yrl", 50).
+yeccpars2_63_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { jnz , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_64_/1}).
+-file("src/egs_script_parser.yrl", 49).
+yeccpars2_64_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { jmp , unwrap ( __2 ) }
+  end | __Stack].
+
+-compile({inline,yeccpars2_66_/1}).
+-file("src/egs_script_parser.yrl", 80).
+yeccpars2_66_(__Stack0) ->
+ [__1 | __Stack] = __Stack0,
+ [begin
+   { __1 , nil }
+  end | __Stack].
+
+-compile({inline,yeccpars2_69_/1}).
+-file("src/egs_script_parser.yrl", 81).
+yeccpars2_69_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { case_test , unwrap ( __1 ) , __3 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_71_/1}).
+-file("src/egs_script_parser.yrl", 78).
+yeccpars2_71_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { __1 , __3 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_72_/1}).
+-file("src/egs_script_parser.yrl", 79).
+yeccpars2_72_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { __1 , { __3 , nil } }
+  end | __Stack].
+
+-compile({inline,yeccpars2_75_/1}).
+-file("src/egs_script_parser.yrl", 82).
+yeccpars2_75_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { case_default , __3 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_76_/1}).
+-file("src/egs_script_parser.yrl", 77).
+yeccpars2_76_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { 'case' , __2 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_78_/1}).
+-file("src/egs_script_parser.yrl", 32).
+yeccpars2_78_(__Stack0) ->
+ [__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { __1 , __3 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_79_/1}).
+-file("src/egs_script_parser.yrl", 28).
+yeccpars2_79_(__Stack0) ->
+ [__5,__4,__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { function_def , unwrap ( __2 ) , __4 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_83_/1}).
+-file("src/egs_script_parser.yrl", 27).
+yeccpars2_83_(__Stack0) ->
+ [__5,__4,__3,__2,__1 | __Stack] = __Stack0,
+ [begin
+   { event_def , unwrap ( __2 ) , __4 }
+  end | __Stack].
+
+-compile({inline,yeccpars2_84_/1}).
+-file("src/egs_script_parser.yrl", 24).
+yeccpars2_84_(__Stack0) ->
+ [__2,__1 | __Stack] = __Stack0,
+ [begin
+   { __1 , __2 }
+  end | __Stack].
+
+
+-file("src/egs_script_parser.yrl", 91).
diff --git a/src/egs_script_parser.yrl b/apps/egs/src/egs_script_parser.yrl
similarity index 100%
rename from src/egs_script_parser.yrl
rename to apps/egs/src/egs_script_parser.yrl
diff --git a/src/egs_seasons.erl b/apps/egs/src/egs_seasons.erl
similarity index 100%
rename from src/egs_seasons.erl
rename to apps/egs/src/egs_seasons.erl
diff --git a/src/egs_shops_db.erl b/apps/egs/src/egs_shops_db.erl
similarity index 100%
rename from src/egs_shops_db.erl
rename to apps/egs/src/egs_shops_db.erl
diff --git a/src/egs_sup.erl b/apps/egs/src/egs_sup.erl
similarity index 100%
rename from src/egs_sup.erl
rename to apps/egs/src/egs_sup.erl
diff --git a/src/egs_universes.erl b/apps/egs/src/egs_universes.erl
similarity index 100%
rename from src/egs_universes.erl
rename to apps/egs/src/egs_universes.erl
diff --git a/src/egs_users.erl b/apps/egs/src/egs_users.erl
similarity index 100%
rename from src/egs_users.erl
rename to apps/egs/src/egs_users.erl
diff --git a/src/egs_zones.erl b/apps/egs/src/egs_zones.erl
similarity index 100%
rename from src/egs_zones.erl
rename to apps/egs/src/egs_zones.erl
diff --git a/src/egs_zones_sup.erl b/apps/egs/src/egs_zones_sup.erl
similarity index 100%
rename from src/egs_zones_sup.erl
rename to apps/egs/src/egs_zones_sup.erl
diff --git a/src/objects/egs_obj_chair.erl b/apps/egs/src/objects/egs_obj_chair.erl
similarity index 100%
rename from src/objects/egs_obj_chair.erl
rename to apps/egs/src/objects/egs_obj_chair.erl
diff --git a/src/objects/egs_obj_door.erl b/apps/egs/src/objects/egs_obj_door.erl
similarity index 100%
rename from src/objects/egs_obj_door.erl
rename to apps/egs/src/objects/egs_obj_door.erl
diff --git a/src/objects/egs_obj_entrance.erl b/apps/egs/src/objects/egs_obj_entrance.erl
similarity index 100%
rename from src/objects/egs_obj_entrance.erl
rename to apps/egs/src/objects/egs_obj_entrance.erl
diff --git a/src/objects/egs_obj_exit.erl b/apps/egs/src/objects/egs_obj_exit.erl
similarity index 100%
rename from src/objects/egs_obj_exit.erl
rename to apps/egs/src/objects/egs_obj_exit.erl
diff --git a/src/objects/egs_obj_invisible_block.erl b/apps/egs/src/objects/egs_obj_invisible_block.erl
similarity index 100%
rename from src/objects/egs_obj_invisible_block.erl
rename to apps/egs/src/objects/egs_obj_invisible_block.erl
diff --git a/src/objects/egs_obj_label.erl b/apps/egs/src/objects/egs_obj_label.erl
similarity index 100%
rename from src/objects/egs_obj_label.erl
rename to apps/egs/src/objects/egs_obj_label.erl
diff --git a/src/objects/egs_obj_npc.erl b/apps/egs/src/objects/egs_obj_npc.erl
similarity index 100%
rename from src/objects/egs_obj_npc.erl
rename to apps/egs/src/objects/egs_obj_npc.erl
diff --git a/src/objects/egs_obj_pp_cube.erl b/apps/egs/src/objects/egs_obj_pp_cube.erl
similarity index 100%
rename from src/objects/egs_obj_pp_cube.erl
rename to apps/egs/src/objects/egs_obj_pp_cube.erl
diff --git a/src/objects/egs_obj_sensor.erl b/apps/egs/src/objects/egs_obj_sensor.erl
similarity index 100%
rename from src/objects/egs_obj_sensor.erl
rename to apps/egs/src/objects/egs_obj_sensor.erl
diff --git a/src/objects/egs_obj_static_model.erl b/apps/egs/src/objects/egs_obj_static_model.erl
similarity index 100%
rename from src/objects/egs_obj_static_model.erl
rename to apps/egs/src/objects/egs_obj_static_model.erl
diff --git a/src/objects/egs_obj_type_counter.erl b/apps/egs/src/objects/egs_obj_type_counter.erl
similarity index 100%
rename from src/objects/egs_obj_type_counter.erl
rename to apps/egs/src/objects/egs_obj_type_counter.erl
diff --git a/src/objects/egs_obj_uni_cube.erl b/apps/egs/src/objects/egs_obj_uni_cube.erl
similarity index 100%
rename from src/objects/egs_obj_uni_cube.erl
rename to apps/egs/src/objects/egs_obj_uni_cube.erl
diff --git a/src/psu/psu_appearance.erl b/apps/egs/src/psu/psu_appearance.erl
similarity index 100%
rename from src/psu/psu_appearance.erl
rename to apps/egs/src/psu/psu_appearance.erl
diff --git a/src/psu/psu_characters.erl b/apps/egs/src/psu/psu_characters.erl
similarity index 100%
rename from src/psu/psu_characters.erl
rename to apps/egs/src/psu/psu_characters.erl
diff --git a/src/psu/psu_party.erl b/apps/egs/src/psu/psu_party.erl
similarity index 100%
rename from src/psu/psu_party.erl
rename to apps/egs/src/psu/psu_party.erl
diff --git a/data/lobby/.gitignore b/data/lobby/.gitignore
deleted file mode 100644
index 72e8ffc..0000000
--- a/data/lobby/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-*
diff --git a/data/missions/.gitignore b/data/missions/.gitignore
deleted file mode 100644
index 72e8ffc..0000000
--- a/data/missions/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-*
diff --git a/data/rooms/.gitignore b/data/rooms/.gitignore
deleted file mode 100644
index 72e8ffc..0000000
--- a/data/rooms/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-*
diff --git a/data/tutorial/.gitignore b/data/tutorial/.gitignore
deleted file mode 100644
index 72e8ffc..0000000
--- a/data/tutorial/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-*
diff --git a/rebar.config b/rebar.config
index 8521aa2..1a3e200 100644
--- a/rebar.config
+++ b/rebar.config
@@ -1,6 +1,5 @@
-{deps, [
-	{ex_reloader, ".*", {git, "git://github.com/extend/ex_reloader.git", "HEAD"}},
-	{cowboy, ".*", {git, "git://github.com/extend/cowboy.git", "HEAD"}}
+{sub_dirs, [
+	"apps/egs"
 ]}.
 {dialyzer_opts, [src, {warnings, [
 	behaviours,
diff --git a/start.sh b/start.sh
index 9dcfb52..eb5abe5 100755
--- a/start.sh
+++ b/start.sh
@@ -2,4 +2,4 @@
 echo "EGS is free software available under the GNU GPL version 3"
 echo "Copyright (C) 2010-2011  Loic Hoguin"
 echo 
-erl -sname egs -pa ebin -pa deps/*/ebin -boot start_sasl -s ex_reloader -s egs
+erl -sname egs -pa apps/*/ebin -pa deps/*/ebin -boot start_sasl -s ex_reloader -s egs