# HG changeset patch # User KUDr # Date 1169811487 0 # Node ID a4805866f6fc646b48a9ed0d554d54e777b23a20 # Parent d59aa5885dccd58f45314fa4bfae239695b32c54 (svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr. -Simplifies assignment from raw pointers -Should be harder to crash the program by incorrect assignment into it. -Should help with MorphOS compilation errors diff --git a/projects/openttd.vcproj b/projects/openttd.vcproj --- a/projects/openttd.vcproj +++ b/projects/openttd.vcproj @@ -1021,6 +1021,9 @@ RelativePath=".\..\src\misc\autocopyptr.hpp"> + + + + +class AutoPtrT { +public: + typedef T obj_t; + +protected: + mutable T* m_p; ///< points to the data + +public: + FORCEINLINE AutoPtrT() + : m_p(NULL) + {}; + + FORCEINLINE AutoPtrT(const AutoPtrT& src) + : m_p(src.m_p) + { + if (m_p != NULL) src.m_p = NULL; + }; + + FORCEINLINE AutoPtrT(T *p) + : m_p(p) + {} + + FORCEINLINE ~AutoPtrT() + { + if (m_p != NULL) { + delete m_p; + m_p = NULL; + } + } + + /** give-up ownership and NULLify the raw pointer */ + FORCEINLINE T* Release() + { + T* p = m_p; + m_p = NULL; + return p; + } + + /** raw-pointer cast operator (read only) */ + FORCEINLINE operator const T* () const + { + return m_p; + } + + /** raw-pointer cast operator */ + FORCEINLINE operator T* () + { + return m_p; + } + + /** dereference operator (read only) */ + FORCEINLINE const T* operator -> () const + { + assert(m_p != NULL); + return m_p; + } + + /** dereference operator (read / write) */ + FORCEINLINE T* operator -> () + { + assert(m_p != NULL); + return m_p; + } + + /** assignment operator */ + FORCEINLINE AutoPtrT& operator = (const AutoPtrT& src) + { + m_p = src.m_p; + if (m_p != NULL) src.m_p = NULL; + return *this; + } + + /** forwarding 'lower than' operator to the underlaying items */ + FORCEINLINE bool operator < (const AutoPtrT& other) const + { + assert(m_p != NULL); + assert(other.m_p != NULL); + return (*m_p) < (*other.m_p); + } +}; + +#endif /* AUTOPTR_HPP */ diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp --- a/src/station_cmd.cpp +++ b/src/station_cmd.cpp @@ -34,8 +34,7 @@ #include "yapf/yapf.h" #include "date.h" #include "helpers.hpp" - -#include // for auto_ptr +#include "misc/autoptr.hpp" /** * Called if a new block is added to the station-pool @@ -932,7 +931,7 @@ /* In case of new station if DC_EXEC is NOT set we still need to create the station * to test if everything is OK. In this case we need to delete it before return. */ - std::auto_ptr st_auto_delete; + AutoPtrT st_auto_delete; if (st != NULL) { // Reuse an existing station. @@ -955,7 +954,7 @@ if (st == NULL) return CMD_ERROR; /* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ - st_auto_delete = std::auto_ptr(st); + st_auto_delete = st; st->town = ClosestTownFromTile(tile_org, (uint)-1); if (!GenerateStationName(st, tile_org, 0)) return CMD_ERROR; @@ -1044,7 +1043,7 @@ RebuildStationLists(); InvalidateWindow(WC_STATION_LIST, st->owner); /* success, so don't delete the new station */ - st_auto_delete.release(); + st_auto_delete.Release(); } return cost; @@ -1366,7 +1365,7 @@ } /* ensure that in case of error (or no DC_EXEC) the new road stop gets deleted upon return */ - std::auto_ptr rs_auto_delete(road_stop); + AutoPtrT rs_auto_delete(road_stop); if (st != NULL && GetNumRoadStopsInStation(st, RoadStop::BUS) + GetNumRoadStopsInStation(st, RoadStop::TRUCK) >= RoadStop::LIMIT) { @@ -1375,7 +1374,7 @@ /* In case of new station if DC_EXEC is NOT set we still need to create the station * to test if everything is OK. In this case we need to delete it before return. */ - std::auto_ptr st_auto_delete; + AutoPtrT st_auto_delete; if (st != NULL) { if (st->owner != OWNER_NONE && st->owner != _current_player) { @@ -1391,7 +1390,7 @@ if (st == NULL) return CMD_ERROR; /* ensure that in case of error (or no DC_EXEC) the new station gets deleted upon return */ - st_auto_delete = std::auto_ptr(st); + st_auto_delete = st; Town *t = st->town = ClosestTownFromTile(tile, (uint)-1); @@ -1425,8 +1424,8 @@ RebuildStationLists(); InvalidateWindow(WC_STATION_LIST, st->owner); /* success, so don't delete the new station and the new road stop */ - st_auto_delete.release(); - rs_auto_delete.release(); + st_auto_delete.Release(); + rs_auto_delete.Release(); } return cost; } @@ -1633,7 +1632,7 @@ /* In case of new station if DC_EXEC is NOT set we still need to create the station * to test if everything is OK. In this case we need to delete it before return. */ - std::auto_ptr st_auto_delete; + AutoPtrT st_auto_delete; if (st != NULL) { if (st->owner != OWNER_NONE && st->owner != _current_player) @@ -1651,7 +1650,7 @@ if (st == NULL) return CMD_ERROR; /* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ - st_auto_delete = std::auto_ptr(st); + st_auto_delete = st; st->town = t; @@ -1699,7 +1698,7 @@ RebuildStationLists(); InvalidateWindow(WC_STATION_LIST, st->owner); /* success, so don't delete the new station */ - st_auto_delete.release(); + st_auto_delete.Release(); } return cost; @@ -1771,7 +1770,7 @@ if (st == NULL) return CMD_ERROR; /* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ - std::auto_ptr st_auto_delete(st); + AutoPtrT st_auto_delete(st); st->town = ClosestTownFromTile(tile, (uint)-1); st->sign.width_1 = 0; @@ -1795,7 +1794,7 @@ RebuildStationLists(); InvalidateWindow(WC_STATION_LIST, st->owner); /* success, so don't delete the new station */ - st_auto_delete.release(); + st_auto_delete.Release(); } return _price.build_dock; @@ -1915,7 +1914,7 @@ /* In case of new station if DC_EXEC is NOT set we still need to create the station * to test if everything is OK. In this case we need to delete it before return. */ - std::auto_ptr st_auto_delete; + AutoPtrT st_auto_delete; if (st != NULL) { if (st->owner != OWNER_NONE && st->owner != _current_player) @@ -1930,7 +1929,7 @@ if (st == NULL) return CMD_ERROR; /* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ - st_auto_delete = std::auto_ptr(st); + st_auto_delete = st; Town *t = st->town = ClosestTownFromTile(tile, (uint)-1); @@ -1956,7 +1955,7 @@ RebuildStationLists(); InvalidateWindow(WC_STATION_LIST, st->owner); /* success, so don't delete the new station */ - st_auto_delete.release(); + st_auto_delete.Release(); } return _price.build_dock; }