summaryrefslogtreecommitdiffstats
path: root/mbbsd/admin.c
diff options
context:
space:
mode:
authorptt <ptt@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2004-07-01 10:51:12 +0800
committerptt <ptt@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2004-07-01 10:51:12 +0800
commit2846cb73dbb035197c88ec52d73e6267c2b6608a (patch)
treee8ce688ea5b871a2850bcb6742c5f4338e695ffc /mbbsd/admin.c
parentbec9f21f48476db6e3c83f66f8eda67e4cc9d0d2 (diff)
downloadpttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.tar
pttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.tar.gz
pttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.tar.bz2
pttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.tar.lz
pttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.tar.xz
pttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.tar.zst
pttbbs-2846cb73dbb035197c88ec52d73e6267c2b6608a.zip
merge the branch from ptt.fpg
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@2109 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'mbbsd/admin.c')
-rw-r--r--mbbsd/admin.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/mbbsd/admin.c b/mbbsd/admin.c
index d9211c74..43c48995 100644
--- a/mbbsd/admin.c
+++ b/mbbsd/admin.c
@@ -271,7 +271,7 @@ int dir_cmp(const void *a, const void *b)
atoi( &((fileheader_t *)b)->filename[2] ));
}
-void merge_dir(char *dir1, char *dir2)
+void merge_dir(char *dir1, char *dir2, int isoutter)
{
int i, pn, sn;
fileheader_t *fh;
@@ -293,19 +293,25 @@ void merge_dir(char *dir1, char *dir2)
fh= (fileheader_t *)malloc( (pn+sn)*sizeof(fileheader_t));
get_records(dir1, fh, sizeof(fileheader_t), 1, pn);
get_records(dir2, fh+pn, sizeof(fileheader_t), 1, sn);
+ if(isoutter)
+ {
+ for(i=0; i<sn; i++)
+ if(fh[pn+i].owner[0])
+ strcat(fh[pn+i].owner, ".");
+ }
qsort(fh, pn+sn, sizeof(fileheader_t), dir_cmp);
sprintf(bakdir,"%s.bak", dir1);
Rename(dir1, bakdir);
- for(i=1; i<pn+sn; i++ )
+ for(i=1; i<=pn+sn; i++ )
{
- if(!fh[i].title[0] || !fh[i].filename[0]) continue;
- if( strcmp(fh[i-1].filename, fh[i].filename))
+ if(!fh[i-1].title[0] || !fh[i-1].filename[0]) continue;
+ if(i == pn+sn || strcmp(fh[i-1].filename, fh[i].filename))
{
fh[i-1].recommend =0;
fh[i-1].filemode |= 1;
append_record(dir1, &fh[i-1], sizeof(fileheader_t));
strcpy(p1, fh[i-1].filename);
- if(!dashd(file1))
+ if(!dashf(file1))
{
strcpy(p2, fh[i-1].filename);
Copy(file2, file1);
@@ -314,6 +320,7 @@ void merge_dir(char *dir1, char *dir2)
else
fh[i].filemode |= fh[i-1].filemode;
}
+
free(fh);
}
@@ -367,6 +374,7 @@ m_mod_board(char *bname)
setbdir(genbuf, bname);
m_fpg_brd(bname, fromdir);
if(!fromdir[0]) break;
+ merge_dir(genbuf, fromdir, 1);
}
else{
#endif
@@ -380,10 +388,10 @@ m_mod_board(char *bname)
break;
setbdir(genbuf, bname);
setbdir(fromdir, frombname);
+ merge_dir(genbuf, fromdir, 0);
#ifdef MERGEBBS
}
#endif
- merge_dir(genbuf, fromdir);
touchbtotal(bid);
}
break;