rnd-20020824-2-src
[rocksndiamonds.git] / src / libgame / setup.h
index 5096f2b7d0c504eea9cc07de0ffbcf0897ba17fd..67f42611ee0c3c7da4d1087789695cd942d8fc9a 100644 (file)
@@ -134,7 +134,44 @@ struct TokenInfo
                         IS_LEVELCLASS_DX(n) ? LEVELCLASS_DX : \
                         LEVELCLASS_UNDEFINED)
 
-
+/* sort priorities of artwork */
+#define ARTWORKCLASS_CLASSICS_START    100
+#define ARTWORKCLASS_CLASSICS_END      199
+#define ARTWORKCLASS_CONTRIBUTION_START        200
+#define ARTWORKCLASS_CONTRIBUTION_END  299
+#define ARTWORKCLASS_LEVEL_START       300
+#define ARTWORKCLASS_LEVEL_END         399
+#define ARTWORKCLASS_USER_START                400
+#define ARTWORKCLASS_USER_END          499
+
+#define ARTWORKCLASS_CLASSICS          ARTWORKCLASS_CLASSICS_START
+#define ARTWORKCLASS_CONTRIBUTION      ARTWORKCLASS_CONTRIBUTION_START
+#define ARTWORKCLASS_LEVEL             ARTWORKCLASS_LEVEL_START
+#define ARTWORKCLASS_USER              ARTWORKCLASS_USER_START
+
+#define ARTWORKCLASS_UNDEFINED         999
+
+#define IS_ARTWORKCLASS_CLASSICS(p) \
+       ((p)->sort_priority >= ARTWORKCLASS_CLASSICS_START && \
+        (p)->sort_priority <= ARTWORKCLASS_CLASSICS_END)
+#define IS_ARTWORKCLASS_CONTRIBUTION(p) \
+       ((p)->sort_priority >= ARTWORKCLASS_CONTRIBUTION_START && \
+        (p)->sort_priority <= ARTWORKCLASS_CONTRIBUTION_END)
+#define IS_ARTWORKCLASS_LEVEL(p) \
+       ((p)->sort_priority >= ARTWORKCLASS_LEVEL_START && \
+        (p)->sort_priority <= ARTWORKCLASS_LEVEL_END)
+#define IS_ARTWORKCLASS_USER(p) \
+       ((p)->sort_priority >= ARTWORKCLASS_USER_START && \
+        (p)->sort_priority <= ARTWORKCLASS_USER_END)
+
+#define ARTWORKCLASS(n)        (IS_ARTWORKCLASS_CLASSICS(n) ? ARTWORKCLASS_CLASSICS :\
+                        IS_ARTWORKCLASS_CONTRIBUTION(n) ? ARTWORKCLASS_CONTRIBUTION : \
+                        IS_ARTWORKCLASS_LEVEL(n) ? ARTWORKCLASS_LEVEL : \
+                        IS_ARTWORKCLASS_USER(n) ? ARTWORKCLASS_USER : \
+                        ARTWORKCLASS_UNDEFINED)
+
+
+char *getLevelArtworkDir(TreeInfo *);
 char *getLevelFilename(int);
 char *getTapeFilename(int);
 char *getScoreFilename(int);
@@ -159,7 +196,7 @@ TreeInfo *getTreeInfoFirstGroupEntry(TreeInfo *);
 int numTreeInfoInGroup(TreeInfo *);
 int posTreeInfo(TreeInfo *);
 TreeInfo *getTreeInfoFromPos(TreeInfo *, int);
-TreeInfo *getTreeInfoFromFilename(TreeInfo *, char *);
+TreeInfo *getTreeInfoFromIdentifier(TreeInfo *, char *);
 void dumpTreeInfo(TreeInfo *, int);
 void sortTreeInfo(TreeInfo **,
                  int (*compare_function)(const void *, const void *));