142 lines
2.7 KiB
C
Raw Normal View History

/*
Minetest-c55
Copyright (C) 2010 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 General Public License as published by
the Free Software Foundation; either version 2 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 General Public License for more details.
You should have received a copy of the GNU 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-27 01:02:21 +02:00
/*
(c) 2010 Perttu Ahola <celeron55@gmail.com>
*/
#ifndef MAPSECTOR_HEADER
#define MAPSECTOR_HEADER
#include <jmutex.h>
#include "common_irrlicht.h"
#include "exceptions.h"
2011-06-26 00:03:58 +03:00
#include <ostream>
class MapBlock;
2011-06-26 01:31:43 +03:00
class Map;
2011-11-14 21:41:30 +02:00
class IGameDef;
2010-11-27 01:02:21 +02:00
/*
This is an Y-wise stack of MapBlocks.
*/
#define MAPSECTOR_SERVER 0
#define MAPSECTOR_CLIENT 1
2011-06-26 00:03:58 +03:00
class MapSector
2010-11-27 01:02:21 +02:00
{
public:
2011-11-14 21:41:30 +02:00
MapSector(Map *parent, v2s16 pos, IGameDef *gamedef);
2010-11-27 01:02:21 +02:00
virtual ~MapSector();
virtual u32 getId() const = 0;
void deleteBlocks();
v2s16 getPos()
{
return m_pos;
}
MapBlock * getBlockNoCreateNoEx(s16 y);
2010-11-27 01:02:21 +02:00
MapBlock * createBlankBlockNoInsert(s16 y);
MapBlock * createBlankBlock(s16 y);
void insertBlock(MapBlock *block);
2011-06-26 00:03:58 +03:00
void deleteBlock(MapBlock *block);
2010-11-27 01:02:21 +02:00
void getBlocks(core::list<MapBlock*> &dest);
2011-06-26 00:03:58 +03:00
// Always false at the moment, because sector contains no metadata.
2010-11-27 01:02:21 +02:00
bool differs_from_disk;
protected:
// The pile of MapBlocks
core::map<s16, MapBlock*> m_blocks;
2011-06-26 01:31:43 +03:00
Map *m_parent;
2010-11-27 01:02:21 +02:00
// Position on parent (in MapBlock widths)
v2s16 m_pos;
2011-11-14 21:41:30 +02:00
IGameDef *m_gamedef;
2011-06-26 00:03:58 +03:00
// Last-used block is cached here for quicker access.
2010-11-27 01:02:21 +02: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 21:41:30 +02:00
ServerMapSector(Map *parent, v2s16 pos, IGameDef *gamedef);
2010-11-27 01:02:21 +02:00
~ServerMapSector();
u32 getId() const
{
return MAPSECTOR_SERVER;
}
/*
These functions handle metadata.
They do not handle blocks.
*/
2011-06-26 00:03:58 +03:00
2010-11-27 01:02:21 +02:00
void serialize(std::ostream &os, u8 version);
static ServerMapSector* deSerialize(
std::istream &is,
2011-06-26 01:31:43 +03:00
Map *parent,
2010-11-27 01:02:21 +02:00
v2s16 p2d,
2011-11-14 21:41:30 +02:00
core::map<v2s16, MapSector*> & sectors,
IGameDef *gamedef
2010-11-27 01:02:21 +02:00
);
private:
};
#ifndef SERVER
2010-11-27 01:02:21 +02:00
class ClientMapSector : public MapSector
{
public:
2011-11-14 21:41:30 +02:00
ClientMapSector(Map *parent, v2s16 pos, IGameDef *gamedef);
2010-11-27 01:02:21 +02:00
~ClientMapSector();
u32 getId() const
{
return MAPSECTOR_CLIENT;
}
private:
};
#endif
2010-11-27 01:02:21 +02:00
#endif