From 756fadf08a839aceba87198136e4dd096cf9a349 Mon Sep 17 00:00:00 2001 From: skotlex Date: Fri, 29 Dec 2006 14:21:09 +0000 Subject: - Skill use is now cancelled when you use it while cloaking, and the uncloaking process warps you. git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@9591 54d463be-8e91-2dee-dedb-b68131a5f0ec --- Changelog-Trunk.txt | 3 +++ src/common/socket.c | 2 +- src/map/unit.c | 6 ++++++ 3 files changed, 10 insertions(+), 1 deletion(-) diff --git a/Changelog-Trunk.txt b/Changelog-Trunk.txt index cc065aec6..7d3efc38c 100644 --- a/Changelog-Trunk.txt +++ b/Changelog-Trunk.txt @@ -3,6 +3,9 @@ Date Added AS OF SVN REV. 5091, WE ARE NOW USING TRUNK. ALL UNTESTED BUGFIXES/FEATURES GO INTO TRUNK. IF YOU HAVE A WORKING AND TESTED BUGFIX PUT IT INTO STABLE AS WELL AS TRUNK. +2006/12/29 + * Skill use is now cancelled when you use it while cloaking, and the + uncloaking process warps you. [Skotlex] 2006/12/28 * Reapplied Skotlex's socket.c changes from r9587 and r9582. :S * Part 3 of TheUltraMage's socket cleanup. diff --git a/src/common/socket.c b/src/common/socket.c index c9e282997..f8e65fb60 100644 --- a/src/common/socket.c +++ b/src/common/socket.c @@ -175,7 +175,7 @@ static int recv_to_fifo(int fd) if( (fd < 0) || (fd >= FD_SETSIZE) || (NULL == session[fd]) || (session[fd]->eof) ) return -1; - len = recv(fd, (char *) session[fd]->rdata + session[fd]->rdata_size, RFIFOSPACE(fd), 0); + len = recv(fd, (char *) session[fd]->rdata + session[fd]->rdata_size, RFIFOSPACE(fd), 0); if (len == SOCKET_ERROR) { if (s_errno == S_ECONNABORTED) { diff --git a/src/map/unit.c b/src/map/unit.c index 4997f13b2..213168682 100644 --- a/src/map/unit.c +++ b/src/map/unit.c @@ -988,7 +988,10 @@ int unit_skilluse_id2(struct block_list *src, int target_id, int skill_num, int if(sc && sc->data[SC_CLOAKING].timer != -1 && !(sc->data[SC_CLOAKING].val4&4) && skill_num != AS_CLOAKING) + { status_change_end(src,SC_CLOAKING,-1); + if (!src->prev) return 0; //Warped away! + } if(casttime > 0) { ud->skilltimer = add_timer( tick+casttime, skill_castend_id, src->id, 0 ); @@ -1088,7 +1091,10 @@ int unit_skilluse_pos2( struct block_list *src, int skill_x, int skill_y, int sk if (sc && sc->data[SC_CLOAKING].timer != -1 && !(sc->data[SC_CLOAKING].val4&4)) + { status_change_end(src,SC_CLOAKING,-1); + if (!src->prev) return 0; //Warped away! + } if(casttime > 0) { ud->skilltimer = add_timer( tick+casttime, skill_castend_pos, src->id, 0 ); -- cgit v1.2.3-70-g09d2