ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/common/image.C
Revision: 1.37
Committed: Sat Apr 23 04:56:45 2011 UTC (13 years, 1 month ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.36: +1 -1 lines
Log Message:
update copyright to 2011

File Contents

# User Rev Content
1 elmex 1.1 /*
2 root 1.29 * This file is part of Deliantra, the Roguelike Realtime MMORPG.
3 pippijn 1.12 *
4 root 1.37 * Copyright (©) 2005,2006,2007,2008,2009,2010,2011 Marc Alexander Lehmann / Robin Redeker / the Deliantra team
5 pippijn 1.12 *
6 root 1.31 * Deliantra is free software: you can redistribute it and/or modify it under
7     * the terms of the Affero GNU General Public License as published by the
8     * Free Software Foundation, either version 3 of the License, or (at your
9     * option) any later version.
10 pippijn 1.12 *
11 root 1.26 * This program is distributed in the hope that it will be useful,
12     * but WITHOUT ANY WARRANTY; without even the implied warranty of
13     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14     * GNU General Public License for more details.
15 pippijn 1.12 *
16 root 1.31 * You should have received a copy of the Affero GNU General Public License
17     * and the GNU General Public License along with this program. If not, see
18     * <http://www.gnu.org/licenses/>.
19 root 1.24 *
20 root 1.29 * The authors can be reached via e-mail to <support@deliantra.net>
21 pippijn 1.12 */
22 elmex 1.1
23     #include <global.h>
24     #include <stdio.h>
25    
26 root 1.19 #include "face.h"
27 root 1.17 #include "crc.h"
28    
29 root 1.35 faceidx blank_face, empty_face, magicmouth_face;
30 elmex 1.1
31 root 1.19 facehash_t facehash;
32     std::vector<faceinfo> faces;
33 elmex 1.1
34 root 1.20 faceidx
35     face_find (const char *name, faceidx defidx)
36 elmex 1.1 {
37 root 1.22 if (!name)
38     return defidx;
39    
40 root 1.19 facehash_t::iterator i = facehash.find (name);
41 root 1.6
42 root 1.19 return i == facehash.end ()
43     ? defidx : i->second;
44 elmex 1.1 }
45    
46 root 1.20 faceinfo *
47     face_info (faceidx idx)
48 root 1.6 {
49 root 1.21 assert (0 < (faceidx)-1); // faceidx must be unsigned
50    
51 root 1.20 if (idx >= faces.size ())
52     return 0;
53 elmex 1.1
54 root 1.20 return &faces [idx];
55 elmex 1.1 }
56    
57 root 1.20 facedata *
58 root 1.28 faceinfo::data (int faceset) const
59     {
60 root 1.36 if (!face [faceset].data.size ())
61     faceset = 0;
62    
63     return (facedata *)(face + faceset);
64 root 1.28 }
65    
66     facedata *
67 root 1.20 face_data (faceidx idx, int faceset)
68 root 1.6 {
69 root 1.20 if (faceinfo *f = face_info (idx))
70 root 1.28 return f->data (faceset);
71 elmex 1.1
72 root 1.20 return 0;
73 elmex 1.1 }
74