/* $Id: hometown.c,v 1.666 2004/09/20 10:50:19 shrike Exp $ */
/************************************************************************************
* Copyright 2004 Astrum Metaphora consortium *
* *
* Licensed under the Apache License, Version 2.0 (the "License"); *
* you may not use this file except in compliance with the License. *
* You may obtain a copy of the License at *
* *
* http://www.apache.org/licenses/LICENSE-2.0 *
* *
* Unless required by applicable law or agreed to in writing, software *
* distributed under the License is distributed on an "AS IS" BASIS, *
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
* See the License for the specific language governing permissions and *
* limitations under the License. *
* *
************************************************************************************/
#include <stdio.h>
#include <string.h>
#include "merc.h"
static hometown_t * get_hometown (int htn);
varr hometowns = { sizeof(hometown_t), 4 };
hometown_t *hometown_new(void)
{
return varr_enew(&hometowns);
}
void hometown_free(hometown_t *hometown)
{
free_string(hometown->area);
}
/*
* lookup hometown number by name
*/
int htn_lookup(const char *name)
{
int i;
for (i = 0; i < hometowns.nused; i++) {
hometown_t *h = VARR_GET(&hometowns, i);
if (!str_prefix(name, h->area))
return i;
}
return -1;
}
/*
* lookup hometown name by htn
*/
const char* hometown_name(int htn)
{
return get_hometown(htn)->area;
}
bool hometown_restrict(hometown_t *h, CHAR_DATA *ch)
{
race_t *r;
class_t *cl;
if ((r = race_lookup(ORG_RACE(ch))) == NULL
|| !r->pcdata
|| (cl = class_lookup(ch->class)) == NULL)
return TRUE;
if (IS_SET(r->flags, RACE_NOCH))
return !is_name(r->name, h->restrict_race);
if (IS_SET(cl->flags, CLASS_NOCH))
return !is_name(cl->name, h->restrict_class);
if (h->restrict_race
&& !is_name(r->name, h->restrict_race))
return TRUE;
if (h->restrict_class
&& !is_name(cl->name, h->restrict_class))
return TRUE;
if (h->restrict_align
&& (RALIGN(ch) & h->restrict_align) == 0)
return TRUE;
return FALSE;
}
/*
* just prints the list of available hometowns
*/
void hometown_print_avail(CHAR_DATA *ch)
{
int i;
int col = 0;
for (i = 0; i < hometowns.nused; i++) {
hometown_t *h = VARR_GET(&hometowns, i);
if (hometown_restrict(h, ch))
continue;
if (col > 60) {
char_act(str_empty, ch);
col = 0;
}
if (col)
char_puts(", ", ch);
char_puts(h->area, ch);
col += strlen(h->area) + 2;
}
}
int hometown_permanent(CHAR_DATA *ch)
{
int i;
int htn_perm = -1;
for (i = 0; i < hometowns.nused; i++) {
hometown_t *h = VARR_GET(&hometowns, i);
if (hometown_restrict(h, ch))
continue;
if (htn_perm < 0)
htn_perm = i;
else
return -1; /* more than one hometown */
}
return htn_perm;
}
/*
* recall lookup by ch hometown and align (must always return non NULL)
*/
ROOM_INDEX_DATA *get_recall(CHAR_DATA *ch)
{
// if (!IS_NPC(ch) && ch->pcdata->homepoint)
// return ch->pcdata->homepoint;
return get_hometown(ch->hometown)->recall[NALIGN(ch)];
}
OBJ_INDEX_DATA *get_map(CHAR_DATA *ch)
{
return get_hometown(ch->hometown)->map[NALIGN(ch)];
}
ROOM_INDEX_DATA *get_random_recall(void)
{
return get_hometown(number_range(1, hometowns.nused-1))->recall[number_range(0, MAX_ANUM-1)];
}
altar_t *get_altar(CHAR_DATA *ch)
{
return get_hometown(ch->hometown)->altar + NALIGN(ch);
}
/*----------------------------------------------------------------------------
* local functions
*/
static hometown_t* get_hometown(int htn)
{
hometown_t *h = varr_get(&hometowns, htn);
if (!h)
h = VARR_GET(&hometowns, 0);
return h;
}