This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.

228 lines
6.2 KiB
C++

// This may look like C code, but it is really -*- C++ -*-
// ------------------------------------------------------------------
// The Goldware Library
// Copyright (C) 1999-2000 Alexander S. Aganichev
// ------------------------------------------------------------------
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Library General Public
// License as published by the Free Software Foundation; either
// version 2 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Library General Public License for more details.
//
// You should have received a copy of the GNU Library General Public
// License along with this program; if not, write to the Free
// Software Foundation, Inc., 59 Temple Place, Suite 330, Boston,
// MA 02111-1307, USA
// ------------------------------------------------------------------
// $Id$
// ------------------------------------------------------------------
// Read areas from Crashmail II
// ------------------------------------------------------------------
#include <cstdlib>
#include <gcrcall.h>
#include <gstrall.h>
#undef GCFG_NOCMAIL
#include <gedacfg.h>
// ------------------------------------------------------------------
bool gareafile::jbstrcpy(char *dest, char *src, size_t maxlen, size_t *jbc) {
size_t d=0;
size_t stopchar1,stopchar2;
size_t jbcpos;
jbcpos= *jbc;
while(isspace(src[jbcpos])) jbcpos++;
if(src[jbcpos]=='\"') {
jbcpos++;
stopchar1='\"';
stopchar2=0;
}
else {
stopchar1=' ';
stopchar2=9;
}
while(src[jbcpos]!=stopchar1 and src[jbcpos]!=stopchar2 and src[jbcpos]!='\n' and src[jbcpos]!=NUL and d<maxlen-1) {
if(src[jbcpos]=='\\' and src[jbcpos+1]!=NUL and src[jbcpos+1]!='\n') {
jbcpos++;
dest[d++]=src[jbcpos++];
}
else
dest[d++]=src[jbcpos++];
}
dest[d]=0;
if(isspace(src[jbcpos]) or src[jbcpos]=='\"') jbcpos++;
*jbc=jbcpos;
if(d!=0 or stopchar1=='\"') return true;
return false;
}
// ------------------------------------------------------------------
// Read areas from HPT (echomail processor)
void gareafile::ReadCrashmail(char* tag) {
Path file, path;
char options[80];
strcpy(options, tag);
char* ptr = strtok(tag, " \t");
while(ptr) {
if(*ptr != '-') {
strcpy(file, ptr);
}
ptr = strtok(NULL, " \t");
}
extractdirname(path, file);
if(*squishuserpath == NUL)
PathCopy(squishuserpath, path);
FILE* fp = fsopen(file, "rb", sharemode);
if(fp) {
setvbuf(fp, NULL, _IOFBF, 8192);
if(not quiet)
cout << "* Reading " << file << endl;
char buf[4000];
char key[30];
char tmp[100], address[50], domain[50];
bool unconfirmed = true;
size_t jbcpos;
AreaCfg aa;
aa.reset();
aa.type = 0xff;
address[0] = NUL;
domain[0] = NUL;
const word CRC_AKA = 0x13A4;
const word CRC_AREA = 0x010B;
const word CRC_LOCALAREA = 0xAEC1;
const word CRC_DESCRIPTION = 0x2DF1;
const word CRC_DOMAIN = 0xFFCA;
const word CRC_GROUP = 0x1C9B;
const word CRC_NETMAIL = 0xE42E;
const word CRC_SYSOP = 0x967F;
const word CRC_UNCONFIRMED = 0x195E;
const word CRC_MSG = 0xCA2E;
const word CRC_JAM = 0xA8C3;
const word CRC_SQUISH = 0xFCF6;
word crc16;
while(fgets(buf, 4000, fp) != NULL) {
jbcpos=0;
jbstrcpy(key, buf, 30, &jbcpos);
switch(crc16 = strCrc16(key)) {
case CRC_SYSOP:
jbstrcpy(tmp, buf, 100, &jbcpos);
CfgUsername(tmp);
break;
case CRC_AKA:
if(address[0]) {
strxmerge(tmp, 100, address, "@", domain, NULL);
CfgAddress(tmp);
}
jbstrcpy(address, buf, 50, &jbcpos);
break;
case CRC_DOMAIN:
jbstrcpy(domain, buf, 50, &jbcpos);
break;
case CRC_AREA:
case CRC_NETMAIL:
case CRC_LOCALAREA:
if(aa.type != 0xff) {
if(not unconfirmed)
AddNewArea(aa);
aa.reset();
}
unconfirmed = false;
jbstrcpy(tmp, buf, 100, &jbcpos);
if(strieql(tmp, "DEFAULT") or strnieql(tmp, "DEFAULT_", 8)) {
aa.type = 0xff;
break;
}
switch(crc16) {
case CRC_NETMAIL:
aa.type = GMB_NET;
aa.attr = attribsnet;
break;
case CRC_AREA:
aa.type = GMB_ECHO;
aa.attr = attribsecho;
break;
case CRC_LOCALAREA:
aa.type = GMB_LOCAL;
aa.attr = attribslocal;
break;
}
aa.setechoid(tmp);
jbstrcpy(tmp, buf, 50, &jbcpos);
aa.aka = primary_aka;
aa.aka.set(tmp);
jbstrcpy(tmp, buf, 10, &jbcpos);
switch(strCrc16(tmp)) {
case CRC_MSG:
aa.msgbase = fidomsgtype;
break;
case CRC_JAM:
aa.msgbase = GMB_JAM;
break;
case CRC_SQUISH:
aa.msgbase = GMB_SQUISH;
break;
default:
aa.reset();
aa.type = 0xff;
break;
}
if(aa.type == 0xff)
break;
jbstrcpy(path, buf, sizeof(Path), &jbcpos);
strxcpy(buf, path, sizeof(Path));
aa.setpath(MapPath(buf));
break;
case CRC_DESCRIPTION:
jbstrcpy(tmp, buf, 100, &jbcpos);
aa.setdesc(tmp);
break;
case CRC_UNCONFIRMED:
unconfirmed = true;
break;
case CRC_GROUP:
if(jbstrcpy(tmp, buf, 100, &jbcpos))
aa.groupid = toupper(tmp[0]);
break;
}
}
if(aa.type != 0xff) {
if(not unconfirmed) {
AddNewArea(aa);
}
} else if(address[0]) {
strxmerge(tmp, 100, address, "@", domain, NULL);
CfgAddress(tmp);
}
}
fclose(fp);
}
// ------------------------------------------------------------------