summaryrefslogtreecommitdiffstats
path: root/mbbsd/gamble.c
diff options
context:
space:
mode:
authorvictor <victor@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2004-10-27 23:35:11 +0800
committervictor <victor@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2004-10-27 23:35:11 +0800
commit773f263060586631b3c184cfbbe5cfd2c9467f4c (patch)
treead40e4de72de61b920a635a744b911688d0d4d5b /mbbsd/gamble.c
parentdc9303ee4b5f1374c1ff39f2d5b6f79d7e85057e (diff)
downloadpttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.tar
pttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.tar.gz
pttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.tar.bz2
pttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.tar.lz
pttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.tar.xz
pttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.tar.zst
pttbbs-773f263060586631b3c184cfbbe5cfd2c9467f4c.zip
race
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@2282 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'mbbsd/gamble.c')
-rw-r--r--mbbsd/gamble.c38
1 files changed, 24 insertions, 14 deletions
diff --git a/mbbsd/gamble.c b/mbbsd/gamble.c
index 0a4ba166..5ca312ca 100644
--- a/mbbsd/gamble.c
+++ b/mbbsd/gamble.c
@@ -1,7 +1,6 @@
/* $Id$ */
#include "bbs.h"
-#ifndef _BBS_UTIL_C_
#define MAX_ITEM 8 //最大 賭項(item) 個數
#define MAX_ITEM_LEN 30 //最大 每一賭項名字長度
#define MAX_SUBJECT_LEN 650 //8*81 = 648 最大 主題長度
@@ -92,14 +91,18 @@ show_ticket_data(char betname[MAX_ITEM][MAX_ITEM_LEN],char *direct, int *price,
return count;
}
-static void
+static int
append_ticket_record(char *direct, int ch, int n, int count)
{
FILE *fp;
int ticket[8] = {0, 0, 0, 0, 0, 0, 0, 0}, i;
char genbuf[256];
- snprintf(genbuf, sizeof(genbuf), "%s/" FN_TICKET_USER, direct);
+ snprintf(genbuf, sizeof(genbuf), "%s/" FN_TICKET, direct);
+ if (!dashf(genbuf))
+ return -1;
+
+ snprintf(genbuf, sizeof(genbuf), "%s/" FN_TICKET_USER, direct);
if ((fp = fopen(genbuf, "a"))) {
fprintf(fp, "%s %d %d\n", cuser.userid, ch, n);
fclose(fp);
@@ -129,13 +132,15 @@ append_ticket_record(char *direct, int ch, int n, int count)
flock(fileno(fp), LOCK_UN);
fclose(fp);
}
+ return 0;
}
#define lockreturn0(unmode, state) if(lockutmpmode(unmode, state)) return 0
int
ticket(int bid)
{
- int ch, n, price, count, end = 0;
+ int ch, end = 0;
+ int n, price, count; /* 購買張數、單價、選項數 */
char path[128], fn_ticket[128];
char betname[MAX_ITEM][MAX_ITEM_LEN];
boardheader_t *bh = NULL;
@@ -175,19 +180,25 @@ ticket(int bid)
n = 0;
ch_buyitem(price, "etc/buyticket", &n, 0);
- if (bid && !dashf(fn_ticket)) {
- int money = price * n;
- if (money > 0)
- deumoney(currutmp->uid, money);
- vmsg("哇!! 耐ㄚ捏...板主已經停止下注了 不能賭嚕");
- break;
- }
+ if (bid && !dashf(fn_ticket))
+ goto doesnt_catch_up;
- if (n > 0)
- append_ticket_record(path, ch, n, count);
+ if (n > 0) {
+ if (append_ticket_record(path, ch, n, count) < 0)
+ goto doesnt_catch_up;
+ }
}
unlockutmpmode();
return 0;
+
+doesnt_catch_up:
+
+ price = price * n;
+ if (price > 0)
+ deumoney(currutmp->uid, price);
+ vmsg("哇!! 耐ㄚ捏...板主已經停止下注了 不能賭嚕");
+ unlockutmpmode();
+ return -1;
}
int
@@ -361,4 +372,3 @@ ticket_main()
ticket(0);
return 0;
}
-#endif