ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/common/image.C
Revision: 1.38
Committed: Tue Jan 3 11:23:41 2012 UTC (12 years, 4 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.37: +33 -0 lines
Log Message:
*** empty log message ***

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.38 static std::vector<faceidx> faces_free;
35    
36     faceidx face_alloc ()
37     {
38     faceidx idx;
39    
40     if (faces_freelist.empty ())
41     {
42     idx = faces_free.back ();
43     faces_free.pop_back ();
44     }
45     else
46     {
47     idx = faces.size ();
48    
49     if (!idx) // skip index 0
50     idx = 1;
51    
52     faces.resize (idx + 1);
53     }
54    
55     return idx;
56     }
57    
58     faceinfo::unref ()
59     {
60     if (--refcnt)
61     return;
62    
63     refcnt = 1;
64    
65     }
66    
67 root 1.20 faceidx
68     face_find (const char *name, faceidx defidx)
69 elmex 1.1 {
70 root 1.22 if (!name)
71     return defidx;
72    
73 root 1.19 facehash_t::iterator i = facehash.find (name);
74 root 1.6
75 root 1.19 return i == facehash.end ()
76     ? defidx : i->second;
77 elmex 1.1 }
78    
79 root 1.20 faceinfo *
80     face_info (faceidx idx)
81 root 1.6 {
82 root 1.21 assert (0 < (faceidx)-1); // faceidx must be unsigned
83    
84 root 1.20 if (idx >= faces.size ())
85     return 0;
86 elmex 1.1
87 root 1.20 return &faces [idx];
88 elmex 1.1 }
89    
90 root 1.20 facedata *
91 root 1.28 faceinfo::data (int faceset) const
92     {
93 root 1.36 if (!face [faceset].data.size ())
94     faceset = 0;
95    
96     return (facedata *)(face + faceset);
97 root 1.28 }
98    
99     facedata *
100 root 1.20 face_data (faceidx idx, int faceset)
101 root 1.6 {
102 root 1.20 if (faceinfo *f = face_info (idx))
103 root 1.28 return f->data (faceset);
104 elmex 1.1
105 root 1.20 return 0;
106 elmex 1.1 }
107