Added some experimental code for tic orphans processing
This commit is contained in:
parent
faf5c18a67
commit
75b6e42acd
@ -2,6 +2,8 @@ $Id$
|
|||||||
|
|
||||||
v0.83.1 12-Nov-2005
|
v0.83.1 12-Nov-2005
|
||||||
|
|
||||||
|
mbfido:
|
||||||
|
Added some experimental code for tic orphans processing.
|
||||||
|
|
||||||
v0.83.0 06-Nov-2005 - 12-Nov-2005
|
v0.83.0 06-Nov-2005 - 12-Nov-2005
|
||||||
|
|
||||||
|
@ -68,8 +68,8 @@ extern int check_dupe;
|
|||||||
*/
|
*/
|
||||||
int ProcessTic(fa_list **sbl, orphans **opl)
|
int ProcessTic(fa_list **sbl, orphans **opl)
|
||||||
{
|
{
|
||||||
time_t Now, Fdate;
|
time_t Now;
|
||||||
int Age, First, Listed = FALSE, DownLinks = 0, MustRearc = FALSE;
|
int First, Listed = FALSE, DownLinks = 0, MustRearc = FALSE;
|
||||||
int UnPacked = FALSE, IsArchive = FALSE, rc, i, j, k, File_Id = FALSE;
|
int UnPacked = FALSE, IsArchive = FALSE, rc, i, j, k, File_Id = FALSE;
|
||||||
char *Temp, *unarc = NULL, *cmd = NULL;
|
char *Temp, *unarc = NULL, *cmd = NULL;
|
||||||
char temp1[PATH_MAX], temp2[PATH_MAX], sbe[24], TDesc[256];
|
char temp1[PATH_MAX], temp2[PATH_MAX], sbe[24], TDesc[256];
|
||||||
@ -80,6 +80,7 @@ int ProcessTic(fa_list **sbl, orphans **opl)
|
|||||||
int BBS_Imp = FALSE, DidBanner = FALSE;
|
int BBS_Imp = FALSE, DidBanner = FALSE;
|
||||||
faddr *p_from;
|
faddr *p_from;
|
||||||
qualify *qal = NULL, *tmpq;
|
qualify *qal = NULL, *tmpq;
|
||||||
|
orphans *topl;
|
||||||
|
|
||||||
Now = time(NULL);
|
Now = time(NULL);
|
||||||
|
|
||||||
@ -98,19 +99,20 @@ int ProcessTic(fa_list **sbl, orphans **opl)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (TIC.Orphaned) {
|
if (TIC.Orphaned) {
|
||||||
WriteError("File not in inbound: %s", TIC.TicIn.File);
|
fill_orphans(opl, TIC.TicName, TIC.TicIn.Area, TIC.TicIn.File, TRUE, FALSE);
|
||||||
|
Syslog('+', "File not in inbound: %s", TIC.TicIn.File);
|
||||||
/*
|
/*
|
||||||
* Now check the age of the .tic file.
|
* Now check the age of the .tic file.
|
||||||
*/
|
*/
|
||||||
snprintf(Temp, PATH_MAX, "%s/%s", TIC.Inbound, TIC.TicName);
|
// snprintf(Temp, PATH_MAX, "%s/%s", TIC.Inbound, TIC.TicName);
|
||||||
Fdate = file_time(Temp);
|
// Fdate = file_time(Temp);
|
||||||
Age = (Now - Fdate) / 84400;
|
// Age = (Now - Fdate) / 84400;
|
||||||
Syslog('+', "Orphaned tic age %d days", Age);
|
// Syslog('+', "Orphaned tic age %d days", Age);
|
||||||
|
|
||||||
if (Age > 21) {
|
// if (Age > 21) {
|
||||||
tic_bad++;
|
// tic_bad++;
|
||||||
mover(TIC.TicName);
|
// mover(TIC.TicName);
|
||||||
}
|
// }
|
||||||
|
|
||||||
free(Temp);
|
free(Temp);
|
||||||
return 2;
|
return 2;
|
||||||
@ -134,8 +136,10 @@ int ProcessTic(fa_list **sbl, orphans **opl)
|
|||||||
if (TIC.Crc_Int) {
|
if (TIC.Crc_Int) {
|
||||||
if (crc != TIC.Crc_Int) {
|
if (crc != TIC.Crc_Int) {
|
||||||
Syslog('!', "CRC: expected %08lX, the file is %08lX", TIC.Crc_Int, crc);
|
Syslog('!', "CRC: expected %08lX, the file is %08lX", TIC.Crc_Int, crc);
|
||||||
|
fill_orphans(opl, TIC.TicName, TIC.TicIn.Area, TIC.TicIn.File, FALSE, TRUE);
|
||||||
if (check_crc) {
|
if (check_crc) {
|
||||||
Bad((char *)"CRC: error, %s may be damaged", TIC.TicIn.File);
|
// Bad((char *)"CRC: error, %s may be damaged", TIC.TicIn.File);
|
||||||
|
Syslog('+', "Bad CRC, will check this ticfile later");
|
||||||
free(Temp);
|
free(Temp);
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
} else {
|
||||||
@ -577,6 +581,15 @@ int ProcessTic(fa_list **sbl, orphans **opl)
|
|||||||
}
|
}
|
||||||
} /* not get FILE_ID.DIZ */
|
} /* not get FILE_ID.DIZ */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Now check if other (older) ticfiles point to this file
|
||||||
|
*/
|
||||||
|
for (topl = *opl; topl; topl = topl->next) {
|
||||||
|
if ((strcmp(topl->Area, TIC.TicIn.Area) == 0) && (strcmp(topl->FileName, TIC.TicIn.File) == 0)) {
|
||||||
|
Syslog('f', "Found matching tic file %s, should purge this one", topl->TicName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Rearc file if it is an unpacked archive.
|
* Rearc file if it is an unpacked archive.
|
||||||
*/
|
*/
|
||||||
|
@ -66,7 +66,7 @@ int Tic()
|
|||||||
struct stat sbuf;
|
struct stat sbuf;
|
||||||
int i, rc = 0;
|
int i, rc = 0;
|
||||||
fd_list *fdl = NULL;
|
fd_list *fdl = NULL;
|
||||||
orphans *opl = NULL;
|
orphans *opl = NULL, *tmp;
|
||||||
|
|
||||||
IsDoing("Process .tic files");
|
IsDoing("Process .tic files");
|
||||||
CompileNL = FALSE;
|
CompileNL = FALSE;
|
||||||
@ -152,6 +152,11 @@ int Tic()
|
|||||||
if (CompileNL)
|
if (CompileNL)
|
||||||
CreateSema((char *)"mbindex");
|
CreateSema((char *)"mbindex");
|
||||||
|
|
||||||
|
Syslog('f', "start tidy_orphans()");
|
||||||
|
for (tmp = opl; tmp; tmp = opl->next) {
|
||||||
|
Syslog('f', "%-12s %-20s %-12s %s %s", tmp->TicName, tmp->Area, tmp->FileName,
|
||||||
|
tmp->Orphaned ? "ORP" : "n/a", tmp->BadCRC ? "CRC" : "n/a");
|
||||||
|
}
|
||||||
tidy_orphans(&opl);
|
tidy_orphans(&opl);
|
||||||
|
|
||||||
free(inbound);
|
free(inbound);
|
||||||
@ -452,7 +457,7 @@ int LoadTic(char *inb, char *tfn, orphans **opl)
|
|||||||
* will handle this orphaned tic file.
|
* will handle this orphaned tic file.
|
||||||
*/
|
*/
|
||||||
TIC.Orphaned = TRUE;
|
TIC.Orphaned = TRUE;
|
||||||
WriteError("Can't find file in inbound");
|
Syslog('+', "Can't find file in inbound, will check later");
|
||||||
} else {
|
} else {
|
||||||
Syslog('f', "Returned RealName %s", RealName);
|
Syslog('f', "Returned RealName %s", RealName);
|
||||||
/*
|
/*
|
||||||
|
Reference in New Issue
Block a user