campo-sirio/include/utility.cpp

352 lines
7.5 KiB
C++
Raw Normal View History

#include <ctype.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <xvt.h>
#if XVT_OS == XVT_OS_WIN
#include <direct.h>
#else
#include <sys/types.h>
#include <sys/stat.h>
#endif
#define __UTILITY_CPP
#include <utility.h>
#if XVT_OS == XVT_OS_SCOUNIX
#include <unistd.h>
int remove(const char* path)
{ return unlink(path); }
#else
#include <io.h>
#define F_OK 0
#endif
bool fcopy(const char* orig, const char* dest, bool append)
{
const char* wflag;
#if XVT_OS == XVT_OS_SCOUNIX
const char* const rflag = "r";
if (append)
wflag = "a";
else
wflag = "w";
#else
const char* const rflag = "rb";
if (append)
wflag = "ab";
else
wflag = "wb";
#endif
FILE* i = fopen(orig, rflag);
if (!i) return error_box("Impossibile leggere il file %s", orig);
FILE* o = fopen(dest, wflag);
CHECKS(o, "Impossibile scrivere il file ", dest);
const word size = 16*1024;
TString buffer(size);
bool ok = TRUE;
while (ok)
{
const word letti = fread((char*)(const char*)buffer, 1, size, i);
ok = fwrite((char*)(const char*)buffer, 1, letti, o) == letti;
if (letti < size) break;
}
if (!ok) error_box("Errore di scrittura: probabile disco pieno!");
fclose(o);
fclose(i);
return ok;
}
bool fexist(const char* file)
{
return access(file, F_OK) == 0;
}
bool make_dir(const char* dir)
{
int res =
#if XVT_OS==XVT_OS_SCOUNIX
mkdir(dir, 0777);
#else
mkdir(dir);
#endif
return res == 0;
}
int list_files(TToken_string& filelist)
{
TFilename dir(filelist.get(0));
for (int i = dir.len()-1; i >= 0; i--)
if (dir[i] == '/' || dir[i] == '\\') break;
const TString16 mask(dir.mid(i+1));
dir.cut(i > 0 ? i : 0);
xvt_fsys_save_dir();
DIRECTORY directory; xvt_fsys_convert_str_to_dir((char*)(const char*)dir, &directory);
BOOLEAN ok = xvt_fsys_set_dir(&directory);
if (!ok) fatal_box ("Impossibile entrare in %s", (const char*)dir);
SLIST files = xvt_fsys_list_files("", (char*)(const char*)mask, FALSE);
const int count = xvt_slist_count(files);
filelist.spaces(count*12);
filelist.cut(0);
for (SLIST_ELT e = xvt_slist_get_first(files); e; e = xvt_slist_get_next(files, e))
{
char* f = xvt_slist_get(files, e, NULL);
if (dir.not_empty())
{
filelist.add(dir);
filelist << '/' << f;
}
else
filelist.add(f);
}
xvt_slist_destroy(files);
xvt_fsys_restore_dir();
return count;
}
// Best function of the year
// Certified 99%
char* format(const char* fmt, ...)
{
va_list pars;
va_start(pars, fmt);
const int tot = vsprintf(__tmp_string, fmt, pars);
va_end(pars);
CHECK(tot >= 0 && tot < sizeof(__tmp_string)-1, "Ue'! Ma quanto scrivi?");
return(__tmp_string);
}
// Converte la coppia nome-parametro in una stringa una che identifica il programma
const char* cmd2name(const char* argv0, const char* argv1)
{
TFilename app(argv0);
app = app.name();
if (argv1 && *argv1) app << ' ' << argv1;
else app << " -0";
app.lower();
const int par = app.find(" -");
const int num = par > 0 ? atoi(app.mid(par+2))+1 : 1;
const char c = (num > 9) ? ('a'+num-10) : ('0'+num);
app.cut(3);
app << c << "00";
return strcpy(__tmp_string, app);
}
///////////////////////////////////////////////////////////
// Conversione in cifre romane
///////////////////////////////////////////////////////////
HIDDEN const char * cifre_romane = "IVXLCDM@";
HIDDEN const int valori_cifre [] = { 1, 5, 10, 50, 100, 500, 1000, -1 };
HIDDEN int ctoi(char c)
{
if (c == '\0') return 0;
c = toupper(c);
for (int i = 0; cifre_romane[i]; i++)
if (cifre_romane[i] == c) return valori_cifre[i];
return -1;
}
int rtoi(const char * val)
{
if (val == NULL) return 0;
int tot = 0;
int value = ctoi (val[0]);
for (int i = 1; value > 0; i++)
{
const int next_val = ctoi(val[i]);
if (value < next_val) tot -= value;
else tot += value;
value = next_val;
}
return (value == 0) ? tot : -1;
}
const char* itor(int num)
{
HIDDEN char roman_string[16];
int cifra = 0;
for (int pos = 7; pos--;)
{
int val = valori_cifre[pos];
int quanti = num / val;
if (quanti < 4)
{
if ((pos & 1) && quanti == 1 && (num/valori_cifre[pos-1]) == 9)
{
roman_string[cifra++] = cifre_romane[pos-1];
roman_string[cifra++] = cifre_romane[pos+1];
val = valori_cifre[pos-1];
quanti = 9;
}
else for (int i = 0; i < quanti; i++)
roman_string[cifra++] = cifre_romane[pos];
}
else
{
roman_string[cifra++] = cifre_romane[pos];
roman_string[cifra++] = cifre_romane[pos+1];
}
num -= quanti * val;
}
roman_string[cifra] = '\0';
return roman_string;
}
const char *esc(const char* s)
{
const char *s1 = s;
char *s2 = __tmp_string;
int base;
while (*s1)
{
if (*s1 == '\\')
{
s1++;
switch (tolower(*s1))
{
case 'b' : *s2++ = '\b'; break;
case 'e' : *s2++ = '\033'; break;
case 'f' : *s2++ = '\f'; break;
case 'n' : *s2++ = '\n'; break;
case 'r' : *s2++ = '\r'; break;
case 't' : *s2++ = '\t'; break;
default :
{
if (isdigit(*s1))
{
if (*s1 == '0')
{
s1++;
if (tolower(*s1) == 'x')
{
s1++;
base = 16;
}
else base = 8;
}
else base = 10;
*s2 = 0;
char c = tolower(*s1);
while (isdigit(c) || (base == 16 && c >= 'a' && c <= 'f'))
{
*s2 *= base;
if (isdigit(*s1)) *s2 += (*s1 - 48);
else *s2 += (*s1 - 'a' + 10) & 0x0F;
s1++;
c = tolower(*s1);
}
s2++; s1--;
}
else *s2++ = *s1;
}
}
}
else
if (*s1 == '^')
{
s1++;
*s2++ = (tolower(*s1) - 'a' + 1);
}
else *s2++ = *s1 ;
s1++;
}
*s2 = '\0';
return(__tmp_string);
}
HIDDEN const char * const key = "QSECOFR-";
const char * encode( const char * data)
{
for (int i = 0; data[i]; i++)
__tmp_string[i] = data[i] + (i < 8 ? key[i] : data[i - 8]);
__tmp_string[i] = '\0';
return __tmp_string;
}
const char * decode( const char * data)
{
for (int i = 0; data[i]; i++)
__tmp_string[i] = data[i] - (i < 8 ? key[i] : __tmp_string[i - 8]);
__tmp_string[i] = '\0';
return __tmp_string;
}
#if XVT_OS == XVT_OS_SCOUNIX
int stricmp(const char* s1, const char* s2)
{
for(int d = 0 ; (d = toupper(*s1)-toupper(*s2)) == 0; s1++, s2++)
if (*s1 == '\0' && *s2 == '\0')
return 0;
return d;
}
#endif
#ifdef __WATCOMC__
char * tempnam(const char * dir , const char * prefix)
{
TFilename tmpdir(getenv("TMP"));
static word counter = 1;
if (tmpdir.empty() || !fexist(tmpdir))
{
tmpdir = dir;
if (tmpdir.empty() || !fexist(tmpdir))
tmpdir = "";
}
if (is_not_slash(tmpdir.right(1)[0]))
tmpdir << '/';
tmpdir << prefix ;
const int lastpos = tmpdir.len() ;
tmpdir << format("%ud", counter);
while (!fexist(tmpdir))
{
counter++;
if (counter == 0) counter = 1;
tmpdir.cut(lastpos);
tmpdir << format("%ud", counter);
}
return strdup(tmpdir);
}
#endif