/*- * Copyright (c) 1998 fjoe <fjoe@iclub.nsu.ru> * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $Id: db_race.c,v 1.7 1999/04/16 15:52:23 fjoe Exp $ */ #include <stdio.h> #include "merc.h" #include "db.h" DECLARE_DBLOAD_FUN(load_race); DECLARE_DBLOAD_FUN(load_pcrace); DECLARE_DBINIT_FUN(init_race); DBFUN dbfun_races[] = { { "RACE", load_race }, { "PCRACE", load_pcrace }, { NULL } }; DBDATA db_races = { dbfun_races, init_race }; DBINIT_FUN(init_race) { db_set_arg(dbdata, "PCRACE", NULL); } DBLOAD_FUN(load_race) { race_t *race = race_new(); race->file_name = get_filename(filename); db_set_arg(dbdata, "PCRACE", race); for (;;) { char *word = feof(fp) ? "End" : fread_word(fp); bool fMatch = FALSE; switch(UPPER(word[0])) { case 'A': KEY("Aff", race->aff, fread_fstring(affect_flags, fp)); KEY("Act", race->act, fread_fstring(act_flags, fp)); break; case 'E': if (!str_cmp(word, "End")) { if (IS_NULLSTR(race->name)) { db_error("load_race", "race name undefined"); race_free(race); races.nused--; } return; } break; case 'F': KEY("Form", race->form, fread_fstring(form_flags, fp)); KEY("Flags", race->flags, fread_fstring(race_flags, fp)); break; case 'I': KEY("Imm", race->imm, fread_fstring(imm_flags, fp)); break; case 'N': SKEY("Name", race->name); break; case 'O': KEY("Off", race->off, fread_fstring(off_flags, fp)); break; case 'P': KEY("Parts", race->parts, fread_fstring(part_flags, fp)); break; case 'R': KEY("Res", race->res, fread_fstring(res_flags, fp)); break; case 'V': KEY("Vuln", race->vuln, fread_fstring(vuln_flags, fp)); break; } if (!fMatch) db_error("load_race", "%s: Unknown keyword", word); } } DBLOAD_FUN(load_pcrace) { race_t *race = arg; pcrace_t *pcr; if (!race) { db_error("load_pcrace", "#PCRACE before #RACE"); return; } pcr = race->pcdata = pcrace_new(); for (;;) { int i; char *word = feof(fp) ? "End" : fread_word(fp); bool fMatch = FALSE; switch(UPPER(word[0])) { case 'B': SKEY("BonusSkills", pcr->bonus_skills); break; case 'C': if (!str_cmp(word, "Class")) { rclass_t *rcl; rcl = varr_enew(&pcr->classes); rcl->name = str_dup(fread_word(fp)); rcl->mult = fread_number(fp); fMatch = TRUE; } break; case 'E': if (!str_cmp(word, "End")) { if (pcr->who_name[0] == '\0') { db_error("load_pcrace", "race who_name undefined"); pcrace_free(pcr); race->pcdata = NULL; } varr_qsort(&pcr->classes, cmpstr); varr_qsort(&pcr->skills, cmpint); return; } break; case 'H': KEY("HPBonus", pcr->hp_bonus, fread_number(fp)); break; case 'M': KEY("ManaBonus", pcr->mana_bonus, fread_number(fp)); if (!str_cmp(word, "MaxStats")) { for (i = 0; i < MAX_STATS; i++) pcr->max_stats[i] = fread_number(fp); fMatch = TRUE; } case 'P': KEY("Points", pcr->points, fread_number(fp)); KEY("PracBonus", pcr->prac_bonus, fread_number(fp)); break; case 'R': KEY("RestrictAlign", pcr->restrict_align, fread_fstring(ralign_names, fp)); KEY("RestrictEthos", pcr->restrict_ethos, fread_fstring(ethos_table, fp)); break; case 'S': KEY("Size", pcr->size, fread_fword(size_table, fp)); KEY("Slang", pcr->slang, fread_fword(slang_table, fp)); if (!str_cmp(word, "ShortName")) { const char *p = fread_string(fp); strnzcpy(pcr->who_name, sizeof(pcr->who_name), p); free_string(p); fMatch = TRUE; } if (!str_cmp(word, "Skill")) { rskill_t *rsk; rsk = varr_enew(&pcr->skills); rsk->sn = sn_lookup(fread_word(fp)); rsk->level = fread_number(fp); fMatch = TRUE; } if (!str_cmp(word, "Stats")) { for (i = 0; i < MAX_STATS; i++) pcr->stats[i] = fread_number(fp); fMatch = TRUE; } } if (!fMatch) db_error("load_pcrace", "%s: Unknown keyword", word); } }