Created separate file for ItemEventInfo.
This commit is contained in:
parent
0d850201fb
commit
ad82dca6cc
54
src/items/item_event_info.cpp
Executable file
54
src/items/item_event_info.cpp
Executable file
@ -0,0 +1,54 @@
|
|||||||
|
//
|
||||||
|
// SuperTuxKart - a fun racing game with go-kart
|
||||||
|
// Copyright (C) 2018 Joerg Henrichs
|
||||||
|
//
|
||||||
|
// 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 3
|
||||||
|
// 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
|
#include "items/item_event_info.hpp"
|
||||||
|
|
||||||
|
#include "network/network_config.hpp"
|
||||||
|
#include "network/protocols/game_protocol.hpp"
|
||||||
|
#include "network/rewind_manager.hpp"
|
||||||
|
#include "network/stk_host.hpp"
|
||||||
|
|
||||||
|
|
||||||
|
/** Loads an event from a server message. It helps encapsulate the encoding
|
||||||
|
* of events from and into a message buffer.
|
||||||
|
* \param buffer A network string with the event data.
|
||||||
|
* \param count The number of bytes read will be subtracted from this value.
|
||||||
|
*/
|
||||||
|
ItemEventInfo::ItemEventInfo(BareNetworkString *buffer, int *count)
|
||||||
|
{
|
||||||
|
m_ticks = buffer->getTime();
|
||||||
|
m_kart_id = buffer->getUInt8();
|
||||||
|
m_index = buffer->getUInt16();
|
||||||
|
*count -= 7;
|
||||||
|
} // ItemEventInfo(BareNetworkString, int *count)
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
/** Stores this event into a network string.
|
||||||
|
* \param buffer The network string to which the data should be appended.
|
||||||
|
*/
|
||||||
|
void ItemEventInfo::saveState(BareNetworkString *buffer)
|
||||||
|
{
|
||||||
|
assert(NetworkConfig::get()->isServer());
|
||||||
|
buffer->addTime(m_ticks).addUInt8(m_kart_id).addUInt16(m_index);
|
||||||
|
if(isNewItem())
|
||||||
|
{
|
||||||
|
}
|
||||||
|
} // saveState
|
||||||
|
|
||||||
|
|
||||||
|
|
114
src/items/item_event_info.hpp
Executable file
114
src/items/item_event_info.hpp
Executable file
@ -0,0 +1,114 @@
|
|||||||
|
//
|
||||||
|
// SuperTuxKart - a fun racing game with go-kart
|
||||||
|
// Copyright (C) 2018 Joerg Henrichs
|
||||||
|
//
|
||||||
|
// 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 3
|
||||||
|
// 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
|
#ifndef HEADER_ITEM_EVENT_INFO_HPP
|
||||||
|
#define HEADER_ITEM_EVENT_INFO_HPP
|
||||||
|
|
||||||
|
#include "items/item.hpp"
|
||||||
|
#include "utils/vec3.hpp"
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
class BareNetworkString;
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
/** This class stores a delta, i.e. an item event (either collection of
|
||||||
|
* an item, adding a new item, or an item switch being activated). All
|
||||||
|
* those deltas will be applied to the confirmed state to get a new state.
|
||||||
|
*/
|
||||||
|
class ItemEventInfo
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
/** Time at which this event happens. */
|
||||||
|
int m_ticks;
|
||||||
|
|
||||||
|
/** Index of this item in the item list. Only used when creating
|
||||||
|
* new items (e.g. bubble gum). */
|
||||||
|
int m_index;
|
||||||
|
|
||||||
|
/** The kart id that collected an item if >=0; if -1 it indicates
|
||||||
|
* a new item, and a -2 indicates a switch being used. */
|
||||||
|
int m_kart_id;
|
||||||
|
|
||||||
|
/** In case of new items the position of the new item. */
|
||||||
|
Vec3 m_xyz;
|
||||||
|
|
||||||
|
public:
|
||||||
|
/** Constructor for collecting an existing item.
|
||||||
|
* \param ticks Time of the event.
|
||||||
|
* \param item_id The index of the item that was collected.
|
||||||
|
* \param kart_id the kart that collected the item. */
|
||||||
|
ItemEventInfo(int ticks, int index, int kart_id)
|
||||||
|
: m_ticks(ticks), m_index(index), m_kart_id(kart_id)
|
||||||
|
{
|
||||||
|
assert(kart_id >= 0);
|
||||||
|
} // ItemEventInfo(collected existing item)
|
||||||
|
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Constructor for creating a new item (i.e. a bubble gum is dropped).
|
||||||
|
*/
|
||||||
|
ItemEventInfo(int ticks, ItemState::ItemType type, int index,
|
||||||
|
const Vec3 &xyz)
|
||||||
|
: m_ticks(ticks), m_index(index), m_kart_id(-1), m_xyz(xyz)
|
||||||
|
{
|
||||||
|
} // ItemEventInfo(new item)
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Constructor for switching items. */
|
||||||
|
ItemEventInfo(int ticks) : m_ticks(ticks), m_kart_id(-2)
|
||||||
|
{
|
||||||
|
} // ItemEventInfo(switch)
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
ItemEventInfo(BareNetworkString *buffer, int *count);
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
void saveState(BareNetworkString *buffer);
|
||||||
|
|
||||||
|
/** Returns if this event represents a new item. */
|
||||||
|
bool isNewItem() const { return m_kart_id == -1; }
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Returns true if this event represents collection of an item. */
|
||||||
|
bool isItemCollection() const { return m_kart_id >= 0; }
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Returns true if this event represent a switch usage. */
|
||||||
|
bool isSwitch() const { return m_kart_id == -2; }
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Returns the index of this item. */
|
||||||
|
int getIndex() const { return m_index; }
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Returns the time of the event in ticks. */
|
||||||
|
int getTicks() const { return m_ticks; }
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Returns the id of the kart that collected an item. Only allowed
|
||||||
|
* to be called when this event is an item collection. */
|
||||||
|
int getKartId() const
|
||||||
|
{
|
||||||
|
assert(isItemCollection());
|
||||||
|
return m_kart_id;
|
||||||
|
} // getKartId
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
/** Returns the location of a new item. Only allowed to be called when
|
||||||
|
* this is a new item event. */
|
||||||
|
const Vec3& getXYZ() const
|
||||||
|
{
|
||||||
|
assert(isNewItem());
|
||||||
|
return m_xyz;
|
||||||
|
} // getXYZ
|
||||||
|
|
||||||
|
}; // class ItemEventInfo
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
30
src/items/network_item_manager.cpp
Normal file → Executable file
30
src/items/network_item_manager.cpp
Normal file → Executable file
@ -112,8 +112,7 @@ void NetworkItemManager::collectedItem(Item *item, AbstractKart *kart)
|
|||||||
m_item_events.lock();
|
m_item_events.lock();
|
||||||
m_item_events.getData().emplace_back(World::getWorld()->getTimeTicks(),
|
m_item_events.getData().emplace_back(World::getWorld()->getTimeTicks(),
|
||||||
item->getItemId(),
|
item->getItemId(),
|
||||||
kart->getWorldKartId(),
|
kart->getWorldKartId());
|
||||||
/*item_info*/0);
|
|
||||||
m_item_events.unlock();
|
m_item_events.unlock();
|
||||||
ItemManager::collectedItem(item, kart);
|
ItemManager::collectedItem(item, kart);
|
||||||
}
|
}
|
||||||
@ -172,7 +171,7 @@ void NetworkItemManager::setItemConfirmationTime(int host_id, int ticks)
|
|||||||
// entry can be deleted.
|
// entry can be deleted.
|
||||||
m_item_events.lock();
|
m_item_events.lock();
|
||||||
auto p = m_item_events.getData().begin();
|
auto p = m_item_events.getData().begin();
|
||||||
while (p != m_item_events.getData().end() && p->m_ticks < min_time)
|
while (p != m_item_events.getData().end() && p->getTicks() < min_time)
|
||||||
p++;
|
p++;
|
||||||
m_item_events.getData().erase(m_item_events.getData().begin(), p);
|
m_item_events.getData().erase(m_item_events.getData().begin(), p);
|
||||||
m_item_events.unlock();
|
m_item_events.unlock();
|
||||||
@ -215,8 +214,7 @@ BareNetworkString* NetworkItemManager::saveState()
|
|||||||
+ sizeof(uint8_t) ) );
|
+ sizeof(uint8_t) ) );
|
||||||
for (auto p : m_item_events.getData())
|
for (auto p : m_item_events.getData())
|
||||||
{
|
{
|
||||||
s->addTime(p.m_ticks).addUInt16(p.m_index);
|
p.saveState(s);
|
||||||
if (p.m_index > -1) s->addUInt8(p.m_kart_id);
|
|
||||||
}
|
}
|
||||||
m_item_events.unlock();
|
m_item_events.unlock();
|
||||||
Log::verbose("NIM", "Including %d item update at %d",
|
Log::verbose("NIM", "Including %d item update at %d",
|
||||||
@ -259,20 +257,12 @@ void NetworkItemManager::restoreState(BareNetworkString *buffer, int count)
|
|||||||
{
|
{
|
||||||
// 1) Decode the event in the message
|
// 1) Decode the event in the message
|
||||||
// ----------------------------------
|
// ----------------------------------
|
||||||
int ticks = buffer->getTime();
|
ItemEventInfo iei(buffer, &count);
|
||||||
int item_index = buffer->getUInt16();
|
|
||||||
int kart_id = -1;
|
|
||||||
count -= 6;
|
|
||||||
if(item_index>-1)
|
|
||||||
{
|
|
||||||
kart_id = buffer->getUInt8();
|
|
||||||
count --;
|
|
||||||
} // item_id>-1
|
|
||||||
|
|
||||||
// 2) If the event needs to be applied, forward
|
// 2) If the event needs to be applied, forward
|
||||||
// the time to the time of this event:
|
// the time to the time of this event:
|
||||||
// --------------------------------------------
|
// --------------------------------------------
|
||||||
int dt = ticks - current_time;
|
int dt = iei.getTicks() - current_time;
|
||||||
// Skip an event that are 'in the past' (i.e. have been sent again by
|
// Skip an event that are 'in the past' (i.e. have been sent again by
|
||||||
// the server because it has not yet received confirmation from all
|
// the server because it has not yet received confirmation from all
|
||||||
// clients.
|
// clients.
|
||||||
@ -282,15 +272,15 @@ void NetworkItemManager::restoreState(BareNetworkString *buffer, int count)
|
|||||||
if (dt>0) forwardTime(dt);
|
if (dt>0) forwardTime(dt);
|
||||||
|
|
||||||
// TODO: apply the various events types, atm only collection is supported:
|
// TODO: apply the various events types, atm only collection is supported:
|
||||||
ItemState *item_state = m_confirmed_state[item_index];
|
ItemState *item_state = m_confirmed_state[iei.getIndex()];
|
||||||
if (item_index > -1)
|
if(iei.isItemCollection())
|
||||||
{
|
{
|
||||||
// An item on the track was collected:
|
// An item on the track was collected:
|
||||||
AbstractKart *kart = World::getWorld()->getKart(kart_id);
|
AbstractKart *kart = World::getWorld()->getKart(iei.getKartId());
|
||||||
m_confirmed_state[item_index]->collected(kart);
|
m_confirmed_state[iei.getIndex()]->collected(kart);
|
||||||
}
|
}
|
||||||
|
|
||||||
current_time = ticks;
|
current_time = iei.getTicks();
|
||||||
} // while count >0
|
} // while count >0
|
||||||
|
|
||||||
// Inform the server which events have been received.
|
// Inform the server which events have been received.
|
||||||
|
58
src/items/network_item_manager.hpp
Normal file → Executable file
58
src/items/network_item_manager.hpp
Normal file → Executable file
@ -19,6 +19,7 @@
|
|||||||
#ifndef HEADER_NETWORK_ITEM_MANAGER_HPP
|
#ifndef HEADER_NETWORK_ITEM_MANAGER_HPP
|
||||||
#define HEADER_NETWORK_ITEM_MANAGER_HPP
|
#define HEADER_NETWORK_ITEM_MANAGER_HPP
|
||||||
|
|
||||||
|
#include "items/item_event_info.hpp"
|
||||||
#include "items/item_manager.hpp"
|
#include "items/item_manager.hpp"
|
||||||
#include "network/rewinder.hpp"
|
#include "network/rewinder.hpp"
|
||||||
#include "utils/cpp2011.hpp"
|
#include "utils/cpp2011.hpp"
|
||||||
@ -48,63 +49,6 @@ private:
|
|||||||
/** Stores on the server the latest confirmed tick from each client. */
|
/** Stores on the server the latest confirmed tick from each client. */
|
||||||
Synchronised< std::vector<int> > m_last_confirmed_item_ticks;
|
Synchronised< std::vector<int> > m_last_confirmed_item_ticks;
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
|
||||||
/** This class stores a delta, i.e. an item event (either collection of
|
|
||||||
* an item, adding a new item, or an item switch being activated). All
|
|
||||||
* those deltas will be applied to the confirmed state to get a new state.
|
|
||||||
*/
|
|
||||||
class ItemEventInfo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
/** Time at which this event happens. */
|
|
||||||
int m_ticks;
|
|
||||||
|
|
||||||
/** Index of this item in the item list. Only used when creating
|
|
||||||
* new items (e.g. bubble gum). */
|
|
||||||
int m_index;
|
|
||||||
|
|
||||||
/** Additional info about the item: -1 if a switch is activated.
|
|
||||||
* Otherwise it contains information about what item the kart gets
|
|
||||||
* (e.g. banana --> anchor or bomb). */
|
|
||||||
int m_item_info;
|
|
||||||
|
|
||||||
/** The kart id that collected an item ,
|
|
||||||
* otherwise undefined. */
|
|
||||||
int m_kart_id;
|
|
||||||
|
|
||||||
/** In case of new items the position of the new item. */
|
|
||||||
Vec3 m_xyz;
|
|
||||||
|
|
||||||
/** Constructor for collecting an existing item.
|
|
||||||
* \param ticks Time of the event.
|
|
||||||
* \param item_id The index of the item that was collected.
|
|
||||||
* \param kart_id the kart that collected the item. */
|
|
||||||
ItemEventInfo(int ticks, int index, int kart_id, int item_info)
|
|
||||||
: m_ticks(ticks), m_index(index), m_kart_id(kart_id),
|
|
||||||
m_item_info(item_info)
|
|
||||||
{
|
|
||||||
} // ItemEventInfo(collected existing item)
|
|
||||||
|
|
||||||
// --------------------------------------------------------------------
|
|
||||||
/** Constructor for creating a new item (i.e. a bubble gum is dropped).
|
|
||||||
*/
|
|
||||||
ItemEventInfo(int ticks, ItemState::ItemType type, int index,
|
|
||||||
const Vec3 &xyz)
|
|
||||||
{
|
|
||||||
m_ticks = ticks;
|
|
||||||
m_index = index;
|
|
||||||
m_xyz = xyz;
|
|
||||||
} // ItemEventInfo(new item)
|
|
||||||
// --------------------------------------------------------------------
|
|
||||||
/** Constructor for switching items. */
|
|
||||||
ItemEventInfo(int ticks)
|
|
||||||
: m_ticks(ticks), m_kart_id(-1), m_item_info(-1)
|
|
||||||
{
|
|
||||||
} // ItemEventInfo(switch)
|
|
||||||
|
|
||||||
}; // class ItemEventInfo
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
|
||||||
/** List of all items events. */
|
/** List of all items events. */
|
||||||
Synchronised< std::vector<ItemEventInfo> > m_item_events;
|
Synchronised< std::vector<ItemEventInfo> > m_item_events;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user