summaryrefslogtreecommitdiff
path: root/src/char/char.c
diff options
context:
space:
mode:
authorMadCamel <madcamel@gmail.com>2009-03-16 19:40:12 +0000
committerJared Adams <jaxad0127@gmail.com>2009-03-16 13:50:30 -0600
commitd450f9fd7b5d4fd71d4f7e244ef9d0786d0f745a (patch)
tree207f03c028ea16500032bde862d9ade38d317d06 /src/char/char.c
parent1f073198ce4a175191da2815c00cca11e81735d8 (diff)
downloadtmwa-d450f9fd7b5d4fd71d4f7e244ef9d0786d0f745a.tar.gz
tmwa-d450f9fd7b5d4fd71d4f7e244ef9d0786d0f745a.tar.bz2
tmwa-d450f9fd7b5d4fd71d4f7e244ef9d0786d0f745a.tar.xz
tmwa-d450f9fd7b5d4fd71d4f7e244ef9d0786d0f745a.zip
Now possible to divorce when partner is offline
Diffstat (limited to 'src/char/char.c')
-rw-r--r--src/char/char.c58
1 files changed, 40 insertions, 18 deletions
diff --git a/src/char/char.c b/src/char/char.c
index 2719c03..185a412 100644
--- a/src/char/char.c
+++ b/src/char/char.c
@@ -1384,21 +1384,33 @@ int set_account_reg2(int acc, int num, struct global_reg *reg) {
return c;
}
-// —£₯(charνœŽž‚ΙŽg—p)
+// Divorce a character from it's partner and let the map server know
int char_divorce(struct mmo_charstatus *cs) {
+ int i;
+ char buf[10];
+
if (cs == NULL)
return 0;
- if (cs->partner_id > 0){
- int i;
- for(i = 0; i < char_num; i++) {
- if (char_dat[i].char_id == cs->partner_id && char_dat[i].partner_id == cs->char_id) {
- cs->partner_id = 0;
- char_dat[i].partner_id = 0;
- return 0;
- }
+ if (cs->partner_id <= 0)
+ return 0;
+
+ WBUFW(buf,0) = 0x2b12;
+ WBUFL(buf,2) = cs->char_id;
+
+ for(i = 0; i < char_num; i++) {
+ if (char_dat[i].char_id == cs->partner_id && char_dat[i].partner_id == cs->char_id) {
+ WBUFL(buf,6) = cs->partner_id;
+ mapif_sendall(buf,10);
+ cs->partner_id = 0;
+ char_dat[i].partner_id = 0;
+ return 0;
}
}
+
+ WBUFL(buf,6) = 0; // partner id 0 means failure
+ mapif_sendall(buf,10);
+
return 0;
}
@@ -1472,16 +1484,9 @@ static int char_delete(struct mmo_charstatus *cs) {
if (cs->party_id)
inter_party_leave(cs->party_id, cs->account_id);
// —£₯
- if (cs->partner_id){
- // —£₯ξ•ρ‚πmap‚Ι’Κ’m
- char buf[10];
- WBUFW(buf,0) = 0x2b12;
- WBUFL(buf,2) = cs->char_id;
- WBUFL(buf,6) = cs->partner_id;
- mapif_sendall(buf,10);
- // —£₯
+ if (cs->partner_id)
char_divorce(cs);
- }
+
return 0;
}
@@ -2285,6 +2290,23 @@ int parse_frommap(int fd) {
break;
}
+ // Map server is requesting a divorce
+ case 0x2b16:
+ if (RFIFOREST(fd) < 4)
+ return 0;
+ {
+ for (i = 0; i < char_num; i++)
+ if (char_dat[i].char_id == RFIFOL(fd, 2))
+ break;
+
+ if (i != char_num)
+ char_divorce(&char_dat[i]);
+
+ RFIFOSKIP(fd,6);
+ break;
+
+ }
+
default:
// inter serverˆ—‚Ι“n‚·
{