source: git/Singular/tesths.cc @ 3b1a83c

spielwiese
Last change on this file since 3b1a83c was 3b1a83c, checked in by Hans Schönemann <hannes@…>, 23 years ago
*hannes: dagstuhl improvements git-svn-id: file:///usr/local/Singular/svn/trunk@5653 2c84dea3-7e68-4137-9b89-c4e89433aadc
  • Property mode set to 100644
File size: 6.0 KB
Line 
1/****************************************
2*  Computer Algebra System SINGULAR     *
3****************************************/
4/* $Id: tesths.cc,v 1.88 2001-10-23 14:04:26 Singular Exp $ */
5
6/*
7* ABSTRACT - initialize SINGULARs components, run Script and start SHELL
8*/
9
10#include <unistd.h>
11#include <string.h>
12#include <stdio.h>
13#include <stddef.h>
14#include <stdlib.h>
15#include <time.h>
16#include <errno.h>
17#include "mod2.h"
18#include "tok.h"
19#include "ipshell.h"
20#include "sing_dld.h"
21#include "febase.h"
22#include "cntrlc.h"
23#include "omalloc.h"
24#include "silink.h"
25#include "ipid.h"
26#include "timer.h"
27#include "sdb.h"
28#include "fegetopt.h"
29#include "feOpt.h"
30#include "distrib.h"
31#include "version.h"
32#include "slInit.h"
33
34#ifdef HAVE_FACTORY
35#define SI_DONT_HAVE_GLOBAL_VARS
36#include <factory.h>
37#endif
38
39char *singular_date=__DATE__ " " __TIME__;
40
41/*0 implementation*/
42int main(          /* main entry to Singular */
43    int argc,      /* number of parameter */
44    char** argv)   /* parameter array */
45{
46#ifdef INIT_BUG
47  jjInitTab1();
48#endif
49#ifdef GENTABLE
50  extern void ttGen1();
51  extern void ttGen2();
52  #ifndef __MWERKS__
53    extern void mpsr_ttGen(); // For initialization of (CMD, MP_COP) tables
54    mpsr_ttGen();
55  #endif
56  ttGen1();
57  ttGen2();
58#else
59  // Don't worry: ifdef OM_NDEBUG, then all these calls are undef'ed
60  omInitRet_2_Info(argv[0]);
61  omInitGetBackTrace();
62
63  /* initialize components */
64  siRandomStart=inits();
65  feOptSpec[FE_OPT_RANDOM].value = (void*) siRandomStart;
66  int optc, option_index;
67  char* errormsg;
68
69  // do this first, because -v might print version path
70  feInitResources(argv[0]);
71
72  // parse command line options
73  while((optc = fe_getopt_long(argc, argv,
74                               SHORT_OPTS_STRING, feOptSpec, &option_index))
75        != EOF)
76  {
77    if (optc == '?' || optc == 0)
78    {
79      fprintf(stderr, "Use '%s --help' for a complete list of options\n", feArgv0);
80      exit(1);
81    }
82
83    if (optc != LONG_OPTION_RETURN)
84      option_index = feGetOptIndex(optc);
85
86    assume(option_index >= 0 && option_index < (int) FE_OPT_UNDEF);
87
88    if (fe_optarg == NULL &&
89        (feOptSpec[option_index].type == feOptBool ||
90         feOptSpec[option_index].has_arg == optional_argument))
91      errormsg = feSetOptValue((feOptIndex) option_index, (int) 1);
92    else
93      errormsg = feSetOptValue((feOptIndex) option_index, fe_optarg);
94
95    if (errormsg)
96    {
97      if (fe_optarg == NULL)
98        fprintf(stderr, "Error: Option '--%s' %s\n",
99               feOptSpec[option_index].name, errormsg);
100      else
101        fprintf(stderr, "Error: Option '--%s=%s' %s\n",
102               feOptSpec[option_index].name, fe_optarg, errormsg);
103      fprintf(stderr, "Use '%s --help' for a complete list of options\n", feArgv0);
104      exit(1);
105    }
106    if (optc == 'h') exit(0);
107  }
108
109  /* say hello */
110  {
111#ifdef HAVE_NAMESPACES
112    namespaceroot->push(NULL, "Top", 0, TRUE);
113    idhdl h;
114    h=enterid("Top", 0, PACKAGE_CMD, &IDROOT, TRUE);
115    IDPACKAGE(h) = NSPACK(namespaceroot);
116    IDPACKAGE(h)->language = LANG_TOP;
117#endif /* HAVE_NAMESPACES */
118#ifdef HAVE_NS
119    basePack=(package)omAlloc0(sizeof(*basePack));
120    currPack=basePack;
121    idhdl h;
122    h=enterid("Top", 0, PACKAGE_CMD, &IDROOT, TRUE);
123    IDPACKAGE(h)->language = LANG_TOP;
124    IDPACKAGE(h)=basePack;
125    currPackHdl=h;
126    basePackHdl=h;
127#endif /* HAVE_NAMESPACES */
128  }
129  if (BVERBOSE(0))
130  {
131    (printf)(
132"                     SINGULAR                             /"
133#ifndef MAKE_DISTRIBUTION
134"  Development"
135#endif
136"\n"
137" A Computer Algebra System for Polynomial Computations   /   version %s\n"
138"                                                       0<\n"
139"     by: G.-M. Greuel, G. Pfister, H. Schoenemann        \\   %s\n"
140"FB Mathematik der Universitaet, D-67653 Kaiserslautern    \\\n"
141, S_VERSION1,S_VERSION2);
142  }
143  else
144  {
145#ifdef HAVE_SDB
146    sdb_flags = 0;
147#endif
148#ifdef __MWERKS__
149    memcpy(stderr,stdout,sizeof(FILE));
150#else
151    dup2(1,2);
152#endif
153  }
154  slStandardInit();
155  dlInit(feArgv0);
156  myynest=0;
157  if (! feOptValue(FE_OPT_NO_STDLIB))
158  {
159    int vv=verbose;
160    verbose &= ~Sy_bit(V_LOAD_LIB);
161#ifdef HAVE_NAMESPACES
162    iiLibCmd(omStrDup("standard.lib"),TRUE, TRUE);
163#else /* HAVE_NAMESPACES */
164    iiLibCmd(omStrDup("standard.lib"), TRUE);
165#endif /* HAVE_NAMESPACES */
166    verbose=vv;
167  }
168  errorreported = 0;
169
170  // and again, ifdef OM_NDEBUG this call is undef'ed
171  // otherwise, it marks all memory allocated so far as static
172  // i.e. as memory which is not mention on omPrintUsedAddr:
173  //omMarkMemoryAsStatic();
174
175  setjmp(si_start_jmpbuf);
176
177  // Now, put things on the stack of stuff to do
178  // Last thing to do is to execute given scripts
179  if (fe_optind < argc)
180  {
181    int i = argc - 1;
182    FILE *fd;
183    while (i >= fe_optind)
184    {
185      if ((fd = feFopen(argv[i], "r")) == NULL)
186      {
187        Warn("Can not open %s", argv[i]);
188      }
189      else
190      {
191        fclose(fd);
192        newFile(argv[i]);
193      }
194      i--;
195    }
196  }
197  else
198  {
199    currentVoice=feInitStdin();
200  }
201
202  // before scripts, we execute -c, if it was given
203  if (feOptValue(FE_OPT_EXECUTE) != NULL)
204    newBuffer(omStrDup((char*) feOptValue(FE_OPT_EXECUTE)), BT_execute);
205
206  // first thing, however, is to load .singularrc from Singularpath
207  // and cwd/$HOME (in that order).
208  if (! feOptValue(FE_OPT_NO_RC))
209  {
210    char buf[MAXPATHLEN];
211    FILE * rc = feFopen("." DIR_SEPP ".singularrc", "r", buf);
212    if (rc == NULL) rc = feFopen("~" DIR_SEPP ".singularrc", "r", buf);
213    if (rc == NULL) rc = feFopen(".singularrc", "r", buf);
214
215    if (rc != NULL)
216    {
217      if (BVERBOSE(V_LOAD_LIB))
218        Print("// ** executing %s\n", buf);
219      fclose(rc);
220      newFile(buf);
221    }
222  }
223
224  /* start shell */
225  if (fe_fgets_stdin==fe_fgets_dummy)
226  {
227#ifdef HAVE_MPSR
228    BatchDoProc batch_do = slInitMPBatchDo();
229    if (batch_do != NULL)
230      return (*batch_do)((char*) feOptValue(FE_OPT_MPPORT),
231                         (char*) feOptValue(FE_OPT_MPHOST));
232    else
233      return 1;
234#else
235    assume(0);
236#endif
237  }
238  setjmp(si_start_jmpbuf);
239  yyparse();
240  m2_end(0);
241#endif
242  return 0;
243}
244
Note: See TracBrowser for help on using the repository browser.