Add Client::getEnv() and remove some unnecessary wrappers

master
Perttu Ahola 2012-03-15 23:54:10 +02:00
parent 81385682c8
commit 54917e3062
3 changed files with 17 additions and 66 deletions

View File

@ -1848,8 +1848,6 @@ void Client::sendPlayerItem(u16 item)
void Client::removeNode(v3s16 p) void Client::removeNode(v3s16 p)
{ {
//JMutexAutoLock envlock(m_env_mutex); //bulk comment-out
core::map<v3s16, MapBlock*> modified_blocks; core::map<v3s16, MapBlock*> modified_blocks;
try try
@ -1875,8 +1873,6 @@ void Client::removeNode(v3s16 p)
void Client::addNode(v3s16 p, MapNode n) void Client::addNode(v3s16 p, MapNode n)
{ {
//JMutexAutoLock envlock(m_env_mutex); //bulk comment-out
TimeTaker timer1("Client::addNode()"); TimeTaker timer1("Client::addNode()");
core::map<v3s16, MapBlock*> modified_blocks; core::map<v3s16, MapBlock*> modified_blocks;
@ -1889,8 +1885,6 @@ void Client::addNode(v3s16 p, MapNode n)
catch(InvalidPositionException &e) catch(InvalidPositionException &e)
{} {}
//TimeTaker timer2("Client::addNode(): addUpdateMeshTaskWithEdge");
for(core::map<v3s16, MapBlock * >::Iterator for(core::map<v3s16, MapBlock * >::Iterator
i = modified_blocks.getIterator(); i = modified_blocks.getIterator();
i.atEnd() == false; i++) i.atEnd() == false; i++)
@ -1900,32 +1894,6 @@ void Client::addNode(v3s16 p, MapNode n)
} }
} }
void Client::updateCamera(v3f pos, v3f dir, f32 fov)
{
m_env.getClientMap().updateCamera(pos, dir, fov);
}
void Client::renderPostFx()
{
m_env.getClientMap().renderPostFx();
}
MapNode Client::getNode(v3s16 p)
{
//JMutexAutoLock envlock(m_env_mutex); //bulk comment-out
return m_env.getMap().getNode(p);
}
NodeMetadata* Client::getNodeMetadata(v3s16 p)
{
return m_env.getMap().getNodeMetadata(p);
}
LocalPlayer* Client::getLocalPlayer()
{
return m_env.getLocalPlayer();
}
void Client::setPlayerControl(PlayerControl &control) void Client::setPlayerControl(PlayerControl &control)
{ {
//JMutexAutoLock envlock(m_env_mutex); //bulk comment-out //JMutexAutoLock envlock(m_env_mutex); //bulk comment-out

View File

@ -42,6 +42,7 @@ class IWritableTextureSource;
class IWritableItemDefManager; class IWritableItemDefManager;
class IWritableNodeDefManager; class IWritableNodeDefManager;
//class IWritableCraftDefManager; //class IWritableCraftDefManager;
class ClientEnvironment;
class ClientNotReadyException : public BaseException class ClientNotReadyException : public BaseException
{ {
@ -197,19 +198,12 @@ public:
*/ */
void step(float dtime); void step(float dtime);
// Called from updater thread
// Returns dtime
//float asyncStep();
void ProcessData(u8 *data, u32 datasize, u16 sender_peer_id); void ProcessData(u8 *data, u32 datasize, u16 sender_peer_id);
// Returns true if something was received // Returns true if something was received
bool AsyncProcessPacket(); bool AsyncProcessPacket();
bool AsyncProcessData(); bool AsyncProcessData();
void Send(u16 channelnum, SharedBuffer<u8> data, bool reliable); void Send(u16 channelnum, SharedBuffer<u8> data, bool reliable);
// Pops out a packet from the packet queue
//IncomingPacket getPacket();
void interact(u8 action, const PointedThing& pointed); void interact(u8 action, const PointedThing& pointed);
void sendSignNodeText(v3s16 p, std::string text); void sendSignNodeText(v3s16 p, std::string text);
@ -219,23 +213,14 @@ public:
const std::wstring newpassword); const std::wstring newpassword);
void sendDamage(u8 damage); void sendDamage(u8 damage);
void sendRespawn(); void sendRespawn();
ClientEnvironment& getEnv()
{ return m_env; }
// locks envlock // Causes urgent mesh updates (unlike Map::add/removeNodeWithEvent)
void removeNode(v3s16 p); void removeNode(v3s16 p);
// locks envlock
void addNode(v3s16 p, MapNode n); void addNode(v3s16 p, MapNode n);
void updateCamera(v3f pos, v3f dir, f32 fov);
void renderPostFx();
// Returns InvalidPositionException if not found
MapNode getNode(v3s16 p);
// Wrapper to Map
NodeMetadata* getNodeMetadata(v3s16 p);
LocalPlayer* getLocalPlayer();
void setPlayerControl(PlayerControl &control); void setPlayerControl(PlayerControl &control);
void selectPlayerItem(u16 item); void selectPlayerItem(u16 item);

View File

@ -284,6 +284,7 @@ PointedThing getPointedThing(Client *client, v3f player_position,
selected_object = NULL; selected_object = NULL;
INodeDefManager *nodedef = client->getNodeDefManager(); INodeDefManager *nodedef = client->getNodeDefManager();
ClientMap &map = client->getEnv().getClientMap();
// First try to find a pointed at active object // First try to find a pointed at active object
if(look_for_object) if(look_for_object)
@ -337,7 +338,7 @@ PointedThing getPointedThing(Client *client, v3f player_position,
MapNode n; MapNode n;
try try
{ {
n = client->getNode(v3s16(x,y,z)); n = map.getNode(v3s16(x,y,z));
} }
catch(InvalidPositionException &e) catch(InvalidPositionException &e)
{ {
@ -1818,7 +1819,7 @@ void the_game(
Update camera Update camera
*/ */
LocalPlayer* player = client.getLocalPlayer(); LocalPlayer* player = client.getEnv().getLocalPlayer();
float full_punch_interval = playeritem_toolcap.full_punch_interval; float full_punch_interval = playeritem_toolcap.full_punch_interval;
float tool_reload_ratio = time_from_last_punch / full_punch_interval; float tool_reload_ratio = time_from_last_punch / full_punch_interval;
tool_reload_ratio = MYMIN(tool_reload_ratio, 1.0); tool_reload_ratio = MYMIN(tool_reload_ratio, 1.0);
@ -1831,7 +1832,7 @@ void the_game(
f32 camera_fov = camera.getFovMax(); f32 camera_fov = camera.getFovMax();
if(!disable_camera_update){ if(!disable_camera_update){
client.updateCamera(camera_position, client.getEnv().getClientMap().updateCamera(camera_position,
camera_direction, camera_fov); camera_direction, camera_fov);
} }
@ -1929,15 +1930,13 @@ void the_game(
/* /*
Check information text of node Check information text of node
*/ */
NodeMetadata *meta = client.getNodeMetadata(nodepos); ClientMap &map = client.getEnv().getClientMap();
if(meta) NodeMetadata *meta = map.getNodeMetadata(nodepos);
{ if(meta){
infotext = narrow_to_wide(meta->infoText()); infotext = narrow_to_wide(meta->infoText());
} } else {
else MapNode n = map.getNode(nodepos);
{
MapNode n = client.getNode(nodepos);
if(nodedef->get(n).tname_tiles[0] == "unknown_block.png"){ if(nodedef->get(n).tname_tiles[0] == "unknown_block.png"){
infotext = L"Unknown node: "; infotext = L"Unknown node: ";
infotext += narrow_to_wide(nodedef->get(n).name); infotext += narrow_to_wide(nodedef->get(n).name);
@ -1948,7 +1947,6 @@ void the_game(
Handle digging Handle digging
*/ */
if(nodig_delay_timer <= 0.0 && input->getLeftState()) if(nodig_delay_timer <= 0.0 && input->getLeftState())
{ {
if(!digging) if(!digging)
@ -1958,7 +1956,7 @@ void the_game(
digging = true; digging = true;
ldown_for_dig = true; ldown_for_dig = true;
} }
MapNode n = client.getNode(nodepos); MapNode n = client.getEnv().getClientMap().getNode(nodepos);
// Get digging parameters // Get digging parameters
DigParams params = getDigParams(nodedef->get(n).groups, DigParams params = getDigParams(nodedef->get(n).groups,
@ -2501,7 +2499,7 @@ void the_game(
Post effects Post effects
*/ */
{ {
client.renderPostFx(); client.getEnv().getClientMap().renderPostFx();
} }
/* /*