Warning fixes

This commit is contained in:
Alexander S. Aganichev 2001-04-01 09:46:21 +00:00
parent c57e3b2863
commit f79327b384
9 changed files with 129 additions and 120 deletions

View File

@ -25,7 +25,8 @@ assistance!
14. € § ç¥¬ ¬­¥ íâ®â <censored> । ªâ®à ­ã¦¥­? “ Ž¤¨­­  ¡ë«® «ãçè¥! 14. € § ç¥¬ ¬­¥ íâ®â <censored> । ªâ®à ­ã¦¥­? “ Ž¤¨­­  ¡ë«® «ãçè¥!
15. € ¢®â ï å®çã  ­ «®£ MCITY ¢áâ஥­­ë©. 15. € ¢®â ï å®çã  ­ «®£ MCITY ¢áâ஥­­ë©.
16. $^%$^*! —â® âë ᤥ« « á á®åà ­¥­¨¥¬ á®®¡é¥­¨© ¢ 1.1.5? 16. $^%$^*! —â® âë ᤥ« « á á®åà ­¥­¨¥¬ á®®¡é¥­¨© ¢ 1.1.5?
17. ’¨¯  íâ ... € ¯¨á âì ªã¤   ¢â®àã? ;-) 17. <20>®á«¥ ãáâ ­®¢ª¨ GoldED+ ã ¬¥­ï ­ ç «¨ à §¤ ¢ âìáï áâ㪨 ¨§-¯®¤ ¯®« .
18. ’¨¯  íâ ... € ¯¨á âì ªã¤   ¢â®àã? ;-)
>============================================================================== >==============================================================================
@ -39,11 +40,16 @@ assistance!
­¥¯à ¢¨«ì­®¥. ­¥¯à ¢¨«ì­®¥.
*A:* —⮡ë GoldED+ £«î稫 ¯®¬¥­ìè¥, ­ ¤® ­ áâநâì ॣ¨®­ «ì­ë¥ ãáâ ­®¢ª¨: *A:* —⮡ë GoldED+ £«î稫 ¯®¬¥­ìè¥, ­ ¤® ­ áâநâì ॣ¨®­ «ì­ë¥ ãáâ ­®¢ª¨:
¤«ï DPMI32: country.sys, ¯¥à¥¬¥­­ ï TZ ¤«ï DPMI32: country.sys, ¯¥à¥¬¥­­ ï TZ
¤«ï Win32: control panel ¤«ï Win32: control panel, ¯¥à¥¬¥­­ ï TZ
¤«ï OS/2: [­¥ §­ î £¤¥ ­ áâà ¨¢ ¥âáï, ­® ॣ¨®­ «ì­ë¥ ­ áâனª¨ - ᢮¨], ¤«ï OS/2: [­¥ §­ î £¤¥ ­ áâà ¨¢ ¥âáï, ­® ॣ¨®­ «ì­ë¥ ­ áâனª¨ - ᢮¨],
¯¥à¥¬¥­­ ï TZ ¯¥à¥¬¥­­ ï TZ
¤«ï UNIX: ¯¥à¥¬¥­­ë¥ LANG ¨ TZ. ¤«ï UNIX: ¯¥à¥¬¥­­ë¥ LANG ¨ TZ.
<>ˆŒ€<C592>ˆ…: â®, çâ® GoldED+/w32 ¯®ª §ë¢ ¥â ­¥¯à ¢¨«ì­®¥ ¢à¥¬ï ¤¢¥ ­¥¤¥«¨ ¢
£®¤ã ­¥ ï¥âáï ¡ £®¬ GoldED+, íâ® ¯à®¡«¥¬  CRTDLL.DLL, ¯®áâ ¢«ï¥¬®£®
ä¨à¬®© Microsoft ¢ á®áâ ¢¥ ¢ è¥© ®¯¥à æ¨®­­®© á¨á⥬ë. Ž¡à â¨â¥áì ª
¯à®¨§¢®¤¨â¥«î ¢ è¥© Ž‘ á ¯à®áì¡®© ¨á¯à ¢¨âì íâ㠮訡ªã.
*Q:* € ª ª ¦¥ ¢á¥-â ª¨ ¯à ¢¨«ì­® ¬¥­ïâì SoftCR ¯à¨ ­ ¡®à¥ ¨ ¨¬¥âì á í⨬ *Q:* € ª ª ¦¥ ¢á¥-â ª¨ ¯à ¢¨«ì­® ¬¥­ïâì SoftCR ¯à¨ ­ ¡®à¥ ¨ ¨¬¥âì á í⨬
¬¥­ìè¥ ¢á¥£® ¯à®¡«¥¬? ¬¥­ìè¥ ¢á¥£® ¯à®¡«¥¬?
*A:* —â®¡ë § ¬¥­ïâì SoftCR (¤«ï ç ©­¨ª®¢ - íâ® ¡®«ìè ï àãááª ï ¡ãª¢  "H") *A:* —â®¡ë § ¬¥­ïâì SoftCR (¤«ï ç ©­¨ª®¢ - íâ® ¡®«ìè ï àãááª ï ¡ãª¢  "H")
@ -136,6 +142,10 @@ assistance!
ª á®åà ­¥­¨î ⥫  á®®¡é¥­¨ï, ­® § ç¥¬ ®­® ¬®¦¥â ¯®­ ¤®¡¨âìáï ï ­¥ ª á®åà ­¥­¨î ⥫  á®®¡é¥­¨ï, ­® § ç¥¬ ®­® ¬®¦¥â ¯®­ ¤®¡¨âìáï ï ­¥
¯à¨¤ã¬ «. <20> §¢¥ çâ® ®¯¨á âì ¯¥à¢ãî áâà®çªã ª ª @write ;) ¯à¨¤ã¬ «. <20> §¢¥ çâ® ®¯¨á âì ¯¥à¢ãî áâà®çªã ª ª @write ;)
*Q:* <20>®á«¥ ãáâ ­®¢ª¨ GoldED+ ã ¬¥­ï ­ ç «¨ à §¤ ¢ âìáï áâ㪨 ¨§-¯®¤ ¯®« .
*A:* Žâªà®©â¥ ¯®£à¥¡ ¨ ¯®á¬®âà¨â¥, ¬®¦¥â ¡ëâì ã ¯ à⨧ ­, á¯àïâ ­­ëå ¢ è¨¬
¤¥¤®¬ ¢® ¢à¥¬ï ¢®©­ë, ª®­ç¨«¨áì ¯à®¤ãªâë.
*Q:* ’¨¯  íâ ... € ¯¨á âì ªã¤   ¢â®àã? ;-) *Q:* ’¨¯  íâ ... € ¯¨á âì ªã¤   ¢â®àã? ;-)
*A:* <20>¨á âì «ãçè¥ ¢á¥£® ¢ Ru.GoldED. „ ¦¥ «ãçè¥ á­ ç «  ¥£® ¯®ç¨â âì, ¤®¦¤ âìáï *A:* <20>¨á âì «ãçè¥ ¢á¥£® ¢ Ru.GoldED. „ ¦¥ «ãçè¥ á­ ç «  ¥£® ¯®ç¨â âì, ¤®¦¤ âìáï
¬¥áâ­®£® FAQ, ¡ £«¨áâ  ¨ ⮫쪮 ¯®â®¬ ¯¨á âì. …᫨ 㦠ᨫ쭮 ¯à¨á¯¨ç¨â, â® ¬¥áâ­®£® FAQ, ¡ £«¨áâ  ¨ ⮫쪮 ¯®â®¬ ¯¨á âì. …᫨ 㦠ᨫ쭮 ¯à¨á¯¨ç¨â, â®

