diff --git a/src/client.cpp b/src/client.cpp index 2687d01e0..398b2602d 100644 --- a/src/client.cpp +++ b/src/client.cpp @@ -1864,6 +1864,28 @@ void Client::sendPlayerPos() Send(0, data, false); } +void Client::sendPlayerItem(u16 item) +{ + Player *myplayer = m_env.getLocalPlayer(); + if(myplayer == NULL) + return; + + u16 our_peer_id = m_con.GetPeerID(); + + // Set peer id if not set already + if(myplayer->peer_id == PEER_ID_INEXISTENT) + myplayer->peer_id = our_peer_id; + // Check that an existing peer_id is the same as the connection's + assert(myplayer->peer_id == our_peer_id); + + SharedBuffer data(2+2); + writeU16(&data[0], TOSERVER_PLAYERITEM); + writeU16(&data[2], item); + + // Send as reliable + Send(0, data, true); +} + void Client::removeNode(v3s16 p) { //JMutexAutoLock envlock(m_env_mutex); //bulk comment-out @@ -1959,6 +1981,8 @@ void Client::selectPlayerItem(u16 item) assert(player != NULL); player->wieldItem(item); + + sendPlayerItem(item); } // Returns true if the inventory of the local player has been diff --git a/src/client.h b/src/client.h index d21764f75..963eb6702 100644 --- a/src/client.h +++ b/src/client.h @@ -318,6 +318,8 @@ private: void sendPlayerPos(); // This sends the player's current name etc to the server void sendPlayerInfo(); + // Send the item number 'item' as player item to the server + void sendPlayerItem(u16 item); float m_packetcounter_timer; float m_connection_reinit_timer; diff --git a/src/clientserver.h b/src/clientserver.h index 4981b7ea8..717e657b7 100644 --- a/src/clientserver.h +++ b/src/clientserver.h @@ -301,6 +301,14 @@ enum ToServerCommand [30] u8[28] new password */ + TOSERVER_PLAYERITEM=0x37, + /* + Sent to change selected item. + + [0] u16 TOSERVER_PLAYERITEM + [2] u16 item + */ + }; inline SharedBuffer makePacket_TOCLIENT_TIME_OF_DAY(u16 time) diff --git a/src/server.cpp b/src/server.cpp index c2fb6097e..e3747775a 100644 --- a/src/server.cpp +++ b/src/server.cpp @@ -3381,6 +3381,14 @@ void Server::ProcessData(u8 *data, u32 datasize, u16 peer_id) <wieldItem(item); + } else { derr_server<<"WARNING: Server::ProcessData(): Ignoring "