diff options
-rw-r--r-- | mbbsd/bbs.c | 4 | ||||
-rw-r--r-- | mbbsd/record.c | 102 |
2 files changed, 57 insertions, 49 deletions
diff --git a/mbbsd/bbs.c b/mbbsd/bbs.c index ac8993b8..d2f15454 100644 --- a/mbbsd/bbs.c +++ b/mbbsd/bbs.c @@ -960,7 +960,7 @@ edit_post(int ent, fileheader_t * fhdr, char *direct) /* rocker.011018: 這裡是不是該檢查一下修改文章後的money和原有的比較? */ if (vedit(genbuf, 0, NULL) != -1) { - lock_substitute_record(direct, fhdr, sizeof(*fhdr), ent, LOCK_EX); + substitute_record(direct, fhdr, sizeof(*fhdr), ent); setbpath(fpath, currboard); stampfile(fpath, &postfile); strlcpy(genbuf, fhdr->filename, sizeof(genbuf)); @@ -997,7 +997,7 @@ edit_post(int ent, fileheader_t * fhdr, char *direct) strlcpy(fhdr->filename, postfile.filename, sizeof(fhdr->filename)); strlcpy(fhdr->title, save_title, sizeof(fhdr->title)); brc_addlist(postfile.filename); - lock_substitute_record(direct, fhdr, sizeof(*fhdr), ent, LOCK_UN); + substitute_record(direct, fhdr, sizeof(*fhdr), ent); /* rocker.011018: 順便更新一下cache */ touchdircache(currbid); diff --git a/mbbsd/record.c b/mbbsd/record.c index 00568f3e..c56e79e0 100644 --- a/mbbsd/record.c +++ b/mbbsd/record.c @@ -5,17 +5,18 @@ #define BUFSIZE 512 static void -PttLock(int fd, int size, int mode) +PttLock(int fd, int start, int size, int mode) { static struct flock lock_it; int ret; lock_it.l_whence = SEEK_CUR;/* from current point */ - lock_it.l_start = 0; /* -"- */ + lock_it.l_start = start; /* -"- */ lock_it.l_len = size; /* length of data */ lock_it.l_type = mode; /* set exclusive/write lock */ lock_it.l_pid = 0; /* pid not actually interesting */ - while ((ret = fcntl(fd, F_SETLKW, &lock_it)) < 0 && errno == EINTR); + while ((ret = fcntl(fd, F_SETLKW, &lock_it)) < 0 && errno == EINTR) + sleep(1); } #define safewrite write @@ -96,11 +97,6 @@ get_records(char *fpath, void *rptr, int size, int id, int number) if (id < 1 || (fd = open(fpath, O_RDONLY, 0)) == -1) return -1; - if( flock(fd, LOCK_EX) < 0 ){ - close(fd); - return -1; - } - if (lseek(fd, (off_t) (size * (id - 1)), SEEK_SET) == -1) { close(fd); return 0; @@ -114,49 +110,17 @@ get_records(char *fpath, void *rptr, int size, int id, int number) } int -lock_substitute_record(char *fpath, void *rptr, int size, int id, int mode) -{ - static int fd = -1; - switch( mode ){ - case LOCK_EX: - if( id < 1 || (fd = open(fpath, O_RDWR | O_CREAT, 0644)) == -1 ) - return -1; - - if( flock(fd, LOCK_EX) < 0 ){ - close(fd); - return -1; - } - lseek(fd, (off_t) (size * (id - 1)), SEEK_SET); - read(fd, rptr, size); - return 0; - - case LOCK_UN: - if( fd < 0 ) - return -1; - lseek(fd, (off_t) (size * (id - 1)), SEEK_SET); - write(fd, rptr, size); - flock(fd, LOCK_UN); - close(fd); - fd = -1; - return 0; - - default: - return -1; - } -} - -int substitute_record(char *fpath, void *rptr, int size, int id) { - int fd; - + int fd; + int offset=size * (id - 1); if (id < 1 || (fd = open(fpath, O_WRONLY | O_CREAT, 0644)) == -1) return -1; - lseek(fd, (off_t) (size * (id - 1)), SEEK_SET); - PttLock(fd, size, F_WRLCK); - safewrite(fd, rptr, size); - PttLock(fd, size, F_UNLCK); + lseek(fd, (off_t) (offset), SEEK_SET); + PttLock(fd, offset, size, F_WRLCK); + write(fd, rptr, size); + PttLock(fd, offset, size, F_UNLCK); close(fd); return 0; @@ -199,6 +163,51 @@ nolfilename(nol_t * n, char *fpath) int delete_record(char fpath[], int size, int id) { + char abuf[BUFSIZE]; + int fi, fo, locksize=0, readsize=0, offset = size * (id - 1), c, d=0; + struct stat st; + + + if ((fi=open(fpath, O_RDONLY, 0)) == -1) + return -1; + + if ((fo=open(fpath, O_WRONLY, 0)) == -1) + { + close(fi); + return -1; + } + + if(fstat(fi, &st)==-1) + { close(fo); close(fi); return -1;} + + locksize = st.st_size - offset; + readsize = locksize - size; + if (locksize < 0 ) + { close(fo); close(fi); return -1;} + + PttLock(fo, offset, locksize, F_WRLCK); + if(readsize>0) + { + lseek(fi, offset+size, SEEK_SET); + lseek(fo, offset, SEEK_SET); + while( d<readsize && (c = read(fi, abuf, BUFSIZE))>0) + { + write(fo, abuf, c); + d=d+c; + } + } + close(fi); + ftruncate(fo, st.st_size - size); + PttLock(fo, offset, locksize, F_UNLCK); + close(fo); + return 0; + +} + +#if 0 +int +delete_record(char fpath[], int size, int id) +{ nol_t my; char abuf[BUFSIZE]; int fdr, fdw, fd; @@ -249,7 +258,6 @@ delete_record(char fpath[], int size, int id) return 0; } -#if 0 static char * title_body(char *title) { |