[SCM] FreeFem++ packaging branch, eftaxiop, updated. debian/3.23-1-2-gcadeba5

Dimitrios Eftaxiopoulos eftaxi12 at otenet.gr
Tue Jul 23 21:00:09 UTC 2013


The following commit has been merged in the eftaxiop branch:
commit cadeba588f9c51a7fb1a5112c4c857f3d50672e1
Author: Dimitrios Eftaxiopoulos <eftaxi12 at otenet.gr>
Date:   Tue Jul 23 23:58:59 2013 +0300

    Import Cristoph's patches

diff --git a/.gitignore b/.gitignore
index 66b2949..35a9d8a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -4,6 +4,7 @@ INSTALL
 Makefile.in
 aclocal.m4
 compile
+config.h.in
 config.guess
 config.sub
 configure
diff --git a/config.h.in b/config.h.in
deleted file mode 100644
index 6c05317..0000000
--- a/config.h.in
+++ /dev/null
@@ -1,199 +0,0 @@
-/* config.h.in.  Generated from configure.ac by autoheader.  */
-
-/* Define to dummy `main' function (if any) required to link to the Fortran
-   libraries. */
-#undef F77_DUMMY_MAIN
-
-/* Define to a macro mangling the given C identifier (in lower and upper
-   case), which must not contain underscores, for linking with Fortran. */
-#undef F77_FUNC
-
-/* As F77_FUNC, but for C identifiers containing underscores. */
-#undef F77_FUNC_
-
-/* Define if F77 and FC dummy `main' functions are identical. */
-#undef FC_DUMMY_MAIN_EQ_F77
-
-/* FreeFem prefix dir */
-#undef FF_PREFIX_DIR
-
-/* FreeFem prefix dir */
-#undef FF_PREFIX_DIR_APPLE
-
-/* Define to 1 if you have the `acosh' function. */
-#undef HAVE_ACOSH
-
-/* Define to 1 if you have the `asinh' function. */
-#undef HAVE_ASINH
-
-/* Define to 1 if you have the `atanh' function. */
-#undef HAVE_ATANH
-
-/* Define to 1 if you have the <atlas/cblas.h> header file. */
-#undef HAVE_ATLAS_CBLAS_H
-
-/* If umfpack.h is located in UMFPACK subdir */
-#undef HAVE_BIG_UMFPACK_UMFPACK_H
-
-/* freecadna is use to evalute the round-off error propagation */
-#undef HAVE_CADNA
-
-/* Define to 1 if you have the <cblas.h> header file. */
-#undef HAVE_CBLAS_H
-
-/* Dynamic loading - not mandatory */
-#undef HAVE_DLFCN_H
-
-/* Define to 1 if you have the `erfc' function. */
-#undef HAVE_ERFC
-
-/* Define to 1 if you have the <fftw3.h> header file. */
-#undef HAVE_FFTW3_H
-
-/* Define to 1 if you have the `getenv' function. */
-#undef HAVE_GETENV
-
-/* Define to 1 if you have the `gettimeofday' function. */
-#undef HAVE_GETTIMEOFDAY
-
-/* Define to 1 if you have the <GLUT/glut.h> header file. */
-#undef HAVE_GLUT_GLUT_H
-
-/* Define to 1 if you have the <GL/glut.h> header file. */
-#undef HAVE_GL_GLUT_H
-
-/* Define to 1 if you have the <GL/gl.h> header file. */
-#undef HAVE_GL_GL_H
-
-/* Define to 1 if you have the <inttypes.h> header file. */
-#undef HAVE_INTTYPES_H
-
-/* Define to 1 if you have the `jn' function. */
-#undef HAVE_JN
-
-/* Arpack is used for eigenvalue computation */
-#undef HAVE_LIBARPACK
-
-/* Define to 1 if you have the `dl' library (-ldl). */
-#undef HAVE_LIBDL
-
-/* UMFPACK */
-#undef HAVE_LIBUMFPACK
-
-/* Define to 1 if you have the <malloc.h> header file. */
-#undef HAVE_MALLOC_H
-
-/* Define to 1 if you have the <memory.h> header file. */
-#undef HAVE_MEMORY_H
-
-/* mpi_double_complex */
-#undef HAVE_MPI_DOUBLE_COMPLEX
-
-/* Define to 1 if you have the <OpenGL/gl.h> header file. */
-#undef HAVE_OPENGL_GL_H
-
-/* Define to 1 if you have the `second_' function. */
-#undef HAVE_SECOND_
-
-/* Define to 1 if you have the `srandomdev' function. */
-#undef HAVE_SRANDOMDEV
-
-/* Define to 1 if you have the <stdint.h> header file. */
-#undef HAVE_STDINT_H
-
-/* Define to 1 if you have the <stdlib.h> header file. */
-#undef HAVE_STDLIB_H
-
-/* Define to 1 if you have the <strings.h> header file. */
-#undef HAVE_STRINGS_H
-
-/* Define to 1 if you have the <string.h> header file. */
-#undef HAVE_STRING_H
-
-/* Define to 1 if you have the <suitesparse/umfpack.h> header file. */
-#undef HAVE_SUITESPARSE_UMFPACK_H
-
-/* Define to 1 if you have the `sysconf' function. */
-#undef HAVE_SYSCONF
-
-/* Define to 1 if you have the <sys/stat.h> header file. */
-#undef HAVE_SYS_STAT_H
-
-/* Define to 1 if you have the <sys/types.h> header file. */
-#undef HAVE_SYS_TYPES_H
-
-/* tetgen is compute tetrahedralize volume of an enclosed surface */
-#undef HAVE_TETGEN
-
-/* Define to 1 if you have the <tetgen.h> header file. */
-#undef HAVE_TETGEN_H
-
-/* Define to 1 if you have the `tgamma' function. */
-#undef HAVE_TGAMMA
-
-/* Define to 1 if you have the `times' function. */
-#undef HAVE_TIMES
-
-/* Define to 1 if you have the <ufsparse/umfpack.h> header file. */
-#undef HAVE_UFSPARSE_UMFPACK_H
-
-/* Define to 1 if you have the <umfpack.h> header file. */
-#undef HAVE_UMFPACK_H
-
-/* Define to 1 if you have the <umfpack/umfpack.h> header file. */
-#undef HAVE_UMFPACK_UMFPACK_H
-
-/* Define to 1 if you have the <unistd.h> header file. */
-#undef HAVE_UNISTD_H
-
-/* Define to 1 if you have the <vecLib/cblas.h> header file. */
-#undef HAVE_VECLIB_CBLAS_H
-
-/* Define to 1 if your C compiler doesn't accept -c and -o together. */
-#undef NO_MINUS_C_MINUS_O
-
-/* Name of package */
-#undef PACKAGE
-
-/* Define to the address where bug reports for this package should be sent. */
-#undef PACKAGE_BUGREPORT
-
-/* Define to the full name of this package. */
-#undef PACKAGE_NAME
-
-/* Define to the full name and version of this package. */
-#undef PACKAGE_STRING
-
-/* Define to the one symbol short name of this package. */
-#undef PACKAGE_TARNAME
-
-/* Define to the home page for this package. */
-#undef PACKAGE_URL
-
-/* Define to the version of this package. */
-#undef PACKAGE_VERSION
-
-/* the ffglut application for the new graphics */
-#undef PROG_FFGLUT
-
-/* A pure windows applications no cygwin dll */
-#undef PURE_WIN32
-
-/* Define to 1 if you have the ANSI C header files. */
-#undef STDC_HEADERS
-
-/* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
-#undef TIME_WITH_SYS_TIME
-
-/* Version number of package */
-#undef VERSION
-
-/* FreeFem++ build date */
-#undef VersionFreeFemDate
-
-/* FreeFem++ version as a float */
-#undef VersionFreeFempp
-
-/* Define to 1 if `lex' declares `yytext' as a `char *' by default, not a
-   `char[]'. */
-#undef YYTEXT_POINTER
diff --git a/debian/patches/configure.patch b/debian/patches/configure.patch
new file mode 100644
index 0000000..c38678b
--- /dev/null
+++ b/debian/patches/configure.patch
@@ -0,0 +1,94 @@
+Fix compilation issues related to libraries and flags
+--- a/configure.ac
++++ b/configure.ac
+@@ -41,6 +41,7 @@
+ ]) dnl 
+ m4_define([AC_FF_WHERELIB],
+     [  	if test -z "$ff_where_lib_conf_$1" ; then
++	 dnl AC_MSG_NOTICE([AC_FF_WHERELIB check $1 $2 $3 $4])
+         AC_MSG_CHECKING(check $1)
+ 	ff_save_libs=$LIBS
+ 	LIBS="$LIBS $2 $4"
+@@ -49,6 +50,7 @@
+ 	    echo "$1 LD $2"  >>$ff_where_lib_conf
+ 	    ff_WHERE_INC=`AS_DIRNAME(["$3"])`
+ 	    if test -n "$ff_WHERE_INC" -a  "$ff_WHERE_INC" != '.'   ; then
++		dnl AC_MSG_NOTICE([AC_FF_WHERELIB $1 INCLUDE -I$ff_WHERE_INC])
+ 		echo "$1 INCLUDE -I$ff_WHERE_INC"  >>$ff_where_lib_conf
+ 	    fi 
+ 	fi
+@@ -56,6 +58,8 @@
+ 
+         ff_where_lib_conf_$1=1
+ 	LIBS=$ff_save_libs
++	dnl else
++	dnl    AC_MSG_NOTICE([AC_FF_WHERELIB nocheck $1 $2 $3 $4])
+ 	fi	
+     ])dnl end m4_define AC_FF_WHERELIB
+ 
+@@ -1977,29 +1981,42 @@
+ test -n "$ff_mkl_scalapack" && ff_scalapack="$ff_mkl_scalapack"
+ test -n "$ff_mkl_root" && ff_winc="$ff_mkl_root/include/mkl_blas.h"
+ 
++# For ipot
++AC_CHECK_HEADERS(cstddef,
++  [AC_DEFINE(HAVE_CSTDDEF, 1, cstddef exists)],
++  [])
++AC_CHECK_HEADERS(stddef.h,
++  [AC_DEFINE(HAVE_STDDEF_H, 1, stddef.h exists)],
++  [])
+ 
+ m4_map([AC_FF_WHERELIB],[ 
+-	[[mumps],[-ldmumps -lzmumps  -lmumps_common  -lpord],[dmumps_c.h],[]],
+-	[[mumps_ptscotch],[-lpord_ptscotch -lmumps_common_ptscotch -ldmumps_ptscotch -lzmumps_ptscotch -lpord_ptscotch],[dmumps_c.h]],
+-	[[mumps_scotch],[-lpord_scotch -lmumps_common_scotch -ldmumps_scotch -lzmumps_scotch -lpord_scotch],[dmumps_c.h]],
++	[[mumps_seq],[-ldmumps_seq -lzmumps_seq  -lmumps_common_seq  -lpord_seq],[/usr/include/dmumps_c.h],[]],
++	[[mumps],[-ldmumps -lzmumps  -lmumps_common  -lpord],[/usr/include/dmumps_c.h],[]],
++	[[mumps_ptscotch],[-lpord_ptscotch -lmumps_common_ptscotch -ldmumps_ptscotch -lzmumps_ptscotch -lpord_ptscotch],[/usr/include/dmumps_c.h]],
++	[[mumps_scotch],[-lpord_scotch -lmumps_common_scotch -ldmumps_scotch -lzmumps_scotch -lpord_scotch],[/usr/include/dmumps_c.h]],
+ 	[[hypre],[-lHYPRE]],
+ 	[[fftw3],[-lfftw3],[/usr/include/fftw3.h],[]],
+-	[[superlu_dist],[-lsuperlu-dist],[superlu-dist/superlu_defs.h],[]],
+-	[[superlu],[-lsuperlu],[superlu/slu_ddefs.h],[]],
+-	[[Superlu4],[-lsuperlu4],[superlu4/slu_ddefs.h],[]],
++	[[superlu_dist],[-lsuperlu-dist],[/usr/include/superlu-dist/superlu_defs.h],[]],
++	[[superlu],[-lsuperlu],[/usr/include/superlu/slu_ddefs.h],[]],
++	[[Superlu4],[-lsuperlu4],[/usr/include/superlu4/slu_ddefs.h],[]],
+         [[blacs],[ -lblacsCinit$ff_with_mpi	-lblacsF77init$ff_with_mpi	-lblacs$ff_with_mpi],[]],
+         [[scalapack],[-lscalapack$ff_with_mpi],[]],
+-        [[scotch],[-lscotch -lscotcherr],[]],
++        [[scotch],[-lscotch -lscotcherr],[/usr/include/scotch/scotch.h],[]],
+         [[ptscotch],[-lptscotch -lptscotcherr],[]],
+-	[[metis],[-lscotch -lmetis],[metis/metis.h],[]],
+-	[[metis],[-lscotch -lmetis],[metis.h],[]],
++	[[metis],[-lscotch -lmetis],[/usr/include/metis/metis.h],[]],
+ 	[[parmetis],[-lptscotch -lparmetis],[],[]],
+-	[[freeyams],[-lfreeyams],[freeyamslib.h],[]],
+-	[[mmg3d],[-lmmg3d],[libmmg3d.h],[]],
++	[[freeyams],[-lfreeyams],[/usr/include/freeyamslib.h],[]],
++	[[mmg3d_v4],[-lmmg3dlib4.0],[/usr/include/libmmg3d.h],[]],
+ 	[[mshmet],[-lmshmet],[],[]],
+-	[[gsl],[-lgsl -lgslcblas -lm],[gsl/gsl_sf.h],[]],
+-	[[parms],[-lparms -litsol -llapack -lblas -lm],[],[]],
+-	[[tetgen],[-ltet],[tetgen.h],[]],
++	[[gsl],[-lgsl -lgslcblas -lm],[/usr/include/gsl/gsl_sf.h],[]],
++	[[parms],[-lparms2 -litsol -llapack -lblas -lm -lmpi_f77],[/usr/include/libparms2/psparslib.h],[]],
++	[[double_pastix],[-lpastix -lgfortran -lm -lrt -L/usr/lib -lscotch -lscotcherrexit -lpthread],[],[]],
++	[[complex_pastix],[-lpastix -lgfortran -lm -lrt -L/usr/lib -lscotch -lscotcherrexit -lpthread],[],[]],
++	[[tetgen],[-ltet],[/usr/include/tetgen.h],[]],
++	[[hips],[-lhips],[/usr/include/hips/hips.h],[]],
++	[[nlopt],[-lnlopt],[/usr/include/nlopt.h],[]],
++	[[Ipopt],[-lipopt -ldmumps -lblas -lm -ldl],[/usr/include/coin/IpIpoptApplication.hpp],[]],
++	[[gmm],[-lm],[/usr/include/gmm/gmm.h],[]],
+     ]
+     )
+ 
+@@ -2093,3 +2110,8 @@
+     AC_MSG_NOTICE([     *********************************************** ])
+ fi
+ 
++AC_MSG_NOTICE([Compilation options: ])
++AC_MSG_NOTICE([CPPFLAGS=$CPPFLAGS])
++AC_MSG_NOTICE([CFLAGS=$CFLAGS])
++AC_MSG_NOTICE([CXXFLAGS=$CXXFLAGS])
++AC_MSG_NOTICE([LDFLAGS=$LDFLAGS])
diff --git a/debian/patches/examples++-load.patch b/debian/patches/examples++-load.patch
new file mode 100644
index 0000000..74a1b53
--- /dev/null
+++ b/debian/patches/examples++-load.patch
@@ -0,0 +1,72 @@
+Add ability to compile freefem++ with Ipopt, freeyams, mmg3d_v4, mshmet, mumps_seq and superlu4
+--- a/examples++-load/ff-Ipopt.cpp
++++ b/examples++-load/ff-Ipopt.cpp
+@@ -23,7 +23,11 @@
+  along with Freefem++; if not, write to the Free Software
+  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+  */
+-//ff-c++-LIBRARY-dep:  Ipopt mumps-seq blas  libseq  fc  
++//ff-c++-LIBRARY-dep:  Ipopt
++
++#ifndef HAVE_CSTDDEF
++#define HAVE_CSTDDEF
++#endif
+ 
+ using namespace std;
+ #include "IpTNLP.hpp"
+--- a/examples++-load/MUMPS_seq.cpp
++++ b/examples++-load/MUMPS_seq.cpp
+@@ -25,7 +25,7 @@
+  */
+ 
+ //   for automatic  compilation with ff-c++
+-//ff-c++-LIBRARY-dep:  mumps-seq blas  libseq  fc  pthread
++//ff-c++-LIBRARY-dep:  mumps_seq blas  fc  pthread
+ //ff-c++-cpp-dep: 
+ //
+ // F. Hecht  december 2011
+--- a/examples++-load/mmg3d-v4.0.cpp
++++ b/examples++-load/mmg3d-v4.0.cpp
+@@ -10,7 +10,7 @@
+ 
+ //
+ //   for automatic  compilation with ff-c++
+-//ff-c++-LIBRARY-dep:   mmg3d-v4
++//ff-c++-LIBRARY-dep:   mmg3d_v4
+ //ff-c++-cpp-dep: 
+ //  
+ 
+--- a/examples++-load/SuperLu.cpp
++++ b/examples++-load/SuperLu.cpp
+@@ -1,7 +1,7 @@
+ //   for automatic  compilation with ff-c++
+-//ff-c++-LIBRARY-dep:   superlu blas 
++//ff-c++-LIBRARY-dep:   Superlu4 blas
+ //ff-c++-cpp-dep: 
+-//  for Super4.0 library   
++//  for Super4.0 library
+ #include "ff++.hpp"
+ /*
+ #include  <iostream>
+--- a/examples++-load/mshmet.cpp
++++ b/examples++-load/mshmet.cpp
+@@ -8,7 +8,7 @@
+ // E-MAIL   : jacques.morice at ann.jussieu.fr
+ //
+ //   for automatic  compilation with ff-c++
+-//ff-c++-LIBRARY-dep:  mshmet libMesh
++//ff-c++-LIBRARY-dep:  mshmet
+ //ff-c++-cpp-dep:
+ //  
+ 
+--- a/examples++-load/freeyams.cpp
++++ b/examples++-load/freeyams.cpp
+@@ -8,7 +8,7 @@
+ // E-MAIL   : jacques.morice at ann.jussieu.fr
+ //
+ //   for automatic  compilation with ff-c++
+-//ff-c++-LIBRARY-dep:   freeyams libMesh
++//ff-c++-LIBRARY-dep:   freeyams
+ //ff-c++-cpp-dep: 
+ //  
+ 
diff --git a/debian/patches/examples++-mpi.patch b/debian/patches/examples++-mpi.patch
new file mode 100644
index 0000000..25ec639
--- /dev/null
+++ b/debian/patches/examples++-mpi.patch
@@ -0,0 +1,36 @@
+Correct location of pastix, hips and metis header files
+--- a/examples++-mpi/hips_FreeFem.cpp
++++ b/examples++-mpi/hips_FreeFem.cpp
+@@ -45,8 +45,8 @@
+ #endif
+ 
+ extern "C" {
+-#include "hips.h"  
+-#include "metis.h"
++#include "hips/hips.h"
++#include "metis/metis.h"
+ }
+ #include <stdio.h>
+ #include <stdlib.h>
+--- a/examples++-mpi/complex_pastix_FreeFem.cpp
++++ b/examples++-mpi/complex_pastix_FreeFem.cpp
+@@ -55,7 +55,7 @@
+ #include <sys/time.h>
+ 
+ 
+-#include "pastix_long_complex.h"
++#include "pastix/pastix_long_complex.h"
+ 
+ #undef memFree_null
+ #define memFree_null(x) {if (x ==NULL) {fprintf(stdout,"%s:%d freeing NULL\n",__FILE__,__LINE__);} free(x); x=NULL;}
+--- a/examples++-mpi/real_pastix_FreeFem.cpp
++++ b/examples++-mpi/real_pastix_FreeFem.cpp
+@@ -76,7 +76,7 @@
+ #ifdef __cplusplus
+ extern "C" {
+ #endif
+-#include "pastix.h"
++#include "pastix/pastix.h"
+ //#include "cscd_utils.h"
+ #ifdef __cplusplus
+ }
diff --git a/debian/patches/series b/debian/patches/series
index 3c68d8f..55140d6 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -1,3 +1,6 @@
+configure.patch
+examples++-load.patch
 examples++-load-Makefile-am.patch
 examples++-load-load-link-in.patch
 examples-bamg-test-dotest-pl.patch
+examples++-mpi.patch
diff --git a/debian/source/options b/debian/source/options
index 34c0f60..53e84e0 100644
--- a/debian/source/options
+++ b/debian/source/options
@@ -1 +1 @@
- extend-diff-ignore = "(^|/)(examples\+\+-load/all\.edp|examples\+\+-3d/all\.edp|DOC/freefem\+\+doc\.pdf|download/gmm/cxxflags|src/fflib/strversionnumber\.cpp|src/lglib/lg\.tab\.cpp|src/lglib/lg\.tab\.hpp)$"
\ No newline at end of file
+ extend-diff-ignore = "(^|/)(examples\+\+-load/all\.edp|examples\+\+-3d/all\.edp|DOC/freefem\+\+doc\.pdf|download/gmm/cxxflags|src/fflib/strversionnumber\.cpp)$"
\ No newline at end of file
diff --git a/src/lglib/lg.tab.cpp b/src/lglib/lg.tab.cpp
deleted file mode 100644
index 351fb2f..0000000
--- a/src/lglib/lg.tab.cpp
+++ /dev/null
@@ -1,3579 +0,0 @@
-/* A Bison parser, made by GNU Bison 2.7.12-4996.  */
-
-/* Bison implementation for Yacc-like parsers in C
-   
-      Copyright (C) 1984, 1989-1990, 2000-2013 Free Software Foundation, Inc.
-   
-   This program is free software: you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation, either version 3 of the License, or
-   (at your option) any later version.
-   
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-   
-   You should have received a copy of the GNU General Public License
-   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
-
-/* As a special exception, you may create a larger work that contains
-   part or all of the Bison parser skeleton and distribute that work
-   under terms of your choice, so long as that work isn't itself a
-   parser generator using the skeleton or a modified version thereof
-   as a parser skeleton.  Alternatively, if you modify or redistribute
-   the parser skeleton itself, you may (at your option) remove this
-   special exception, which will cause the skeleton and the resulting
-   Bison output files to be licensed under the GNU General Public
-   License without this special exception.
-   
-   This special exception was added by the Free Software Foundation in
-   version 2.2 of Bison.  */
-
-/* C LALR(1) parser skeleton written by Richard Stallman, by
-   simplifying the original so-called "semantic" parser.  */
-
-/* All symbols defined below should begin with yy or YY, to avoid
-   infringing on user name space.  This should be done even for local
-   variables, as they might otherwise be expanded by user macros.
-   There are some unavoidable exceptions within include files to
-   define necessary library symbols; they are noted "INFRINGES ON
-   USER NAME SPACE" below.  */
-
-/* Identify Bison output.  */
-#define YYBISON 1
-
-/* Bison version.  */
-#define YYBISON_VERSION "2.7.12-4996"
-
-/* Skeleton name.  */
-#define YYSKELETON_NAME "yacc.c"
-
-/* Pure parsers.  */
-#define YYPURE 0
-
-/* Push parsers.  */
-#define YYPUSH 0
-
-/* Pull parsers.  */
-#define YYPULL 1
-
-
-/* Substitute the variable and function names.  */
-#define yyparse         lgparse
-#define yylex           lglex
-#define yyerror         lgerror
-#define yylval          lglval
-#define yychar          lgchar
-#define yydebug         lgdebug
-#define yynerrs         lgnerrs
-
-/* Copy the first part of user declarations.  */
-/* Line 371 of yacc.c  */
-#line 1 "lg.ypp"
- 
-    // -*- Mode : c++ -*-
-    //
-    // SUMMARY  :      
-    // USAGE    :        
-    // ORG      : 
-    // AUTHOR   : Frederic Hecht
-    // E-MAIL   : hecht at ann.jussieu.fr
-    //
-    
-    /*
-     
-     This file is part of Freefem++
-     
-     Freefem++ is free software; you can redistribute it and/or modify
-     it under the terms of the GNU Lesser General Public License as published by
-     the Free Software Foundation; either version 2.1 of the License, or
-     (at your option) any later version.
-     
-     Freefem++  is distributed in the hope that it will be useful,
-     but WITHOUT ANY WARRANTY; without even the implied warranty of
-     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-     GNU Lesser General Public License for more details.
-     
-     You should have received a copy of the GNU Lesser General Public License
-     along with Freefem++; if not, write to the Free Software
-     Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
-     */
-    
-#include "config-wrapper.h"
-#define eflval yylval 
-#include <iostream>
-#include  <complex>
-#include <string>
-  // for reset cout,cin  in windows  dll
-#ifdef _WIN32
-#include <ext/stdio_filebuf.h>
-#include <iostream>
-#include <cstdio>
-#endif
-
-#include "error.hpp"
-class Iden;
-#include "strversionnumber.hpp"
-#include "InitFunct.hpp"
-#ifdef __MWERKS__
-#ifdef __INTEL__
-#include <malloc.h>
-#else
-#include <alloca.h>
-#endif
-#endif
-#include "AFunction.hpp"
-//  to reserve space to graphical pointer function
-#include "rgraph.hpp"
-#include "RNM.hpp"
-#include "fem.hpp"
-#include "FESpacen.hpp" 
-#include "FESpace.hpp" 
-#include "MeshPoint.hpp"
-
-#include "lgfem.hpp" 
-#include "lex.hpp"
-#include "environment.hpp"
-
-    extern FILE *ThePlotStream;
-    extern KN<String> *pkarg;
-
-class Routine;
-bool load(string s);
-
- template <class R,int d> class FE;
- template <class R,int d,int i> class FE_;
-
-extern mylex *zzzfff;
-// modif FH for window to have 1 dll  for mpi and none mpi ..
-extern  void (*initparallele)(int &, char **&);
-extern  void (*init_lgparallele)();
-extern  void (*end_parallele)();
-// 
-#ifdef HAVE_LIBARPACK
-  void init_eigenvalue();
-#endif
-   
-  aType dcltype;
-const int nbembtype=10;
-aType rettype[nbembtype];
-Block * routineinblock[nbembtype]; // Add FH july 2005 pb clean on return 
-int kkembtype=-1;
-int inloopcount=0;
-Block *currentblock;
-// Add FH july 2005 
-//  problem clean variable after break,continue and return.
-const int sizeStackOfLoop=100; 
-Block * StackOfLoop[sizeStackOfLoop];
-// end ADD
-double CPUcompileInit =0;
-//class pfes;
-C_F0  fespacetype;
-bool fespacecomplex;
-int fespacedim;
-extern int UnShowAlloc;
-int ShowAlloc(const char *s,size_t &);
-inline int yylex()  {return zzzfff->scan();}
-inline int lineno() {return zzzfff->lineno();}
-
-extern bool withrgraphique;
-inline void fingraphique()
- { if(withrgraphique) 
-   { withrgraphique=false;
-    rattente(1);
-    closegraphique();
-  }}
-
-void lgerror (const char* s) ;
-
-
- // mpi ptr to function ... 
-void (*initparallele)(int &argc, char **& argv)=0 ;
-void (*init_lgparallele)()=0;
-void (*end_parallele)()=0;
-
-/* Line 371 of yacc.c  */
-#line 198 "lg.tab.cpp"
-
-# ifndef YY_NULL
-#  if defined __cplusplus && 201103L <= __cplusplus
-#   define YY_NULL nullptr
-#  else
-#   define YY_NULL 0
-#  endif
-# endif
-
-/* Enabling verbose error messages.  */
-#ifdef YYERROR_VERBOSE
-# undef YYERROR_VERBOSE
-# define YYERROR_VERBOSE 1
-#else
-# define YYERROR_VERBOSE 0
-#endif
-
-/* In a future release of Bison, this section will be replaced
-   by #include "lg.tab.hpp".  */
-#ifndef YY_LG_LG_TAB_HPP_INCLUDED
-# define YY_LG_LG_TAB_HPP_INCLUDED
-/* Enabling traces.  */
-#ifndef YYDEBUG
-# define YYDEBUG 1
-#endif
-#if YYDEBUG
-extern int lgdebug;
-#endif
-
-/* Tokens.  */
-#ifndef YYTOKENTYPE
-# define YYTOKENTYPE
-   /* Put the tokens into the symbol table, so that GDB and other debuggers
-      know about them.  */
-   enum yytokentype {
-     IF = 258,
-     ELSE = 259,
-     SET = 260,
-     GTGT = 261,
-     LTLT = 262,
-     OR = 263,
-     AND = 264,
-     NE = 265,
-     EQ = 266,
-     GE = 267,
-     LE = 268,
-     DOTSLASH = 269,
-     DOTSTAR = 270,
-     MOINSMOINS = 271,
-     PLUSPLUS = 272,
-     UNARY = 273,
-     LNUM = 274,
-     DNUM = 275,
-     CNUM = 276,
-     ID = 277,
-     FESPACEID = 278,
-     IDPARAM = 279,
-     STRING = 280,
-     ENDOFFILE = 281,
-     INCLUDE = 282,
-     LOAD = 283,
-     BIDON = 284,
-     FOR = 285,
-     WHILE = 286,
-     BREAK = 287,
-     CONTINUE = 288,
-     RETURN = 289,
-     TRY = 290,
-     CATCH = 291,
-     THROW = 292,
-     TYPE = 293,
-     FUNCTION = 294,
-     FESPACE = 295,
-     FESPACE1 = 296,
-     FESPACE3 = 297,
-     PLUSEQ = 298,
-     MOINSEQ = 299,
-     MULEQ = 300,
-     DIVEQ = 301,
-     DOTMULEQ = 302,
-     DOTDIVEQ = 303,
-     ARROW = 304,
-     BORDER = 305,
-     CURVE = 306,
-     SOLVE = 307
-   };
-#endif
-
-
-#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
-typedef union YYSTYPE
-{
-/* Line 387 of yacc.c  */
-#line 124 "lg.ypp"
- 
- double dnum;
- long lnum;
- char * str;
- char oper[8];
- CC_F0 cexp;
- Routine   *routine;
- AC_F0 args;
- aType type;
- CListOfInst cinst;
- Block * block; 
- ListOfId *clist_id;
-/* ListCatch * clist_Catchs;*/
-
-
-/* Line 387 of yacc.c  */
-#line 309 "lg.tab.cpp"
-} YYSTYPE;
-# define YYSTYPE_IS_TRIVIAL 1
-# define yystype YYSTYPE /* obsolescent; will be withdrawn */
-# define YYSTYPE_IS_DECLARED 1
-#endif
-
-extern YYSTYPE lglval;
-
-#ifdef YYPARSE_PARAM
-#if defined __STDC__ || defined __cplusplus
-int lgparse (void *YYPARSE_PARAM);
-#else
-int lgparse ();
-#endif
-#else /* ! YYPARSE_PARAM */
-#if defined __STDC__ || defined __cplusplus
-int lgparse (void);
-#else
-int lgparse ();
-#endif
-#endif /* ! YYPARSE_PARAM */
-
-#endif /* !YY_LG_LG_TAB_HPP_INCLUDED  */
-
-/* Copy the second part of user declarations.  */
-
-/* Line 390 of yacc.c  */
-#line 337 "lg.tab.cpp"
-
-#ifdef short
-# undef short
-#endif
-
-#ifdef YYTYPE_UINT8
-typedef YYTYPE_UINT8 yytype_uint8;
-#else
-typedef unsigned char yytype_uint8;
-#endif
-
-#ifdef YYTYPE_INT8
-typedef YYTYPE_INT8 yytype_int8;
-#elif (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-typedef signed char yytype_int8;
-#else
-typedef short int yytype_int8;
-#endif
-
-#ifdef YYTYPE_UINT16
-typedef YYTYPE_UINT16 yytype_uint16;
-#else
-typedef unsigned short int yytype_uint16;
-#endif
-
-#ifdef YYTYPE_INT16
-typedef YYTYPE_INT16 yytype_int16;
-#else
-typedef short int yytype_int16;
-#endif
-
-#ifndef YYSIZE_T
-# ifdef __SIZE_TYPE__
-#  define YYSIZE_T __SIZE_TYPE__
-# elif defined size_t
-#  define YYSIZE_T size_t
-# elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-#  include <stddef.h> /* INFRINGES ON USER NAME SPACE */
-#  define YYSIZE_T size_t
-# else
-#  define YYSIZE_T unsigned int
-# endif
-#endif
-
-#define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
-
-#ifndef YY_
-# if defined YYENABLE_NLS && YYENABLE_NLS
-#  if ENABLE_NLS
-#   include <libintl.h> /* INFRINGES ON USER NAME SPACE */
-#   define YY_(Msgid) dgettext ("bison-runtime", Msgid)
-#  endif
-# endif
-# ifndef YY_
-#  define YY_(Msgid) Msgid
-# endif
-#endif
-
-#ifndef __attribute__
-/* This feature is available in gcc versions 2.5 and later.  */
-# if (! defined __GNUC__ || __GNUC__ < 2 \
-      || (__GNUC__ == 2 && __GNUC_MINOR__ < 5))
-#  define __attribute__(Spec) /* empty */
-# endif
-#endif
-
-/* Suppress unused-variable warnings by "using" E.  */
-#if ! defined lint || defined __GNUC__
-# define YYUSE(E) ((void) (E))
-#else
-# define YYUSE(E) /* empty */
-#endif
-
-
-/* Identity function, used to suppress warnings about constant conditions.  */
-#ifndef lint
-# define YYID(N) (N)
-#else
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static int
-YYID (int yyi)
-#else
-static int
-YYID (yyi)
-    int yyi;
-#endif
-{
-  return yyi;
-}
-#endif
-
-#if ! defined yyoverflow || YYERROR_VERBOSE
-
-/* The parser invokes alloca or malloc; define the necessary symbols.  */
-
-# ifdef YYSTACK_USE_ALLOCA
-#  if YYSTACK_USE_ALLOCA
-#   ifdef __GNUC__
-#    define YYSTACK_ALLOC __builtin_alloca
-#   elif defined __BUILTIN_VA_ARG_INCR
-#    include <alloca.h> /* INFRINGES ON USER NAME SPACE */
-#   elif defined _AIX
-#    define YYSTACK_ALLOC __alloca
-#   elif defined _MSC_VER
-#    include <malloc.h> /* INFRINGES ON USER NAME SPACE */
-#    define alloca _alloca
-#   else
-#    define YYSTACK_ALLOC alloca
-#    if ! defined _ALLOCA_H && ! defined EXIT_SUCCESS && (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-#     include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
-      /* Use EXIT_SUCCESS as a witness for stdlib.h.  */
-#     ifndef EXIT_SUCCESS
-#      define EXIT_SUCCESS 0
-#     endif
-#    endif
-#   endif
-#  endif
-# endif
-
-# ifdef YYSTACK_ALLOC
-   /* Pacify GCC's `empty if-body' warning.  */
-#  define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0))
-#  ifndef YYSTACK_ALLOC_MAXIMUM
-    /* The OS might guarantee only one guard page at the bottom of the stack,
-       and a page size can be as small as 4096 bytes.  So we cannot safely
-       invoke alloca (N) if N exceeds 4096.  Use a slightly smaller number
-       to allow for a few compiler-allocated temporary stack slots.  */
-#   define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
-#  endif
-# else
-#  define YYSTACK_ALLOC YYMALLOC
-#  define YYSTACK_FREE YYFREE
-#  ifndef YYSTACK_ALLOC_MAXIMUM
-#   define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
-#  endif
-#  if (defined __cplusplus && ! defined EXIT_SUCCESS \
-       && ! ((defined YYMALLOC || defined malloc) \
-	     && (defined YYFREE || defined free)))
-#   include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
-#   ifndef EXIT_SUCCESS
-#    define EXIT_SUCCESS 0
-#   endif
-#  endif
-#  ifndef YYMALLOC
-#   define YYMALLOC malloc
-#   if ! defined malloc && ! defined EXIT_SUCCESS && (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */
-#   endif
-#  endif
-#  ifndef YYFREE
-#   define YYFREE free
-#   if ! defined free && ! defined EXIT_SUCCESS && (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-void free (void *); /* INFRINGES ON USER NAME SPACE */
-#   endif
-#  endif
-# endif
-#endif /* ! defined yyoverflow || YYERROR_VERBOSE */
-
-
-#if (! defined yyoverflow \
-     && (! defined __cplusplus \
-	 || (defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
-
-/* A type that is properly aligned for any stack member.  */
-union yyalloc
-{
-  yytype_int16 yyss_alloc;
-  YYSTYPE yyvs_alloc;
-};
-
-/* The size of the maximum gap between one aligned stack and the next.  */
-# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
-
-/* The size of an array large to enough to hold all stacks, each with
-   N elements.  */
-# define YYSTACK_BYTES(N) \
-     ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \
-      + YYSTACK_GAP_MAXIMUM)
-
-# define YYCOPY_NEEDED 1
-
-/* Relocate STACK from its old location to the new one.  The
-   local variables YYSIZE and YYSTACKSIZE give the old and new number of
-   elements in the stack, and YYPTR gives the new location of the
-   stack.  Advance YYPTR to a properly aligned location for the next
-   stack.  */
-# define YYSTACK_RELOCATE(Stack_alloc, Stack)				\
-    do									\
-      {									\
-	YYSIZE_T yynewbytes;						\
-	YYCOPY (&yyptr->Stack_alloc, Stack, yysize);			\
-	Stack = &yyptr->Stack_alloc;					\
-	yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
-	yyptr += yynewbytes / sizeof (*yyptr);				\
-      }									\
-    while (YYID (0))
-
-#endif
-
-#if defined YYCOPY_NEEDED && YYCOPY_NEEDED
-/* Copy COUNT objects from SRC to DST.  The source and destination do
-   not overlap.  */
-# ifndef YYCOPY
-#  if defined __GNUC__ && 1 < __GNUC__
-#   define YYCOPY(Dst, Src, Count) \
-      __builtin_memcpy (Dst, Src, (Count) * sizeof (*(Src)))
-#  else
-#   define YYCOPY(Dst, Src, Count)              \
-      do                                        \
-        {                                       \
-          YYSIZE_T yyi;                         \
-          for (yyi = 0; yyi < (Count); yyi++)   \
-            (Dst)[yyi] = (Src)[yyi];            \
-        }                                       \
-      while (YYID (0))
-#  endif
-# endif
-#endif /* !YYCOPY_NEEDED */
-
-/* YYFINAL -- State number of the termination state.  */
-#define YYFINAL  81
-/* YYLAST -- Last index in YYTABLE.  */
-#define YYLAST   1058
-
-/* YYNTOKENS -- Number of terminals.  */
-#define YYNTOKENS  78
-/* YYNNTS -- Number of nonterminals.  */
-#define YYNNTS  45
-/* YYNRULES -- Number of rules.  */
-#define YYNRULES  190
-/* YYNRULES -- Number of states.  */
-#define YYNSTATES  415
-
-/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX.  */
-#define YYUNDEFTOK  2
-#define YYMAXUTOK   307
-
-#define YYTRANSLATE(YYX)						\
-  ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
-
-/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX.  */
-static const yytype_uint8 yytranslate[] =
-{
-       0,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,    27,     2,     2,     2,    24,    12,    32,
-      34,    37,    22,    20,     5,    21,    36,    23,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,    77,    73,
-      16,     6,    17,    76,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,    35,     2,    38,    31,    33,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,    74,    10,    75,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     1,     2,     3,     4,
-       7,     8,     9,    11,    13,    14,    15,    18,    19,    25,
-      26,    28,    29,    30,    39,    40,    41,    42,    43,    44,
-      45,    46,    47,    48,    49,    50,    51,    52,    53,    54,
-      55,    56,    57,    58,    59,    60,    61,    62,    63,    64,
-      65,    66,    67,    68,    69,    70,    71,    72
-};
-
-#if YYDEBUG
-/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
-   YYRHS.  */
-static const yytype_uint16 yyprhs[] =
-{
-       0,     0,     3,     6,     8,    10,    13,    14,    16,    20,
-      23,    27,    30,    34,    37,    41,    45,    49,    55,    61,
-      66,    72,    77,    83,    88,    94,    96,   100,   102,   104,
-     106,   108,   110,   114,   119,   123,   125,   128,   131,   134,
-     138,   142,   148,   150,   155,   163,   170,   180,   185,   193,
-     203,   205,   210,   214,   218,   225,   231,   236,   243,   245,
-     247,   249,   251,   256,   258,   262,   264,   268,   271,   277,
-     282,   284,   288,   289,   294,   298,   301,   307,   308,   319,
-     320,   330,   332,   334,   336,   338,   339,   343,   345,   347,
-     350,   353,   359,   362,   364,   374,   384,   390,   396,   404,
-     408,   412,   419,   422,   425,   429,   437,   445,   448,   450,
-     454,   456,   458,   460,   462,   464,   466,   470,   474,   478,
-     482,   486,   490,   494,   496,   502,   506,   512,   514,   518,
-     522,   526,   530,   534,   538,   542,   546,   550,   554,   558,
-     562,   566,   570,   574,   578,   582,   586,   590,   592,   594,
-     598,   604,   605,   607,   609,   611,   615,   617,   621,   625,
-     629,   633,   639,   641,   645,   647,   650,   652,   656,   660,
-     663,   665,   667,   669,   671,   673,   678,   683,   690,   694,
-     698,   702,   707,   711,   716,   720,   725,   728,   731,   736,
-     740
-};
-
-/* YYRHS -- A `-1'-separated list of the rules' RHS.  */
-static const yytype_int8 yyrhs[] =
-{
-      79,     0,    -1,    80,    46,    -1,    81,    -1,   108,    -1,
-      81,   108,    -1,    -1,    84,    -1,    84,     6,   114,    -1,
-      60,    84,    -1,    60,    12,    84,    -1,    62,    84,    -1,
-      62,    12,    84,    -1,    87,    84,    -1,    87,    12,    84,
-      -1,    35,    82,    38,    -1,    82,     5,    84,    -1,    82,
-       5,    35,    82,    38,    -1,    82,     5,    84,     6,   114,
-      -1,    82,     5,    60,    84,    -1,    82,     5,    60,    12,
-      84,    -1,    82,     5,    62,    84,    -1,    82,     5,    62,
-      12,    84,    -1,    82,     5,    87,    84,    -1,    82,     5,
-      87,    12,    84,    -1,    84,    -1,    83,     5,    84,    -1,
-      42,    -1,    60,    -1,    62,    -1,    61,    -1,    42,    -1,
-      42,     6,   114,    -1,    42,    34,    86,    37,    -1,    85,
-       5,    85,    -1,   115,    -1,    60,    42,    -1,    61,    42,
-      -1,    62,    42,    -1,    42,     6,   115,    -1,    86,     5,
-     115,    -1,    86,     5,    84,     6,   115,    -1,    58,    -1,
-      58,    35,    58,    38,    -1,    58,    35,    58,    38,    35,
-      58,    38,    -1,    58,    35,    58,     5,    58,    38,    -1,
-      58,    35,    58,     5,    58,    38,    35,    58,    38,    -1,
-      58,    16,    58,    17,    -1,    58,    16,    58,    17,    35,
-      58,    38,    -1,    58,    16,    58,    17,    35,    58,     5,
-      58,    38,    -1,    42,    -1,    42,    35,   115,    38,    -1,
-      42,     6,   115,    -1,    35,    83,    38,    -1,    35,    83,
-      38,    35,   115,    38,    -1,    35,    83,    38,     6,   115,
-      -1,    42,    34,   115,    37,    -1,    35,    83,    38,    34,
-     115,    37,    -1,    60,    -1,    61,    -1,    62,    -1,    90,
-      -1,    90,    16,    58,    17,    -1,    89,    -1,    92,     5,
-      89,    -1,    88,    -1,    93,     5,    88,    -1,    91,    93,
-      -1,    91,    35,    58,    38,    92,    -1,    42,    34,    86,
-      37,    -1,    95,    -1,    96,     5,    95,    -1,    -1,    87,
-      98,    85,    73,    -1,    43,    96,    73,    -1,    94,    73,
-      -1,    59,    42,     6,   112,    73,    -1,    -1,    59,    87,
-      42,    34,    82,    37,    99,    74,    81,    75,    -1,    -1,
-      59,    42,    34,    82,    37,   100,     6,   114,    73,    -1,
-      74,    -1,    75,    -1,    50,    -1,    51,    -1,    -1,    87,
-     106,    85,    -1,    55,    -1,    73,    -1,    47,    45,    -1,
-      48,    45,    -1,   107,    74,    81,    75,   109,    -1,   112,
-      73,    -1,    97,    -1,   103,    34,   112,    73,   112,    73,
-     112,    37,   108,    -1,   103,    34,   105,    73,   112,    73,
-     112,    37,   108,    -1,   104,    34,   112,    37,   108,    -1,
-       3,    34,   112,    37,   108,    -1,     3,    34,   112,    37,
-     108,     4,   108,    -1,   101,    81,   102,    -1,    70,    42,
-     111,    -1,    70,    42,    35,   119,    38,    73,    -1,    52,
-      73,    -1,    53,    73,    -1,    54,   112,    73,    -1,    56,
-      34,    36,    36,    36,    37,   108,    -1,    34,    42,     6,
-     112,     5,   112,    37,    -1,   110,   108,    -1,   114,    -1,
-     112,     5,   112,    -1,    21,    -1,    20,    -1,    27,    -1,
-      29,    -1,    28,    -1,   115,    -1,   115,     6,   114,    -1,
-     115,    63,   114,    -1,   115,    64,   114,    -1,   115,    65,
-     114,    -1,   115,    66,   114,    -1,   115,    67,   114,    -1,
-     115,    68,   114,    -1,   116,    -1,   116,    76,   116,    77,
-     116,    -1,   116,    77,   116,    -1,   116,    77,   116,    77,
-     116,    -1,   120,    -1,   116,    22,   116,    -1,   116,    26,
-     116,    -1,   116,    25,   116,    -1,   116,    23,   116,    -1,
-     116,    24,   116,    -1,   116,    20,   116,    -1,   116,    21,
-     116,    -1,   116,     9,   116,    -1,   116,     8,   116,    -1,
-     116,    12,   116,    -1,   116,    13,   116,    -1,   116,    10,
-     116,    -1,   116,    11,   116,    -1,   116,    16,   116,    -1,
-     116,    19,   116,    -1,   116,    17,   116,    -1,   116,    18,
-     116,    -1,   116,    15,   116,    -1,   116,    14,   116,    -1,
-     116,    -1,    77,    -1,   116,    77,   116,    -1,   116,    77,
-     116,    77,   116,    -1,    -1,    60,    -1,    61,    -1,    62,
-      -1,    84,     6,   115,    -1,   117,    -1,   118,     5,    60,
-      -1,   118,     5,    61,    -1,   118,     5,    62,    -1,   118,
-       5,   117,    -1,   118,     5,    84,     6,   115,    -1,   114,
-      -1,   119,     5,   114,    -1,   121,    -1,   113,   121,    -1,
-     122,    -1,   122,    31,   120,    -1,   122,    33,   120,    -1,
-     122,    32,    -1,    42,    -1,    39,    -1,    40,    -1,    41,
-      -1,    45,    -1,   122,    34,   118,    37,    -1,   122,    35,
-     117,    38,    -1,   122,    35,   117,     5,   117,    38,    -1,
-     122,    35,    38,    -1,   122,    36,    42,    -1,    60,    36,
-      42,    -1,    60,    34,   118,    37,    -1,    61,    36,    42,
-      -1,    61,    34,   118,    37,    -1,    62,    36,    42,    -1,
-      62,    34,   118,    37,    -1,   122,    29,    -1,   122,    28,
-      -1,    58,    34,   112,    37,    -1,    34,   112,    37,    -1,
-      35,   119,    38,    -1
-};
-
-/* YYRLINE[YYN] -- source line where rule number YYN was defined.  */
-static const yytype_uint16 yyrline[] =
-{
-       0,   257,   257,   299,   302,   303,   306,   307,   308,   309,
-     310,   311,   312,   313,   314,   315,   316,   317,   318,   319,
-     320,   321,   322,   323,   324,   327,   328,   331,   331,   331,
-     331,   333,   334,   335,   337,   344,   345,   346,   347,   348,
-     349,   350,   353,   354,   355,   356,   357,   358,   359,   360,
-     367,   368,   369,   370,   371,   372,   375,   376,   380,   380,
-     380,   381,   382,   387,   388,   390,   391,   393,   394,   398,
-     401,   402,   405,   405,   406,   407,   408,   410,   409,   426,
-     425,   434,   435,   437,   439,   444,   444,   447,   449,   450,
-     451,   452,   453,   454,   455,   456,   460,   461,   462,   463,
-     465,   467,   470,   474,   478,   485,   488,   494,   500,   501,
-     506,   507,   508,   509,   510,   514,   515,   516,   517,   518,
-     519,   520,   521,   526,   527,   528,   529,   533,   534,   535,
-     536,   537,   538,   539,   540,   541,   542,   543,   544,   545,
-     546,   547,   548,   549,   550,   551,   552,   557,   558,   559,
-     560,   564,   565,   566,   567,   568,   569,   570,   571,   572,
-     573,   574,   577,   578,   582,   583,   586,   587,   588,   589,
-     593,   594,   595,   596,   597,   598,   599,   600,   601,   602,
-     603,   604,   605,   606,   607,   608,   609,   610,   611,   620,
-     621
-};
-#endif
-
-#if YYDEBUG || YYERROR_VERBOSE || 0
-/* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
-   First, the terminals, then, starting at YYNTOKENS, nonterminals.  */
-static const char *const yytname[] =
-{
-  "$end", "error", "$undefined", "IF", "ELSE", "','", "'='", "SET",
-  "GTGT", "LTLT", "'|'", "OR", "'&'", "AND", "NE", "EQ", "'<'", "'>'",
-  "GE", "LE", "'+'", "'-'", "'*'", "'/'", "'%'", "DOTSLASH", "DOTSTAR",
-  "'!'", "MOINSMOINS", "PLUSPLUS", "UNARY", "'^'", "'\\''", "'_'", "'('",
-  "'['", "'.'", "')'", "']'", "LNUM", "DNUM", "CNUM", "ID", "FESPACEID",
-  "IDPARAM", "STRING", "ENDOFFILE", "INCLUDE", "LOAD", "BIDON", "FOR",
-  "WHILE", "BREAK", "CONTINUE", "RETURN", "TRY", "CATCH", "THROW", "TYPE",
-  "FUNCTION", "FESPACE", "FESPACE1", "FESPACE3", "PLUSEQ", "MOINSEQ",
-  "MULEQ", "DIVEQ", "DOTMULEQ", "DOTDIVEQ", "ARROW", "BORDER", "CURVE",
-  "SOLVE", "';'", "'{'", "'}'", "'?'", "':'", "$accept", "start", "input",
-  "instructions", "list_of_id_args", "list_of_id1", "id", "list_of_dcls",
-  "parameters_list", "type_of_dcl", "ID_space", "ID_array_space",
-  "fespace123", "fespace", "spaceIDa", "spaceIDb", "spaceIDs",
-  "fespace_def", "fespace_def_list", "declaration", "$@1", "$@2", "$@3",
-  "begin", "end", "for_loop", "while_loop", "declaration_for", "$@4",
-  "try", "instruction", "catchs", "bornes", "border_expr", "Expr", "unop",
-  "no_comma_expr", "no_set_expr", "no_ternary_expr", "sub_script_expr",
-  "parameters", "array", "unary_expr", "pow_expr", "primary", YY_NULL
-};
-#endif
-
-# ifdef YYPRINT
-/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
-   token YYLEX-NUM.  */
-static const yytype_uint16 yytoknum[] =
-{
-       0,   256,   257,   258,   259,    44,    61,   260,   261,   262,
-     124,   263,    38,   264,   265,   266,    60,    62,   267,   268,
-      43,    45,    42,    47,    37,   269,   270,    33,   271,   272,
-     273,    94,    39,    95,    40,    91,    46,    41,    93,   274,
-     275,   276,   277,   278,   279,   280,   281,   282,   283,   284,
-     285,   286,   287,   288,   289,   290,   291,   292,   293,   294,
-     295,   296,   297,   298,   299,   300,   301,   302,   303,   304,
-     305,   306,   307,    59,   123,   125,    63,    58
-};
-# endif
-
-/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives.  */
-static const yytype_uint8 yyr1[] =
-{
-       0,    78,    79,    80,    81,    81,    82,    82,    82,    82,
-      82,    82,    82,    82,    82,    82,    82,    82,    82,    82,
-      82,    82,    82,    82,    82,    83,    83,    84,    84,    84,
-      84,    85,    85,    85,    85,    86,    86,    86,    86,    86,
-      86,    86,    87,    87,    87,    87,    87,    87,    87,    87,
-      88,    88,    88,    88,    88,    88,    89,    89,    90,    90,
-      90,    91,    91,    92,    92,    93,    93,    94,    94,    95,
-      96,    96,    98,    97,    97,    97,    97,    99,    97,   100,
-      97,   101,   102,   103,   104,   106,   105,   107,   108,   108,
-     108,   108,   108,   108,   108,   108,   108,   108,   108,   108,
-     108,   108,   108,   108,   108,   109,   110,   111,   112,   112,
-     113,   113,   113,   113,   113,   114,   114,   114,   114,   114,
-     114,   114,   114,   115,   115,   115,   115,   116,   116,   116,
-     116,   116,   116,   116,   116,   116,   116,   116,   116,   116,
-     116,   116,   116,   116,   116,   116,   116,   117,   117,   117,
-     117,   118,   118,   118,   118,   118,   118,   118,   118,   118,
-     118,   118,   119,   119,   120,   120,   121,   121,   121,   121,
-     122,   122,   122,   122,   122,   122,   122,   122,   122,   122,
-     122,   122,   122,   122,   122,   122,   122,   122,   122,   122,
-     122
-};
-
-/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN.  */
-static const yytype_uint8 yyr2[] =
-{
-       0,     2,     2,     1,     1,     2,     0,     1,     3,     2,
-       3,     2,     3,     2,     3,     3,     3,     5,     5,     4,
-       5,     4,     5,     4,     5,     1,     3,     1,     1,     1,
-       1,     1,     3,     4,     3,     1,     2,     2,     2,     3,
-       3,     5,     1,     4,     7,     6,     9,     4,     7,     9,
-       1,     4,     3,     3,     6,     5,     4,     6,     1,     1,
-       1,     1,     4,     1,     3,     1,     3,     2,     5,     4,
-       1,     3,     0,     4,     3,     2,     5,     0,    10,     0,
-       9,     1,     1,     1,     1,     0,     3,     1,     1,     2,
-       2,     5,     2,     1,     9,     9,     5,     5,     7,     3,
-       3,     6,     2,     2,     3,     7,     7,     2,     1,     3,
-       1,     1,     1,     1,     1,     1,     3,     3,     3,     3,
-       3,     3,     3,     1,     5,     3,     5,     1,     3,     3,
-       3,     3,     3,     3,     3,     3,     3,     3,     3,     3,
-       3,     3,     3,     3,     3,     3,     3,     1,     1,     3,
-       5,     0,     1,     1,     1,     3,     1,     3,     3,     3,
-       3,     5,     1,     3,     1,     2,     1,     3,     3,     2,
-       1,     1,     1,     1,     1,     4,     4,     6,     3,     3,
-       3,     4,     3,     4,     3,     4,     2,     2,     4,     3,
-       3
-};
-
-/* YYDEFACT[STATE-NAME] -- Default reduction number in state STATE-NUM.
-   Performed when YYTABLE doesn't specify something else to do.  Zero
-   means the default is an error.  */
-static const yytype_uint8 yydefact[] =
-{
-       0,     0,   111,   110,   112,   114,   113,     0,     0,   171,
-     172,   173,   170,     0,   174,     0,     0,    83,    84,     0,
-       0,     0,    87,    42,     0,    58,    59,    60,     0,    88,
-      81,     0,     0,     3,    72,    61,     0,     0,    93,     0,
-       0,     0,     0,     4,     0,     0,   108,   115,   123,   127,
-     164,   166,     0,     0,     0,     0,     0,     0,   162,     0,
-       0,    70,     0,    89,    90,   102,   103,     0,     0,     0,
-       0,     0,    42,     0,   151,     0,   151,     0,   151,     0,
-       0,     1,     2,     5,     0,     0,     0,    50,    65,    67,
-      75,     0,     0,     0,     0,     0,    92,   165,     0,     0,
-       0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
-       0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
-       0,     0,     0,     0,     0,     0,   187,   186,     0,   169,
-       0,   151,     0,     0,     0,   189,     0,   190,     0,     0,
-      74,   104,     0,     0,     0,     0,     6,     0,   170,   152,
-     153,   154,   148,     0,   147,   156,     0,   180,     0,   182,
-       0,   184,     0,     0,     0,   100,    31,     0,     0,    27,
-       0,    28,    30,    29,     0,    25,     0,     0,     0,    82,
-      99,    85,     0,     0,     0,     0,   109,   116,   117,   118,
-     119,   120,   121,   122,   136,   135,   139,   140,   137,   138,
-     146,   145,   141,   143,   144,   142,   133,   134,   128,   131,
-     132,   130,   129,     0,   125,   167,   168,     0,   178,     0,
-     179,     0,   163,   170,     0,     0,     0,     0,    35,    71,
-      47,   188,     0,    43,     0,     6,    28,    29,     0,     7,
-       0,     6,     0,     0,     0,   181,   183,   185,     0,     0,
-     107,     0,     0,     0,    73,    62,     0,     0,    53,    52,
-       0,     0,    66,     0,     0,     0,     0,     0,     0,     0,
-     175,     0,   176,    97,     0,    36,    37,    38,     0,    69,
-       0,     0,     0,    76,     0,     0,     9,     0,    11,     0,
-      79,     0,     0,    13,     0,   155,   149,   157,   158,   159,
-       0,   160,     0,     0,    32,     0,    34,     0,     0,    63,
-      68,    26,     0,     0,    51,    86,     0,     0,    96,     0,
-      91,   124,   126,     0,     0,    39,    28,    30,    29,     0,
-      40,     0,    45,     0,    15,    10,    12,     6,    28,    29,
-      16,     0,     0,     8,    14,    77,     0,     0,     0,   101,
-      33,     0,     0,     0,    55,     0,     0,     0,     0,   177,
-      98,     0,     0,    48,     0,    44,     0,     0,    19,     0,
-      21,     0,     0,    23,     0,     0,   150,   161,     0,     0,
-       0,    64,    54,     0,     0,     0,    41,     0,     0,    17,
-      20,    22,    18,    24,     0,     0,   109,     0,    56,     0,
-       0,     0,    49,    46,    80,     0,   106,     0,    95,    94,
-       0,    78,    57,     0,   105
-};
-
-/* YYDEFGOTO[NTERM-NUM].  */
-static const yytype_int16 yydefgoto[] =
-{
-      -1,    31,    32,    33,   238,   174,   153,   167,   227,    34,
-      88,   309,    35,    36,   310,    89,    37,    61,    62,    38,
-      84,   375,   342,    39,   180,    40,    41,   182,   263,    42,
-      43,   320,   164,   165,    44,    45,    46,    47,    48,   155,
-     156,    59,    49,    50,    51
-};
-
-/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
-   STATE-NUM.  */
-#define YYPACT_NINF -230
-static const yytype_int16 yypact[] =
-{
-     576,    20,  -230,  -230,  -230,  -230,  -230,   222,   222,  -230,
-    -230,  -230,  -230,    81,  -230,     1,    90,  -230,  -230,    97,
-     132,   222,  -230,   212,   150,    21,   110,   201,    99,  -230,
-    -230,   182,   166,   576,  -230,   199,    24,   156,  -230,   576,
-     204,   221,   184,  -230,     2,   945,  -230,    39,    15,  -230,
-    -230,   791,   222,   231,    21,   110,   201,   112,  -230,     5,
-     232,  -230,     3,  -230,  -230,  -230,  -230,     4,   217,   222,
-     218,   114,   209,   236,   732,   254,   732,   260,   732,   261,
-     206,  -230,  -230,  -230,   263,   249,     7,    38,  -230,   303,
-    -230,   355,   864,   222,   576,   222,  -230,  -230,   222,   222,
-     222,   222,   222,   222,   222,   222,   222,   222,   222,   222,
-     222,   222,   222,   222,   222,   222,   222,   222,   222,   222,
-     222,   222,   222,   222,   222,   222,  -230,  -230,   222,  -230,
-     222,   732,   688,   268,   119,  -230,   222,  -230,   900,    81,
-    -230,  -230,   297,   129,    46,   222,   251,   281,   311,    14,
-      36,   151,  -230,   312,   423,  -230,   154,  -230,   169,  -230,
-     170,  -230,   277,   222,   576,  -230,   198,     6,   332,  -230,
-     282,  -230,  -230,  -230,    48,  -230,   222,   222,   136,  -230,
-    -230,  -230,   280,     8,   172,   454,  -230,  -230,  -230,  -230,
-    -230,  -230,  -230,  -230,  1017,  1017,  1032,  1032,   447,   447,
-     762,   762,   339,   339,   339,   339,   320,   320,  -230,  -230,
-    -230,  -230,  -230,   643,   662,  -230,  -230,   174,  -230,    89,
-    -230,   576,  -230,   344,   243,   253,   264,   176,  -230,  -230,
-     319,  -230,   298,   334,     9,   251,    51,    68,   179,   349,
-      77,   251,   222,   222,   776,  -230,  -230,  -230,   364,   104,
-    -230,   222,   900,   263,  -230,  -230,   188,   192,   126,  -230,
-     336,   192,  -230,   263,   222,   222,   576,   321,   222,   222,
-    -230,   820,  -230,   374,   222,  -230,  -230,  -230,   936,  -230,
-     323,   341,   327,  -230,   109,   192,  -230,   192,  -230,   676,
-    -230,   222,   192,  -230,   181,  -230,   681,    14,    36,   151,
-     380,  -230,   222,   314,  -230,   185,  -230,   192,   354,  -230,
-     386,  -230,   222,   222,  -230,   387,    10,    12,  -230,   359,
-    -230,  1000,  1000,   361,   576,  -230,    21,   110,   201,   395,
-    -230,   113,   369,   373,  -230,  -230,  -230,   251,   103,   138,
-     406,   141,   412,  -230,  -230,  -230,   222,   222,   414,  -230,
-    -230,   116,   222,   188,  -230,   382,   222,   222,   385,  -230,
-    -230,   222,   365,  -230,   366,  -230,   117,   192,  -230,   192,
-    -230,   222,   192,  -230,   222,   348,  1000,  -230,   222,   392,
-     390,  -230,  -230,   189,   190,   415,  -230,   416,   417,  -230,
-    -230,  -230,  -230,  -230,   377,   576,   419,   222,  -230,   576,
-     576,   422,  -230,  -230,  -230,   516,  -230,   439,  -230,  -230,
-     440,  -230,  -230,   576,  -230
-};
-
-/* YYPGOTO[NTERM-NUM].  */
-static const yytype_int16 yypgoto[] =
-{
-    -230,  -230,  -230,   -38,  -229,   145,   -68,  -201,   226,   -21,
-     275,   127,  -230,  -230,  -230,  -230,  -230,   340,  -230,  -230,
-    -230,  -230,  -230,  -230,  -230,  -230,  -230,  -230,  -230,  -230,
-     -33,  -230,  -230,  -230,    -5,  -230,    -3,  -116,   216,  -128,
-     -57,   328,   144,   441,  -230
-};
-
-/* YYTABLE[YYPACT[STATE-NUM]].  What to do in state STATE-NUM.  If
-   positive, shift that token.  If negative, reduce the rule which
-   number is the opposite.  If YYTABLE_NINF, syntax error.  */
-#define YYTABLE_NINF -31
-static const yytype_int16 yytable[] =
-{
-      83,    91,    57,    73,   219,    58,   284,    95,   139,    95,
-     136,   253,   294,    95,    95,    95,    67,    95,   175,   158,
-     -28,   160,   228,   105,   106,   107,   108,   109,   110,   111,
-     112,   113,   114,   115,   116,   117,   118,   119,   120,   121,
-     122,   123,   -30,   137,   176,    98,    63,   134,    74,   169,
-      75,   232,   306,   257,    52,    74,   185,    75,    83,    86,
-     259,   260,   315,   285,   143,   170,    87,   171,   172,   173,
-      76,   181,    77,   177,   217,    96,   140,   141,   239,   254,
-     287,   265,   283,   356,   233,   357,   258,   183,   184,   292,
-     186,   124,   125,   169,   271,   187,   188,   189,   190,   191,
-     192,   193,    99,   100,   101,   102,   103,   104,   366,   136,
-     169,   171,   172,   173,   289,   367,   301,    95,   362,   169,
-     145,   257,   289,    60,    95,   240,   295,   272,   171,   172,
-     173,   250,   312,   222,    95,    64,   228,   171,   172,   173,
-     234,    80,   303,   323,    76,   169,    77,   334,   146,   135,
-     369,   363,    83,   372,   379,   389,   221,   -29,   325,   244,
-      58,   313,   330,   171,   172,   173,   231,   239,   286,   288,
-      65,   261,   293,   239,   244,   244,   300,    95,    87,   244,
-     169,   278,    81,   169,   289,    78,   289,    79,   273,   311,
-     278,   245,    71,   175,    95,    95,   354,   355,   171,   172,
-     173,   171,   172,   173,   251,    66,   246,   247,    72,   266,
-     329,   270,    82,   279,   240,    85,   290,   335,   345,   336,
-     240,   340,   350,   307,   344,    68,   399,   400,    68,    90,
-     308,   377,   252,   318,   169,    78,   380,    79,    92,   175,
-     162,   163,     2,     3,    70,   386,    69,    70,   304,     4,
-       5,     6,   171,   172,   173,    93,     7,     8,    94,   316,
-     317,     9,    10,    11,    12,    69,   138,    14,   341,   239,
-     368,   370,   215,   373,   216,   142,   144,    74,   147,    75,
-      53,   407,    54,    55,    56,   275,   235,    76,   343,    77,
-     154,   360,   154,   169,   154,   276,   157,   348,    78,   390,
-      79,   391,   159,   161,   393,   166,   277,   168,   178,    72,
-     220,   236,   172,   237,   230,   241,   240,   -27,   242,   248,
-     256,   194,   195,   196,   197,   198,   199,   200,   201,   202,
-     203,   204,   205,   206,   207,   208,   209,   210,   211,   212,
-     213,   214,   119,   120,   121,   122,   123,   154,   154,   255,
-     274,   383,   384,   264,   280,   291,   281,   405,     1,   117,
-     118,   119,   120,   121,   122,   123,   408,   409,   392,   282,
-     302,   394,    83,   396,   314,     2,     3,   319,   324,   332,
-     414,   331,     4,     5,     6,   333,   347,   349,   352,     7,
-       8,   353,   253,   358,     9,    10,    11,    12,    13,   359,
-      14,   361,    15,    16,   364,    17,    18,    19,    20,    21,
-      22,   365,   371,    23,    24,    25,    26,    27,   374,   378,
-     382,   385,   395,   387,   388,    28,   397,   398,    29,    30,
-     179,   105,   106,   107,   108,   109,   110,   111,   112,   113,
-     114,   115,   116,   117,   118,   119,   120,   121,   122,   123,
-     404,   401,   351,   262,   402,   403,   406,     1,   410,   296,
-     154,   111,   112,   113,   114,   115,   116,   117,   118,   119,
-     120,   121,   122,   123,     2,     3,   412,   413,   305,   229,
-     381,     4,     5,     6,   321,   322,    97,   154,     7,     8,
-       0,   249,     0,     9,    10,    11,    12,    13,     0,    14,
-     243,    15,    16,     0,    17,    18,    19,    20,    21,    22,
-       0,     0,    23,    24,    25,    26,    27,     0,     0,     1,
-       0,     0,     0,     0,    28,     0,     0,    29,    30,   267,
-       0,     0,     0,     0,     0,     0,     2,     3,     0,     0,
-       0,     0,     0,     4,     5,     6,     0,     0,     0,     0,
-       7,     8,     0,     0,     0,     9,    10,    11,    12,    13,
-       0,    14,   376,    15,    16,     0,    17,    18,    19,    20,
-      21,    22,     0,     0,    23,    24,    25,    26,    27,     1,
-       0,     0,     0,     0,     0,     0,    28,     0,     0,    29,
-      30,   411,     0,     0,     0,     0,     2,     3,     0,     0,
-       0,     0,     0,     4,     5,     6,     0,     0,     0,     0,
-       7,     8,     0,     0,     0,     9,    10,    11,    12,    13,
-       0,    14,     0,    15,    16,     0,    17,    18,    19,    20,
-      21,    22,     0,     0,    23,    24,    25,    26,    27,     0,
-       0,     0,     0,     0,     0,     0,    28,     0,     0,    29,
-      30,   105,   106,   107,   108,   109,   110,   111,   112,   113,
-     114,   115,   116,   117,   118,   119,   120,   121,   122,   123,
-     105,   106,   107,   108,   109,   110,   111,   112,   113,   114,
-     115,   116,   117,   118,   119,   120,   121,   122,   123,   105,
-     106,   107,   108,   109,   110,   111,   112,   113,   114,   115,
-     116,   117,   118,   119,   120,   121,   122,   123,     2,     3,
-       0,   337,     0,     0,     0,     4,     5,     6,   169,     0,
-     268,     0,     7,     8,     0,     0,   218,     9,    10,    11,
-      12,     0,     0,    14,    72,     0,   338,   172,   339,   269,
-       0,     0,     0,     0,     0,     0,    53,     0,    54,    55,
-      56,     0,     2,     3,     0,     0,     0,     0,   346,     4,
-       5,     6,     0,     0,     0,   152,     7,     8,     0,     0,
-       0,     9,    10,    11,   148,     0,     0,    14,   113,   114,
-     115,   116,   117,   118,   119,   120,   121,   122,   123,     0,
-      53,     0,   149,   150,   151,     0,     2,     3,     0,     0,
-       0,     0,     0,     4,     5,     6,     0,     0,     0,   152,
-       7,     8,     0,     0,     0,     9,    10,    11,   148,   126,
-     127,    14,   128,   129,   130,   131,   132,   133,     0,     0,
-       0,     0,     0,     0,    53,     0,   297,   298,   299,     0,
-       2,     3,     0,     0,     0,     0,     0,     4,     5,     6,
-       0,     0,     0,   152,     7,     8,     0,     0,     0,     9,
-      10,    11,    12,     0,     0,    14,     0,     0,     0,     0,
-       0,     0,     0,     0,     0,     0,     0,     0,    53,     0,
-      54,    55,    56,     0,     2,     3,     0,     0,     0,     0,
-       0,     4,     5,     6,     0,     0,     0,   152,     7,     8,
-       0,     0,     0,     9,    10,    11,    12,     0,     0,    14,
-       0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
-       2,     3,    23,     0,    54,    55,    56,     4,     5,     6,
-       0,     0,     0,     0,     7,     8,     0,     0,     0,     9,
-      10,    11,   223,     0,     0,    14,     0,     0,     0,     0,
-       0,     0,     0,     0,     0,     0,     2,     3,    53,     0,
-     224,   225,   226,     4,     5,     6,     0,     0,     0,     0,
-       7,     8,     0,     0,     0,     9,    10,    11,   148,     7,
-       8,    14,     0,     0,     9,    10,    11,    12,     0,     0,
-      14,     0,     0,     0,    53,     0,   326,   327,   328,     0,
-       0,     0,     0,    53,     0,    54,    55,    56,   105,   106,
-     107,   108,   109,   110,   111,   112,   113,   114,   115,   116,
-     117,   118,   119,   120,   121,   122,   123,   107,   108,   109,
-     110,   111,   112,   113,   114,   115,   116,   117,   118,   119,
-     120,   121,   122,   123,   109,   110,   111,   112,   113,   114,
-     115,   116,   117,   118,   119,   120,   121,   122,   123
-};
-
-#define yypact_value_is_default(Yystate) \
-  (!!((Yystate) == (-230)))
-
-#define yytable_value_is_error(Yytable_value) \
-  YYID (0)
-
-static const yytype_int16 yycheck[] =
-{
-      33,    39,     7,    24,   132,     8,   235,     5,     5,     5,
-       5,     5,   241,     5,     5,     5,    21,     5,    86,    76,
-       6,    78,   138,     8,     9,    10,    11,    12,    13,    14,
-      15,    16,    17,    18,    19,    20,    21,    22,    23,    24,
-      25,    26,     6,    38,     6,     6,    45,    52,    34,    42,
-      36,     5,   253,     5,    34,    34,    94,    36,    91,    35,
-     176,   177,   263,    12,    69,    58,    42,    60,    61,    62,
-      34,    92,    36,    35,   131,    73,    73,    73,   146,    73,
-      12,    73,    73,    73,    38,    73,    38,    92,    93,    12,
-      95,    76,    77,    42,     5,    98,    99,   100,   101,   102,
-     103,   104,    63,    64,    65,    66,    67,    68,   337,     5,
-      42,    60,    61,    62,     5,    12,   244,     5,     5,    42,
-       6,     5,     5,    42,     5,   146,   242,    38,    60,    61,
-      62,   164,     6,   136,     5,    45,   252,    60,    61,    62,
-     145,    42,    38,   271,    34,    42,    36,    38,    34,    37,
-      12,    38,   185,    12,    38,    38,    37,     6,   274,     5,
-     163,    35,   278,    60,    61,    62,    37,   235,   236,   237,
-      73,    35,   240,   241,     5,     5,   244,     5,    42,     5,
-      42,     5,     0,    42,     5,    34,     5,    36,   221,   257,
-       5,    37,    42,   261,     5,     5,   312,   313,    60,    61,
-      62,    60,    61,    62,     6,    73,    37,    37,    58,    37,
-     278,    37,    46,    37,   235,    16,    37,   285,    37,   287,
-     241,   289,    37,    35,   292,    16,    37,    37,    16,    73,
-      42,   347,    34,   266,    42,    34,   352,    36,    34,   307,
-      34,    35,    20,    21,    35,   361,    34,    35,   251,    27,
-      28,    29,    60,    61,    62,    34,    34,    35,    74,   264,
-     265,    39,    40,    41,    42,    34,    34,    45,   289,   337,
-     338,   339,   128,   341,   130,    58,    58,    34,    42,    36,
-      58,   397,    60,    61,    62,    42,    35,    34,   291,    36,
-      74,   324,    76,    42,    78,    42,    42,   302,    34,   367,
-      36,   369,    42,    42,   372,    42,    42,    58,     5,    58,
-      42,    60,    61,    62,    17,    34,   337,     6,     6,    42,
-      38,   105,   106,   107,   108,   109,   110,   111,   112,   113,
-     114,   115,   116,   117,   118,   119,   120,   121,   122,   123,
-     124,   125,    22,    23,    24,    25,    26,   131,   132,    17,
-       6,   356,   357,    73,    35,     6,    58,   395,     3,    20,
-      21,    22,    23,    24,    25,    26,   399,   400,   371,    35,
-       6,   374,   405,   378,    38,    20,    21,    56,     4,    38,
-     413,    58,    27,    28,    29,    58,     6,    73,    34,    34,
-      35,     5,     5,    34,    39,    40,    41,    42,    43,    38,
-      45,     6,    47,    48,    35,    50,    51,    52,    53,    54,
-      55,    38,     6,    58,    59,    60,    61,    62,     6,     5,
-      38,    36,    74,    58,    58,    70,    34,    37,    73,    74,
-      75,     8,     9,    10,    11,    12,    13,    14,    15,    16,
-      17,    18,    19,    20,    21,    22,    23,    24,    25,    26,
-      73,    36,   307,   178,    38,    38,    37,     3,    36,   243,
-     244,    14,    15,    16,    17,    18,    19,    20,    21,    22,
-      23,    24,    25,    26,    20,    21,    37,    37,   252,   139,
-     353,    27,    28,    29,   268,   269,    45,   271,    34,    35,
-      -1,   163,    -1,    39,    40,    41,    42,    43,    -1,    45,
-      77,    47,    48,    -1,    50,    51,    52,    53,    54,    55,
-      -1,    -1,    58,    59,    60,    61,    62,    -1,    -1,     3,
-      -1,    -1,    -1,    -1,    70,    -1,    -1,    73,    74,    75,
-      -1,    -1,    -1,    -1,    -1,    -1,    20,    21,    -1,    -1,
-      -1,    -1,    -1,    27,    28,    29,    -1,    -1,    -1,    -1,
-      34,    35,    -1,    -1,    -1,    39,    40,    41,    42,    43,
-      -1,    45,   346,    47,    48,    -1,    50,    51,    52,    53,
-      54,    55,    -1,    -1,    58,    59,    60,    61,    62,     3,
-      -1,    -1,    -1,    -1,    -1,    -1,    70,    -1,    -1,    73,
-      74,    75,    -1,    -1,    -1,    -1,    20,    21,    -1,    -1,
-      -1,    -1,    -1,    27,    28,    29,    -1,    -1,    -1,    -1,
-      34,    35,    -1,    -1,    -1,    39,    40,    41,    42,    43,
-      -1,    45,    -1,    47,    48,    -1,    50,    51,    52,    53,
-      54,    55,    -1,    -1,    58,    59,    60,    61,    62,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    70,    -1,    -1,    73,
-      74,     8,     9,    10,    11,    12,    13,    14,    15,    16,
-      17,    18,    19,    20,    21,    22,    23,    24,    25,    26,
-       8,     9,    10,    11,    12,    13,    14,    15,    16,    17,
-      18,    19,    20,    21,    22,    23,    24,    25,    26,     8,
-       9,    10,    11,    12,    13,    14,    15,    16,    17,    18,
-      19,    20,    21,    22,    23,    24,    25,    26,    20,    21,
-      -1,    35,    -1,    -1,    -1,    27,    28,    29,    42,    -1,
-      77,    -1,    34,    35,    -1,    -1,    38,    39,    40,    41,
-      42,    -1,    -1,    45,    58,    -1,    60,    61,    62,    77,
-      -1,    -1,    -1,    -1,    -1,    -1,    58,    -1,    60,    61,
-      62,    -1,    20,    21,    -1,    -1,    -1,    -1,    77,    27,
-      28,    29,    -1,    -1,    -1,    77,    34,    35,    -1,    -1,
-      -1,    39,    40,    41,    42,    -1,    -1,    45,    16,    17,
-      18,    19,    20,    21,    22,    23,    24,    25,    26,    -1,
-      58,    -1,    60,    61,    62,    -1,    20,    21,    -1,    -1,
-      -1,    -1,    -1,    27,    28,    29,    -1,    -1,    -1,    77,
-      34,    35,    -1,    -1,    -1,    39,    40,    41,    42,    28,
-      29,    45,    31,    32,    33,    34,    35,    36,    -1,    -1,
-      -1,    -1,    -1,    -1,    58,    -1,    60,    61,    62,    -1,
-      20,    21,    -1,    -1,    -1,    -1,    -1,    27,    28,    29,
-      -1,    -1,    -1,    77,    34,    35,    -1,    -1,    -1,    39,
-      40,    41,    42,    -1,    -1,    45,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    58,    -1,
-      60,    61,    62,    -1,    20,    21,    -1,    -1,    -1,    -1,
-      -1,    27,    28,    29,    -1,    -1,    -1,    77,    34,    35,
-      -1,    -1,    -1,    39,    40,    41,    42,    -1,    -1,    45,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
-      20,    21,    58,    -1,    60,    61,    62,    27,    28,    29,
-      -1,    -1,    -1,    -1,    34,    35,    -1,    -1,    -1,    39,
-      40,    41,    42,    -1,    -1,    45,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    20,    21,    58,    -1,
-      60,    61,    62,    27,    28,    29,    -1,    -1,    -1,    -1,
-      34,    35,    -1,    -1,    -1,    39,    40,    41,    42,    34,
-      35,    45,    -1,    -1,    39,    40,    41,    42,    -1,    -1,
-      45,    -1,    -1,    -1,    58,    -1,    60,    61,    62,    -1,
-      -1,    -1,    -1,    58,    -1,    60,    61,    62,     8,     9,
-      10,    11,    12,    13,    14,    15,    16,    17,    18,    19,
-      20,    21,    22,    23,    24,    25,    26,    10,    11,    12,
-      13,    14,    15,    16,    17,    18,    19,    20,    21,    22,
-      23,    24,    25,    26,    12,    13,    14,    15,    16,    17,
-      18,    19,    20,    21,    22,    23,    24,    25,    26
-};
-
-/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
-   symbol of state STATE-NUM.  */
-static const yytype_uint8 yystos[] =
-{
-       0,     3,    20,    21,    27,    28,    29,    34,    35,    39,
-      40,    41,    42,    43,    45,    47,    48,    50,    51,    52,
-      53,    54,    55,    58,    59,    60,    61,    62,    70,    73,
-      74,    79,    80,    81,    87,    90,    91,    94,    97,   101,
-     103,   104,   107,   108,   112,   113,   114,   115,   116,   120,
-     121,   122,    34,    58,    60,    61,    62,   112,   114,   119,
-      42,    95,    96,    45,    45,    73,    73,   112,    16,    34,
-      35,    42,    58,    87,    34,    36,    34,    36,    34,    36,
-      42,     0,    46,   108,    98,    16,    35,    42,    88,    93,
-      73,    81,    34,    34,    74,     5,    73,   121,     6,    63,
-      64,    65,    66,    67,    68,     8,     9,    10,    11,    12,
-      13,    14,    15,    16,    17,    18,    19,    20,    21,    22,
-      23,    24,    25,    26,    76,    77,    28,    29,    31,    32,
-      33,    34,    35,    36,   112,    37,     5,    38,    34,     5,
-      73,    73,    58,   112,    58,     6,    34,    42,    42,    60,
-      61,    62,    77,    84,   116,   117,   118,    42,   118,    42,
-     118,    42,    34,    35,   110,   111,    42,    85,    58,    42,
-      58,    60,    61,    62,    83,    84,     6,    35,     5,    75,
-     102,    87,   105,   112,   112,    81,   112,   114,   114,   114,
-     114,   114,   114,   114,   116,   116,   116,   116,   116,   116,
-     116,   116,   116,   116,   116,   116,   116,   116,   116,   116,
-     116,   116,   116,   116,   116,   120,   120,   118,    38,   117,
-      42,    37,   114,    42,    60,    61,    62,    86,   115,    95,
-      17,    37,     5,    38,   112,    35,    60,    62,    82,    84,
-      87,    34,     6,    77,     5,    37,    37,    37,    42,   119,
-     108,     6,    34,     5,    73,    17,    38,     5,    38,   115,
-     115,    35,    88,   106,    73,    73,    37,    75,    77,    77,
-      37,     5,    38,   108,     6,    42,    42,    42,     5,    37,
-      35,    58,    35,    73,    82,    12,    84,    12,    84,     5,
-      37,     6,    12,    84,    82,   115,   116,    60,    61,    62,
-      84,   117,     6,    38,   114,    86,    85,    35,    42,    89,
-      92,    84,     6,    35,    38,    85,   112,   112,   108,    56,
-     109,   116,   116,   117,     4,   115,    60,    61,    62,    84,
-     115,    58,    38,    58,    38,    84,    84,    35,    60,    62,
-      84,    87,   100,   114,    84,    37,    77,     6,   112,    73,
-      37,    83,    34,     5,   115,   115,    73,    73,    34,    38,
-     108,     6,     5,    38,    35,    38,    82,    12,    84,    12,
-      84,     6,    12,    84,     6,    99,   116,   115,     5,    38,
-     115,    89,    38,   112,   112,    36,   115,    58,    58,    38,
-      84,    84,   114,    84,   114,    74,   112,    34,    37,    37,
-      37,    36,    38,    38,    73,    81,    37,   115,   108,   108,
-      36,    75,    37,    37,   108
-};
-
-#define yyerrok		(yyerrstatus = 0)
-#define yyclearin	(yychar = YYEMPTY)
-#define YYEMPTY		(-2)
-#define YYEOF		0
-
-#define YYACCEPT	goto yyacceptlab
-#define YYABORT		goto yyabortlab
-#define YYERROR		goto yyerrorlab
-
-
-/* Like YYERROR except do call yyerror.  This remains here temporarily
-   to ease the transition to the new meaning of YYERROR, for GCC.
-   Once GCC version 2 has supplanted version 1, this can go.  However,
-   YYFAIL appears to be in use.  Nevertheless, it is formally deprecated
-   in Bison 2.4.2's NEWS entry, where a plan to phase it out is
-   discussed.  */
-
-#define YYFAIL		goto yyerrlab
-#if defined YYFAIL
-  /* This is here to suppress warnings from the GCC cpp's
-     -Wunused-macros.  Normally we don't worry about that warning, but
-     some users do, and we want to make it easy for users to remove
-     YYFAIL uses, which will produce warnings from Bison 2.5.  */
-#endif
-
-#define YYRECOVERING()  (!!yyerrstatus)
-
-#define YYBACKUP(Token, Value)                                  \
-do                                                              \
-  if (yychar == YYEMPTY)                                        \
-    {                                                           \
-      yychar = (Token);                                         \
-      yylval = (Value);                                         \
-      YYPOPSTACK (yylen);                                       \
-      yystate = *yyssp;                                         \
-      goto yybackup;                                            \
-    }                                                           \
-  else                                                          \
-    {                                                           \
-      yyerror (YY_("syntax error: cannot back up")); \
-      YYERROR;							\
-    }								\
-while (YYID (0))
-
-/* Error token number */
-#define YYTERROR	1
-#define YYERRCODE	256
-
-
-/* This macro is provided for backward compatibility. */
-#ifndef YY_LOCATION_PRINT
-# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
-#endif
-
-
-/* YYLEX -- calling `yylex' with the right arguments.  */
-#ifdef YYLEX_PARAM
-# define YYLEX yylex (YYLEX_PARAM)
-#else
-# define YYLEX yylex ()
-#endif
-
-/* Enable debugging if requested.  */
-#if YYDEBUG
-
-# ifndef YYFPRINTF
-#  include <stdio.h> /* INFRINGES ON USER NAME SPACE */
-#  define YYFPRINTF fprintf
-# endif
-
-# define YYDPRINTF(Args)			\
-do {						\
-  if (yydebug)					\
-    YYFPRINTF Args;				\
-} while (YYID (0))
-
-# define YY_SYMBOL_PRINT(Title, Type, Value, Location)			  \
-do {									  \
-  if (yydebug)								  \
-    {									  \
-      YYFPRINTF (stderr, "%s ", Title);					  \
-      yy_symbol_print (stderr,						  \
-		  Type, Value); \
-      YYFPRINTF (stderr, "\n");						  \
-    }									  \
-} while (YYID (0))
-
-
-/*--------------------------------.
-| Print this symbol on YYOUTPUT.  |
-`--------------------------------*/
-
-/*ARGSUSED*/
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static void
-yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
-#else
-static void
-yy_symbol_value_print (yyoutput, yytype, yyvaluep)
-    FILE *yyoutput;
-    int yytype;
-    YYSTYPE const * const yyvaluep;
-#endif
-{
-  FILE *yyo = yyoutput;
-  YYUSE (yyo);
-  if (!yyvaluep)
-    return;
-# ifdef YYPRINT
-  if (yytype < YYNTOKENS)
-    YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
-# else
-  YYUSE (yyoutput);
-# endif
-  YYUSE (yytype);
-}
-
-
-/*--------------------------------.
-| Print this symbol on YYOUTPUT.  |
-`--------------------------------*/
-
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static void
-yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
-#else
-static void
-yy_symbol_print (yyoutput, yytype, yyvaluep)
-    FILE *yyoutput;
-    int yytype;
-    YYSTYPE const * const yyvaluep;
-#endif
-{
-  if (yytype < YYNTOKENS)
-    YYFPRINTF (yyoutput, "token %s (", yytname[yytype]);
-  else
-    YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]);
-
-  yy_symbol_value_print (yyoutput, yytype, yyvaluep);
-  YYFPRINTF (yyoutput, ")");
-}
-
-/*------------------------------------------------------------------.
-| yy_stack_print -- Print the state stack from its BOTTOM up to its |
-| TOP (included).                                                   |
-`------------------------------------------------------------------*/
-
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static void
-yy_stack_print (yytype_int16 *yybottom, yytype_int16 *yytop)
-#else
-static void
-yy_stack_print (yybottom, yytop)
-    yytype_int16 *yybottom;
-    yytype_int16 *yytop;
-#endif
-{
-  YYFPRINTF (stderr, "Stack now");
-  for (; yybottom <= yytop; yybottom++)
-    {
-      int yybot = *yybottom;
-      YYFPRINTF (stderr, " %d", yybot);
-    }
-  YYFPRINTF (stderr, "\n");
-}
-
-# define YY_STACK_PRINT(Bottom, Top)				\
-do {								\
-  if (yydebug)							\
-    yy_stack_print ((Bottom), (Top));				\
-} while (YYID (0))
-
-
-/*------------------------------------------------.
-| Report that the YYRULE is going to be reduced.  |
-`------------------------------------------------*/
-
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static void
-yy_reduce_print (YYSTYPE *yyvsp, int yyrule)
-#else
-static void
-yy_reduce_print (yyvsp, yyrule)
-    YYSTYPE *yyvsp;
-    int yyrule;
-#endif
-{
-  int yynrhs = yyr2[yyrule];
-  int yyi;
-  unsigned long int yylno = yyrline[yyrule];
-  YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n",
-	     yyrule - 1, yylno);
-  /* The symbols being reduced.  */
-  for (yyi = 0; yyi < yynrhs; yyi++)
-    {
-      YYFPRINTF (stderr, "   $%d = ", yyi + 1);
-      yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi],
-		       &(yyvsp[(yyi + 1) - (yynrhs)])
-		       		       );
-      YYFPRINTF (stderr, "\n");
-    }
-}
-
-# define YY_REDUCE_PRINT(Rule)		\
-do {					\
-  if (yydebug)				\
-    yy_reduce_print (yyvsp, Rule); \
-} while (YYID (0))
-
-/* Nonzero means print parse trace.  It is left uninitialized so that
-   multiple parsers can coexist.  */
-int yydebug;
-#else /* !YYDEBUG */
-# define YYDPRINTF(Args)
-# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
-# define YY_STACK_PRINT(Bottom, Top)
-# define YY_REDUCE_PRINT(Rule)
-#endif /* !YYDEBUG */
-
-
-/* YYINITDEPTH -- initial size of the parser's stacks.  */
-#ifndef	YYINITDEPTH
-# define YYINITDEPTH 200
-#endif
-
-/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
-   if the built-in stack extension method is used).
-
-   Do not make this value too large; the results are undefined if
-   YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
-   evaluated with infinite-precision integer arithmetic.  */
-
-#ifndef YYMAXDEPTH
-# define YYMAXDEPTH 10000
-#endif
-
-
-#if YYERROR_VERBOSE
-
-# ifndef yystrlen
-#  if defined __GLIBC__ && defined _STRING_H
-#   define yystrlen strlen
-#  else
-/* Return the length of YYSTR.  */
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static YYSIZE_T
-yystrlen (const char *yystr)
-#else
-static YYSIZE_T
-yystrlen (yystr)
-    const char *yystr;
-#endif
-{
-  YYSIZE_T yylen;
-  for (yylen = 0; yystr[yylen]; yylen++)
-    continue;
-  return yylen;
-}
-#  endif
-# endif
-
-# ifndef yystpcpy
-#  if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
-#   define yystpcpy stpcpy
-#  else
-/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
-   YYDEST.  */
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static char *
-yystpcpy (char *yydest, const char *yysrc)
-#else
-static char *
-yystpcpy (yydest, yysrc)
-    char *yydest;
-    const char *yysrc;
-#endif
-{
-  char *yyd = yydest;
-  const char *yys = yysrc;
-
-  while ((*yyd++ = *yys++) != '\0')
-    continue;
-
-  return yyd - 1;
-}
-#  endif
-# endif
-
-# ifndef yytnamerr
-/* Copy to YYRES the contents of YYSTR after stripping away unnecessary
-   quotes and backslashes, so that it's suitable for yyerror.  The
-   heuristic is that double-quoting is unnecessary unless the string
-   contains an apostrophe, a comma, or backslash (other than
-   backslash-backslash).  YYSTR is taken from yytname.  If YYRES is
-   null, do not copy; instead, return the length of what the result
-   would have been.  */
-static YYSIZE_T
-yytnamerr (char *yyres, const char *yystr)
-{
-  if (*yystr == '"')
-    {
-      YYSIZE_T yyn = 0;
-      char const *yyp = yystr;
-
-      for (;;)
-	switch (*++yyp)
-	  {
-	  case '\'':
-	  case ',':
-	    goto do_not_strip_quotes;
-
-	  case '\\':
-	    if (*++yyp != '\\')
-	      goto do_not_strip_quotes;
-	    /* Fall through.  */
-	  default:
-	    if (yyres)
-	      yyres[yyn] = *yyp;
-	    yyn++;
-	    break;
-
-	  case '"':
-	    if (yyres)
-	      yyres[yyn] = '\0';
-	    return yyn;
-	  }
-    do_not_strip_quotes: ;
-    }
-
-  if (! yyres)
-    return yystrlen (yystr);
-
-  return yystpcpy (yyres, yystr) - yyres;
-}
-# endif
-
-/* Copy into *YYMSG, which is of size *YYMSG_ALLOC, an error message
-   about the unexpected token YYTOKEN for the state stack whose top is
-   YYSSP.
-
-   Return 0 if *YYMSG was successfully written.  Return 1 if *YYMSG is
-   not large enough to hold the message.  In that case, also set
-   *YYMSG_ALLOC to the required number of bytes.  Return 2 if the
-   required number of bytes is too large to store.  */
-static int
-yysyntax_error (YYSIZE_T *yymsg_alloc, char **yymsg,
-                yytype_int16 *yyssp, int yytoken)
-{
-  YYSIZE_T yysize0 = yytnamerr (YY_NULL, yytname[yytoken]);
-  YYSIZE_T yysize = yysize0;
-  enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
-  /* Internationalized format string. */
-  const char *yyformat = YY_NULL;
-  /* Arguments of yyformat. */
-  char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
-  /* Number of reported tokens (one for the "unexpected", one per
-     "expected"). */
-  int yycount = 0;
-
-  /* There are many possibilities here to consider:
-     - Assume YYFAIL is not used.  It's too flawed to consider.  See
-       <http://lists.gnu.org/archive/html/bison-patches/2009-12/msg00024.html>
-       for details.  YYERROR is fine as it does not invoke this
-       function.
-     - If this state is a consistent state with a default action, then
-       the only way this function was invoked is if the default action
-       is an error action.  In that case, don't check for expected
-       tokens because there are none.
-     - The only way there can be no lookahead present (in yychar) is if
-       this state is a consistent state with a default action.  Thus,
-       detecting the absence of a lookahead is sufficient to determine
-       that there is no unexpected or expected token to report.  In that
-       case, just report a simple "syntax error".
-     - Don't assume there isn't a lookahead just because this state is a
-       consistent state with a default action.  There might have been a
-       previous inconsistent state, consistent state with a non-default
-       action, or user semantic action that manipulated yychar.
-     - Of course, the expected token list depends on states to have
-       correct lookahead information, and it depends on the parser not
-       to perform extra reductions after fetching a lookahead from the
-       scanner and before detecting a syntax error.  Thus, state merging
-       (from LALR or IELR) and default reductions corrupt the expected
-       token list.  However, the list is correct for canonical LR with
-       one exception: it will still contain any token that will not be
-       accepted due to an error action in a later state.
-  */
-  if (yytoken != YYEMPTY)
-    {
-      int yyn = yypact[*yyssp];
-      yyarg[yycount++] = yytname[yytoken];
-      if (!yypact_value_is_default (yyn))
-        {
-          /* Start YYX at -YYN if negative to avoid negative indexes in
-             YYCHECK.  In other words, skip the first -YYN actions for
-             this state because they are default actions.  */
-          int yyxbegin = yyn < 0 ? -yyn : 0;
-          /* Stay within bounds of both yycheck and yytname.  */
-          int yychecklim = YYLAST - yyn + 1;
-          int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
-          int yyx;
-
-          for (yyx = yyxbegin; yyx < yyxend; ++yyx)
-            if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR
-                && !yytable_value_is_error (yytable[yyx + yyn]))
-              {
-                if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
-                  {
-                    yycount = 1;
-                    yysize = yysize0;
-                    break;
-                  }
-                yyarg[yycount++] = yytname[yyx];
-                {
-                  YYSIZE_T yysize1 = yysize + yytnamerr (YY_NULL, yytname[yyx]);
-                  if (! (yysize <= yysize1
-                         && yysize1 <= YYSTACK_ALLOC_MAXIMUM))
-                    return 2;
-                  yysize = yysize1;
-                }
-              }
-        }
-    }
-
-  switch (yycount)
-    {
-# define YYCASE_(N, S)                      \
-      case N:                               \
-        yyformat = S;                       \
-      break
-      YYCASE_(0, YY_("syntax error"));
-      YYCASE_(1, YY_("syntax error, unexpected %s"));
-      YYCASE_(2, YY_("syntax error, unexpected %s, expecting %s"));
-      YYCASE_(3, YY_("syntax error, unexpected %s, expecting %s or %s"));
-      YYCASE_(4, YY_("syntax error, unexpected %s, expecting %s or %s or %s"));
-      YYCASE_(5, YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"));
-# undef YYCASE_
-    }
-
-  {
-    YYSIZE_T yysize1 = yysize + yystrlen (yyformat);
-    if (! (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM))
-      return 2;
-    yysize = yysize1;
-  }
-
-  if (*yymsg_alloc < yysize)
-    {
-      *yymsg_alloc = 2 * yysize;
-      if (! (yysize <= *yymsg_alloc
-             && *yymsg_alloc <= YYSTACK_ALLOC_MAXIMUM))
-        *yymsg_alloc = YYSTACK_ALLOC_MAXIMUM;
-      return 1;
-    }
-
-  /* Avoid sprintf, as that infringes on the user's name space.
-     Don't have undefined behavior even if the translation
-     produced a string with the wrong number of "%s"s.  */
-  {
-    char *yyp = *yymsg;
-    int yyi = 0;
-    while ((*yyp = *yyformat) != '\0')
-      if (*yyp == '%' && yyformat[1] == 's' && yyi < yycount)
-        {
-          yyp += yytnamerr (yyp, yyarg[yyi++]);
-          yyformat += 2;
-        }
-      else
-        {
-          yyp++;
-          yyformat++;
-        }
-  }
-  return 0;
-}
-#endif /* YYERROR_VERBOSE */
-
-/*-----------------------------------------------.
-| Release the memory associated to this symbol.  |
-`-----------------------------------------------*/
-
-/*ARGSUSED*/
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-static void
-yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep)
-#else
-static void
-yydestruct (yymsg, yytype, yyvaluep)
-    const char *yymsg;
-    int yytype;
-    YYSTYPE *yyvaluep;
-#endif
-{
-  YYUSE (yyvaluep);
-
-  if (!yymsg)
-    yymsg = "Deleting";
-  YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
-
-  YYUSE (yytype);
-}
-
-
-
-
-/* The lookahead symbol.  */
-int yychar;
-
-
-#ifndef YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
-# define YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
-# define YY_IGNORE_MAYBE_UNINITIALIZED_END
-#endif
-#ifndef YY_INITIAL_VALUE
-# define YY_INITIAL_VALUE(Value) /* Nothing. */
-#endif
-
-/* The semantic value of the lookahead symbol.  */
-YYSTYPE yylval YY_INITIAL_VALUE(yyval_default);
-
-/* Number of syntax errors so far.  */
-int yynerrs;
-
-
-/*----------.
-| yyparse.  |
-`----------*/
-
-#ifdef YYPARSE_PARAM
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-int
-yyparse (void *YYPARSE_PARAM)
-#else
-int
-yyparse (YYPARSE_PARAM)
-    void *YYPARSE_PARAM;
-#endif
-#else /* ! YYPARSE_PARAM */
-#if (defined __STDC__ || defined __C99__FUNC__ \
-     || defined __cplusplus || defined _MSC_VER)
-int
-yyparse (void)
-#else
-int
-yyparse ()
-
-#endif
-#endif
-{
-    int yystate;
-    /* Number of tokens to shift before error messages enabled.  */
-    int yyerrstatus;
-
-    /* The stacks and their tools:
-       `yyss': related to states.
-       `yyvs': related to semantic values.
-
-       Refer to the stacks through separate pointers, to allow yyoverflow
-       to reallocate them elsewhere.  */
-
-    /* The state stack.  */
-    yytype_int16 yyssa[YYINITDEPTH];
-    yytype_int16 *yyss;
-    yytype_int16 *yyssp;
-
-    /* The semantic value stack.  */
-    YYSTYPE yyvsa[YYINITDEPTH];
-    YYSTYPE *yyvs;
-    YYSTYPE *yyvsp;
-
-    YYSIZE_T yystacksize;
-
-  int yyn;
-  int yyresult;
-  /* Lookahead token as an internal (translated) token number.  */
-  int yytoken = 0;
-  /* The variables used to return semantic value and location from the
-     action routines.  */
-  YYSTYPE yyval;
-
-#if YYERROR_VERBOSE
-  /* Buffer for error messages, and its allocated size.  */
-  char yymsgbuf[128];
-  char *yymsg = yymsgbuf;
-  YYSIZE_T yymsg_alloc = sizeof yymsgbuf;
-#endif
-
-#define YYPOPSTACK(N)   (yyvsp -= (N), yyssp -= (N))
-
-  /* The number of symbols on the RHS of the reduced rule.
-     Keep to zero when no symbol should be popped.  */
-  int yylen = 0;
-
-  yyssp = yyss = yyssa;
-  yyvsp = yyvs = yyvsa;
-  yystacksize = YYINITDEPTH;
-
-  YYDPRINTF ((stderr, "Starting parse\n"));
-
-  yystate = 0;
-  yyerrstatus = 0;
-  yynerrs = 0;
-  yychar = YYEMPTY; /* Cause a token to be read.  */
-  goto yysetstate;
-
-/*------------------------------------------------------------.
-| yynewstate -- Push a new state, which is found in yystate.  |
-`------------------------------------------------------------*/
- yynewstate:
-  /* In all cases, when you get here, the value and location stacks
-     have just been pushed.  So pushing a state here evens the stacks.  */
-  yyssp++;
-
- yysetstate:
-  *yyssp = yystate;
-
-  if (yyss + yystacksize - 1 <= yyssp)
-    {
-      /* Get the current used size of the three stacks, in elements.  */
-      YYSIZE_T yysize = yyssp - yyss + 1;
-
-#ifdef yyoverflow
-      {
-	/* Give user a chance to reallocate the stack.  Use copies of
-	   these so that the &'s don't force the real ones into
-	   memory.  */
-	YYSTYPE *yyvs1 = yyvs;
-	yytype_int16 *yyss1 = yyss;
-
-	/* Each stack pointer address is followed by the size of the
-	   data in use in that stack, in bytes.  This used to be a
-	   conditional around just the two extra args, but that might
-	   be undefined if yyoverflow is a macro.  */
-	yyoverflow (YY_("memory exhausted"),
-		    &yyss1, yysize * sizeof (*yyssp),
-		    &yyvs1, yysize * sizeof (*yyvsp),
-		    &yystacksize);
-
-	yyss = yyss1;
-	yyvs = yyvs1;
-      }
-#else /* no yyoverflow */
-# ifndef YYSTACK_RELOCATE
-      goto yyexhaustedlab;
-# else
-      /* Extend the stack our own way.  */
-      if (YYMAXDEPTH <= yystacksize)
-	goto yyexhaustedlab;
-      yystacksize *= 2;
-      if (YYMAXDEPTH < yystacksize)
-	yystacksize = YYMAXDEPTH;
-
-      {
-	yytype_int16 *yyss1 = yyss;
-	union yyalloc *yyptr =
-	  (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
-	if (! yyptr)
-	  goto yyexhaustedlab;
-	YYSTACK_RELOCATE (yyss_alloc, yyss);
-	YYSTACK_RELOCATE (yyvs_alloc, yyvs);
-#  undef YYSTACK_RELOCATE
-	if (yyss1 != yyssa)
-	  YYSTACK_FREE (yyss1);
-      }
-# endif
-#endif /* no yyoverflow */
-
-      yyssp = yyss + yysize - 1;
-      yyvsp = yyvs + yysize - 1;
-
-      YYDPRINTF ((stderr, "Stack size increased to %lu\n",
-		  (unsigned long int) yystacksize));
-
-      if (yyss + yystacksize - 1 <= yyssp)
-	YYABORT;
-    }
-
-  YYDPRINTF ((stderr, "Entering state %d\n", yystate));
-
-  if (yystate == YYFINAL)
-    YYACCEPT;
-
-  goto yybackup;
-
-/*-----------.
-| yybackup.  |
-`-----------*/
-yybackup:
-
-  /* Do appropriate processing given the current state.  Read a
-     lookahead token if we need one and don't already have one.  */
-
-  /* First try to decide what to do without reference to lookahead token.  */
-  yyn = yypact[yystate];
-  if (yypact_value_is_default (yyn))
-    goto yydefault;
-
-  /* Not known => get a lookahead token if don't already have one.  */
-
-  /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol.  */
-  if (yychar == YYEMPTY)
-    {
-      YYDPRINTF ((stderr, "Reading a token: "));
-      yychar = YYLEX;
-    }
-
-  if (yychar <= YYEOF)
-    {
-      yychar = yytoken = YYEOF;
-      YYDPRINTF ((stderr, "Now at end of input.\n"));
-    }
-  else
-    {
-      yytoken = YYTRANSLATE (yychar);
-      YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
-    }
-
-  /* If the proper action on seeing token YYTOKEN is to reduce or to
-     detect an error, take that action.  */
-  yyn += yytoken;
-  if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
-    goto yydefault;
-  yyn = yytable[yyn];
-  if (yyn <= 0)
-    {
-      if (yytable_value_is_error (yyn))
-        goto yyerrlab;
-      yyn = -yyn;
-      goto yyreduce;
-    }
-
-  /* Count tokens shifted since error; after three, turn off error
-     status.  */
-  if (yyerrstatus)
-    yyerrstatus--;
-
-  /* Shift the lookahead token.  */
-  YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
-
-  /* Discard the shifted token.  */
-  yychar = YYEMPTY;
-
-  yystate = yyn;
-  YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
-  *++yyvsp = yylval;
-  YY_IGNORE_MAYBE_UNINITIALIZED_END
-
-  goto yynewstate;
-
-
-/*-----------------------------------------------------------.
-| yydefault -- do the default action for the current state.  |
-`-----------------------------------------------------------*/
-yydefault:
-  yyn = yydefact[yystate];
-  if (yyn == 0)
-    goto yyerrlab;
-  goto yyreduce;
-
-
-/*-----------------------------.
-| yyreduce -- Do a reduction.  |
-`-----------------------------*/
-yyreduce:
-  /* yyn is the number of a rule to reduce with.  */
-  yylen = yyr2[yyn];
-
-  /* If YYLEN is nonzero, implement the default value of the action:
-     `$$ = $1'.
-
-     Otherwise, the following line sets YYVAL to garbage.
-     This behavior is undocumented and Bison
-     users should not rely upon it.  Assigning to YYVAL
-     unconditionally makes the parser a bit smaller, and it avoids a
-     GCC warning that YYVAL may be used uninitialized.  */
-  yyval = yyvsp[1-yylen];
-
-
-  YY_REDUCE_PRINT (yyn);
-  switch (yyn)
-    {
-        case 2:
-/* Line 1787 of yacc.c  */
-#line 257 "lg.ypp"
-    {
-		        const char *  magicffglut="#!ffglutdata3.1\n";// for complex and vector 3d plot 
-                        if(ThePlotStream) fwrite(magicffglut,strlen(magicffglut),1,ThePlotStream);	            
-                        size_t sizestack = currentblock->size()+1024 ; //  before close 
-                        (yyvsp[(1) - (2)].cinst)+=currentblock->close(currentblock);
-                        if(verbosity>2 || mpirank==0) cout << " sizestack + 1024 =" << sizestack << "  ( " << sizestack-1024 <<" )\n" ;   
-                        size_t lg0,lg1;                       
-                        int NbPtr = ShowAlloc("init execution ",lg0); // number of un delele ptr
-			UnShowAlloc =0;// add FH for parallee
-                        if(verbosity>2  || mpirank==0) cout << endl;  
-                        { Stack stack = newStack(sizestack);
-                        double CPUcompile= CPUtime();
-                        try {                  
-                          (yyvsp[(1) - (2)].cinst).eval(stack);}
-                        catch ( E_exception & e)  {
-                          cerr << e.what() << " ,  mpirank " << mpirank << endl;
-                          return 1; }
-                        catch( Error & err) {
-                          cerr << err.what() << endl;
-			  cerr << " err code " << err.errcode() << " ,  mpirank " << mpirank << endl;
-                          return err.errcode();
-                        }
-                         catch( ...) { cerr << "Strange catch exception ???\n"; 
-                          cerr << " at exec line  " << TheCurrentLine << " ,  mpirank " << mpirank << endl;
-                          return 1; 
-                         }
-
-                        if(verbosity)  cout << "times: compile "<< CPUcompile-CPUcompileInit <<"s, execution " 
-			    <<  CPUtime()-CPUcompile  <<"s,  mpirank:" << mpirank << endl;
-                        deleteStack(stack);
-                        //debugstack.clear() 
-                        } 
-                        fingraphique();
-			if(ThePlotStream) {pclose(ThePlotStream); ThePlotStream=0;}
-			UnShowAlloc =1;
-                        NbPtr = ShowAlloc("end execution -- ",lg1) - NbPtr;
-                        
-			    if (NbPtr) { cout << " ######## We forget of deleting   " << NbPtr 
-			                      << " Nb pointer,   " <<  lg1-lg0 << "Bytes " << " ,  mpirank " << mpirank <<endl;}
-  return 0;}
-    break;
-
-  case 4:
-/* Line 1787 of yacc.c  */
-#line 302 "lg.ypp"
-    {(yyval.cinst)=(yyvsp[(1) - (1)].cexp);;;}
-    break;
-
-  case 5:
-/* Line 1787 of yacc.c  */
-#line 303 "lg.ypp"
-    { (yyval.cinst)= ((yyvsp[(1) - (2)].cinst)+=(yyvsp[(2) - (2)].cexp)) ;}
-    break;
-
-  case 6:
-/* Line 1787 of yacc.c  */
-#line 306 "lg.ypp"
-    { (yyval.clist_id)=new ListOfId();}
-    break;
-
-  case 7:
-/* Line 1787 of yacc.c  */
-#line 307 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(1) - (1)].str)));}
-    break;
-
-  case 8:
-/* Line 1787 of yacc.c  */
-#line 308 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(1) - (3)].str),(yyvsp[(3) - (3)].cexp))) ;}
-    break;
-
-  case 9:
-/* Line 1787 of yacc.c  */
-#line 309 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(2) - (2)].str),Find((yyvsp[(1) - (2)].str)),atype<FE<double,2> **>()));}
-    break;
-
-  case 10:
-/* Line 1787 of yacc.c  */
-#line 310 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(3) - (3)].str),Find((yyvsp[(1) - (3)].str)),atype<FE<double,2> **>(),true));}
-    break;
-
-  case 11:
-/* Line 1787 of yacc.c  */
-#line 311 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(2) - (2)].str),Find((yyvsp[(1) - (2)].str)),atype<FE<double,3> **>()));}
-    break;
-
-  case 12:
-/* Line 1787 of yacc.c  */
-#line 312 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(3) - (3)].str),Find((yyvsp[(1) - (3)].str)),atype<FE<double,3> **>(),true));}
-    break;
-
-  case 13:
-/* Line 1787 of yacc.c  */
-#line 313 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(2) - (2)].str),C_F0(),(yyvsp[(1) - (2)].type)->right())) ;}
-    break;
-
-  case 14:
-/* Line 1787 of yacc.c  */
-#line 314 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(3) - (3)].str),C_F0(),(yyvsp[(1) - (3)].type),true)) ;}
-    break;
-
-  case 15:
-/* Line 1787 of yacc.c  */
-#line 315 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(2) - (3)].clist_id))) ;}
-    break;
-
-  case 16:
-/* Line 1787 of yacc.c  */
-#line 316 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (3)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(3) - (3)].str))) ;}
-    break;
-
-  case 17:
-/* Line 1787 of yacc.c  */
-#line 317 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (5)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(4) - (5)].clist_id))) ;}
-    break;
-
-  case 18:
-/* Line 1787 of yacc.c  */
-#line 318 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (5)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(3) - (5)].str),(yyvsp[(5) - (5)].cexp))) ;}
-    break;
-
-  case 19:
-/* Line 1787 of yacc.c  */
-#line 319 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (4)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(4) - (4)].str),Find((yyvsp[(3) - (4)].str)),atype<FE<double,2> **>())) ;}
-    break;
-
-  case 20:
-/* Line 1787 of yacc.c  */
-#line 320 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (5)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(5) - (5)].str),Find((yyvsp[(3) - (5)].str)),atype<FE<double,2> **>(),true)) ;}
-    break;
-
-  case 21:
-/* Line 1787 of yacc.c  */
-#line 321 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (4)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(4) - (4)].str),Find((yyvsp[(3) - (4)].str)),atype<FE<double,3> **>())) ;}
-    break;
-
-  case 22:
-/* Line 1787 of yacc.c  */
-#line 322 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (5)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(5) - (5)].str),Find((yyvsp[(3) - (5)].str)),atype<FE<double,3> **>(),true)) ;}
-    break;
-
-  case 23:
-/* Line 1787 of yacc.c  */
-#line 323 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (4)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(4) - (4)].str),C_F0(),(yyvsp[(3) - (4)].type)->right())) ;}
-    break;
-
-  case 24:
-/* Line 1787 of yacc.c  */
-#line 324 "lg.ypp"
-    { (yyval.clist_id) = (yyvsp[(1) - (5)].clist_id); (yyval.clist_id)->push_back(UnId((yyvsp[(5) - (5)].str),C_F0(),(yyvsp[(3) - (5)].type),true)) ;}
-    break;
-
-  case 25:
-/* Line 1787 of yacc.c  */
-#line 327 "lg.ypp"
-    { (yyval.clist_id) = new ListOfId(); (yyval.clist_id)->push_back(UnId((yyvsp[(1) - (1)].str))); }
-    break;
-
-  case 26:
-/* Line 1787 of yacc.c  */
-#line 328 "lg.ypp"
-    { (yyval.clist_id)=(yyvsp[(1) - (3)].clist_id)  ; (yyval.clist_id)->push_back(UnId((yyvsp[(3) - (3)].str))); }
-    break;
-
-  case 31:
-/* Line 1787 of yacc.c  */
-#line 333 "lg.ypp"
-    {(yyval.cexp)=currentblock->NewVar<LocalVariable>((yyvsp[(1) - (1)].str),dcltype);}
-    break;
-
-  case 32:
-/* Line 1787 of yacc.c  */
-#line 334 "lg.ypp"
-    {(yyval.cexp)=currentblock->NewVar<LocalVariable>((yyvsp[(1) - (3)].str),dcltype,(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 33:
-/* Line 1787 of yacc.c  */
-#line 335 "lg.ypp"
-    {(yyval.cexp)=currentblock->NewVar<LocalVariable>((yyvsp[(1) - (4)].str),dcltype,(yyvsp[(3) - (4)].args));
-                                              (yyvsp[(3) - (4)].args).destroy();}
-    break;
-
-  case 34:
-/* Line 1787 of yacc.c  */
-#line 337 "lg.ypp"
-    {(yyval.cexp)=C_F0((yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 35:
-/* Line 1787 of yacc.c  */
-#line 344 "lg.ypp"
-    {(yyval.args)=(yyvsp[(1) - (1)].cexp);}
-    break;
-
-  case 36:
-/* Line 1787 of yacc.c  */
-#line 345 "lg.ypp"
-    {(yyval.args)=Find((yyvsp[(1) - (2)].str));}
-    break;
-
-  case 37:
-/* Line 1787 of yacc.c  */
-#line 346 "lg.ypp"
-    {(yyval.args)=Find((yyvsp[(1) - (2)].str));}
-    break;
-
-  case 38:
-/* Line 1787 of yacc.c  */
-#line 347 "lg.ypp"
-    {(yyval.args)=Find((yyvsp[(1) - (2)].str));}
-    break;
-
-  case 39:
-/* Line 1787 of yacc.c  */
-#line 348 "lg.ypp"
-    { (yyval.args)=make_pair<const char *,const C_F0>((yyvsp[(1) - (3)].str),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 40:
-/* Line 1787 of yacc.c  */
-#line 349 "lg.ypp"
-    { (yyval.args) = ((yyvsp[(1) - (3)].args) += (yyvsp[(3) - (3)].cexp)) ;}
-    break;
-
-  case 41:
-/* Line 1787 of yacc.c  */
-#line 350 "lg.ypp"
-    { (yyval.args)= ((yyvsp[(1) - (5)].args)+= make_pair<const char *,const C_F0>((yyvsp[(3) - (5)].str),(yyvsp[(5) - (5)].cexp)));}
-    break;
-
-  case 43:
-/* Line 1787 of yacc.c  */
-#line 354 "lg.ypp"
-    {(yyval.type)=TypeArray((yyvsp[(1) - (4)].type),(yyvsp[(3) - (4)].type));}
-    break;
-
-  case 44:
-/* Line 1787 of yacc.c  */
-#line 355 "lg.ypp"
-    {(yyval.type)=TypeArray(TypeArray((yyvsp[(1) - (7)].type),(yyvsp[(3) - (7)].type)),(yyvsp[(6) - (7)].type));}
-    break;
-
-  case 45:
-/* Line 1787 of yacc.c  */
-#line 356 "lg.ypp"
-    {(yyval.type)=TypeArray((yyvsp[(1) - (6)].type),(yyvsp[(3) - (6)].type),(yyvsp[(5) - (6)].type));}
-    break;
-
-  case 46:
-/* Line 1787 of yacc.c  */
-#line 357 "lg.ypp"
-    {(yyval.type)=TypeArray(TypeArray((yyvsp[(1) - (9)].type),(yyvsp[(3) - (9)].type),(yyvsp[(5) - (9)].type)),(yyvsp[(8) - (9)].type));}
-    break;
-
-  case 47:
-/* Line 1787 of yacc.c  */
-#line 358 "lg.ypp"
-    {(yyval.type)=TypeTemplate((yyvsp[(1) - (4)].type),(yyvsp[(3) - (4)].type));}
-    break;
-
-  case 48:
-/* Line 1787 of yacc.c  */
-#line 359 "lg.ypp"
-    {(yyval.type)=TypeArray(TypeTemplate((yyvsp[(1) - (7)].type),(yyvsp[(3) - (7)].type)),(yyvsp[(6) - (7)].type));}
-    break;
-
-  case 49:
-/* Line 1787 of yacc.c  */
-#line 360 "lg.ypp"
-    {(yyval.type)=TypeArray(TypeTemplate((yyvsp[(1) - (9)].type),(yyvsp[(3) - (9)].type)),(yyvsp[(6) - (9)].type),(yyvsp[(8) - (9)].type));}
-    break;
-
-  case 50:
-/* Line 1787 of yacc.c  */
-#line 367 "lg.ypp"
-    { (yyval.cexp) =  NewFEvariable((yyvsp[(1) - (1)].str),currentblock,fespacetype,fespacecomplex,fespacedim); }
-    break;
-
-  case 51:
-/* Line 1787 of yacc.c  */
-#line 368 "lg.ypp"
-    { (yyval.cexp) =  NewFEarray((yyvsp[(1) - (4)].str),currentblock,fespacetype,(yyvsp[(3) - (4)].cexp),fespacecomplex,fespacedim); }
-    break;
-
-  case 52:
-/* Line 1787 of yacc.c  */
-#line 369 "lg.ypp"
-    { (yyval.cexp) =  NewFEvariable((yyvsp[(1) - (3)].str),currentblock,fespacetype,(yyvsp[(3) - (3)].cexp),fespacecomplex,fespacedim) ;}
-    break;
-
-  case 53:
-/* Line 1787 of yacc.c  */
-#line 370 "lg.ypp"
-    { (yyval.cexp) =  NewFEvariable((yyvsp[(2) - (3)].clist_id),currentblock,fespacetype,fespacecomplex,fespacedim) ;}
-    break;
-
-  case 54:
-/* Line 1787 of yacc.c  */
-#line 371 "lg.ypp"
-    { (yyval.cexp) =  NewFEarray((yyvsp[(2) - (6)].clist_id),currentblock,fespacetype,(yyvsp[(5) - (6)].cexp),fespacecomplex,fespacedim) ;}
-    break;
-
-  case 55:
-/* Line 1787 of yacc.c  */
-#line 372 "lg.ypp"
-    { (yyval.cexp) =  NewFEvariable((yyvsp[(2) - (5)].clist_id),currentblock,fespacetype,(yyvsp[(5) - (5)].cexp),fespacecomplex,fespacedim) ;}
-    break;
-
-  case 56:
-/* Line 1787 of yacc.c  */
-#line 375 "lg.ypp"
-    { (yyval.cexp) =  NewFEarray((yyvsp[(1) - (4)].str),currentblock,fespacetype,(yyvsp[(3) - (4)].cexp),fespacecomplex,fespacedim); }
-    break;
-
-  case 57:
-/* Line 1787 of yacc.c  */
-#line 376 "lg.ypp"
-    { (yyval.cexp) =  NewFEarray((yyvsp[(2) - (6)].clist_id),currentblock,fespacetype,(yyvsp[(5) - (6)].cexp),fespacecomplex,fespacedim) ;}
-    break;
-
-  case 58:
-/* Line 1787 of yacc.c  */
-#line 380 "lg.ypp"
-    { fespacedim=2;}
-    break;
-
-  case 59:
-/* Line 1787 of yacc.c  */
-#line 380 "lg.ypp"
-    { fespacedim=1;}
-    break;
-
-  case 60:
-/* Line 1787 of yacc.c  */
-#line 380 "lg.ypp"
-    { fespacedim=3;}
-    break;
-
-  case 61:
-/* Line 1787 of yacc.c  */
-#line 381 "lg.ypp"
-    {fespacecomplex=false;  fespacetype = Find((yyvsp[(1) - (1)].str));}
-    break;
-
-  case 62:
-/* Line 1787 of yacc.c  */
-#line 382 "lg.ypp"
-    {
-             if ((yyvsp[(3) - (4)].type) != typevarreal && (yyvsp[(3) - (4)].type) != typevarcomplex) lgerror (" type of finite element <real> or <complex>");
-             fespacecomplex=((yyvsp[(3) - (4)].type)==typevarcomplex);
-             fespacetype = Find((yyvsp[(1) - (4)].str));}
-    break;
-
-  case 63:
-/* Line 1787 of yacc.c  */
-#line 387 "lg.ypp"
-    {  (yyval.cexp) = (yyvsp[(1) - (1)].cexp)  ;}
-    break;
-
-  case 64:
-/* Line 1787 of yacc.c  */
-#line 388 "lg.ypp"
-    { (yyval.cexp)=C_F0((yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 65:
-/* Line 1787 of yacc.c  */
-#line 390 "lg.ypp"
-    {  (yyval.cexp) = (yyvsp[(1) - (1)].cexp)  ;}
-    break;
-
-  case 66:
-/* Line 1787 of yacc.c  */
-#line 391 "lg.ypp"
-    { (yyval.cexp)=C_F0((yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 67:
-/* Line 1787 of yacc.c  */
-#line 393 "lg.ypp"
-    { (yyval.cexp)=0;  (yyval.cexp) = (yyvsp[(2) - (2)].cexp);}
-    break;
-
-  case 68:
-/* Line 1787 of yacc.c  */
-#line 394 "lg.ypp"
-    { (yyval.cexp)=0;  (yyval.cexp) = (yyvsp[(5) - (5)].cexp);}
-    break;
-
-  case 69:
-/* Line 1787 of yacc.c  */
-#line 398 "lg.ypp"
-    {(yyval.cexp)=currentblock->NewVar<LocalVariableFES,size_t>((yyvsp[(1) - (4)].str),typeFESpace((yyvsp[(3) - (4)].args)),(yyvsp[(3) - (4)].args),dimFESpaceImage((yyvsp[(3) - (4)].args)));
-     (yyvsp[(3) - (4)].args).destroy(); }
-    break;
-
-  case 71:
-/* Line 1787 of yacc.c  */
-#line 402 "lg.ypp"
-    {(yyval.cexp)=C_F0((yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 72:
-/* Line 1787 of yacc.c  */
-#line 405 "lg.ypp"
-    {dcltype=(yyvsp[(1) - (1)].type);}
-    break;
-
-  case 73:
-/* Line 1787 of yacc.c  */
-#line 405 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(3) - (4)].cexp);}
-    break;
-
-  case 74:
-/* Line 1787 of yacc.c  */
-#line 406 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(2) - (3)].cexp);}
-    break;
-
-  case 75:
-/* Line 1787 of yacc.c  */
-#line 407 "lg.ypp"
-    { (yyval.cexp)=(yyvsp[(1) - (2)].cexp);}
-    break;
-
-  case 76:
-/* Line 1787 of yacc.c  */
-#line 408 "lg.ypp"
-    {(yyval.cexp)=currentblock->NewID((yyvsp[(1) - (5)].type),(yyvsp[(2) - (5)].str),(yyvsp[(4) - (5)].cexp));}
-    break;
-
-  case 77:
-/* Line 1787 of yacc.c  */
-#line 410 "lg.ypp"
-    {   /* use the stack to store the prev return type*/
-                      assert(kkembtype+1<nbembtype);
-                      rettype[++kkembtype] = (yyvsp[(2) - (6)].type)->right();
-                      routineinblock[kkembtype] = currentblock;
-                      (yyvsp[(5) - (6)].routine)=new Routine((yyvsp[(1) - (6)].type),(yyvsp[(2) - (6)].type)->right(),(yyvsp[(3) - (6)].str),(yyvsp[(5) - (6)].clist_id),currentblock);
-		      // routineinblock[kkembtype]->Add($3,"(",$<routine>5); //pas recursif pour l'instanat test  FH 27 dec 2008
-                     // cout << " \n after new routine \n " << endl;                      
-                      }
-    break;
-
-  case 78:
-/* Line 1787 of yacc.c  */
-#line 419 "lg.ypp"
-    { currentblock=(yyvsp[(5) - (10)].routine)->Set((yyvsp[(9) - (10)].cinst));
-                       currentblock->Add((yyvsp[(3) - (10)].str),"(",(yyvsp[(5) - (10)].routine)); //pas recursif pour l'instant test  FH 27 dec 2008
-                       kkembtype--;
-                       (yyval.cexp)=0;
-                    
-                        }
-    break;
-
-  case 79:
-/* Line 1787 of yacc.c  */
-#line 426 "lg.ypp"
-    {Block::open(currentblock); (yyvsp[(1) - (5)].type)->SetArgs((yyvsp[(4) - (5)].clist_id));}
-    break;
-
-  case 80:
-/* Line 1787 of yacc.c  */
-#line 428 "lg.ypp"
-    {  (yyval.cinst)=currentblock->close(currentblock);
-                         (yyval.cexp)=currentblock->NewID((yyvsp[(1) - (9)].type),(yyvsp[(2) - (9)].str),(yyvsp[(8) - (9)].cexp),*(yyvsp[(4) - (9)].clist_id));
-                         delete (yyvsp[(4) - (9)].clist_id); //  FH 23032005
-                         }
-    break;
-
-  case 81:
-/* Line 1787 of yacc.c  */
-#line 434 "lg.ypp"
-    {  Block::open(currentblock);}
-    break;
-
-  case 82:
-/* Line 1787 of yacc.c  */
-#line 435 "lg.ypp"
-    {  (yyval.cexp)=currentblock->close(currentblock);}
-    break;
-
-  case 83:
-/* Line 1787 of yacc.c  */
-#line 437 "lg.ypp"
-    {ffassert(inloopcount<sizeStackOfLoop);  // modif FH july 2005
-                StackOfLoop[inloopcount++]=currentblock;}
-    break;
-
-  case 84:
-/* Line 1787 of yacc.c  */
-#line 439 "lg.ypp"
-    {ffassert(inloopcount<sizeStackOfLoop);
-                StackOfLoop[inloopcount++]=currentblock;}
-    break;
-
-  case 85:
-/* Line 1787 of yacc.c  */
-#line 444 "lg.ypp"
-    {dcltype=(yyvsp[(1) - (1)].type); Block::open(currentblock);  }
-    break;
-
-  case 86:
-/* Line 1787 of yacc.c  */
-#line 445 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(3) - (3)].cexp);}
-    break;
-
-  case 87:
-/* Line 1787 of yacc.c  */
-#line 447 "lg.ypp"
-    { Block::open(currentblock) ;}
-    break;
-
-  case 88:
-/* Line 1787 of yacc.c  */
-#line 449 "lg.ypp"
-    {(yyval.cexp)=0;}
-    break;
-
-  case 89:
-/* Line 1787 of yacc.c  */
-#line 450 "lg.ypp"
-    {zzzfff->input((yyvsp[(2) - (2)].str));(yyval.cexp)= 0; }
-    break;
-
-  case 90:
-/* Line 1787 of yacc.c  */
-#line 451 "lg.ypp"
-    {load((yyvsp[(2) - (2)].str));(yyval.cexp)= 0; }
-    break;
-
-  case 91:
-/* Line 1787 of yacc.c  */
-#line 452 "lg.ypp"
-    {(yyval.cexp)=Try((yyvsp[(3) - (5)].cinst),(yyvsp[(5) - (5)].cexp),currentblock->close(currentblock));}
-    break;
-
-  case 92:
-/* Line 1787 of yacc.c  */
-#line 453 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(1) - (2)].cexp);}
-    break;
-
-  case 93:
-/* Line 1787 of yacc.c  */
-#line 454 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(1) - (1)].cexp);}
-    break;
-
-  case 94:
-/* Line 1787 of yacc.c  */
-#line 455 "lg.ypp"
-    {inloopcount--; (yyval.cexp)=For((yyvsp[(3) - (9)].cexp),(yyvsp[(5) - (9)].cexp),(yyvsp[(7) - (9)].cexp),(yyvsp[(9) - (9)].cexp));}
-    break;
-
-  case 95:
-/* Line 1787 of yacc.c  */
-#line 457 "lg.ypp"
-    {inloopcount--; 
-                (yyval.cexp)=C_F0(For((yyvsp[(3) - (9)].cexp),(yyvsp[(5) - (9)].cexp),(yyvsp[(7) - (9)].cexp),(yyvsp[(9) - (9)].cexp)),currentblock->close(currentblock));}
-    break;
-
-  case 96:
-/* Line 1787 of yacc.c  */
-#line 460 "lg.ypp"
-    {inloopcount--;(yyval.cexp)=While((yyvsp[(3) - (5)].cexp),(yyvsp[(5) - (5)].cexp));}
-    break;
-
-  case 97:
-/* Line 1787 of yacc.c  */
-#line 461 "lg.ypp"
-    {(yyval.cexp)=FIf((yyvsp[(3) - (5)].cexp),(yyvsp[(5) - (5)].cexp));}
-    break;
-
-  case 98:
-/* Line 1787 of yacc.c  */
-#line 462 "lg.ypp"
-    {(yyval.cexp)=FIf((yyvsp[(3) - (7)].cexp),(yyvsp[(5) - (7)].cexp),(yyvsp[(7) - (7)].cexp));}
-    break;
-
-  case 99:
-/* Line 1787 of yacc.c  */
-#line 463 "lg.ypp"
-    { 
-                      (yyval.cexp)=C_F0(new E_block((yyvsp[(2) - (3)].cinst),(yyvsp[(3) - (3)].cexp)),atype<void>()) ;}
-    break;
-
-  case 100:
-/* Line 1787 of yacc.c  */
-#line 465 "lg.ypp"
-    {
-                      (yyval.cexp)=0;currentblock->NewID(atype<const E_Border *>(),(yyvsp[(2) - (3)].str),C_F0(TheOperators,"[border]",(yyvsp[(3) - (3)].args)));}
-    break;
-
-  case 101:
-/* Line 1787 of yacc.c  */
-#line 467 "lg.ypp"
-    {
-                      (yyval.cexp)=0;currentblock->NewID(atype<const E_Border *>(),(yyvsp[(2) - (6)].str),C_F0(TheOperators,"[border]",(yyvsp[(4) - (6)].args)));}
-    break;
-
-  case 102:
-/* Line 1787 of yacc.c  */
-#line 470 "lg.ypp"
-    {
-                    if(inloopcount) 
-                      (yyval.cexp)= C_F0(new E_throw(E_exception::e_break),atype<void>()); 
-                    else lgerror("break not in loop") ;}
-    break;
-
-  case 103:
-/* Line 1787 of yacc.c  */
-#line 474 "lg.ypp"
-    { 
-                    if(inloopcount)
-                        (yyval.cexp)= C_F0(new E_throw(E_exception::e_continue),atype<void>()) ;
-                    else lgerror("continue not in loop");}
-    break;
-
-  case 104:
-/* Line 1787 of yacc.c  */
-#line 478 "lg.ypp"
-    { 
-                    if (kkembtype>=0)
-                      (yyval.cexp)= C_F0(new E_throw(E_exception::e_return,(rettype[kkembtype]->CastTo((yyvsp[(2) - (3)].cexp))).OnReturn()) ,atype<void>());
-                     else lgerror(" return not in routine ") ;}
-    break;
-
-  case 105:
-/* Line 1787 of yacc.c  */
-#line 485 "lg.ypp"
-    {(yyval.cexp) =  (yyvsp[(7) - (7)].cexp); }
-    break;
-
-  case 106:
-/* Line 1787 of yacc.c  */
-#line 488 "lg.ypp"
-    { 
-   Block::open(currentblock);
-   (yyval.args) = currentblock->NewVar<LocalVariable>((yyvsp[(2) - (7)].str),atype<double*>());
-   (yyval.args)+= (yyvsp[(4) - (7)].cexp);
-   (yyval.args)+= (yyvsp[(6) - (7)].cexp) ;}
-    break;
-
-  case 107:
-/* Line 1787 of yacc.c  */
-#line 494 "lg.ypp"
-    {   
-   (yyval.args) = ((yyvsp[(1) - (2)].args) += (yyvsp[(2) - (2)].cexp));
-   currentblock->close(currentblock);}
-    break;
-
-  case 109:
-/* Line 1787 of yacc.c  */
-#line 501 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 116:
-/* Line 1787 of yacc.c  */
-#line 515 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 117:
-/* Line 1787 of yacc.c  */
-#line 516 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"+=",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 118:
-/* Line 1787 of yacc.c  */
-#line 517 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"-=",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 119:
-/* Line 1787 of yacc.c  */
-#line 518 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"*=",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 120:
-/* Line 1787 of yacc.c  */
-#line 519 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"/=",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 121:
-/* Line 1787 of yacc.c  */
-#line 520 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,".*=",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 122:
-/* Line 1787 of yacc.c  */
-#line 521 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"./=",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 124:
-/* Line 1787 of yacc.c  */
-#line 527 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"?:",(yyvsp[(1) - (5)].cexp),(yyvsp[(3) - (5)].cexp),(yyvsp[(5) - (5)].cexp));}
-    break;
-
-  case 125:
-/* Line 1787 of yacc.c  */
-#line 528 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"::",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 126:
-/* Line 1787 of yacc.c  */
-#line 529 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,"::",(yyvsp[(1) - (5)].cexp),(yyvsp[(3) - (5)].cexp),(yyvsp[(5) - (5)].cexp));}
-    break;
-
-  case 128:
-/* Line 1787 of yacc.c  */
-#line 534 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 129:
-/* Line 1787 of yacc.c  */
-#line 535 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 130:
-/* Line 1787 of yacc.c  */
-#line 536 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 131:
-/* Line 1787 of yacc.c  */
-#line 537 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 132:
-/* Line 1787 of yacc.c  */
-#line 538 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 133:
-/* Line 1787 of yacc.c  */
-#line 539 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 134:
-/* Line 1787 of yacc.c  */
-#line 540 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 135:
-/* Line 1787 of yacc.c  */
-#line 541 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 136:
-/* Line 1787 of yacc.c  */
-#line 542 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 137:
-/* Line 1787 of yacc.c  */
-#line 543 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 138:
-/* Line 1787 of yacc.c  */
-#line 544 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 139:
-/* Line 1787 of yacc.c  */
-#line 545 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 140:
-/* Line 1787 of yacc.c  */
-#line 546 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 141:
-/* Line 1787 of yacc.c  */
-#line 547 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 142:
-/* Line 1787 of yacc.c  */
-#line 548 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 143:
-/* Line 1787 of yacc.c  */
-#line 549 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 144:
-/* Line 1787 of yacc.c  */
-#line 550 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 145:
-/* Line 1787 of yacc.c  */
-#line 551 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 146:
-/* Line 1787 of yacc.c  */
-#line 552 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 147:
-/* Line 1787 of yacc.c  */
-#line 557 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(1) - (1)].cexp);}
-    break;
-
-  case 148:
-/* Line 1787 of yacc.c  */
-#line 558 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,":");}
-    break;
-
-  case 149:
-/* Line 1787 of yacc.c  */
-#line 559 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,":",(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 150:
-/* Line 1787 of yacc.c  */
-#line 560 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,":",(yyvsp[(1) - (5)].cexp),(yyvsp[(3) - (5)].cexp),(yyvsp[(5) - (5)].cexp));}
-    break;
-
-  case 151:
-/* Line 1787 of yacc.c  */
-#line 564 "lg.ypp"
-    {(yyval.args)=0;}
-    break;
-
-  case 152:
-/* Line 1787 of yacc.c  */
-#line 565 "lg.ypp"
-    {(yyval.args)=Find((yyvsp[(1) - (1)].str));}
-    break;
-
-  case 153:
-/* Line 1787 of yacc.c  */
-#line 566 "lg.ypp"
-    {(yyval.args)=Find((yyvsp[(1) - (1)].str));}
-    break;
-
-  case 154:
-/* Line 1787 of yacc.c  */
-#line 567 "lg.ypp"
-    {(yyval.args)=Find((yyvsp[(1) - (1)].str));}
-    break;
-
-  case 155:
-/* Line 1787 of yacc.c  */
-#line 568 "lg.ypp"
-    { (yyval.args)=make_pair<const char *,const C_F0>((yyvsp[(1) - (3)].str),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 156:
-/* Line 1787 of yacc.c  */
-#line 569 "lg.ypp"
-    {(yyval.args)=(yyvsp[(1) - (1)].cexp);}
-    break;
-
-  case 157:
-/* Line 1787 of yacc.c  */
-#line 570 "lg.ypp"
-    { (yyval.args) = ((yyvsp[(1) - (3)].args) += Find((yyvsp[(3) - (3)].str))) ;}
-    break;
-
-  case 158:
-/* Line 1787 of yacc.c  */
-#line 571 "lg.ypp"
-    { (yyval.args) = ((yyvsp[(1) - (3)].args) += Find((yyvsp[(3) - (3)].str))) ;}
-    break;
-
-  case 159:
-/* Line 1787 of yacc.c  */
-#line 572 "lg.ypp"
-    { (yyval.args) = ((yyvsp[(1) - (3)].args) += Find((yyvsp[(3) - (3)].str))) ;}
-    break;
-
-  case 160:
-/* Line 1787 of yacc.c  */
-#line 573 "lg.ypp"
-    { (yyval.args) = ((yyvsp[(1) - (3)].args) += (yyvsp[(3) - (3)].cexp)) ;}
-    break;
-
-  case 161:
-/* Line 1787 of yacc.c  */
-#line 574 "lg.ypp"
-    { (yyval.args)= ((yyvsp[(1) - (5)].args)+= make_pair<const char *,const C_F0>((yyvsp[(3) - (5)].str),(yyvsp[(5) - (5)].cexp))) ;}
-    break;
-
-  case 162:
-/* Line 1787 of yacc.c  */
-#line 577 "lg.ypp"
-    {(yyval.args)=(yyvsp[(1) - (1)].cexp);}
-    break;
-
-  case 163:
-/* Line 1787 of yacc.c  */
-#line 578 "lg.ypp"
-    {(yyval.args) = ((yyvsp[(1) - (3)].args) += (yyvsp[(3) - (3)].cexp)) ;}
-    break;
-
-  case 165:
-/* Line 1787 of yacc.c  */
-#line 583 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(1) - (2)].oper),(yyvsp[(2) - (2)].cexp));}
-    break;
-
-  case 167:
-/* Line 1787 of yacc.c  */
-#line 587 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 168:
-/* Line 1787 of yacc.c  */
-#line 588 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (3)].oper),(yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].cexp));}
-    break;
-
-  case 169:
-/* Line 1787 of yacc.c  */
-#line 589 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheOperators,(yyvsp[(2) - (2)].oper),(yyvsp[(1) - (2)].cexp));}
-    break;
-
-  case 170:
-/* Line 1787 of yacc.c  */
-#line 593 "lg.ypp"
-    {(yyval.cexp)=Find((yyvsp[(1) - (1)].str));}
-    break;
-
-  case 171:
-/* Line 1787 of yacc.c  */
-#line 594 "lg.ypp"
-    {(yyval.cexp)= CConstant((yyvsp[(1) - (1)].lnum));}
-    break;
-
-  case 172:
-/* Line 1787 of yacc.c  */
-#line 595 "lg.ypp"
-    {(yyval.cexp)= CConstant((yyvsp[(1) - (1)].dnum));}
-    break;
-
-  case 173:
-/* Line 1787 of yacc.c  */
-#line 596 "lg.ypp"
-    {(yyval.cexp)= CConstant(complex<double>(0,(yyvsp[(1) - (1)].dnum)));}
-    break;
-
-  case 174:
-/* Line 1787 of yacc.c  */
-#line 597 "lg.ypp"
-    {(yyval.cexp)= CConstant<const char *>((yyvsp[(1) - (1)].str));}
-    break;
-
-  case 175:
-/* Line 1787 of yacc.c  */
-#line 598 "lg.ypp"
-    {(yyval.cexp)=C_F0((yyvsp[(1) - (4)].cexp),(yyvsp[(2) - (4)].oper),(yyvsp[(3) - (4)].args));}
-    break;
-
-  case 176:
-/* Line 1787 of yacc.c  */
-#line 599 "lg.ypp"
-    {(yyval.cexp)=C_F0((yyvsp[(1) - (4)].cexp),(yyvsp[(2) - (4)].oper),(yyvsp[(3) - (4)].cexp));}
-    break;
-
-  case 177:
-/* Line 1787 of yacc.c  */
-#line 600 "lg.ypp"
-    {(yyval.cexp)=C_F0((yyvsp[(1) - (6)].cexp),(yyvsp[(2) - (6)].oper),(yyvsp[(3) - (6)].cexp),(yyvsp[(5) - (6)].cexp));}
-    break;
-
-  case 178:
-/* Line 1787 of yacc.c  */
-#line 601 "lg.ypp"
-    {(yyval.cexp)=C_F0((yyvsp[(1) - (3)].cexp),"[]");}
-    break;
-
-  case 179:
-/* Line 1787 of yacc.c  */
-#line 602 "lg.ypp"
-    { (yyval.cexp)=C_F0((yyvsp[(1) - (3)].cexp),(yyvsp[(3) - (3)].str)) ;}
-    break;
-
-  case 180:
-/* Line 1787 of yacc.c  */
-#line 603 "lg.ypp"
-    { (yyval.cexp)=C_F0(Find((yyvsp[(1) - (3)].str)),(yyvsp[(3) - (3)].str)) ;}
-    break;
-
-  case 181:
-/* Line 1787 of yacc.c  */
-#line 604 "lg.ypp"
-    { (yyval.cexp)=C_F0(Find((yyvsp[(1) - (4)].str)),(yyvsp[(2) - (4)].oper),(yyvsp[(3) - (4)].args)) ;}
-    break;
-
-  case 182:
-/* Line 1787 of yacc.c  */
-#line 605 "lg.ypp"
-    { (yyval.cexp)=C_F0(Find((yyvsp[(1) - (3)].str)),(yyvsp[(3) - (3)].str)) ;}
-    break;
-
-  case 183:
-/* Line 1787 of yacc.c  */
-#line 606 "lg.ypp"
-    { (yyval.cexp)=C_F0(Find((yyvsp[(1) - (4)].str)),(yyvsp[(2) - (4)].oper),(yyvsp[(3) - (4)].args)) ;}
-    break;
-
-  case 184:
-/* Line 1787 of yacc.c  */
-#line 607 "lg.ypp"
-    { (yyval.cexp)=C_F0(Find((yyvsp[(1) - (3)].str)),(yyvsp[(3) - (3)].str)) ;}
-    break;
-
-  case 185:
-/* Line 1787 of yacc.c  */
-#line 608 "lg.ypp"
-    { (yyval.cexp)=C_F0(Find((yyvsp[(1) - (4)].str)),(yyvsp[(2) - (4)].oper),(yyvsp[(3) - (4)].args)) ;}
-    break;
-
-  case 186:
-/* Line 1787 of yacc.c  */
-#line 609 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheRightOperators,(yyvsp[(2) - (2)].oper),(yyvsp[(1) - (2)].cexp));}
-    break;
-
-  case 187:
-/* Line 1787 of yacc.c  */
-#line 610 "lg.ypp"
-    {(yyval.cexp)=C_F0(TheRightOperators,(yyvsp[(2) - (2)].oper),(yyvsp[(1) - (2)].cexp));}
-    break;
-
-  case 188:
-/* Line 1787 of yacc.c  */
-#line 611 "lg.ypp"
-    {
-             if ((yyvsp[(1) - (4)].type)->right()->CastingFrom((yyvsp[(3) - (4)].cexp).left()) ) 
-                (yyval.cexp)=(yyvsp[(1) - (4)].type)->right()->CastTo((yyvsp[(3) - (4)].cexp))  ;
-             else { (yyval.cexp)=(yyvsp[(1) - (4)].type)->right()->Find("<--",basicAC_F0_wa((yyvsp[(3) - (4)].cexp)));
-             if (!(yyval.cexp).left()) { cerr << " no wait to change " << (yyvsp[(3) - (4)].cexp).left()->right()->name() << " in " << 
-                                        (yyvsp[(1) - (4)].type)->right()->name() << endl;
-                                CompileError(" Error in type(exp) "); }
-             }
-            }
-    break;
-
-  case 189:
-/* Line 1787 of yacc.c  */
-#line 620 "lg.ypp"
-    {(yyval.cexp)=(yyvsp[(2) - (3)].cexp);}
-    break;
-
-  case 190:
-/* Line 1787 of yacc.c  */
-#line 621 "lg.ypp"
-    { (yyval.cexp)=C_F0(TheOperators,"[]",(yyvsp[(2) - (3)].args));}
-    break;
-
-
-/* Line 1787 of yacc.c  */
-#line 3145 "lg.tab.cpp"
-      default: break;
-    }
-  /* User semantic actions sometimes alter yychar, and that requires
-     that yytoken be updated with the new translation.  We take the
-     approach of translating immediately before every use of yytoken.
-     One alternative is translating here after every semantic action,
-     but that translation would be missed if the semantic action invokes
-     YYABORT, YYACCEPT, or YYERROR immediately after altering yychar or
-     if it invokes YYBACKUP.  In the case of YYABORT or YYACCEPT, an
-     incorrect destructor might then be invoked immediately.  In the
-     case of YYERROR or YYBACKUP, subsequent parser actions might lead
-     to an incorrect destructor call or verbose syntax error message
-     before the lookahead is translated.  */
-  YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
-
-  YYPOPSTACK (yylen);
-  yylen = 0;
-  YY_STACK_PRINT (yyss, yyssp);
-
-  *++yyvsp = yyval;
-
-  /* Now `shift' the result of the reduction.  Determine what state
-     that goes to, based on the state we popped back to and the rule
-     number reduced by.  */
-
-  yyn = yyr1[yyn];
-
-  yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
-  if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
-    yystate = yytable[yystate];
-  else
-    yystate = yydefgoto[yyn - YYNTOKENS];
-
-  goto yynewstate;
-
-
-/*------------------------------------.
-| yyerrlab -- here on detecting error |
-`------------------------------------*/
-yyerrlab:
-  /* Make sure we have latest lookahead translation.  See comments at
-     user semantic actions for why this is necessary.  */
-  yytoken = yychar == YYEMPTY ? YYEMPTY : YYTRANSLATE (yychar);
-
-  /* If not already recovering from an error, report this error.  */
-  if (!yyerrstatus)
-    {
-      ++yynerrs;
-#if ! YYERROR_VERBOSE
-      yyerror (YY_("syntax error"));
-#else
-# define YYSYNTAX_ERROR yysyntax_error (&yymsg_alloc, &yymsg, \
-                                        yyssp, yytoken)
-      {
-        char const *yymsgp = YY_("syntax error");
-        int yysyntax_error_status;
-        yysyntax_error_status = YYSYNTAX_ERROR;
-        if (yysyntax_error_status == 0)
-          yymsgp = yymsg;
-        else if (yysyntax_error_status == 1)
-          {
-            if (yymsg != yymsgbuf)
-              YYSTACK_FREE (yymsg);
-            yymsg = (char *) YYSTACK_ALLOC (yymsg_alloc);
-            if (!yymsg)
-              {
-                yymsg = yymsgbuf;
-                yymsg_alloc = sizeof yymsgbuf;
-                yysyntax_error_status = 2;
-              }
-            else
-              {
-                yysyntax_error_status = YYSYNTAX_ERROR;
-                yymsgp = yymsg;
-              }
-          }
-        yyerror (yymsgp);
-        if (yysyntax_error_status == 2)
-          goto yyexhaustedlab;
-      }
-# undef YYSYNTAX_ERROR
-#endif
-    }
-
-
-
-  if (yyerrstatus == 3)
-    {
-      /* If just tried and failed to reuse lookahead token after an
-	 error, discard it.  */
-
-      if (yychar <= YYEOF)
-	{
-	  /* Return failure if at end of input.  */
-	  if (yychar == YYEOF)
-	    YYABORT;
-	}
-      else
-	{
-	  yydestruct ("Error: discarding",
-		      yytoken, &yylval);
-	  yychar = YYEMPTY;
-	}
-    }
-
-  /* Else will try to reuse lookahead token after shifting the error
-     token.  */
-  goto yyerrlab1;
-
-
-/*---------------------------------------------------.
-| yyerrorlab -- error raised explicitly by YYERROR.  |
-`---------------------------------------------------*/
-yyerrorlab:
-
-  /* Pacify compilers like GCC when the user code never invokes
-     YYERROR and the label yyerrorlab therefore never appears in user
-     code.  */
-  if (/*CONSTCOND*/ 0)
-     goto yyerrorlab;
-
-  /* Do not reclaim the symbols of the rule which action triggered
-     this YYERROR.  */
-  YYPOPSTACK (yylen);
-  yylen = 0;
-  YY_STACK_PRINT (yyss, yyssp);
-  yystate = *yyssp;
-  goto yyerrlab1;
-
-
-/*-------------------------------------------------------------.
-| yyerrlab1 -- common code for both syntax error and YYERROR.  |
-`-------------------------------------------------------------*/
-yyerrlab1:
-  yyerrstatus = 3;	/* Each real token shifted decrements this.  */
-
-  for (;;)
-    {
-      yyn = yypact[yystate];
-      if (!yypact_value_is_default (yyn))
-	{
-	  yyn += YYTERROR;
-	  if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
-	    {
-	      yyn = yytable[yyn];
-	      if (0 < yyn)
-		break;
-	    }
-	}
-
-      /* Pop the current state because it cannot handle the error token.  */
-      if (yyssp == yyss)
-	YYABORT;
-
-
-      yydestruct ("Error: popping",
-		  yystos[yystate], yyvsp);
-      YYPOPSTACK (1);
-      yystate = *yyssp;
-      YY_STACK_PRINT (yyss, yyssp);
-    }
-
-  YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
-  *++yyvsp = yylval;
-  YY_IGNORE_MAYBE_UNINITIALIZED_END
-
-
-  /* Shift the error token.  */
-  YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
-
-  yystate = yyn;
-  goto yynewstate;
-
-
-/*-------------------------------------.
-| yyacceptlab -- YYACCEPT comes here.  |
-`-------------------------------------*/
-yyacceptlab:
-  yyresult = 0;
-  goto yyreturn;
-
-/*-----------------------------------.
-| yyabortlab -- YYABORT comes here.  |
-`-----------------------------------*/
-yyabortlab:
-  yyresult = 1;
-  goto yyreturn;
-
-#if !defined yyoverflow || YYERROR_VERBOSE
-/*-------------------------------------------------.
-| yyexhaustedlab -- memory exhaustion comes here.  |
-`-------------------------------------------------*/
-yyexhaustedlab:
-  yyerror (YY_("memory exhausted"));
-  yyresult = 2;
-  /* Fall through.  */
-#endif
-
-yyreturn:
-  if (yychar != YYEMPTY)
-    {
-      /* Make sure we have latest lookahead translation.  See comments at
-         user semantic actions for why this is necessary.  */
-      yytoken = YYTRANSLATE (yychar);
-      yydestruct ("Cleanup: discarding lookahead",
-                  yytoken, &yylval);
-    }
-  /* Do not reclaim the symbols of the rule which action triggered
-     this YYABORT or YYACCEPT.  */
-  YYPOPSTACK (yylen);
-  YY_STACK_PRINT (yyss, yyssp);
-  while (yyssp != yyss)
-    {
-      yydestruct ("Cleanup: popping",
-		  yystos[*yyssp], yyvsp);
-      YYPOPSTACK (1);
-    }
-#ifndef yyoverflow
-  if (yyss != yyssa)
-    YYSTACK_FREE (yyss);
-#endif
-#if YYERROR_VERBOSE
-  if (yymsg != yymsgbuf)
-    YYSTACK_FREE (yymsg);
-#endif
-  /* Make sure YYID is used.  */
-  return YYID (yyresult);
-}
-
-
-/* Line 2050 of yacc.c  */
-#line 626 "lg.ypp"
- 
-
-
-#include <fstream>
-using namespace std;
-// bool lgdebug;
-// bool lexdebug;
-void ForDebug();
-void ForDebug()
-{
-  int i=0;
-  i++;
-}
-//extern void ShowAlloc(const char *s, size_t lg);
-//extern void ShowNbAlloc(const char *s);
-void init_lgfem() ;
-void init_lgmesh() ;
-void init_lgmesh3() ;
-void init_algo();
-bool withrgraphique = false;
-//string  StrVersionNumber();
-
-int Compile()
-{
-  extern   YYSTYPE *plglval;  // modif FH 
-  plglval = &lglval;
-  int retvalue=0;
-  //  int ok;
-  
-  currentblock=0;
-  Block::open(currentblock);  
-  try {
-    UnShowAlloc =0;
-    retvalue=yyparse (); //  compile
-   
-    if(retvalue==0)  
-      if(currentblock) 
-	{retvalue=1; if(!mpirank) cerr <<  "Error:a block is not close" << endl; }  
-      else {
-	  if( verbosity  ) {
-	      UnShowAlloc =1;
-	      cerr << " CodeAlloc : nb ptr  "<< CodeAlloc::nb << ",  size :"  <<  CodeAlloc::lg << " mpirank: " <<mpirank << endl;
-	      if(!mpirank) cerr <<  "Bien: On a fini Normalement" << endl; }
-	}
-  }
-
-  catch (Error & e) 
-    {
-      retvalue=e.errcode();
-      if(mpirank ==0)
-      cerr << "error " << e.what() 
-	   << "\n code = "<<  retvalue << " mpirank: " <<mpirank  << endl;
-    }
-  catch(std::ios_base::failure & e)
-    {
-     cerr << "std  catch io failure \n what : " << e.what() << endl;; 
-     cerr << " at exec line  " << TheCurrentLine << " mpirank: " <<mpirank  << endl; 
-    }
-  catch(std::exception & e)
-    {
-     cerr << "std  catch exception \n what : " << e.what() << endl;; 
-     cerr << " at exec line  " << TheCurrentLine << " mpirank: " <<mpirank  << endl; 
-    
-    }
-  catch(...)
-   {
-     cerr << "Strange catch exception ???\n"; 
-     cerr << " at exec line  " << TheCurrentLine << " mpirank: " <<mpirank << endl; 
-    }
-  return retvalue; 
-}
-static void SetcppIo()
-{
-
-#ifdef _WIN32XXXX
-  freopen("conin$", "r", stdin);
-  freopen("conout$", "w", stdout);
-  using namespace __gnu_cxx;
-  //  stdio_filebuf<char> * ccout = new stdio_filebuf<char>(stdout, std::ios_base::out);
-  static  stdio_filebuf<char> ccout(stdout, std::ios_base::out);
-  static  stdio_filebuf<char> ccin(stdin, std::ios_base::in);
-   //stdio_filebuf<char> *ccin= new stdio_filebuf<char>(stdin, std::ios_base::in);
-   
-   cout.rdbuf(&ccout);
-   cin.rdbuf(&ccin);
-   cerr.rdbuf(&ccout);
-   cout << " -- SetcppIo --" << endl; 
-#endif
-   ios::sync_with_stdio();
-}
-// pour l'environement.
-extern const char *  prognamearg;
-extern  bool echo_edp;
-int mainff (int  argc, char **argv)
-{
-    
-   ffapi::init(); 
-  if(argc)  
-    prognamearg=argv[0];
-
-    int vvold=verbosity; 
-    if(mpirank !=0) verbosity=0;
-  SetcppIo();
-  GetEnvironment();   
-    vvold=verbosity; 
-    if(mpirank !=0) verbosity=0; 
-  //  size_t lg000;
- // ShowAlloc("begin main ",lg000);
-  int retvalue=0;
-
-   if (initparallele)initparallele(argc,argv);
-
-  CPUcompileInit= CPUtime();
-  withrgraphique = false;
-   atexit(ForDebug);
-//  AllFunctions::maptype  xlocal;
-//  local=&xlocal;
-  lexdebug = false;
-  lgdebug = false;
-
-  char *  cc= new char [1024];
-  //  istream * ccin=0;
-  if ( ! (getprog(cc,argc,argv) >0)  ) 
-    {
-      cout << "-- FreeFem++ v" << StrVersionNumber() << " (error parameter!)\n"  ;
-      if(ThePlotStream) {pclose(ThePlotStream); ThePlotStream=0;}  
-      return 1; 
-    }
-   
-  if(verbosity && (mpirank==0)) { 
-      cout << "-- FreeFem++ v" << StrVersionNumber() << endl;
-      if(verbosity>1) cout << "   file :" << cc << " " << " verbosity= " << verbosity << endl;
-  }
-    
-    KN<String> karg(argc);
-    for(int i=0;i< argc;++i)
-	karg[i]=argv[i];
-    pkarg= &karg;
-
-  zzzfff = Newlex(cout,echo_edp);
-  
-  
-/*  
-  ccin= new ifstream(cc);
-  if (argc >1 && (ccin!=0) )  
-     ccin= new ifstream(argv[1]),throwassert(ccin);
-  if (ccin!=0) 
-    zzzfff = new  mylex(*ccin,cout) ;
-  else 
-    zzzfff = new  mylex(cin,cout) ;
-*/    
-//  les motsclefs    
-   zzzfff->Add("include",INCLUDE);
-   zzzfff->Add("load",LOAD);
-   zzzfff->Add("while",WHILE);
-   zzzfff->Add("for",FOR);
-   zzzfff->Add("if",IF);
-   zzzfff->Add("else",ELSE);
-   zzzfff->Add("end",ENDOFFILE);
-   zzzfff->Add("break",BREAK);
-   zzzfff->Add("continue",CONTINUE);
-   zzzfff->Add("return",RETURN);
-   zzzfff->Add("border",BORDER);
-   zzzfff->Add("fespace",FESPACEID);
-   zzzfff->Add("try",TRY);
-   zzzfff->Add("catch",CATCH);
-   zzzfff->Add("throw",THROW);
-//   Init_map_type();
-   if(verbosity>2 || (mpirank==0 ) ) cout << " Load: ";
-   callInitsFunct() ; //  init for dynamique libs ...
-  // init_lgfem() ;
-   init_lgmesh() ;
-   init_lgmesh3() ;
-   init_algo();
-
-#ifdef HAVE_LIBARPACK
-   init_eigenvalue();
-#endif   
-
-   if(init_lgparallele)  init_lgparallele(); 
-  //  callInitsFunct() ; //  init for dynamique libs ...
-
-   if(verbosity>2 || mpirank==0)  cout << endl;
-  zzzfff->input(cc);
-  EnvironmentLoad(); // just before compile
-  verbosity=vvold; 
-    
-  retvalue= Compile();
-   // cout << " xxxxx " <<  retvalue << " " << ThePlotStream << endl;
-
-  if(end_parallele) end_parallele();
-
-  //  currentblock->close(currentblock).eval(thestack);
-  fingraphique();
-  if(ThePlotStream) {pclose(ThePlotStream); ThePlotStream=0;}  
-  Destroylex( zzzfff);
-  
-   // ClearMem();
-  return retvalue;
-}
-
-
-
diff --git a/src/lglib/lg.tab.hpp b/src/lglib/lg.tab.hpp
deleted file mode 100644
index 0bb4ebc..0000000
--- a/src/lglib/lg.tab.hpp
+++ /dev/null
@@ -1,147 +0,0 @@
-/* A Bison parser, made by GNU Bison 2.7.12-4996.  */
-
-/* Bison interface for Yacc-like parsers in C
-   
-      Copyright (C) 1984, 1989-1990, 2000-2013 Free Software Foundation, Inc.
-   
-   This program is free software: you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation, either version 3 of the License, or
-   (at your option) any later version.
-   
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-   
-   You should have received a copy of the GNU General Public License
-   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
-
-/* As a special exception, you may create a larger work that contains
-   part or all of the Bison parser skeleton and distribute that work
-   under terms of your choice, so long as that work isn't itself a
-   parser generator using the skeleton or a modified version thereof
-   as a parser skeleton.  Alternatively, if you modify or redistribute
-   the parser skeleton itself, you may (at your option) remove this
-   special exception, which will cause the skeleton and the resulting
-   Bison output files to be licensed under the GNU General Public
-   License without this special exception.
-   
-   This special exception was added by the Free Software Foundation in
-   version 2.2 of Bison.  */
-
-#ifndef YY_LG_LG_TAB_HPP_INCLUDED
-# define YY_LG_LG_TAB_HPP_INCLUDED
-/* Enabling traces.  */
-#ifndef YYDEBUG
-# define YYDEBUG 1
-#endif
-#if YYDEBUG
-extern int lgdebug;
-#endif
-
-/* Tokens.  */
-#ifndef YYTOKENTYPE
-# define YYTOKENTYPE
-   /* Put the tokens into the symbol table, so that GDB and other debuggers
-      know about them.  */
-   enum yytokentype {
-     IF = 258,
-     ELSE = 259,
-     SET = 260,
-     GTGT = 261,
-     LTLT = 262,
-     OR = 263,
-     AND = 264,
-     NE = 265,
-     EQ = 266,
-     GE = 267,
-     LE = 268,
-     DOTSLASH = 269,
-     DOTSTAR = 270,
-     MOINSMOINS = 271,
-     PLUSPLUS = 272,
-     UNARY = 273,
-     LNUM = 274,
-     DNUM = 275,
-     CNUM = 276,
-     ID = 277,
-     FESPACEID = 278,
-     IDPARAM = 279,
-     STRING = 280,
-     ENDOFFILE = 281,
-     INCLUDE = 282,
-     LOAD = 283,
-     BIDON = 284,
-     FOR = 285,
-     WHILE = 286,
-     BREAK = 287,
-     CONTINUE = 288,
-     RETURN = 289,
-     TRY = 290,
-     CATCH = 291,
-     THROW = 292,
-     TYPE = 293,
-     FUNCTION = 294,
-     FESPACE = 295,
-     FESPACE1 = 296,
-     FESPACE3 = 297,
-     PLUSEQ = 298,
-     MOINSEQ = 299,
-     MULEQ = 300,
-     DIVEQ = 301,
-     DOTMULEQ = 302,
-     DOTDIVEQ = 303,
-     ARROW = 304,
-     BORDER = 305,
-     CURVE = 306,
-     SOLVE = 307
-   };
-#endif
-
-
-#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
-typedef union YYSTYPE
-{
-/* Line 2053 of yacc.c  */
-#line 124 "lg.ypp"
- 
- double dnum;
- long lnum;
- char * str;
- char oper[8];
- CC_F0 cexp;
- Routine   *routine;
- AC_F0 args;
- aType type;
- CListOfInst cinst;
- Block * block; 
- ListOfId *clist_id;
-/* ListCatch * clist_Catchs;*/
-
-
-/* Line 2053 of yacc.c  */
-#line 125 "lg.tab.hpp"
-} YYSTYPE;
-# define YYSTYPE_IS_TRIVIAL 1
-# define yystype YYSTYPE /* obsolescent; will be withdrawn */
-# define YYSTYPE_IS_DECLARED 1
-#endif
-
-extern YYSTYPE lglval;
-
-#ifdef YYPARSE_PARAM
-#if defined __STDC__ || defined __cplusplus
-int lgparse (void *YYPARSE_PARAM);
-#else
-int lgparse ();
-#endif
-#else /* ! YYPARSE_PARAM */
-#if defined __STDC__ || defined __cplusplus
-int lgparse (void);
-#else
-int lgparse ();
-#endif
-#endif /* ! YYPARSE_PARAM */
-
-#endif /* !YY_LG_LG_TAB_HPP_INCLUDED  */

-- 
FreeFem++ packaging



More information about the debian-science-commits mailing list