source: git/libpolys/reporter/reporter.cc @ 91dd8a5

fieker-DuValspielwiese
Last change on this file since 91dd8a5 was 91dd8a5, checked in by Hans Schoenemann <hannes@…>, 10 years ago
add: description for StringSetS/..StringEndS, SPrintStart/SPrintEnd
  • Property mode set to 100644
File size: 8.4 KB
Line 
1/****************************************
2*  Computer Algebra System SINGULAR     *
3****************************************/
4/*
5* ABSTRACT: output system
6*/
7
8#ifdef HAVE_CONFIG_H
9#include "libpolysconfig.h"
10#endif /* HAVE_CONFIG_H */
11
12#include <stdlib.h>
13#include <stdio.h>
14#include <misc/mylimits.h>
15#include <stdarg.h>
16#include <sys/stat.h>
17#include <ctype.h>
18#include <unistd.h>
19
20#ifdef HAVE_PWD_H
21#include <pwd.h>
22#endif
23
24#include <reporter/reporter.h>
25#include <resources/feResource.h>
26#include <resources/feFopen.h>
27#include <omalloc/omalloc.h>
28//#include "options.h"
29
30#define fePutChar(c) fputc((unsigned char)(c),stdout)
31/*0 implementation */
32
33// output/print buffer:
34#define INITIAL_PRINT_BUFFER 24*1024L
35// line buffer for reading:
36// minimal value for MAX_FILE_BUFFER: 4*4096 - see Tst/Long/gcd0_l.tst
37// this is an upper limit for the size of monomials/numbers read via the interpreter
38#define MAX_FILE_BUFFER 4*4096
39static long feBufferLength=0;
40static char * feBuffer=NULL;
41static long feBufferLength_save[8];
42static char * feBuffer_save[8];
43static int feBuffer_cnt=0;
44static char * feBufferStart_save[8];
45
46
47char *  feErrors=NULL;
48int     feErrorsLen=0;
49BOOLEAN feWarn = TRUE;
50BOOLEAN feOut = TRUE;
51
52//void (*WerrorS_callback)(const char *s) = NULL;
53
54const char feNotImplemented[]="not implemented";
55
56int feProt = FALSE;
57FILE*   feProtFile;
58
59static char * feBufferStart;
60  /* only used in StringSet(S)/StringAppend(S)*/
61void StringAppend(const char *fmt, ...)
62{
63  va_list ap;
64  char *s = feBufferStart; /*feBuffer + strlen(feBuffer);*/
65  int vs;
66  long more;
67  va_start(ap, fmt);
68  if ((more=feBufferStart-feBuffer+strlen(fmt)+100)>feBufferLength)
69  {
70    more = ((more + (8*1024-1))/(8*1024))*(8*1024);
71    int l=s-feBuffer;
72    feBuffer=(char *)omReallocSize((void *)feBuffer,feBufferLength,
73                                                     more);
74#if (!defined(SING_NDEBUG)) && (!defined(OM_NDEBUG)) && defined(HAVE_CONFIG_H)
75    omMarkAsStaticAddr(feBuffer);
76#endif
77    feBufferLength=more;
78    s=feBuffer+l;
79#ifndef BSD_SPRINTF
80    feBufferStart=s;
81#endif
82  }
83#ifdef BSD_SPRINTF
84  vsprintf(s, fmt, ap);
85  while (*s!='\0') s++;
86  feBufferStart =s;
87#else
88#ifdef HAVE_VSNPRINTF
89  vs = vsnprintf(s, feBufferLength - (feBufferStart - feBuffer), fmt, ap);
90  if (vs == -1)
91  {
92    assume(0);
93    feBufferStart = feBuffer + feBufferLength -1;
94  }
95  else
96  {
97    feBufferStart += vs;
98  }
99#else
100  feBufferStart += vsprintf(s, fmt, ap);
101#endif
102#endif
103  omCheckAddrSize(feBuffer, feBufferLength);
104  va_end(ap);
105}
106
107void StringAppendS(const char *st)
108{
109  if (*st!='\0')
110  {
111    /* feBufferStart is feBuffer + strlen(feBuffer);*/
112    int l;
113    long more;
114    int ll=feBufferStart-feBuffer;
115    if ((more=ll+2+(l=strlen(st)))>feBufferLength)
116    {
117      more = ((more + (8*1024-1))/(8*1024))*(8*1024);
118      feBuffer=(char *)omreallocSize((void *)feBuffer,feBufferLength,
119                                                       more);
120      feBufferLength=more;
121      feBufferStart=feBuffer+ll;
122    }
123    strcat(feBufferStart, st);
124    feBufferStart +=l;
125  }
126}
127
128void StringSetS(const char *st)
129{
130  feBuffer_save[feBuffer_cnt]=feBuffer;
131  feBuffer=(char*)omAlloc0(INITIAL_PRINT_BUFFER);
132  feBufferLength_save[feBuffer_cnt]=feBufferLength;
133  feBufferLength=INITIAL_PRINT_BUFFER;
134  feBufferStart_save[feBuffer_cnt]=feBufferStart;
135  feBufferStart=feBuffer;
136  feBuffer_cnt++;
137  int l;
138  long more;
139  if ((l=strlen(st))>feBufferLength)
140  {
141    more = ((l + (4*1024-1))/(4*1024))*(4*1024);
142    feBuffer=(char *)omReallocSize((ADDRESS)feBuffer,feBufferLength,
143                                                     more);
144    feBufferLength=more;
145  }
146  strcpy(feBuffer,st);
147  feBufferStart=feBuffer+l;
148}
149
150char * StringEndS()
151{
152  char *r=feBuffer;
153  feBuffer_cnt--;
154  feBuffer=feBuffer_save[feBuffer_cnt];
155  feBufferLength=feBufferLength_save[feBuffer_cnt];
156  feBufferStart=feBufferStart_save[feBuffer_cnt];
157  if (strlen(r)<1024)
158  {
159    // if the used buffer is a "smal block",
160    // substitue the "large" initial block by a smal one
161    char *s=omStrDup(r); omFree(r); r=s;
162  }
163  return r;
164}
165
166#ifdef HAVE_TCL
167extern "C" {
168void PrintTCLS(const char c, const char *s)
169{
170  int l=strlen(s);
171  if (l>0) PrintTCL(c,l,s);
172}
173}
174#endif
175
176void WerrorS_batch(const char *s)
177{
178  if (feErrors==NULL)
179  {
180    feErrors=(char *)omAlloc(256);
181    feErrorsLen=256;
182    *feErrors = '\0';
183  }
184  else
185  {
186    if (((int)(strlen((char *)s)+ 20 +strlen(feErrors)))>=feErrorsLen)
187    {
188      feErrors=(char *)omReallocSize(feErrors,feErrorsLen,feErrorsLen+256);
189      feErrorsLen+=256;
190    }
191  }
192  strcat(feErrors, "Singular error: ");
193  strcat(feErrors, (char *)s);
194  errorreported = TRUE;
195}
196
197void Werror(const char *fmt, ...)
198{
199  va_list ap;
200  va_start(ap, fmt);
201  char *s=(char *)omAlloc(256);
202  vsprintf(s, fmt, ap);
203  WerrorS(s);
204  omFreeSize(s,256);
205  va_end(ap);
206}
207
208void WarnS(const char *s)
209{
210  #define warn_str "// ** "
211#ifdef HAVE_TCL
212  if (tclmode)
213  {
214    PrintTCLS('W',warn_str);
215    PrintTCLS('W',s);
216    PrintTCLS('W',"\n");
217  }
218  else
219#endif
220  if (feWarn) /* ignore warnings if option --no-warn was given */
221  {
222    fwrite(warn_str,1,6,stdout);
223    fwrite(s,1,strlen(s),stdout);
224    fwrite("\n",1,1,stdout);
225    fflush(stdout);
226    if (feProt&SI_PROT_O)
227    {
228      fwrite(warn_str,1,6,feProtFile);
229      fwrite(s,1,strlen(s),feProtFile);
230      fwrite("\n",1,1,feProtFile);
231    }
232  }
233}
234
235void Warn(const char *fmt, ...)
236{
237  va_list ap;
238  va_start(ap, fmt);
239  char *s=(char *)omAlloc(256);
240  vsprintf(s, fmt, ap);
241  WarnS(s);
242  omFreeSize(s,256);
243  va_end(ap);
244}
245
246
247// some routines which redirect the output of print to a string
248static char* sprint = NULL;
249static char* sprint_backup = NULL;
250void SPrintStart()
251{
252  if (sprint!=NULL)
253  {
254    if (sprint_backup!=NULL) WerrorS("internal error: SPrintStart");
255    else sprint_backup=sprint;
256  }
257  sprint = omStrDup("");
258}
259
260static void SPrintS(const char* s)
261{
262  omCheckAddr(sprint);
263  if ((s == NULL)||(*s == '\0')) return;
264  int ls = strlen(s);
265
266  char* ns;
267  int l = strlen(sprint);
268  ns = (char*) omAlloc((l + ls + 1)*sizeof(char));
269  if (l > 0) strcpy(ns, sprint);
270
271  strcpy(&(ns[l]), s);
272  omFree(sprint);
273  sprint = ns;
274  omCheckAddr(sprint);
275}
276
277char* SPrintEnd()
278{
279  char* ns = sprint;
280  sprint = sprint_backup;
281  sprint_backup=NULL;
282  omCheckAddr(ns);
283  return ns;
284}
285
286// Print routines
287extern "C" {
288void PrintS(const char *s)
289{
290  if (sprint != NULL)
291  {
292    SPrintS(s);
293    return;
294  }
295  else if (feOut) /* do not print when option --no-out was given */
296  {
297
298#ifdef HAVE_TCL
299    if (tclmode)
300    {
301      PrintTCLS('N',s);
302    }
303    else
304#endif
305    {
306      fwrite(s,1,strlen(s),stdout);
307      fflush(stdout);
308      if (feProt&SI_PROT_O)
309      {
310        fwrite(s,1,strlen(s),feProtFile);
311      }
312    }
313  }
314}
315
316void PrintLn()
317{
318  PrintS("\n");
319}
320
321void Print(const char *fmt, ...)
322{
323  if (sprint != NULL)
324  {
325    va_list ap;
326    va_start(ap, fmt);
327    omCheckAddr(sprint);
328    int ls = strlen(fmt);
329    if (fmt != NULL && ls > 0)
330    {
331      char* ns;
332      int l = strlen(sprint);
333      ns = (char*) omAlloc(sizeof(char)*(ls + l + 512));
334      if (l > 0)  strcpy(ns, sprint);
335
336#ifdef HAVE_VSNPRINTF
337      l = vsnprintf(&(ns[l]), ls+511, fmt, ap);
338      assume(l != -1);
339#else
340      vsprintf(&(ns[l]), fmt, ap);
341#endif
342      omCheckAddr(ns);
343      omFree(sprint);
344      sprint = ns;
345    }
346    va_end(ap);
347    return;
348  }
349  else if (feOut)
350  {
351    va_list ap;
352    va_start(ap, fmt);
353    int l;
354    long ls=strlen(fmt);
355    char *s=(char *)omAlloc(ls+512);
356#ifdef HAVE_VSNPRINTF
357    l = vsnprintf(s, ls+511, fmt, ap);
358    if ((l==-1)||(s[l]!='\0')||(l!=(int)strlen(s)))
359    {
360      printf("Print problem: l=%d, fmt=>>%s<<\n",l,fmt);
361    }
362#else
363    vsprintf(s, fmt, ap);
364#endif
365    PrintS(s);
366    omFree(s);
367    va_end(ap);
368  }
369}
370void PrintNSpaces(const int n)
371{
372  int l=n-1;
373  while(l>=0) { PrintS(" "); l--; }
374}
375
376/* end extern "C" */
377}
378
379const char* eati(const char *s, int *i)
380{
381  int l=0;
382
383  if    (*s >= '0' && *s <= '9')
384  {
385    *i = 0;
386    while (*s >= '0' && *s <= '9')
387    {
388      *i *= 10;
389      *i += *s++ - '0';
390      l++;
391      if ((l>=MAX_INT_LEN)||((*i) <0))
392      {
393        s-=l;
394        Werror("`%s` greater than %d(max. integer representation)",
395                s,MAX_INT_VAL);
396        return s;
397      }
398    }
399  }
400  else *i = 1;
401  return s;
402}
403
404void feStringAppendResources(int warn)
405{
406  int i = 0;
407  char* r;
408  StringAppend("%-10s:\t%s\n", "argv[0]", feArgv0);
409  while (feResourceConfigs[i].key != NULL)
410  {
411    r = feResource(feResourceConfigs[i].key, warn);
412    StringAppend("%-10s:\t%s\n", feResourceConfigs[i].key,
413                 (r != NULL ? r : ""));
414    i++;
415  }
416}
Note: See TracBrowser for help on using the repository browser.