--- deliantra/server/common/readable.C 2006/09/10 16:00:23 1.5 +++ deliantra/server/common/readable.C 2006/09/14 22:34:00 1.9 @@ -1,9 +1,3 @@ - -/* - * static char *rcsid_readable_c = - * "$Id: readable.C,v 1.5 2006/09/10 16:00:23 root Exp $"; - */ - /* CrossFire, A Multiplayer game for X-windows @@ -24,7 +18,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - The authors can be reached via e-mail at crossfire-devel@real-time.com + The authors can be reached via e-mail at */ @@ -82,7 +76,7 @@ */ /* 'title' and 'titlelist' are used by the readable code */ -typedef struct titlestruct:zero_initialised +struct title : zero_initialised { shstr name; /* the name of the book */ shstr authour; /* the name of the book authour */ @@ -90,25 +84,22 @@ int level; /* level of difficulty of this message */ int size; /* size of the book message */ int msg_index; /* an index value derived from book message */ - struct titlestruct *next; -} title; + title *next; +}; -typedef struct titleliststruct:zero_initialised +struct titlelist : zero_initialised { int number; /* number of items in the list */ - struct titlestruct *first_book; /* pointer to first book in this list */ - struct titleliststruct *next; /* pointer to next book list */ -} titlelist; + title *first_book; /* pointer to first book in this list */ + titlelist *next; /* pointer to next book list */ +}; /* special structure, used only by art_name_array[] */ - -typedef struct namebytype +struct arttypename { const char *name; /* generic name to call artifacts of this type */ int type; /* matching type */ -} -arttypename; - +}; /* booklist is the buffer of books read in from the bookarch file */ static titlelist *booklist = NULL; @@ -567,6 +558,7 @@ { if (!tl->next) tl->next = get_empty_booklist (); + tl = tl->next; number--; } @@ -735,6 +727,7 @@ if (did_init_barch) return; + did_init_barch = 1; if (!booklist) @@ -893,6 +886,7 @@ if (tl) t = tl->first_book; + while (t) if (t->size == length && t->msg_index == index) break; @@ -1619,7 +1613,7 @@ /* preamble */ sprintf (retbuf, "Herein is described a project using %s: \n", formula->skill ? &formula->skill : "an unknown skill"); - if ((at = find_archetype (op_name)) != (archetype *) NULL) + if ((at = archetype::find (op_name)) != (archetype *) NULL) op_name = at->clone.name; else LOG (llevError, "formula_msg() can't find arch %s for formula.\n", op_name); @@ -1658,7 +1652,7 @@ linked_char *next; archetype *at; - at = find_archetype (formula->cauldron); + at = archetype::find (formula->cauldron); sprintf (retbuf + strlen (retbuf), " may be made at %s using the following ingredients:\n", at ? query_name (&at->clone) : "an unknown place");