--- deliantra/server/include/map.h 2007/02/07 02:04:46 1.65 +++ deliantra/server/include/map.h 2007/03/11 02:12:44 1.71 @@ -120,7 +120,7 @@ struct mapspace { object *bot, *top; /* lowest/highest object on this space */ - facetile *faces[MAP_LAYERS]; /* faces for the 3 layers */ + faceidx faces[MAP_LAYERS]; /* faces for the 3 layers */ object *faces_obj[MAP_LAYERS];/* face objects for the 3 layers */ uint8 flags_; /* flags about this space (see the P_ values above) */ sint8 light; /* How much light this space provides */ @@ -156,8 +156,8 @@ return 0; } - // return the item volume on this mapspace in kg/m³ - uint64 volume (); + // return the item volume on this mapspace in cm³ + uint64 volume () const; }; /* @@ -186,6 +186,7 @@ static region *default_region (); static region *find (const char *name); static region *find_fuzzy (const char *name); + static region *read (object_thawer &f); }; typedef object_vector regionvec; @@ -193,7 +194,7 @@ extern regionvec regions; #define for_all_regions(var) \ - for (int _i = 0; _i < regions.size (); ++_i) \ + for (unsigned _i = 0; _i < regions.size (); ++_i) \ declvar (region *, var, regions [_i]) struct shopitems : zero_initialised @@ -277,6 +278,8 @@ shstr ACC (RW, tile_path[4]); /* path to adjoining maps */ maptile *ACC (RW, tile_map[4]); /* Next map, linked list */ shstr ACC (RW, path); /* Filename of the map */ + int ACC (RW, max_nrof); // maximum nrof of any single item on a mapspace + uint64 ACC (RW, max_volume); // maximum volume for all items on a mapspace MTH void activate (); MTH void deactivate (); @@ -354,9 +357,10 @@ void make_map_floor (char **layout, char *floorstyle, random_map_params *RP); bool generate_random_map (random_map_params *RP); - static maptile *find_sync (const char *path, maptile *original = 0);//PERL - // async prefetch static maptile *find_async (const char *path, maptile *original = 0);//PERL + static maptile *find_sync (const char *path, maptile *original = 0);//PERL + static maptile *find_style_sync (const char *dir, const char *file = 0);//PERL + MTH object *pick_random_object () const; mapspace const &at (uint32 x, uint32 y) const { return spaces [x * height + y]; } mapspace &at (uint32 x, uint32 y) { return spaces [x * height + y]; }