--- deliantra/server/common/anim.C 2007/06/04 13:03:59 1.26 +++ deliantra/server/common/anim.C 2009/11/06 13:03:34 1.33 @@ -1,25 +1,25 @@ /* - * This file is part of Crossfire TRT, the Multiplayer Online Role Playing Game. + * This file is part of Deliantra, the Roguelike Realtime MMORPG. * - * Copyright (©) 2005,2006,2007 Marc Alexander Lehmann / Robin Redeker / the Crossfire TRT team + * Copyright (©) 2005,2006,2007,2008 Marc Alexander Lehmann / Robin Redeker / the Deliantra team * Copyright (©) 2002-2003,2007 Mark Wedel & Crossfire Development Team * Copyright (©) 1992,2007 Frank Tore Johansen * - * Crossfire TRT is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License as published by the Free - * Software Foundation; either version 2 of the License, or (at your option) - * any later version. + * Deliantra is free software: you can redistribute it and/or modify it under + * the terms of the Affero GNU General Public License as published by the + * Free Software Foundation, either version 3 of the License, or (at your + * option) any later version. * - * This program is distributed in the hope that it will be useful, but - * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY - * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * for more details. + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. * - * You should have received a copy of the GNU General Public License along - * with Crossfire TRT; if not, write to the Free Software Foundation, Inc. 51 - * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * You should have received a copy of the Affero GNU General Public License + * and the GNU General Public License along with this program. If not, see + * . * - * The authors can be reached via e-mail to + * The authors can be reached via e-mail to */ /* This file contains animation related code. */ @@ -27,13 +27,13 @@ #include #include -animhash_t animhash; +static animhash_t animhash; std::vector animations; void animation::resize (int new_size) { - sfree (faces, num_animations); + sfree (faces, num_animations); num_animations = new_size; faces = salloc (num_animations); } @@ -131,27 +131,15 @@ * is facing. */ - if (NUM_FACINGS (op) == 2) - { - if (dir < 5) - base_state = 0; - else - base_state = NUM_ANIMATIONS (op) / 2; - } - else if (NUM_FACINGS (op) == 4) - { - if (dir == 0) - base_state = 0; - else - base_state = ((dir - 1) / 2) * (NUM_ANIMATIONS (op) / 4); - } - else if (NUM_FACINGS (op) == 8) - { - if (dir == 0) - base_state = 0; - else - base_state = (dir - 1) * (NUM_ANIMATIONS (op) / 8); - } + if (dir > 0) + switch (NUM_FACINGS (op)) + { + case 2: base_state = ((dir - 1) / (8 / 2)) * (NUM_ANIMATIONS (op) / 2); break; + case 4: base_state = ((dir - 1) / (8 / 4)) * (NUM_ANIMATIONS (op) / 4); break; + case 8: base_state = ((dir - 1) / (8 / 8)) * (NUM_ANIMATIONS (op) / 8); break; + } + else + base_state = 0; /* If beyond drawable states, reset */ if (op->state >= max_state)