377 lines
11 KiB
C++
377 lines
11 KiB
C++
// This may look like C code, but it is really -*- C++ -*-
|
|
|
|
// ------------------------------------------------------------------
|
|
// The Goldware Library
|
|
// Copyright (C) 1990-1999 Odinn Sorensen
|
|
// ------------------------------------------------------------------
|
|
// 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 PCBoard.
|
|
// ------------------------------------------------------------------
|
|
|
|
#include <cstdlib>
|
|
#include <gmemdbg.h>
|
|
#include <gstrall.h>
|
|
#if defined(__GOLD_GUI__)
|
|
#include <gvidall.h>
|
|
#include <gvidgui.h>
|
|
#endif
|
|
#undef GCFG_NOPCB
|
|
#include <gedacfg.h>
|
|
#include <gs_pcb.h>
|
|
|
|
|
|
// ------------------------------------------------------------------
|
|
|
|
void gareafile::ReadPCBoard(char* tag) {
|
|
|
|
AreaCfg aa;
|
|
Path _path;
|
|
char _options[80];
|
|
Path _usersidxpath;
|
|
Path _userspath;
|
|
Path _cnamespath;
|
|
Path _fidopath;
|
|
|
|
PcbFidoArea* areap = NULL;
|
|
PcbFidoDirectories* dirp = NULL;
|
|
PcbFidoAddress* akap = NULL;
|
|
int akanumrecs = 0;
|
|
int numareas = 0;
|
|
|
|
PcbDirectories* dir3 = NULL;
|
|
PcbAreasDat* area3 = NULL;
|
|
PcbAkasDat* aka3 = NULL;
|
|
PcbOriginsDat* origin3 = NULL;
|
|
|
|
word fido_version = 0;
|
|
|
|
*_fidopath = NUL;
|
|
strcpy(_path, pcboardpath);
|
|
strcpy(_options, tag);
|
|
|
|
char* ptr = strtok(tag, " \t");
|
|
while(ptr) {
|
|
if(*ptr != '-') {
|
|
AddBackslash(strcpy(_path, ptr));
|
|
break;
|
|
}
|
|
ptr = strtok(NULL, " \t");
|
|
}
|
|
if(*_path == NUL) {
|
|
ptr = getenv("PCBOARD");
|
|
if(ptr)
|
|
AddBackslash(strcpy(_path, ptr));
|
|
}
|
|
if(*_path == NUL)
|
|
strcpy(_path, areapath);
|
|
|
|
CfgPcboardpath(_path);
|
|
|
|
const char* _file = AddPath(_path, "pcboard.dat");
|
|
gfile fp(_file, "rt");
|
|
if (fp.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
int _line = 0;
|
|
|
|
char _buf[256];
|
|
while (fp.Fgets(_buf, sizeof(_buf)))
|
|
{
|
|
_line++;
|
|
switch(_line) {
|
|
case 28: // Location of User INDEX Files
|
|
strxcpy(_usersidxpath, strbtrim(_buf), GMAXPATH);
|
|
break;
|
|
case 29: // Name/Location of USERS File
|
|
strxcpy(_userspath, strbtrim(_buf), GMAXPATH);
|
|
break;
|
|
case 31: // Name/Location of CNAMES File
|
|
strxcpy(_cnamespath, strbtrim(_buf), GMAXPATH);
|
|
break;
|
|
case 324: // Path to FidoNet config files
|
|
strxcpy(_fidopath, strbtrim(_buf), GMAXPATH);
|
|
break;
|
|
}
|
|
}
|
|
|
|
fp.Fclose();
|
|
|
|
if (*_fidopath)
|
|
{
|
|
const char* _file = AddPath(_fidopath, "pcbfido.cfg");
|
|
fp.Fopen(_file, "rb");
|
|
if (fp.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
// Get configuration file version
|
|
fp.Fread(&fido_version, 2);
|
|
|
|
if(fido_version == 2) {
|
|
|
|
word numrecs = 0;
|
|
|
|
// Get areas
|
|
fp.Fread(&numrecs, 2);
|
|
numareas = numrecs;
|
|
areap = (PcbFidoArea*)throw_calloc(1+numrecs, sizeof(PcbFidoArea));
|
|
fp.Fread(areap, sizeof(PcbFidoArea), numrecs);
|
|
|
|
// Skip archivers
|
|
fp.Fseek(sizeof(PcbFidoArchivers), SEEK_CUR);
|
|
|
|
// Get directories
|
|
dirp = (PcbFidoDirectories*)throw_calloc(1, sizeof(PcbFidoDirectories));
|
|
fp.Fread(dirp, sizeof(PcbFidoDirectories));
|
|
|
|
// Skip EMSI profile
|
|
fp.Fseek(sizeof(PcbFidoEmsiData), SEEK_CUR);
|
|
|
|
// Get akas
|
|
fp.Fread(&numrecs, 2);
|
|
akanumrecs = numrecs;
|
|
akap = (PcbFidoAddress*)throw_calloc(1+numrecs, sizeof(PcbFidoAddress));
|
|
fp.Fread(akap, sizeof(PcbFidoAddress), numrecs);
|
|
int akano = 0;
|
|
while(akano < numrecs) {
|
|
CfgAddress(akap[akano].nodestr);
|
|
akano++;
|
|
}
|
|
}
|
|
else if(fido_version == 3) {
|
|
|
|
dir3 = (PcbDirectories*)throw_calloc(1, sizeof(PcbDirectories));
|
|
fp.Fread(dir3, sizeof(PcbDirectories));
|
|
fp.Fclose();
|
|
|
|
_file = AddPath(_fidopath, "areas.dat");
|
|
fp.Fopen(_file, "rb");
|
|
if (fp.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
word cfgver = 0;
|
|
fp.Fread(&cfgver, 2);
|
|
if (cfgver == 3)
|
|
{
|
|
word numrecs = (word)(fp.FileLength() / sizeof(PcbAreasDat));
|
|
area3 = (PcbAreasDat*)throw_calloc(1+numrecs, sizeof(PcbAreasDat));
|
|
fp.Fread(area3, sizeof(PcbAreasDat), numrecs);
|
|
numareas = numrecs;
|
|
}
|
|
fp.Fclose();
|
|
}
|
|
|
|
_file = AddPath(_fidopath, "akas.dat");
|
|
fp.Fopen(_file, "rb");
|
|
if (fp.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
word cfgver = 0;
|
|
fp.Fread(&cfgver, 2);
|
|
if (cfgver == 3)
|
|
{
|
|
word numrecs = (word)(fp.FileLength() / sizeof(PcbAkasDat));
|
|
akanumrecs = numrecs;
|
|
aka3 = (PcbAkasDat*)throw_calloc(1+numrecs, sizeof(PcbAkasDat));
|
|
fp.Fread(aka3, sizeof(PcbAkasDat), numrecs);
|
|
int akano = 0;
|
|
while(akano < numrecs) {
|
|
char abuf[40];
|
|
CfgAddress(aka3[akano].addr.make_string(abuf));
|
|
akano++;
|
|
}
|
|
}
|
|
fp.Fclose();
|
|
}
|
|
|
|
_file = AddPath(_fidopath, "origins.dat");
|
|
fp.Fopen(_file, "rb");
|
|
if (fp.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
word cfgver = 0;
|
|
fp.Fread(&cfgver, 2);
|
|
if (cfgver == 3)
|
|
{
|
|
word numrecs = (word)(fp.FileLength() / sizeof(PcbOriginsDat));
|
|
origin3 = (PcbOriginsDat*)throw_calloc(1+numrecs, sizeof(PcbOriginsDat));
|
|
fp.Fread(origin3, sizeof(PcbOriginsDat), numrecs);
|
|
}
|
|
fp.Fclose();
|
|
}
|
|
}
|
|
|
|
fp.Fclose();
|
|
}
|
|
|
|
Path netmailpath;
|
|
*netmailpath = NUL;
|
|
if(dirp)
|
|
strcpy(netmailpath, dirp->outgoing_msg);
|
|
else if(dir3)
|
|
strcpy(netmailpath, dir3->outgoing_msg);
|
|
if(*netmailpath) {
|
|
aa.reset();
|
|
aa.basetype = fidomsgtype;
|
|
aa.type = GMB_NET;
|
|
aa.attr = attribsnet;
|
|
if(fido_version == 2)
|
|
aa.aka.reset(akap[0].nodestr);
|
|
else if(fido_version == 3) {
|
|
for(int n=0; n<akanumrecs; n++) {
|
|
if(aka3[n].primary_address) {
|
|
aa.aka = aka3[n].addr;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
aa.setpath(netmailpath);
|
|
aa.setdesc("PCBoard Netmail (*.MSG)");
|
|
aa.setautoid("NETMAIL.MSG");
|
|
AddNewArea(aa);
|
|
}
|
|
}
|
|
|
|
_file = AddPath(_cnamespath, ".@@@");
|
|
fp.Fopen(_file, "rb");
|
|
if (fp.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
gfile fp2;
|
|
_file = AddPath(_cnamespath, ".add");
|
|
fp2.Fopen(_file, "rb");
|
|
if (fp2.isopen())
|
|
{
|
|
if (not quiet)
|
|
STD_PRINTNL("* Reading " << _file);
|
|
|
|
word _recsize = 0;
|
|
fp.Fread(&_recsize, 2);
|
|
|
|
int confno = 0;
|
|
PcbConf* _cnames = (PcbConf*)throw_calloc(1, _recsize);
|
|
PcbAddConf* _cnamesadd = (PcbAddConf*)throw_calloc(1, sizeof(PcbAddConf));
|
|
while (fp.Fread(_cnames, _recsize) == 1)
|
|
{
|
|
fp2.Fread(_cnamesadd, sizeof(PcbAddConf));
|
|
if (*_cnames->name and *_cnames->msgfile)
|
|
{
|
|
aa.reset();
|
|
aa.basetype = "PCBOARD";
|
|
switch(_cnamesadd->conftype) {
|
|
case PCBCONFTYPE_EMAIL:
|
|
case PCBCONFTYPE_USENETMOD:
|
|
aa.type = GMB_EMAIL;
|
|
aa.attr = attribsemail;
|
|
break;
|
|
case PCBCONFTYPE_USENETJUNK:
|
|
case PCBCONFTYPE_USENETPUB:
|
|
aa.type = GMB_NEWSGROUP;
|
|
aa.attr = attribsnews;
|
|
break;
|
|
case PCBCONFTYPE_FIDOCONF:
|
|
aa.type = GMB_ECHO;
|
|
aa.attr = attribsecho;
|
|
break;
|
|
case PCBCONFTYPE_NORMAL:
|
|
default:
|
|
if(_cnames->echomail) {
|
|
aa.type = GMB_ECHO;
|
|
aa.attr = attribsecho;
|
|
}
|
|
else {
|
|
aa.type = GMB_LOCAL;
|
|
aa.attr = attribslocal;
|
|
}
|
|
}
|
|
if(_cnamesadd->readonly)
|
|
aa.attr.r_o1();
|
|
if(_cnames->privmsgs)
|
|
aa.attr.pvt1();
|
|
aa.board = confno;
|
|
aa.setpath(_cnames->msgfile);
|
|
char namebuf[61];
|
|
strcpy(stpcpy(namebuf, _cnames->name), _cnamesadd->name2);
|
|
aa.setdesc(namebuf);
|
|
strchg(namebuf, ' ', '_');
|
|
aa.setechoid(namebuf);
|
|
int areano = 0;
|
|
while(areano < numareas) {
|
|
if(fido_version == 2) {
|
|
if(areap[areano].pcbconference == confno) {
|
|
strchg(areap[areano].areaname, ' ', '_');
|
|
aa.setechoid(areap[areano].areaname);
|
|
aa.aka.set(areap[areano].defaultaka);
|
|
aa.setorigin(areap[areano].origin);
|
|
aa.setpath(areap[areano].messages);
|
|
break;
|
|
}
|
|
}
|
|
else if(fido_version == 3) {
|
|
if(area3[areano].confno == confno) {
|
|
aa.setechoid(area3[areano].areatag);
|
|
aa.aka = aka3[area3[areano].aka].addr;
|
|
aa.setorigin(origin3[area3[areano].origin].origin);
|
|
break;
|
|
}
|
|
}
|
|
areano++;
|
|
}
|
|
if(strieql(aa.echoid, "NETMAIL")) {
|
|
aa.type = GMB_NET;
|
|
aa.attr = attribsnet;
|
|
}
|
|
AddNewArea(aa);
|
|
}
|
|
confno++;
|
|
}
|
|
|
|
throw_free(_cnamesadd);
|
|
throw_free(_cnames);
|
|
|
|
fp2.Fclose();
|
|
}
|
|
|
|
fp.Fclose();
|
|
}
|
|
}
|
|
|
|
throw_free(origin3);
|
|
throw_free(area3);
|
|
throw_free(dir3);
|
|
throw_free(aka3);
|
|
throw_free(areap);
|
|
throw_free(dirp);
|
|
throw_free(akap);
|
|
}
|
|
|
|
|
|
// ------------------------------------------------------------------
|