1
0
mirror of https://github.com/moparisthebest/minetest synced 2025-01-11 05:38:01 -05:00
minetest/src/mapsector.h

140 lines
2.7 KiB
C
Raw Normal View History

/*
2013-02-24 12:40:43 -05:00
Minetest
2013-02-24 13:38:45 -05:00
Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
2010-11-26 18:02:21 -05:00
#ifndef MAPSECTOR_HEADER
#define MAPSECTOR_HEADER
#include <jmutex.h>
2012-06-16 21:00:31 -04:00
#include "irrlichttypes_bloated.h"
2010-11-26 18:02:21 -05:00
#include "exceptions.h"
2011-06-25 17:03:58 -04:00
#include <ostream>
2012-12-20 12:19:49 -05:00
#include <map>
#include <list>
2011-06-25 17:03:58 -04:00
class MapBlock;
2011-06-25 18:31:43 -04:00
class Map;
2011-11-14 14:41:30 -05:00
class IGameDef;
2010-11-26 18:02:21 -05:00
/*
This is an Y-wise stack of MapBlocks.
*/
#define MAPSECTOR_SERVER 0
#define MAPSECTOR_CLIENT 1
2011-06-25 17:03:58 -04:00
class MapSector
2010-11-26 18:02:21 -05:00
{
public:
2011-11-14 14:41:30 -05:00
MapSector(Map *parent, v2s16 pos, IGameDef *gamedef);
2010-11-26 18:02:21 -05:00
virtual ~MapSector();
virtual u32 getId() const = 0;
void deleteBlocks();
v2s16 getPos()
{
return m_pos;
}
MapBlock * getBlockNoCreateNoEx(s16 y);
2010-11-26 18:02:21 -05:00
MapBlock * createBlankBlockNoInsert(s16 y);
MapBlock * createBlankBlock(s16 y);
void insertBlock(MapBlock *block);
2011-06-25 17:03:58 -04:00
void deleteBlock(MapBlock *block);
2010-11-26 18:02:21 -05:00
2012-12-20 12:19:49 -05:00
void getBlocks(std::list<MapBlock*> &dest);
2010-11-26 18:02:21 -05:00
2011-06-25 17:03:58 -04:00
// Always false at the moment, because sector contains no metadata.
2010-11-26 18:02:21 -05:00
bool differs_from_disk;
protected:
// The pile of MapBlocks
2012-12-20 12:19:49 -05:00
std::map<s16, MapBlock*> m_blocks;
2010-11-26 18:02:21 -05:00
2011-06-25 18:31:43 -04:00
Map *m_parent;
2010-11-26 18:02:21 -05:00
// Position on parent (in MapBlock widths)
v2s16 m_pos;
2011-11-14 14:41:30 -05:00
IGameDef *m_gamedef;
2011-06-25 17:03:58 -04:00
// Last-used block is cached here for quicker access.
2010-11-26 18:02:21 -05:00
// Be sure to set this to NULL when the cached block is deleted
MapBlock *m_block_cache;
s16 m_block_cache_y;
/*
Private methods
*/
MapBlock *getBlockBuffered(s16 y);
};
class ServerMapSector : public MapSector
{
public:
2011-11-14 14:41:30 -05:00
ServerMapSector(Map *parent, v2s16 pos, IGameDef *gamedef);
2010-11-26 18:02:21 -05:00
~ServerMapSector();
u32 getId() const
{
return MAPSECTOR_SERVER;
}
/*
These functions handle metadata.
They do not handle blocks.
*/
2011-06-25 17:03:58 -04:00
2010-11-26 18:02:21 -05:00
void serialize(std::ostream &os, u8 version);
static ServerMapSector* deSerialize(
std::istream &is,
2011-06-25 18:31:43 -04:00
Map *parent,
2010-11-26 18:02:21 -05:00
v2s16 p2d,
2012-12-20 12:19:49 -05:00
std::map<v2s16, MapSector*> & sectors,
2011-11-14 14:41:30 -05:00
IGameDef *gamedef
2010-11-26 18:02:21 -05:00
);
private:
};
#ifndef SERVER
2010-11-26 18:02:21 -05:00
class ClientMapSector : public MapSector
{
public:
2011-11-14 14:41:30 -05:00
ClientMapSector(Map *parent, v2s16 pos, IGameDef *gamedef);
2010-11-26 18:02:21 -05:00
~ClientMapSector();
u32 getId() const
{
return MAPSECTOR_CLIENT;
}
private:
};
#endif
2010-11-26 18:02:21 -05:00
#endif