diff -r 58c20c0e394f -r 1d1ed96f32ad src/map.cpp --- a/src/map.cpp Mon Mar 19 12:30:11 2007 +0000 +++ b/src/map.cpp Mon Mar 19 12:49:27 2007 +0000 @@ -22,7 +22,8 @@ uint _map_tile_mask; uint _map_size; -Tile* _m = NULL; +Tile *_m = NULL; +TileExtended *_me = NULL; void AllocateMap(uint size_x, uint size_y) @@ -44,10 +45,16 @@ _map_tile_mask = _map_size - 1; free(_m); - _m = CallocT(_map_size); + free(_me); - /* XXX TODO handle memory shortage more gracefully */ - if (_m == NULL) error("Failed to allocate memory for the map"); + _m = CallocT(_map_size); + _me = CallocT(_map_size); + + /* XXX @todo handle memory shortage more gracefully + * Maybe some attemps could be made to try with smaller maps down to 64x64 + * Maybe check for available memory before doing the calls, after all, we know how big + * the map is */ + if ((_m == NULL) || (_me == NULL)) error("Failed to allocate memory for the map"); }