From 5aa818e65eaa3cc288e097ed3b1a134015215500 Mon Sep 17 00:00:00 2001 From: HampusM Date: Mon, 14 Mar 2022 10:40:26 +0100 Subject: refactor: move UniquePtr to memory dir in common --- src/common/conversion.cpp | 3 +++ src/common/conversion.hpp | 2 +- src/common/memory.hpp | 31 ---------------------- src/common/memory.tpp | 49 ----------------------------------- src/common/memory/unique_ptr.hpp | 37 +++++++++++++++++++++++++++ src/common/memory/unique_ptr.tpp | 55 ++++++++++++++++++++++++++++++++++++++++ src/gyronardo.cpp | 2 +- 7 files changed, 97 insertions(+), 82 deletions(-) create mode 100644 src/common/memory/unique_ptr.hpp create mode 100644 src/common/memory/unique_ptr.tpp (limited to 'src') diff --git a/src/common/conversion.cpp b/src/common/conversion.cpp index 0bdc81a..b016537 100644 --- a/src/common/conversion.cpp +++ b/src/common/conversion.cpp @@ -1,5 +1,8 @@ #include "conversion.hpp" +#include +#include + namespace common { diff --git a/src/common/conversion.hpp b/src/common/conversion.hpp index 81a4a52..e87adc5 100644 --- a/src/common/conversion.hpp +++ b/src/common/conversion.hpp @@ -1,6 +1,6 @@ #pragma once -#include "common/memory.hpp" +#include "common/memory/unique_ptr.hpp" #include "common/string.hpp" namespace common diff --git a/src/common/memory.hpp b/src/common/memory.hpp index de72d80..888ede3 100644 --- a/src/common/memory.hpp +++ b/src/common/memory.hpp @@ -8,37 +8,6 @@ namespace common template memType *malloc_s(unsigned int size); -template -class UniquePtr -{ -public: - explicit UniquePtr() = default; - explicit UniquePtr(Target *target); - - // Move constructor - UniquePtr(UniquePtr &&unique_ptr) noexcept; - - // Move assignment operator - UniquePtr &operator=(UniquePtr &&unique_ptr) noexcept; - - // Disable the copy constructor - UniquePtr(const UniquePtr &unique_ptr) = delete; - - // Disable the copy assignment operator - UniquePtr &operator=(const UniquePtr &unique_ptr) = delete; - - ~UniquePtr(); - - Target operator*() const; - Target *operator->() const; - -private: - Target *_target = nullptr; -}; - -template -UniquePtr make_unique(Args... args); - } // namespace common #include "memory.tpp" diff --git a/src/common/memory.tpp b/src/common/memory.tpp index ace2432..af833bc 100644 --- a/src/common/memory.tpp +++ b/src/common/memory.tpp @@ -24,53 +24,4 @@ memType *malloc_s(unsigned int size) return static_cast(mem); } -template -UniquePtr::UniquePtr(Target *target) : _target(target) -{ -} - -template -UniquePtr::UniquePtr(UniquePtr &&unique_ptr) noexcept - : _target(unique_ptr._target) -{ - unique_ptr._target = nullptr; -} - -template -UniquePtr &UniquePtr::operator=(UniquePtr &&unique_ptr) noexcept -{ - if (&unique_ptr != this) - { - delete _target; - _target = unique_ptr._target; - unique_ptr._target = nullptr; - } - - return *this; -} - -template -UniquePtr::~UniquePtr() -{ - delete _target; -} - -template -Target UniquePtr::operator*() const -{ - return *(_target); -} - -template -Target *UniquePtr::operator->() const -{ - return _target; -} - -template -UniquePtr make_unique(Args... args) -{ - return UniquePtr(new Target(args...)); -} - } // namespace common diff --git a/src/common/memory/unique_ptr.hpp b/src/common/memory/unique_ptr.hpp new file mode 100644 index 0000000..94c02d0 --- /dev/null +++ b/src/common/memory/unique_ptr.hpp @@ -0,0 +1,37 @@ +#pragma once + +namespace common +{ +template +class UniquePtr +{ +public: + explicit UniquePtr() = default; + explicit UniquePtr(Target *target); + + // Move constructor + UniquePtr(UniquePtr &&unique_ptr) noexcept; + + // Move assignment operator + UniquePtr &operator=(UniquePtr &&unique_ptr) noexcept; + + // Disable the copy constructor + UniquePtr(const UniquePtr &unique_ptr) = delete; + + // Disable the copy assignment operator + UniquePtr &operator=(const UniquePtr &unique_ptr) = delete; + + ~UniquePtr(); + + Target operator*() const; + Target *operator->() const; + +private: + Target *_target = nullptr; +}; + +template +UniquePtr make_unique(Args... args); +} // namespace common + +#include "unique_ptr.tpp" diff --git a/src/common/memory/unique_ptr.tpp b/src/common/memory/unique_ptr.tpp new file mode 100644 index 0000000..3cab9ec --- /dev/null +++ b/src/common/memory/unique_ptr.tpp @@ -0,0 +1,55 @@ +#pragma once + +#include "unique_ptr.hpp" + +namespace common +{ +template +UniquePtr::UniquePtr(Target *target) : _target(target) +{ +} + +template +UniquePtr::UniquePtr(UniquePtr &&unique_ptr) noexcept + : _target(unique_ptr._target) +{ + unique_ptr._target = nullptr; +} + +template +UniquePtr &UniquePtr::operator=(UniquePtr &&unique_ptr) noexcept +{ + if (&unique_ptr != this) + { + delete _target; + _target = unique_ptr._target; + unique_ptr._target = nullptr; + } + + return *this; +} + +template +UniquePtr::~UniquePtr() +{ + delete _target; +} + +template +Target UniquePtr::operator*() const +{ + return *(_target); +} + +template +Target *UniquePtr::operator->() const +{ + return _target; +} + +template +UniquePtr make_unique(Args... args) +{ + return UniquePtr(new Target(args...)); +} +} // namespace common diff --git a/src/gyronardo.cpp b/src/gyronardo.cpp index 4b6b5fd..d05b3ce 100644 --- a/src/gyronardo.cpp +++ b/src/gyronardo.cpp @@ -1,7 +1,7 @@ -#include "common/memory.hpp" #include "sensor/calibration.hpp" #include "sensor/sensor.hpp" #include "serial.hpp" +#include "utils.hpp" #include #include -- cgit v1.2.3-18-g5258