View File

@ -277,7 +277,7 @@ void CfgScreensize() {
} }
else if(CFG->screensize == 0) { else if(CFG->screensize == 0) {
if(strnieql(val, "Mode", 4)) { if(strnieql(val, "Mode", 4)) {
sscanf(val+4, " %x", &CFG->screensize); sscanf(val+4, " %x", (uint *)&CFG->screensize);
CFG->screensize <<= 8; CFG->screensize <<= 8;
} }
} }

View File

@ -204,7 +204,7 @@ int TemplateToText(int mode, GMsg* msg, GMsg* oldmsg, const char* tpl, int origa
} }
if(strieql(tplfile, "built-in") or not fexist(tplfile) or CFG->tpl.empty()) { if(strieql(tplfile, "built-in") or not fexist(tplfile) or CFG->tpl.empty()) {
tmptpl = YES; // Create a temporary template tmptpl = YES; // Create a temporary template
mktemp(strcpy(tplfile, AddPath(CFG->templatepath, "GDXXXXXX"))); mktemp(strcpy(tplfile, AddPath(CFG->goldpath, "GDXXXXXX")));
fp = fsopen(tplfile, "wt", CFG->sharemode); fp = fsopen(tplfile, "wt", CFG->sharemode);
if(fp) { if(fp) {
fputs("@header= @oecho (@caddr) @align{79}{=}\n", fp); fputs("@header= @oecho (@caddr) @align{79}{=}\n", fp);

View File

@ -34,7 +34,7 @@
char* CvtPrnstr(char* str, char* prn) { char* CvtPrnstr(char* str, char* prn) {
int value; uint value;
byte len=0; byte len=0;
char buf[256]; char buf[256];
char* ptr=prn; char* ptr=prn;
@ -54,8 +54,8 @@ char* CvtPrnstr(char* str, char* prn) {
break; break;
case '#': case '#':
ptr++; ptr++;
value = atoi(ptr); value = (byte)atoi(ptr);
buf[len++] = (byte)value; buf[len++] = value;
while(isdigit(*ptr) and *ptr) while(isdigit(*ptr) and *ptr)
ptr++; ptr++;
break; break;

View File

@ -148,7 +148,7 @@ void gareafile::replace_slashes(char **key) {
if(*p == '\\') { if(*p == '\\') {
int size = 1; int size = 1;
int chr = p[1]; uint chr = p[1];
if(isxdigit(p[1])) { if(isxdigit(p[1])) {
if(isxdigit(p[2])) { if(isxdigit(p[2])) {

View File

@ -906,7 +906,7 @@ Line* SMBArea::make_dump_msg(Line*& lin, gmsg* msg, char* lng_head)
line = AddLineF(line, "Written : %s", buf); line = AddLineF(line, "Written : %s", buf);
stpcpy(buf, ctime((time_t *)&smsg.hdr.when_imported.time))[-1] = NUL; stpcpy(buf, ctime((time_t *)&smsg.hdr.when_imported.time))[-1] = NUL;
line = AddLineF(line, "Imported : %s", buf); line = AddLineF(line, "Imported : %s", buf);
line = AddLineF(line, "Number : %ld (%ld)", smsg.hdr.number, ftell(data->sid_fp) / sizeof(idxrec_t)); line = AddLineF(line, "Number : %ld (%ld)", smsg.hdr.number, (long)(ftell(data->sid_fp)/sizeof(idxrec_t)));
line = AddLineF(line, "Thread orig : %ld", smsg.hdr.thread_orig); line = AddLineF(line, "Thread orig : %ld", smsg.hdr.thread_orig);
line = AddLineF(line, "Thread next : %ld", smsg.hdr.thread_next); line = AddLineF(line, "Thread next : %ld", smsg.hdr.thread_next);
line = AddLineF(line, "Thread first : %ld", smsg.hdr.thread_first); line = AddLineF(line, "Thread first : %ld", smsg.hdr.thread_first);

View File

@ -487,6 +487,7 @@ _FP_fgets (char *buf, int n, FILE *stream)
return obp; return obp;
} }
#if 0
/* /*
* A replacement strerror function that just returns the error code * A replacement strerror function that just returns the error code
*/ */
@ -510,3 +511,4 @@ _FP_tempnam (char *dir, char *pfx)
{ {
return _FP_strdup (tmpnam (NULL)); return _FP_strdup (tmpnam (NULL));
} }
#endif

View File

@ -51,8 +51,10 @@ char * TOOLEXPORT _FP_fgets _ANSI_ARGS_((char *, int, FILE *));
char * TOOLEXPORT _FP_strpbrk _ANSI_ARGS_((char *, char *)); char * TOOLEXPORT _FP_strpbrk _ANSI_ARGS_((char *, char *));
char * TOOLEXPORT _FP_strtok _ANSI_ARGS_((char *, char *)); char * TOOLEXPORT _FP_strtok _ANSI_ARGS_((char *, char *));
char * TOOLEXPORT _FP_cutdir _ANSI_ARGS_((char *)); char * TOOLEXPORT _FP_cutdir _ANSI_ARGS_((char *));
#if 0
char * TOOLEXPORT _FP_strerror _ANSI_ARGS_((int)); char * TOOLEXPORT _FP_strerror _ANSI_ARGS_((int));
char * TOOLEXPORT _FP_tempnam _ANSI_ARGS_((char *, char *)); char * TOOLEXPORT _FP_tempnam _ANSI_ARGS_((char *, char *));
#endif
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -2,7 +2,7 @@
// ------------------------------------------------------------------ // ------------------------------------------------------------------
// The Goldware Utilities. // The Goldware Utilities.
// Copyright (C) 1990-1999 Odinn Sorensen // Copyright (C) 1990-1999 Odinn Sorensen
// Copyright (C) 1999-2000 Alexander S. Aganichev // Copyright (C) 1999-2001 Alexander S. Aganichev
// ------------------------------------------------------------------ // ------------------------------------------------------------------
// This program is free software; you can redistribute it and/or // This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as // modify it under the terms of the GNU General Public License as
@ -42,6 +42,7 @@
#include <gdirposx.h> #include <gdirposx.h>
#include <gutlos.h> #include <gutlos.h>
#include <glog.h> #include <glog.h>
#include <iomanip>
//#define GOLDNODE_STATS 1 //#define GOLDNODE_STATS 1
@ -128,16 +129,11 @@ struct nl_stat {
nl_stat statistic; nl_stat statistic;
#endif #endif
// ------------------------------------------------------------------
#define fast_printf if(not quiet) printf
#define fast_putchar if(not quiet) putchar
// ------------------------------------------------------------------ // ------------------------------------------------------------------
// Display a "twirly" // Display a "twirly"
#define TWIRLY_FACTOR 511 #define TWIRLY_FACTOR 511
#define ISTWIRLY(n) (((n)&TWIRLY_FACTOR)==0) #define ISTWIRLY(n) (not quiet and (((n)&TWIRLY_FACTOR)==0))
static void twirly() { static void twirly() {
@ -145,14 +141,11 @@ static void twirly() {
n = (++n)%4; n = (++n)%4;
switch(n) { switch(n) {
case 0: fast_putchar('|'); break; case 0: cout << "|\b" << flush; break;
case 1: fast_putchar('/'); break; case 1: cout << "/\b" << flush; break;
case 2: fast_putchar('-'); break; case 2: cout << "-\b" << flush; break;
case 3: fast_putchar('\\'); break; case 3: cout << "\\\b" << flush; break;
} }
fast_putchar('\b');
fflush(stdout);
} }
@ -467,7 +460,7 @@ static char* CvtName(char* inp) {
// ------------------------------------------------------------------ // ------------------------------------------------------------------
#ifdef GOLDNODE_STATS #ifdef GOLDNODE_STATS
void calc_statistic(FILE* ofp, int* observation, float N) { void calc_statistic(ofstream &ofp, int* observation, float N) {
int i; int i;
float mean = 0.0; float mean = 0.0;
@ -475,9 +468,9 @@ void calc_statistic(FILE* ofp, int* observation, float N) {
float varians = 0.0; float varians = 0.0;
// 12 12345 12345 123456 123456789012 // 12 12345 12345 123456 123456789012
fprintf(ofp, ".---------------------------------------------.\n"); ofp << ".---------------------------------------------." << endl
fprintf(ofp, "| x | h(x) | f(x) | x*f(x) | (x-m)^2*f(x) |\n"); << "| x | h(x) | f(x) | x*f(x) | (x-m)^2*f(x) |" << endl
fprintf(ofp, "|-----+-------+-------+--------+--------------|\n"); << "|-----+-------+-------+--------+--------------|" << endl;
for(i=0; i<100; i++) { for(i=0; i<100; i++) {
float x = i; float x = i;
@ -496,18 +489,18 @@ void calc_statistic(FILE* ofp, int* observation, float N) {
float frekvens = hyppighed / N; float frekvens = hyppighed / N;
float vartmp = (x-mean)*(x-mean)*frekvens; float vartmp = (x-mean)*(x-mean)*frekvens;
varians += vartmp; varians += vartmp;
fprintf(ofp, "| %3i | %5i | %5.3f | %6.3f | %12.3f | \n", i, observation[i], frekvens, x*frekvens, vartmp); ofp << "| " << setw(3) << i << " | " << setw(5) << observation[i] << " | " << setprecision(3) << setw(5) << frekvens << " | " << setw(6) << x*frekvens << " | " << setw(12) << vartmp << " | " << endl;
} }
} }
fprintf(ofp, "|-----+-------+-------+--------+--------------|\n"); ofp << "|-----+-------+-------+--------+--------------|" << endl
fprintf(ofp, "| sum | %5.0f | %5.3f | %5.3f | %12.3f |\n", N, sumfrekvens, mean, varians); << "| sum | " << setprecision(0) << setw(5) << N << " | " << setprecision(3) << setw(5) << sumfrekvens << " | " << setw(5) << mean << " | " << setw(12) << varians << " |" << endl
fprintf(ofp, "`---------------------------------------------'\n"); << "`---------------------------------------------'" << endl
fprintf(ofp, "\n"); << endl
fprintf(ofp, "Mean: %.1f\n", mean); << "Mean: " << setprecision(1) << mean << endl
fprintf(ofp, "Variance = %.1f\n", varians); << "Variance = " << varians << endl
fprintf(ofp, "Standard deviation = %.1f\n", sqrt(varians)); << "Standard deviation = " << sqrt(varians) << endl
fprintf(ofp, "\n"); << endl;
} }
#endif #endif
@ -555,7 +548,7 @@ static void read_nodelists() {
nodes = 0; nodes = 0;
fast_printf("\n* Compiling nodelists:\n"); if(not quiet) cout << endl << "* Compiling nodelists:" << endl;
// Delete the current indexfiles so they don't take up space // Delete the current indexfiles so they don't take up space
remove(addrindex.c_str()); remove(addrindex.c_str());
@ -597,7 +590,10 @@ static void read_nodelists() {
ptr = buf+llen-1; ptr = buf+llen-1;
while(llen and not (*ptr == '\r' or *ptr == '\n' or *ptr == '\x1A')) { while(llen and not (*ptr == '\r' or *ptr == '\n' or *ptr == '\x1A')) {
buf[llen] = ' '; buf[llen] = ' ';
fast_printf("\r* |-%-12s Warning line %u - Invalid NUL char encountered.\n", name, line); if(not quiet) {
int len = 16-strlen(name);
cout << "\r* |--" << name << setw((len > 0) ? len : 1) << " " << "Warning line " << line << " - Invalid NUL char encountered." << endl;
}
llen = strlen(buf); llen = strlen(buf);
ptr = buf+llen-1; ptr = buf+llen-1;
} }
@ -688,7 +684,8 @@ static void read_nodelists() {
} }
if(ISTWIRLY(no)) { if(ISTWIRLY(no)) {
fast_printf("\r* \\--%-12s Zone %-5u Net %-5u Nodes %6lu", name, nlst.addr.zone, nlst.addr.net, (ulong)no); int len = 16-strlen(name);
cout << "\r* \\--" << name << setw((len > 0) ? len : 1) << " " << "Zone " << nlst.addr.zone << "\tNet " << nlst.addr.net << "\tNodes " << (ulong)no << flush;
} }
bool include = true; bool include = true;
@ -733,20 +730,16 @@ static void read_nodelists() {
} }
} }
fast_printf("\r* %c--%-12s Nodes read: %6lu Total read: %6lu", fno==nodelist.end()-1?'\\':'|', name, (ulong)no, (ulong)nodes); if(not quiet) {
int len = 16-strlen(name);
if(nodes >= maxnodes) { cout << "\r* " << ((fno == nodelist.end()-1) ? '\\' : '|') << "--" << name << setw((len > 0) ? len : 1) << " " << "Nodes read: " << (ulong)no << "\tTotal read: " << (ulong)nodes << ((nodes >= maxnodes) ? " (Limit reached)" : " ") << endl;
fast_printf(" (Limit reached)\n");
}
else {
fast_printf(" \n");
} }
fclose(lfp); fclose(lfp);
++realfno; ++realfno;
} }
else { else {
fast_printf("Error Opening nodelist %s!\n", fno->fn); if(not quiet) cout << "Error opening nodelist " << fno->fn << '!' << endl;
*(fno->fn) = NUL; *(fno->fn) = NUL;
} }
} }
@ -754,7 +747,7 @@ static void read_nodelists() {
// Compile userlists // Compile userlists
if(userlist.size()) { if(userlist.size()) {
fast_printf("\n* Compiling userlists:\n"); if(not quiet) cout << endl << "* Compiling userlists:" << endl;
} }
for(fno=userlist.begin(), zno=userzone.begin(); fno != userlist.end() and nodes < maxnodes; fno++, zno++) { for(fno=userlist.begin(), zno=userzone.begin(); fno != userlist.end() and nodes < maxnodes; fno++, zno++) {
@ -819,8 +812,10 @@ static void read_nodelists() {
if(include) { // Address was okay if(include) { // Address was okay
if(ISTWIRLY(nodes)) if(ISTWIRLY(nodes)) {
fast_printf("\r* \\--%s: %6lu", name, (ulong)nodes); int len = 16-strlen(name);
cout << "\r* \\--" << name << setw((len > 0) ? len : 1) << " " << "Nodes: " << (ulong)nodes << flush;
}
// Indicate userlist // Indicate userlist
nlst.pos = (long)0xFFFFFFFFL; nlst.pos = (long)0xFFFFFFFFL;
@ -839,40 +834,36 @@ static void read_nodelists() {
} }
} }
fast_printf("\r* %c--%-12s Nodes read: %6lu Total read: %6lu", fno==userlist.end()-1?'\\':'|', name, (ulong)no, (ulong)nodes); if(not quiet) {
int len = 16-strlen(name);
if(nodes >= maxnodes) { cout << "\r* " << ((fno == userlist.end()-1) ? '\\' : '|') << "--" << name << setw((len > 0) ? len : 1) << " " << "Nodes read: " << (ulong)no << "\tTotal read: " << (ulong)nodes << ((nodes >= maxnodes) ? " (Limit reached)" : " ") << endl;
fast_printf(" (Limit reached)\n");
}
else {
fast_printf(" \n");
} }
fclose(lfp); fclose(lfp);
} }
else { else {
fast_printf("Error Opening Userlist %s!\n", fno->fn); if(not quiet) cout << "Error opening userlist " << fno->fn << '!' << endl;
} }
} }
#ifdef GOLDNODE_STATS #ifdef GOLDNODE_STATS
if(make_stats) { if(make_stats) {
fast_printf("* Writing statistics to %s\n", statfilename); if(not quiet) cout << "* Writing statistics to " << statfilename << endl;
FILE *ofp = fopen(statfilename, "wt"); ofstream ofp(statfilename);
if(ofp) { if(not ofp) {
if(not quiet) cout << "Error opening statfile " << statfilename << '!' << endl;
fprintf(ofp, "Nodename size statistics:\n"); }
else
ofp << "Nodename size statistics:" << endl;
calc_statistic(ofp, statistic.nodename, nodes); calc_statistic(ofp, statistic.nodename, nodes);
fprintf(ofp, "\nLocation size statistics:\n"); ofp << endl << "Location size statistics:" << endl;
calc_statistic(ofp, statistic.location, nodes); calc_statistic(ofp, statistic.location, nodes);
fprintf(ofp, "\nSysopname size statistics:\n"); ofp << endl << "Sysopname size statistics:" << endl;
calc_statistic(ofp, statistic.sysopname, nodes); calc_statistic(ofp, statistic.sysopname, nodes);
fclose(ofp);
} }
} }
else { else {
@ -883,7 +874,7 @@ static void read_nodelists() {
map<long, dword> namepos; map<long, dword> namepos;
// Sort by name // Sort by name
fast_printf("\n* Sorting by name "); if(not quiet) cout << endl << "* Sorting by name " << flush;
nodeidx.sort(cmp_nnlsts); nodeidx.sort(cmp_nnlsts);
// Write the name-sorted .GXN // Write the name-sorted .GXN
@ -894,11 +885,11 @@ static void read_nodelists() {
if(fidouser) if(fidouser)
fido = fsopen(fidouserlst, "wt", sh_mod); fido = fsopen(fidouserlst, "wt", sh_mod);
if(fido == NULL) { if(fido == NULL) {
fast_printf("\b, writing %s ", name); if(not quiet) cout << "\b, writing " << name << ' ' << flush;
fidouser = false; fidouser = false;
} }
else { else {
fast_printf("\b, writing %s and %s ", name, fidouserlst); if(not quiet) cout << "\b, writing " << name << " and " << fidouserlst << ' ' << flush;
} }
int nn = 0; int nn = 0;
@ -912,7 +903,7 @@ static void read_nodelists() {
if(prev != nodeidx.end() && match_addr_mask(&curr->addr, &prev->addr)) { if(prev != nodeidx.end() && match_addr_mask(&curr->addr, &prev->addr)) {
if(strieql(curr->name, prev->name)) { if(strieql(curr->name, prev->name)) {
#ifdef DEBUG #ifdef DEBUG
fast_printf("* Dupe: %d:%d/%d.%d %s\n",curr->addr.zone,curr->addr.net,curr->addr.node,curr->addr.point,curr->name); if(not quiet) cout << "* Dupe: " << curr->addr.zone << ':' << curr->addr.net << '/' << curr->addr.node << '.' << curr->addr.point << ' ' << curr->name << endl;
#endif #endif
nodeidx.erase(curr); nodeidx.erase(curr);
curr = prev; curr = prev;
@ -936,14 +927,14 @@ static void read_nodelists() {
} }
// Sort by address // Sort by address
fast_printf(" \n* Sorting by node "); if(not quiet) cout << ' ' << endl << "* Sorting by node " << flush;
nodeidx.sort(cmp_anlsts); nodeidx.sort(cmp_anlsts);
// Write the address-sorted .GXA // Write the address-sorted .GXA
fp = fsopen(addrindex.c_str(), "wb", sh_mod); fp = fsopen(addrindex.c_str(), "wb", sh_mod);
if(fp) { if(fp) {
name = CleanFilename(addrindex.c_str()); name = CleanFilename(addrindex.c_str());
fast_printf("\b, writing %s ", name); if(not quiet) cout << "\b, writing " << name << ' ' << flush;
int nn = 0; int nn = 0;
for(curr = nodeidx.begin(); curr != nodeidx.end(); curr++) { for(curr = nodeidx.begin(); curr != nodeidx.end(); curr++) {
if(ISTWIRLY(nn++)) if(ISTWIRLY(nn++))
@ -957,7 +948,7 @@ static void read_nodelists() {
fp = fsopen(listindex.c_str(), "wt", sh_mod); fp = fsopen(listindex.c_str(), "wt", sh_mod);
if(fp) { if(fp) {
name = CleanFilename(listindex.c_str()); name = CleanFilename(listindex.c_str());
fast_printf(" \n* Writing %s\n", name); if(not quiet) cout << ' ' << endl << "* Writing " << name << endl;
for(fno=nodelist.begin(); fno != nodelist.end(); fno++) { for(fno=nodelist.begin(); fno != nodelist.end(); fno++) {
if(*(fno->fn)) if(*(fno->fn))
fprintf(fp, "%s %lu\n", fno->fn, fno->ft); fprintf(fp, "%s %lu\n", fno->fn, fno->ft);
@ -968,10 +959,12 @@ static void read_nodelists() {
// Note compile time // Note compile time
runtime = time(NULL) - runtime; runtime = time(NULL) - runtime;
if(not quiet) {
if(dups) { if(dups) {
fast_printf("\n* Total duplicate nodes: %6lu.\n", (ulong)dups); cout << endl << "* Total duplicate nodes: " << (ulong)dups << '.' << endl;
}
cout << endl << "* Nodelist compile completed. Compile time: " << (ulong)(runtime/60) << " min, " << (ulong)(runtime%60) << " sec." << endl;
} }
fast_printf("\n* Nodelist compile completed. Compile time: %lu min, %lu sec.\n", (ulong)(runtime/60), (ulong)(runtime%60));
#ifdef GOLDNODE_STATS #ifdef GOLDNODE_STATS
} }
#endif #endif
@ -1044,11 +1037,13 @@ static void check_nodelists(bool force) {
} }
} }
if(not quiet) {
if(compilen) { if(compilen) {
fast_printf("* %u new nodelist file%s found.\n", compilen, compilen==1?"":"s"); cout << "* " << compilen << " new nodelist file" << ((compilen == 1) ? "" : "s") << " found." << endl;
} }
else if(nodelist.size()) { else if(nodelist.size()) {
fast_printf("* The nodelist file%s up-to-date.\n", nodelist.size()==1?" is":"s are"); cout << "* The nodelist file" << ((nodelist.size() == 1) ? " is" : "s are") << " up-to-date." << endl;
}
} }
// Check userlists // Check userlists
@ -1059,11 +1054,13 @@ static void check_nodelists(bool force) {
} }
} }
if(not quiet) {
if(compileu) { if(compileu) {
fast_printf("* %u new userlist file%s found.\n", compileu, compileu==1?"":"s"); cout << "* " << compileu << " new userlist file" << ((compileu == 1) ? "" : "s") << " found." << endl;
} }
else if(userlist.size()) { else if(userlist.size()) {
fast_printf("* The userlist file%s up-to-date.\n", userlist.size()==1?" is":"s are"); cout << "* The userlist file" << ((userlist.size() == 1) ? " is" : "s are") << " up-to-date." << endl;
}
} }
if(force or compilen or compileu) if(force or compilen or compileu)
@ -1075,8 +1072,7 @@ static void check_nodelists(bool force) {
static void fatal_error(const char* what) { static void fatal_error(const char* what) {
fast_printf(what); if(not quiet) cout << what << endl;
fast_printf("\n");
exit(5); exit(5);
} }
@ -1169,7 +1165,7 @@ static int parse_config(const char *__configfile, Addr& zoneaddr) {
switch(crc) { switch(crc) {
case CRC_IF: case CRC_IF:
if(in_if) { if(in_if) {
fast_printf("* %s: Misplaced IF at line %u. IF's cannot be nested.\n", __configfile, line); if(not quiet) cout << "* " << __configfile << ": Misplaced IF at line " << line << ". IF's cannot be nested." << endl;
} }
in_if = YES; in_if = YES;
cond_status = do_if(value); cond_status = do_if(value);
@ -1177,20 +1173,20 @@ static int parse_config(const char *__configfile, Addr& zoneaddr) {
case CRC_ELIF: case CRC_ELIF:
case CRC_ELSEIF: case CRC_ELSEIF:
if((not in_if) or in_else) { if((not in_if) or in_else) {
fast_printf("* %s: Misplaced ELIF/ELSEIF at line %u.\n", __configfile, line); if(not quiet) cout << "* " << __configfile << ": Misplaced ELIF/ELSEIF at line " << line << '.' << endl;
} }
cond_status = do_if(value); cond_status = do_if(value);
break; break;
case CRC_ELSE: case CRC_ELSE:
if((not in_if) or in_else) { if((not in_if) or in_else) {
fast_printf("* %s: Misplaced ELSE at line %u.\n", __configfile, line); if(not quiet) cout << "* " << __configfile << "Misplaced ELSE at line " << line << '.' << endl;
} }
in_else = YES; in_else = YES;
cond_status ^= YES; cond_status ^= YES;
break; break;
case CRC_ENDIF: case CRC_ENDIF:
if(not in_if) { if(not in_if) {
fast_printf("* %s: Misplaced ENDIF at line %u.\n", __configfile, line); if(not quiet) cout << "* " << __configfile << ": Misplaced ENDIF at line " << line << '.' << endl;
} }
in_if = in_else = NO; in_if = in_else = NO;
cond_status = YES; cond_status = YES;
@ -1283,7 +1279,7 @@ static int parse_config(const char *__configfile, Addr& zoneaddr) {
case CRC_INCLUDE: case CRC_INCLUDE:
strschg_environ(value); strschg_environ(value);
if(not parse_config(value,zoneaddr)) // NOTE! This is a recursive call! if(not parse_config(value,zoneaddr)) // NOTE! This is a recursive call!
fast_printf("* Could not read configuration file '%s' !\n",value); if(not quiet) cout << "* Could not read configuration file " << value << '!' << endl;
break; break;
default: default:
break; break;
@ -1467,45 +1463,44 @@ static void run_gn(int argc, char* argv[]) {
cfg = argv[n]; cfg = argv[n];
} }
fast_printf( if(not quiet) {
__GPID__ " " __GVER__ " Nodelist Compiler.\n" cout << __GPID__ " " __GVER__ " Nodelist Compiler." << endl
"Copyright (C) 1990-1999 Odinn Sorensen\n" << "Copyright (C) 1990-1999 Odinn Sorensen" << endl
"Copyright (C) 1999-2000 Alexander S. Aganichev\n" << "Copyright (C) 1999-2001 Alexander S. Aganichev" << endl
"-------------------------------------------------------------------------------\n" << "-------------------------------------------------------------------------------" << endl
"\n" << endl;
); }
if(not(force or conditional)) { if(not(force or conditional)) {
fast_printf( if(not quiet) {
"Commandline syntax: %s [-options] [configfile]\n" cout << "Commandline syntax: " << CleanFilename(argv[0]) << " [-options] [configfile]" << endl
"\n" << endl
"[-options] = -C Conditional compile.\n" << "[-options] =\t-C\t Conditional compile." << endl
" -F Forced compile.\n" << "\t\t-F\t Forced compile." << endl
" -D Remove duplicate nodes from index while compiling.\n" << "\t\t-D\t Remove duplicate nodes from index while compiling." << endl
" -Q Quiet compile. No screen output improves speed.\n" << "\t\t-Q\t Quiet compile. No screen output improves speed." << endl
" -S<size> Set max size of a name in the index.\n" << "\t\t-S<size> Set max size of a name in the index." << endl
" -U<file> Create sorted FIDOUSER.LST userlist file.\n" << "\t\t-U<file> Create sorted FIDOUSER.LST userlist file." << endl
#ifdef GOLDNODE_STATS #ifdef GOLDNODE_STATS
" -T Make statistics.\n" << "\t\t-T\t Make statistics." << endl
#endif #endif
"" << endl
"[configfile] = The path AND filename of GOLDED.CFG\n" << "[configfile] =\t\t The path AND filename of GOLDED.CFG" << endl
" configuration file to read.\n" << "\t\t\t configuration file to read." << endl
"\n", << endl;
CleanFilename(argv[0]) }
);
} }
else { else {
if(force) if(force)
fast_printf("* Forced compile.\n"); if(not quiet) cout << "* Forced compile." << endl;
if(read_config(cfg, argv[0])) { if(read_config(cfg, argv[0])) {
if(force or conditional) if(force or conditional)
check_nodelists(force); check_nodelists(force);
} }
else { else {
fast_printf("\nCould not find the configuration file!\n"); if(not quiet) cout << endl << "Could not find the configuration file!" << endl;
} }
} }
} }