X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=dungeon.c;h=6c6fcfdf1e9639116c52fce8f3a78a28a64af24a;hb=39eed7d678588438a7abe97354987816e9305096;hp=feb98e79be2f7069dbf523049bfd0da20b0e6dde;hpb=3e19c39f579dacb20c1c9b6fc1a26c8d106f1365;p=open-adventure.git diff --git a/dungeon.c b/dungeon.c index feb98e7..6c6fcfd 100644 --- a/dungeon.c +++ b/dungeon.c @@ -60,29 +60,17 @@ * or "attack"). Else, if M=3, the word is a special case verb (such as * "dig") and N % 1000 is an index into section 6. Objects from 50 to * (currently, anyway) 79 are considered treasures (for pirate, closeout). + * Section 7: Object locations. Each line contains an object number and its + * initial location (zero (or omitted) if none). If the object is + * immovable, the location is followed by a "-1". If it has two locations + * (e.g. the grate) the first location is followed with the second, and + * the object is assumed to be immovable. * Section 8: Action defaults. Each line contains an "action-verb" number and * the index (in section 6) of the default message for the verb. * Section 0: End of database. * * Other sections are obsolete and ignored */ -/* The various messages (sections 1, 2, 5, 6, etc.) may include certain - * special character sequences to denote that the program must provide - * parameters to insert into a message when the message is printed. These - * sequences are: - * %S = The letter 'S' or nothing (if a given value is exactly 1) - * %W = A word (up to 10 characters) - * %L = A word mapped to lower-case letters - * %U = A word mapped to upper-case letters - * %C = A word mapped to lower-case, first letter capitalised - * %T = Several words of text, ending with a word of -1 - * %1 = A 1-digit number - * %2 = A 2-digit number - * ... - * %9 = A 9-digit number - * %B = Variable number of blanks - * %! = The entire message should be suppressed */ - #define LINESIZE 100 #define CLSMAX 12 #define LINSIZ 12600 @@ -96,6 +84,7 @@ #include #include #include +#include #include "newdb.h" #include "common.h" @@ -251,45 +240,18 @@ static long GETNUM(FILE *source) return (GETNUM); } -/* Sections 1, 2, 5, 6, 10, 14. Read messages and set up pointers. */ +/* Sections 1, 2, 5, 6, 10, 14. Skip these, they're all in YAML now. */ static void read_messages(FILE* database, long sect) { long KK = LINUSE; while (true) { - long loc; - LINUSE = KK; - loc = GETNUM(database); - if (LNLENG >= LNPOSN + 70) - BUG(MESSAGE_LINE_GT_70_CHARACTERS); - if (loc == -1) return; - if (LNLENG < LNPOSN) - BUG(NULL_LINE_IN_MESSAGE); - do { - KK = KK + 1; - if (KK >= LINSIZ) - BUG(TOO_MANY_WORDS_OF_MESSAGES); - LINES[KK] = GETTXT(false, false, false); - } while (LINES[KK] != -1); - LINES[LINUSE] = KK; - if (loc == OLDLOC) continue; - OLDLOC = loc; - LINES[LINUSE] = -KK; - if (sect == 10 || sect == 14) { - /* now parsed from YAML */ - continue; - } - if (sect == 5) { - /* Now handled in YAML */ - continue; - } - if (sect == 6) { - /* Now handled in YAML */ - continue; - } - if (sect == 1) { - /* Now handled in YAML */ - continue; - } + do { + if (NULL == fgets(INLINE + 1, sizeof(INLINE) - 1, database)) { + printf("Failed fgets()\n"); + } + } while (!feof(database) && INLINE[1] == '#'); + if (strncmp(INLINE + 1, "-1\n", 3) == 0) + break; } }