40char cursortdirp[] =
".";
41char commentchar[] =
"*";
43char highfirst[] =
"highfirst";
44char lowfirst[] =
"lowfirst";
45char procedureextension[] =
"prc";
47#define NUMERICALVALUE 0
55 {(UBYTE *)
"bracketindexsize", NUMERICALVALUE, 0, (LONG)MAXBRACKETBUFFERSIZE}
56 ,{(UBYTE *)
"commentchar", STRINGVALUE, 0, (LONG)commentchar}
57 ,{(UBYTE *)
"compresssize", NUMERICALVALUE, 0, (LONG)COMPRESSBUFFER}
58 ,{(UBYTE *)
"constindex", NUMERICALVALUE, 0, (LONG)NUMFIXED}
59 ,{(UBYTE *)
"continuationlines", NUMERICALVALUE, 0, (LONG)FORTRANCONTINUATIONLINES}
61 ,{(UBYTE *)
"defaultprecision", NUMERICALVALUE, 0, (LONG)DEFAULTPRECISION}
63 ,{(UBYTE *)
"define", DEFINEVALUE, 0, (LONG)0}
64 ,{(UBYTE *)
"dotchar", STRINGVALUE, 0, (LONG)dotchar}
65 ,{(UBYTE *)
"factorizationcache", NUMERICALVALUE, 0, (LONG)FBUFFERSIZE}
66 ,{(UBYTE *)
"filepatches", NUMERICALVALUE, 0, (LONG)MAXFPATCHES}
67 ,{(UBYTE *)
"functionlevels", NUMERICALVALUE, 0, (LONG)MAXFLEVELS}
68 ,{(UBYTE *)
"hidesize", NUMERICALVALUE, 0, (LONG)0}
69 ,{(UBYTE *)
"incdir", PATHVALUE, 0, (LONG)curdirp}
70 ,{(UBYTE *)
"indentspace", NUMERICALVALUE, 0, (LONG)INDENTSPACE}
71 ,{(UBYTE *)
"insidefirst", ONOFFVALUE, 0, (LONG)1}
72 ,{(UBYTE *)
"jumpratio", NUMERICALVALUE, 0, (LONG)JUMPRATIO}
73 ,{(UBYTE *)
"largepatches", NUMERICALVALUE, 0, (LONG)MAXPATCHES}
74 ,{(UBYTE *)
"largesize", NUMERICALVALUE, 0, (LONG)LARGEBUFFER}
75 ,{(UBYTE *)
"maxnumbersize", NUMERICALVALUE, 0, (LONG)0}
77 ,{(UBYTE *)
"maxtermsize", NUMERICALVALUE, 0, (LONG)MAXTER}
79 ,{(UBYTE *)
"maxweight", NUMERICALVALUE, 0, (LONG)MAXWEIGHT}
81 ,{(UBYTE *)
"maxwildcards", NUMERICALVALUE, 0, (LONG)MAXWILDC}
82 ,{(UBYTE *)
"nospacesinnumbers", ONOFFVALUE, 0, (LONG)0}
83 ,{(UBYTE *)
"numstorecaches", NUMERICALVALUE, 0, (LONG)NUMSTORECACHES}
84 ,{(UBYTE *)
"nwritefinalstatistics", ONOFFVALUE, 0, (LONG)0}
85 ,{(UBYTE *)
"nwriteprocessstatistics", ONOFFVALUE, 0, (LONG)0}
86 ,{(UBYTE *)
"nwritestatistics", ONOFFVALUE, 0, (LONG)0}
87 ,{(UBYTE *)
"nwritethreadstatistics", ONOFFVALUE, 0, (LONG)0}
88 ,{(UBYTE *)
"oldfactarg", ONOFFVALUE, 0, (LONG)NEWFACTARG}
89 ,{(UBYTE *)
"oldgcd", ONOFFVALUE, 0, (LONG)1}
90 ,{(UBYTE *)
"oldorder", ONOFFVALUE, 0, (LONG)0}
91 ,{(UBYTE *)
"oldparallelstatistics", ONOFFVALUE, 0, (LONG)0}
92 ,{(UBYTE *)
"parentheses", NUMERICALVALUE, 0, (LONG)MAXPARLEVEL}
93 ,{(UBYTE *)
"path", PATHVALUE, 0, (LONG)curdirp}
94 ,{(UBYTE *)
"procedureextension", STRINGVALUE, 0, (LONG)procedureextension}
95 ,{(UBYTE *)
"processbucketsize", NUMERICALVALUE, 0, (LONG)DEFAULTPROCESSBUCKETSIZE}
96 ,{(UBYTE *)
"resettimeonclear", ONOFFVALUE, 0, (LONG)1}
97 ,{(UBYTE *)
"scratchsize", NUMERICALVALUE, 0, (LONG)SCRATCHSIZE}
98 ,{(UBYTE *)
"shmwinsize", NUMERICALVALUE, 0, (LONG)SHMWINSIZE}
99 ,{(UBYTE *)
"sizestorecache", NUMERICALVALUE, 0, (LONG)SIZESTORECACHE}
100 ,{(UBYTE *)
"smallextension", NUMERICALVALUE, 0, (LONG)SMALLOVERFLOW}
101 ,{(UBYTE *)
"smallsize", NUMERICALVALUE, 0, (LONG)SMALLBUFFER}
102 ,{(UBYTE *)
"sortiosize", NUMERICALVALUE, 0, (LONG)SORTIOSIZE}
103 ,{(UBYTE *)
"sorttype", STRINGVALUE, 0, (LONG)lowfirst}
104 ,{(UBYTE *)
"spectatorsize", NUMERICALVALUE, 0, (LONG)SPECTATORSIZE}
105 ,{(UBYTE *)
"subfilepatches", NUMERICALVALUE, 0, (LONG)SMAXFPATCHES}
106 ,{(UBYTE *)
"sublargepatches", NUMERICALVALUE, 0, (LONG)SMAXPATCHES}
107 ,{(UBYTE *)
"sublargesize", NUMERICALVALUE, 0, (LONG)SLARGEBUFFER}
108 ,{(UBYTE *)
"subsmallextension", NUMERICALVALUE, 0, (LONG)SSMALLOVERFLOW}
109 ,{(UBYTE *)
"subsmallsize", NUMERICALVALUE, 0, (LONG)SSMALLBUFFER}
110 ,{(UBYTE *)
"subsortiosize", NUMERICALVALUE, 0, (LONG)SSORTIOSIZE}
111 ,{(UBYTE *)
"subtermsinsmall", NUMERICALVALUE, 0, (LONG)STERMSSMALL}
112 ,{(UBYTE *)
"tempdir", STRINGVALUE, 0, (LONG)curdirp}
113 ,{(UBYTE *)
"tempsortdir", STRINGVALUE, 0, (LONG)cursortdirp}
114 ,{(UBYTE *)
"termsinsmall", NUMERICALVALUE, 0, (LONG)TERMSSMALL}
115 ,{(UBYTE *)
"threadbucketsize", NUMERICALVALUE, 0, (LONG)DEFAULTTHREADBUCKETSIZE}
116 ,{(UBYTE *)
"threadloadbalancing", ONOFFVALUE, 0, (LONG)DEFAULTTHREADLOADBALANCING}
117 ,{(UBYTE *)
"threads", NUMERICALVALUE, 0, (LONG)DEFAULTTHREADS}
118 ,{(UBYTE *)
"threadscratchoutsize", NUMERICALVALUE, 0, (LONG)THREADSCRATCHOUTSIZE}
119 ,{(UBYTE *)
"threadscratchsize", NUMERICALVALUE, 0, (LONG)THREADSCRATCHSIZE}
120 ,{(UBYTE *)
"threadsortfilesynch", ONOFFVALUE, 0, (LONG)0}
121 ,{(UBYTE *)
"totalsize", ONOFFVALUE, 0, (LONG)2}
122 ,{(UBYTE *)
"workspace", NUMERICALVALUE, 0, (LONG)WORKBUFFER}
123 ,{(UBYTE *)
"wtimestats", ONOFFVALUE, 0, (LONG)2}
134 UBYTE *setbuffer, *s, *t, *u ;
136 setbuffer = LoadInputFile((UBYTE *)setupfilename,SETUPFILE);
145 if ( *s ==
' ' || *s ==
'\t' || *s ==
'*' || *s ==
'#' || *s ==
'\n' ) {
146 while ( *s && *s !=
'\n' ) s++;
148 else if ( tolower(*s) <
'a' || tolower(*s) >
'z' ) {
150 while ( *s && *s !=
'\n' ) s++;
159 while ( tolower(*s) >=
'a' && tolower(*s) <=
'z' ) s++;
161 while ( *s ==
' ' || *s ==
'\t' ) s++;
163 while ( *s && *s !=
'\n' && *s !=
'\r' ) s++;
165 errors += ProcessOption(t,u,0);
167 while ( *s ==
'\n' || *s ==
'\r' ) s++;
169 M_free(setbuffer,
"setup file buffer");
171 if ( errors )
return(1);
180static char *proop1[3] = {
"Setup file",
"Setups in .frm file",
"Setup in environment" };
182int ProcessOption(UBYTE *s1, UBYTE *s2,
int filetype)
185 int n, giveback = 0, error = 0;
186 UBYTE *s, *t, *s2ret;
188 sp = GetSetupPar(s1);
196 UBYTE *s3,*s4,*s5,*s6, c, *start;
200 if ( *s ==
'\\' ) s += 2;
201 else if ( *s ==
'`' ) {
203 while ( *s && *s !=
'\'' ) {
204 if ( *s ==
'\\' ) s++;
208 MesPrint(
"%s: Illegal use of ` character for parameter %s"
209 ,proop1[filetype],s1);
213 s3 = (UBYTE *)getenv((
char *)(start+1));
215 MesPrint(
"%s: Cannot find environment variable %s for parameter %s"
216 ,proop1[filetype],start+1,s1);
221 n1 = start - s2; s4 = s3; n2 = 0;
223 if ( *s4 ==
'\\' ) { s4++; n2++; }
228 if ( *s4 ==
'\\' ) { s4++; n3++; }
231 s4 = (UBYTE *)Malloc1((n1+n2+n3+1)*
sizeof(UBYTE),
"environment in setup");
233 while ( n1-- > 0 ) *s6++ = *s5++;
235 while ( n2-- > 0 ) *s6++ = *s5++;
237 while ( n3-- > 0 ) *s6++ = *s5++;
239 if ( giveback ) M_free(s2,
"environment in setup");
252 if ( *s2 ==
'K' ) { x = x * 1000; s2++; }
253 else if ( *s2 ==
'M' ) { x = x * 1000000; s2++; }
254 else if ( *s2 ==
'G' ) { x = x * 1000000000; s2++; }
255 else if ( *s2 ==
'T' ) { x = x * 1000000000000; s2++; }
256 if ( *s2 && *s2 !=
' ' && *s2 !=
'\t' ) {
257 MesPrint(
"%s: Numerical value expected for parameter %s"
258 ,proop1[filetype],s1);
262 sp->flags = USEDFLAG;
265 if ( StrICmp(s1,(UBYTE *)
"tempsortdir") == 0 ) AM.havesortdir = 1;
268 if ( *s ==
' ' || *s ==
'\t' )
break;
269 if ( *s ==
'\\' ) s++;
273 if ( sp->flags == USEDFLAG && sp->value != 0 )
274 M_free((
void *)(sp->value),
"Process option");
275 sp->value = (LONG)strDup1(s2,
"Process option");
276 sp->flags = USEDFLAG;
279 if ( StrICmp(s1,(UBYTE *)
"incdir") == 0 ) {
282 else if ( StrICmp(s1,(UBYTE *)
"path") == 0 ) {
283 if ( AM.Path ) M_free(AM.Path,
"path");
287 MesPrint(
"Setups: %s not yet implemented",s1);
291 if ( sp->flags == USEDFLAG && sp->value != 0 )
292 M_free((
void *)(sp->value),
"Process option");
293 sp->value = (LONG)strDup1(s2,
"Process option");
294 sp->flags = USEDFLAG;
297 if ( tolower(*s2) ==
'o' && tolower(s2[1]) ==
'n'
298 && ( s2[2] == 0 || s2[2] ==
' ' || s2[2] ==
'\t' ) )
300 else if ( tolower(*s2) ==
'o' && tolower(s2[1]) ==
'f'
301 && tolower(s2[2]) ==
'f'
302 && ( s2[3] == 0 || s2[3] ==
' ' || s2[3] ==
'\t' ) )
305 MesPrint(
"%s: Unrecognized option for parameter %s: %s"
306 ,proop1[filetype],s1,s2);
309 sp->flags = USEDFLAG;
319 Error1(
"Error in setupparameter table for:",s1);
325 MesPrint(
"%s: Keyword not recognized: %s",proop1[filetype],s1);
328 if ( giveback ) M_free(s2ret,
"environment in setup");
344 med = ( hi + lo ) / 2;
345 i = StrICmp(s,(UBYTE *)setupparameters[med].parameter);
346 if ( i == 0 )
return(setupparameters+med);
347 if ( i < 0 ) hi = med-1;
349 }
while ( hi >= lo );
358int RecalcSetups(
void)
362 sp1 = GetSetupPar((UBYTE *)
"threads");
363 if ( AM.totalnumberofthreads > 1 ) sp1->value = AM.totalnumberofthreads - 1;
369 sp = GetSetupPar((UBYTE *)
"filepatches");
370 if ( sp->value < AM.totalnumberofthreads-1 )
371 sp->value = AM.totalnumberofthreads - 1;
373 sp = GetSetupPar((UBYTE *)
"smallsize");
374 sp1 = GetSetupPar((UBYTE *)
"smallextension");
375 if ( 6*sp1->value < 7*sp->value ) sp1->value = (7*sp->value)/6;
376 sp = GetSetupPar((UBYTE *)
"termsinsmall");
377 sp->value = ( sp->value + 15 ) & (-16L);
381 LONG totalsize, minimumsize;
382 sp = GetSetupPar((UBYTE *)
"largesize");
383 totalsize = sp1->value+sp->value;
384 sp2 = GetSetupPar((UBYTE *)
"maxtermsize");
385 AM.MaxTer = sp2->value*
sizeof(WORD);
386 if ( AM.MaxTer < 200*(LONG)(
sizeof(WORD)) ) AM.MaxTer = 200*(LONG)(
sizeof(WORD));
387 if ( AM.MaxTer > MAXPOSITIVE - 200*(LONG)(
sizeof(WORD)) ) AM.MaxTer = MAXPOSITIVE - 200*(LONG)(
sizeof(WORD));
388 AM.MaxTer /=
sizeof(WORD);
389 AM.MaxTer *=
sizeof(WORD);
391 if ( AM.totalnumberofthreads-1 > 2 ) {
392 minimumsize = (2*(AM.totalnumberofthreads-1)-2)*(AM.MaxTer+
393 NUMBEROFBLOCKSINSORT*MINIMUMNUMBEROFTERMS/2*AM.MaxTer);
398 minimumsize = (AM.totalnumberofthreads-1)*(AM.MaxTer+
399 NUMBEROFBLOCKSINSORT*MINIMUMNUMBEROFTERMS*AM.MaxTer);
401 if ( totalsize < minimumsize ) {
402 sp->value = minimumsize - sp1->value;
417 LONG LargeSize, SmallSize, SmallEsize, TermsInSmall, IOsize;
418 int MaxPatches, MaxFpatches, error = 0, i, size;
423 sp = GetSetupPar((UBYTE *)
"threads");
424 if ( sp->value > 0 ) AM.totalnumberofthreads = sp->value+1;
426 AM.OutBuffer = (UBYTE *)Malloc1(AM.OutBufSize+1,
"OutputBuffer");
427 AP.PreAssignStack =(LONG *)Malloc1(AP.MaxPreAssignLevel*
sizeof(LONG *),
"PreAssignStack");
428 for ( i = 0; i < AP.MaxPreAssignLevel; i++ ) AP.PreAssignStack[i] = 0;
429 AC.iBuffer = (UBYTE *)Malloc1(AC.iBufferSize+1,
"statement buffer");
430 AC.iStop = AC.iBuffer + AC.iBufferSize-2;
431 AP.preStart = (UBYTE *)Malloc1(AP.pSize,
"instruction buffer");
432 AP.preStop = AP.preStart + AP.pSize - 3;
435 if ( AP.PreIfStack ) M_free(AP.PreIfStack,
"PreIfStack");
436 AP.PreIfStack = (
int *)Malloc1(AP.MaxPreIfLevel*
sizeof(
int),
437 "Preprocessor if stack");
438 AP.PreIfStack[0] = EXECUTINGIF;
439 sp = GetSetupPar((UBYTE *)
"insidefirst");
440 AM.ginsidefirst = AC.minsidefirst = AC.insidefirst = sp->value;
444 sp = GetSetupPar((UBYTE *)
"maxtermsize");
445 AM.MaxTer = sp->value*
sizeof(WORD);
446 if ( AM.MaxTer < 200*(LONG)(
sizeof(WORD)) ) AM.MaxTer = 200*(LONG)(
sizeof(WORD));
447 if ( AM.MaxTer > MAXPOSITIVE - 200*(LONG)(
sizeof(WORD)) ) AM.MaxTer = MAXPOSITIVE - 200*(LONG)(
sizeof(WORD));
448 AM.MaxTer /= (LONG)
sizeof(WORD);
449 AM.MaxTer *= (LONG)
sizeof(WORD);
453 sp = GetSetupPar((UBYTE *)
"workspace");
454 AM.WorkSize = sp->value;
457 AT.WorkSpace = (WORD *)Malloc1(AM.WorkSize*
sizeof(WORD),(
char *)(sp->parameter));
458 AT.WorkTop = AT.WorkSpace + AM.WorkSize;
459 AT.WorkPointer = AT.WorkSpace;
464 sp = GetSetupPar((UBYTE *)
"constindex");
465 if ( ( sp->value+100+5*WILDOFFSET ) > MAXPOSITIVE ) {
466 MesPrint(
"Setting of %s in setupfile too large",
"constindex");
467 AM.OffsetIndex = MAXPOSITIVE - 5*WILDOFFSET - 100;
468 MesPrint(
"value corrected to maximum allowed: %d",AM.OffsetIndex);
470 else AM.OffsetIndex = sp->value + 1;
471 AC.FixIndices = (WORD *)Malloc1((AM.OffsetIndex)*
sizeof(WORD),(
char *)(sp->parameter));
472 AM.WilInd = AM.OffsetIndex + WILDOFFSET;
473 AM.DumInd = AM.OffsetIndex + 2*WILDOFFSET;
474 AM.IndDum = AM.DumInd + WILDOFFSET;
476 AR.CurDum = AN.IndDum = AM.IndDum;
478 AM.mTraceDum = AM.IndDum + 2*WILDOFFSET;
480 sp = GetSetupPar((UBYTE *)
"parentheses");
481 AM.MaxParLevel = sp->value+1;
482 AC.tokenarglevel = (WORD *)Malloc1((sp->value+1)*
sizeof(WORD),(
char *)(sp->parameter));
486 sp = GetSetupPar((UBYTE *)
"maxnumbersize");
500 if ( sp->value == 0 ) {
501 AM.MaxTal = (AM.MaxTer/
sizeof(WORD)-2)/2;
504 size = ( sp->value + 11 ) & (-4);
505 AM.MaxTal = size - 2;
506 if ( (
size_t)AM.MaxTal > (size_t)((AM.MaxTer/
sizeof(WORD)-2)/2) )
507 AM.MaxTal = (AM.MaxTer/
sizeof(WORD)-2)/2;
509 AM.MaxTal &= -
sizeof(WORD)*2;
511 sp->value = AM.MaxTal;
512 AC.cmod = (UWORD *)Malloc1(AM.MaxTal*4*
sizeof(UWORD),(
char *)(sp->parameter));
513 AM.gcmod = AC.cmod + AM.MaxTal;
514 AC.powmod = AM.gcmod + AM.MaxTal;
515 AM.gpowmod = AC.powmod + AM.MaxTal;
521 sp = GetSetupPar((UBYTE *)
"scratchsize");
522 AM.ScratSize = sp->value/
sizeof(WORD);
523 if ( AM.ScratSize < 4*AM.MaxTer ) AM.ScratSize = 4*AM.MaxTer;
524 AM.HideSize = AM.ScratSize;
525 sp = GetSetupPar((UBYTE *)
"hidesize");
526 if ( sp->value > 0 ) {
527 AM.HideSize = sp->value/
sizeof(WORD);
528 if ( AM.HideSize < 4*AM.MaxTer ) AM.HideSize = 4*AM.MaxTer;
530 sp = GetSetupPar((UBYTE *)
"factorizationcache");
531 AM.fbuffersize = sp->value;
533 sp = GetSetupPar((UBYTE *)
"threadscratchsize");
534 AM.ThreadScratSize = sp->value/
sizeof(WORD);
535 sp = GetSetupPar((UBYTE *)
"threadscratchoutsize");
536 AM.ThreadScratOutSize = sp->value/
sizeof(WORD);
539 for ( j = 0; j < 2; j++ ) {
541 ScratchBuf = (WORD *)Malloc1(AM.ScratSize*
sizeof(WORD),
"scratchsize");
542 AR.Fscr[j].POsize = AM.ScratSize *
sizeof(WORD);
543 AR.Fscr[j].POfull = AR.Fscr[j].POfill = AR.Fscr[j].PObuffer = ScratchBuf;
544 AR.Fscr[j].POstop = AR.Fscr[j].PObuffer + AM.ScratSize;
545 PUTZERO(AR.Fscr[j].POposition);
547 AR.Fscr[2].PObuffer = 0;
549 sp = GetSetupPar((UBYTE *)
"threadbucketsize");
550 AC.ThreadBucketSize = AM.gThreadBucketSize = AM.ggThreadBucketSize = sp->value;
551 sp = GetSetupPar((UBYTE *)
"threadloadbalancing");
552 AC.ThreadBalancing = AM.gThreadBalancing = AM.ggThreadBalancing = sp->value;
553 sp = GetSetupPar((UBYTE *)
"threadsortfilesynch");
554 AC.ThreadSortFileSynch = AM.gThreadSortFileSynch = AM.ggThreadSortFileSynch = sp->value;
558 sp = GetSetupPar((UBYTE *)
"shmwinsize");
559 AM.shmWinSize = sp->value/
sizeof(WORD);
560 if ( AM.shmWinSize < 4*AM.MaxTer ) AM.shmWinSize = 4*AM.MaxTer;
564 sp = GetSetupPar((UBYTE *)
"smallsize");
565 SmallSize = sp->value;
566 sp = GetSetupPar((UBYTE *)
"smallextension");
567 SmallEsize = sp->value;
568 sp = GetSetupPar((UBYTE *)
"largesize");
569 LargeSize = sp->value;
570 sp = GetSetupPar((UBYTE *)
"termsinsmall");
571 TermsInSmall = sp->value;
572 sp = GetSetupPar((UBYTE *)
"largepatches");
573 MaxPatches = sp->value;
574 sp = GetSetupPar((UBYTE *)
"filepatches");
575 MaxFpatches = sp->value;
576 sp = GetSetupPar((UBYTE *)
"sortiosize");
578 if ( IOsize < AM.MaxTer ) { IOsize = AM.MaxTer; sp->value = IOsize; }
581 for ( j = 0; j < 2; j++ ) { AR.Fscr[j].ziosize = IOsize; }
585 AM.S0 = AllocSort(LargeSize,SmallSize,SmallEsize,TermsInSmall
586 ,MaxPatches,MaxFpatches,IOsize,0);
589 AM.S0->file.ziosize = IOsize;
591 AR.FoStage4[0].ziosize = IOsize;
592 AR.FoStage4[1].ziosize = IOsize;
601 AR.FoStage4[0].POsize = ((IOsize+
sizeof(WORD)-1)/
sizeof(WORD))*
sizeof(WORD);
602 AR.FoStage4[1].POsize = ((IOsize+
sizeof(WORD)-1)/
sizeof(WORD))*
sizeof(WORD);
604 sp = GetSetupPar((UBYTE *)
"subsmallsize");
605 AM.SSmallSize = sp->value;
606 sp = GetSetupPar((UBYTE *)
"subsmallextension");
607 AM.SSmallEsize = sp->value;
608 sp = GetSetupPar((UBYTE *)
"sublargesize");
609 AM.SLargeSize = sp->value;
610 sp = GetSetupPar((UBYTE *)
"subtermsinsmall");
611 AM.STermsInSmall = sp->value;
612 sp = GetSetupPar((UBYTE *)
"sublargepatches");
613 AM.SMaxPatches = sp->value;
614 sp = GetSetupPar((UBYTE *)
"subfilepatches");
615 AM.SMaxFpatches = sp->value;
616 sp = GetSetupPar((UBYTE *)
"subsortiosize");
617 AM.SIOsize = sp->value;
619 if ( AM.SIOsize < AM.MaxTer ) { AM.SIOsize = AM.MaxTer; sp->value = AM.SIOsize; }
620 sp = GetSetupPar((UBYTE *)
"spectatorsize");
621 AM.SpectatorSize = sp->value;
627 sp = GetSetupPar((UBYTE *)
"functionlevels");
628 AM.maxFlevels = sp->value + 1;
631 AT.Nest = (
NESTING)Malloc1((LONG)
sizeof(
struct NeStInG)*AM.maxFlevels,
"functionlevels");
632 AT.NestStop = AT.Nest + AM.maxFlevels;
633 AT.NestPoin = AT.Nest;
636 sp = GetSetupPar((UBYTE *)
"maxwildcards");
637 AM.MaxWildcards = sp->value;
640 AT.WildMask = (WORD *)Malloc1((LONG)AM.MaxWildcards*
sizeof(WORD),
"maxwildcards");
643 sp = GetSetupPar((UBYTE *)
"compresssize");
644 if ( sp->value < 2*AM.MaxTer ) sp->value = 2*AM.MaxTer;
645 AM.CompressSize = sp->value;
647 AR.CompressBuffer = (WORD *)Malloc1((AM.CompressSize+10)*
sizeof(WORD),
"compresssize");
648 AR.CompressPointer = AR.CompressBuffer;
649 AR.ComprTop = AR.CompressBuffer + AM.CompressSize;
651 sp = GetSetupPar((UBYTE *)
"bracketindexsize");
652 if ( sp->value < 20*AM.MaxTer ) sp->value = 20*AM.MaxTer;
653 AM.MaxBracketBufferSize = sp->value/
sizeof(WORD);
655 sp = GetSetupPar((UBYTE *)
"dotchar");
656 AO.FortDotChar = ((UBYTE *)(sp->value))[0];
657 sp = GetSetupPar((UBYTE *)
"commentchar");
658 AP.cComChar = AP.ComChar = ((UBYTE *)(sp->value))[0];
659 sp = GetSetupPar((UBYTE *)
"procedureextension");
663 s = (UBYTE *)(sp->value);
664 if ( FG.cTable[*s] != 0 ) {
665 MesPrint(
" Illegal string for procedure extension %s",(UBYTE *)sp->value);
671 if ( *s ==
' ' || *s ==
'\t' || *s ==
'\n' ) {
672 MesPrint(
" Illegal string for procedure extension %s",(UBYTE *)sp->value);
679 AP.cprocedureExtension = strDup1((UBYTE *)(sp->value),
"procedureExtension");
680 AP.procedureExtension = strDup1(AP.cprocedureExtension,
"procedureExtension");
682 sp = GetSetupPar((UBYTE *)
"totalsize");
683 if ( sp->value != 2 ) AM.PrintTotalSize = sp->value;
685 sp = GetSetupPar((UBYTE *)
"continuationlines");
686 AM.FortranCont = sp->value;
687 sp = GetSetupPar((UBYTE *)
"oldorder");
688 AM.OldOrderFlag = sp->value;
689 sp = GetSetupPar((UBYTE *)
"resettimeonclear");
690 AM.resetTimeOnClear = sp->value;
691 sp = GetSetupPar((UBYTE *)
"nospacesinnumbers");
692 AO.NoSpacesInNumbers = AM.gNoSpacesInNumbers = AM.ggNoSpacesInNumbers = sp->value;
693 sp = GetSetupPar((UBYTE *)
"indentspace");
694 AO.IndentSpace = AM.gIndentSpace = AM.ggIndentSpace = sp->value;
695 sp = GetSetupPar((UBYTE *)
"jumpratio");
696 AM.jumpratio = sp->value;
697 sp = GetSetupPar((UBYTE *)
"nwritestatistics");
698 AC.StatsFlag = AM.gStatsFlag = AM.ggStatsFlag = 1-sp->value;
699 sp = GetSetupPar((UBYTE *)
"nwritefinalstatistics");
700 AC.FinalStats = AM.gFinalStats = AM.ggFinalStats = 1-sp->value;
701 sp = GetSetupPar((UBYTE *)
"nwritethreadstatistics");
702 AC.ThreadStats = AM.gThreadStats = AM.ggThreadStats = 1-sp->value;
703 sp = GetSetupPar((UBYTE *)
"nwriteprocessstatistics");
704 AC.ProcessStats = AM.gProcessStats = AM.ggProcessStats = 1-sp->value;
705 sp = GetSetupPar((UBYTE *)
"oldparallelstatistics");
706 AC.OldParallelStats = AM.gOldParallelStats = AM.ggOldParallelStats = sp->value;
707 sp = GetSetupPar((UBYTE *)
"oldfactarg");
708 AC.OldFactArgFlag = AM.gOldFactArgFlag = AM.ggOldFactArgFlag = sp->value;
709 sp = GetSetupPar((UBYTE *)
"oldgcd");
710 AC.OldGCDflag = AM.gOldGCDflag = AM.ggOldGCDflag = sp->value;
711 sp = GetSetupPar((UBYTE *)
"wtimestats");
712 if ( sp->value == 2 ) sp->value = AM.ggWTimeStatsFlag;
713 AC.WTimeStatsFlag = AM.gWTimeStatsFlag = AM.ggWTimeStatsFlag = sp->value;
715 sp = GetSetupPar((UBYTE *)
"maxweight");
716 AC.MaxWeight = AM.gMaxWeight = AM.ggMaxWeight = sp->value;
717 sp = GetSetupPar((UBYTE *)
"defaultprecision");
718 AC.DefaultPrecision = AM.gDefaultPrecision = AM.ggDefaultPrecision = sp->value;
720 sp = GetSetupPar((UBYTE *)
"sorttype");
721 if ( StrICmp((UBYTE *)
"lowfirst",(UBYTE *)sp->value) == 0 ) {
722 AC.lSortType = SORTLOWFIRST;
724 else if ( StrICmp((UBYTE *)
"highfirst",(UBYTE *)sp->value) == 0 ) {
725 AC.lSortType = SORTHIGHFIRST;
728 MesPrint(
" Illegal SortType specification: %s",(UBYTE *)sp->value);
732 sp = GetSetupPar((UBYTE *)
"processbucketsize");
733 AM.hProcessBucketSize = AM.gProcessBucketSize =
734 AC.ProcessBucketSize = AC.mProcessBucketSize = sp->value;
738 sp = GetSetupPar((UBYTE *)
"numstorecaches");
739 AM.NumStoreCaches = sp->value;
740 sp = GetSetupPar((UBYTE *)
"sizestorecache");
741 AM.SizeStoreCache = sp->value;
743 AM.SizeStoreCache = ((AM.SizeStoreCache+
sizeof(WORD)-1)/
sizeof(WORD))*
sizeof(WORD);
749 AT.StoreCache = AT.StoreCacheAlloc = 0;
750 if ( AM.NumStoreCaches > 0 ) {
752 size =
sizeof(
struct StOrEcAcHe)+AM.SizeStoreCache;
753 size = ((size-1)/
sizeof(
size_t)+1)*
sizeof(
size_t);
754 AT.StoreCacheAlloc = (
STORECACHE)Malloc1(size*AM.NumStoreCaches,
"StoreCaches");
755 AT.StoreCache = AT.StoreCacheAlloc;
757 for ( j = 0; j < AM.NumStoreCaches; j++ ) {
759 if ( j == AM.NumStoreCaches-1 ) {
765 SETBASEPOSITION(sa->position,-1);
766 SETBASEPOSITION(sa->toppos,-1);
775 if ( AM.Path == 0 ) {
776 sp = GetSetupPar((UBYTE *)
"path");
777 AM.Path = strDup1((UBYTE *)(sp->value),
"path");
779 if ( AM.IncDir == 0 ) {
780 sp = GetSetupPar((UBYTE *)
"incdir");
781 AM.IncDir = strDup1((UBYTE *)(sp->value),
"incdir");
813 MesPrint(
" The setup parameters are:");
814 for ( sp = setupparameters; n > 0; n--, sp++ ) {
817 MesPrint(
" %s: %l",sp->parameter,sp->value);
820 if ( StrICmp(sp->parameter,(UBYTE *)
"path") == 0 && AM.Path ) {
821 MesPrint(
" %s: '%s'",sp->parameter,(UBYTE *)(AM.Path));
824 if ( StrICmp(sp->parameter,(UBYTE *)
"incdir") == 0 && AM.IncDir ) {
825 MesPrint(
" %s: '%s'",sp->parameter,(UBYTE *)(AM.IncDir));
830 if ( StrICmp(sp->parameter,(UBYTE *)
"tempdir") == 0 && AM.TempDir ) {
831 MesPrint(
" %s: '%s'",sp->parameter,(UBYTE *)(AM.TempDir));
833 else if ( StrICmp(sp->parameter,(UBYTE *)
"tempsortdir") == 0 && AM.TempSortDir ) {
834 MesPrint(
" %s: '%s'",sp->parameter,(UBYTE *)(AM.TempSortDir));
837 MesPrint(
" %s: '%s'",sp->parameter,(UBYTE *)(sp->value));
841 if ( sp->value == 0 )
842 MesPrint(
" %s: OFF",sp->parameter);
843 else if ( sp->value == 1 )
844 MesPrint(
" %s: ON",sp->parameter);
867SORTING *AllocSort(LONG inLargeSize, LONG inSmallSize, LONG inSmallEsize, LONG inTermsInSmall,
868 int inMaxPatches,
int inMaxFpatches, LONG inIOsize,
int level)
871 LONG LargeSize = inLargeSize;
872 LONG SmallSize = inSmallSize;
873 LONG SmallEsize = inSmallEsize;
874 LONG TermsInSmall = inTermsInSmall;
875 int MaxPatches = inMaxPatches;
876 int MaxFpatches = inMaxFpatches;
877 LONG IOsize = inIOsize;
879 LONG longer,terms2insmall,sortsize,longerp;
880 LONG IObuffersize = IOsize;
883 int fname2Size = 0, j = 0;
886 s = FG.fname2; fname2Size = 0;
887 while ( *s ) { s++; fname2Size++; }
890 if ( MaxFpatches < 4 ) MaxFpatches = 4;
891 longer = MaxPatches > MaxFpatches ? MaxPatches : MaxFpatches;
893 while ( (1 << j) < longerp ) j++;
894 longerp = (1 << j) + 1;
895 longerp +=
sizeof(WORD*) - (longerp%
sizeof(WORD *));
897 longer +=
sizeof(WORD*) - (longer%
sizeof(WORD *));
898 if ( SmallSize < 16*AM.MaxTer ) SmallSize = 16*AM.MaxTer+16;
899 TermsInSmall = (TermsInSmall+15) & (-16L);
900 terms2insmall = 2*TermsInSmall;
901 if ( SmallEsize < (SmallSize*3)/2 ) SmallEsize = (SmallSize*3)/2;
902 if ( LargeSize > 0 && LargeSize < 2*SmallSize ) LargeSize = 2*SmallSize;
903 SmallEsize = (SmallEsize+15) & (-16L);
904 if ( LargeSize < 0 ) LargeSize = 0;
906 sortsize = (sortsize+15)&(-16L);
907 IObuffersize = (IObuffersize+
sizeof(WORD)-1)/
sizeof(WORD);
913 if ( (ULONG)( LargeSize+SmallEsize ) < MaxFpatches*((IObuffersize
914 +COMPINC)*
sizeof(WORD)+2*AM.MaxTer) ) {
915 if ( LargeSize == 0 )
916 SmallEsize = MaxFpatches*((IObuffersize+COMPINC)*
sizeof(WORD)+2*AM.MaxTer);
918 LargeSize = MaxFpatches*((IObuffersize+COMPINC)*
sizeof(WORD)+2*AM.MaxTer)
922 IOtry = ((LargeSize+SmallEsize)/MaxFpatches-2*AM.MaxTer)/
sizeof(WORD)-COMPINC;
925 if ( IObuffersize < IOtry ) {
926 IObuffersize = IOtry;
931 if ( level == 0 ) { prefix =
""; }
932 else { prefix =
"Sub"; }
933 if ( LargeSize != inLargeSize ) { MesPrint(
"Warning: %sLargeSize adjusted: %l -> %l", prefix, inLargeSize, LargeSize); }
934 if ( SmallSize != inSmallSize ) { MesPrint(
"Warning: %sSmallSize adjusted: %l -> %l", prefix, inSmallSize, SmallSize); }
935 if ( SmallEsize != inSmallEsize ) {MesPrint(
"Warning: %sSmallEsize adjusted: %l -> %l", prefix, inSmallEsize, SmallEsize); }
936 if ( TermsInSmall != inTermsInSmall ) { MesPrint(
"Warning: %sTermsInSmall adjusted: %l -> %l", prefix, inTermsInSmall, TermsInSmall); }
937 if ( MaxPatches != inMaxPatches ) { MesPrint(
"Warning: MaxPatches adjusted: %d -> %d", inMaxPatches, MaxPatches); }
938 if ( MaxFpatches != inMaxFpatches ) {MesPrint(
"Warning: MaxFPatches adjusted: %d -> %d", inMaxFpatches, MaxFpatches); }
944 sort = Malloc1(
sizeof(*sort),
"AllocSort: sorting struct");
946 sort->LargeSize = LargeSize/
sizeof(WORD);
947 sort->SmallSize = SmallSize/
sizeof(WORD);
948 sort->SmallEsize = SmallEsize/
sizeof(WORD);
949 sort->MaxPatches = MaxPatches;
950 sort->MaxFpatches = MaxFpatches;
951 sort->TermsInSmall = TermsInSmall;
952 sort->Terms2InSmall = terms2insmall;
954 sort->sPointer = Malloc1(
sizeof(*(sort->sPointer ))*terms2insmall,
"AllocSort: sPointer");
955 sort->Patches = Malloc1(
sizeof(*(sort->Patches ))*longer,
"AllocSort: Patches");
956 sort->pStop = Malloc1(
sizeof(*(sort->pStop ))*longer,
"AllocSort: pStop");
957 sort->poina = Malloc1(
sizeof(*(sort->poina ))*longerp,
"AllocSort: poina");
958 sort->poin2a = Malloc1(
sizeof(*(sort->poin2a ))*longerp,
"AllocSort: poin2a");
960 sort->fPatches = Malloc1(
sizeof(*(sort->fPatches ))*longer,
"AllocSort: fPatches");
961 sort->fPatchesStop = Malloc1(
sizeof(*(sort->fPatchesStop))*longer,
"AllocSort: fPatchesStop");
962 sort->inPatches = Malloc1(
sizeof(*(sort->inPatches ))*longer,
"AllocSort: inPatches");
963 sort->tree = Malloc1(
sizeof(*(sort->tree ))*longerp,
"AllocSort: tree");
964 sort->used = Malloc1(
sizeof(*(sort->used ))*longerp,
"AllocSort: used");
967 sort->fpcompressed = Malloc1(
sizeof(*(sort->fpcompressed ))*(longerp+2),
"AllocSort: fpcompressed");
968 sort->fpincompressed = Malloc1(
sizeof(*(sort->fpincompressed))*(longerp+2),
"AllocSort: fpincompressed");
972 sort->ktoi = Malloc1(
sizeof(*(sort->ktoi))*(longerp+2),
"AllocSort: ktoi");
976 sort->lBuffer = Malloc1(
sizeof(*(sort->lBuffer))*(sort->LargeSize+sort->SmallEsize),
"AllocSort: lBuffer+sBuffer");
977 sort->lTop = sort->lBuffer+sort->LargeSize;
979 sort->sBuffer = sort->lTop;
980 if ( sort->LargeSize == 0 ) { sort->lBuffer = 0; sort->lTop = 0; }
981 sort->sTop = sort->sBuffer + sort->SmallSize;
982 sort->sTop2 = sort->sBuffer + sort->SmallEsize;
983 sort->sHalf = sort->sBuffer + (LONG)((sort->SmallSize+sort->SmallEsize)>>1);
985 sort->file.PObuffer = Malloc1(IObuffersize*
sizeof(*(sort->file.PObuffer))+fname2Size+16,
"AllocSort: PObuffer");
986 sort->file.POstop = sort->file.PObuffer+IObuffersize;
987 sort->file.POsize = IObuffersize *
sizeof(WORD);
988 sort->file.POfill = sort->file.POfull = sort->file.PObuffer;
989 sort->file.active = 0;
991 PUTZERO(sort->file.POposition);
993 sort->file.pthreadslock = dummylock;
996 sort->file.ziosize = IObuffersize*
sizeof(WORD);
997 sort->file.ziobuffer = 0;
1000 sort->file.name = (
char *)(sort->file.PObuffer + IObuffersize);
1001 AllocSortFileName(sort);
1003 else sort->file.name = 0;
1005 sort->cBufferSize = 0;
1017void AllocSortFileName(
SORTING *sort)
1025 s = FG.fname2; t = sort->file.name;
1026 while ( *s ) *t++ = *s++;
1029 snprintf(t-1,FG.fname2size-(t-1-sort->file.name),
"%d.%d",identity,AN.filenum);
1032 snprintf(t-1,FG.fname2size-(t-1-sort->file.name),
"%d",AN.filenum);
1042FILEHANDLE *AllocFileHandle(WORD par,
char *name)
1045 LONG allocation, Ssize;
1050 s = FG.fname2; i = 0;
1051 while ( *s ) { s++; i++; }
1052 if ( par == 0 ) { i += 16; Ssize = AM.SIOsize; }
1053 else { s = name;
while ( *s ) { i++; s++; } i+= 2; Ssize = AM.SpectatorSize; }
1055 allocation =
sizeof(
FILEHANDLE) + (Ssize+1)*
sizeof(WORD) + i*
sizeof(
char)
1057 fh = (
FILEHANDLE *)Malloc1(allocation,
"FileHandle");
1059 fh->PObuffer = (WORD *)(fh+1);
1060 fh->POstop = fh->PObuffer+Ssize;
1061 fh->POsize = Ssize *
sizeof(WORD);
1064 PUTZERO(fh->POposition);
1066 fh->pthreadslock = dummylock;
1070 fh->name = (
char *)(fh->POstop + 1);
1071 s = FG.fname2; t = fh->name;
1072 while ( *s ) *t++ = *s++;
1075 snprintf(t-1,FG.fname2size-(t-1-fh->name),
"%d-%d",identity,AN.filenum);
1078 snprintf(t-1,FG.fname2size-(t-1-fh->name),
"%d",AN.filenum);
1085 fh->name = (
char *)(fh->POstop + 1);
1086 s = FG.fname; t = fh->name;
1087 for ( i = 0; i < FG.fnamebase; i++ ) *t++ = *s++;
1089 while ( *s ) *t++ = *s++;
1092 fh->POfill = fh->POfull = fh->PObuffer;
1112 M_free(fh,
"Temporary FileHandle");
1120int MakeSetupAllocs(
void)
1122 if ( RecalcSetups() || AllocSetups() )
return(1);
1138 tmp->psym = Malloc1(7*NORMSIZE*
sizeof(*(tmp->psym)),
"Normalize struct psym");
1139 tmp->pvec = Malloc1(1*NORMSIZE*
sizeof(*(tmp->pvec)),
"Normalize struct pvec");
1140 tmp->pdot = Malloc1(3*NORMSIZE*
sizeof(*(tmp->pdot)),
"Normalize struct pdot");
1141 tmp->pdel = Malloc1(2*NORMSIZE*
sizeof(*(tmp->pdel)),
"Normalize struct pdel");
1142 tmp->pind = Malloc1(1*NORMSIZE*
sizeof(*(tmp->pind)),
"Normalize struct pind");
1143 tmp->peps = Malloc1(NORMSIZE/3*
sizeof(*(tmp->peps)),
"Normalize struct peps");
1144 tmp->pden = Malloc1(NORMSIZE/3*
sizeof(*(tmp->pden)),
"Normalize struct pden");
1145 tmp->pcom = Malloc1(1*NORMSIZE*
sizeof(*(tmp->pcom)),
"Normalize struct pcom");
1146 tmp->pnco = Malloc1(1*NORMSIZE*
sizeof(*(tmp->pnco)),
"Normalize struct pnco");
1147 tmp->pcon = Malloc1(2*NORMSIZE*
sizeof(*(tmp->pcon)),
"Normalize struct pcon");
1164#define SETBUFSIZE 257
1166int TryFileSetups(
void)
1168 LONG oldstreamposition;
1170 int error = 0, eqnum;
1171 int oldNoShowInput = AC.NoShowInput;
1172 UBYTE buff[SETBUFSIZE+1], *s, *t, *u, *settop, c;
1173 LONG linenum, prevline;
1175 if ( AC.CurrentStream == 0 )
return(error);
1176 oldstream = AC.CurrentStream - AC.Streams;
1177 oldstreamposition = GetStreamPosition(AC.CurrentStream);
1178 linenum = AC.CurrentStream->linenumber;
1179 prevline = AC.CurrentStream->prevline;
1180 eqnum = AC.CurrentStream->eqnum;
1182 settop = buff + SETBUFSIZE;
1183 if ( AC.CurrentStream->type == INPUTSTREAM && oldstreamposition == 0 ) AC.CurrentStream->fileposition = 0;
1186 if ( c ==
'*' || c ==
'\n' ) {
1187 while ( c !=
'\n' && c != ENDOFINPUT ) c = GetInput();
1188 if ( c == ENDOFINPUT )
goto eoi;
1191 if ( c == ENDOFINPUT )
goto eoi;
1192 if ( c !=
'#' )
break;
1194 if ( c == ENDOFINPUT )
goto eoi;
1195 if ( c !=
'-' && c !=
'+' && c !=
':' )
break;
1197 while ( c !=
'\n' && c != ENDOFINPUT ) c = GetInput();
1201 while ( ( c = GetInput() ) ==
' ' || c ==
'\t' || c ==
'\r' ) {}
1202 if ( c == ENDOFINPUT )
break;
1203 if ( c == LINEFEED )
continue;
1204 if ( c == 0 || c == ENDOFINPUT )
break;
1205 while ( c != LINEFEED && c != ENDOFINPUT ) {
1208 if ( c != LINEFEED && c !=
'\r' )
continue;
1209 if ( s >= settop ) {
1210 while ( c !=
'\n' && c != ENDOFINPUT ) c = GetInput();
1211 MesPrint(
"Setups in .frm file: Line too long. setup ignored");
1212 error++;
goto nextline;
1217 while ( tolower(*s) >=
'a' && tolower(*s) <=
'z' ) s++;
1220 while ( *s ==
' ' || *s ==
'\t' ) s++;
1222 while ( *s && *s !=
'\n' && *s !=
'\r' ) s++;
1230 error += ProcessOption(t,u,1);
1233 AC.NoShowInput = oldNoShowInput;
1234 AC.CurrentStream = AC.Streams + oldstream;
1235 PositionStream(AC.CurrentStream,oldstreamposition);
1236 AC.CurrentStream->linenumber = linenum;
1237 AC.CurrentStream->prevline = prevline;
1238 AC.CurrentStream->eqnum = eqnum;
1240 if ( AC.CurrentStream->type == INPUTSTREAM ) AC.CurrentStream->fileposition = -1;
1243 MesPrint(
"Input file without a program.");
1252int TryEnvironment(
void)
1254 char *s, *t, *u, varname[100];
1257 varname[0] =
'F'; varname[1] =
'O'; varname[2] =
'R'; varname[3] =
'M';
1258 varname[4] =
'_'; varname[5] = 0;
1259 for ( i = 0; i < imax; i++ ) {
1260 t = s = (
char *)(setupparameters[i].parameter);
1262 while ( *s ) { *u++ = (char)(toupper((
unsigned char)*s)); s++; }
1264 s = (
char *)(getenv(varname));
1266 error += ProcessOption((UBYTE *)t,(UBYTE *)s,2);
int TheDefine(UBYTE *, int)
struct StOrEcAcHe * STORECACHE