123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279 |
- /*
- * Author: Patrick-Christopher Mattulat
- * Company: Lynar Studios
- * E-Mail: webmaster@lynarstudios.com
- * Created: 2020-08-14
- * Changed: 2021-04-23
- *
- * */
- #include <cmath>
- #include <ls_std/boxing/Double.hpp>
- ls_std::Double::Double()
- : ls_std::Class("Double"),
- epsilon(0.00000001)
- {}
- ls_std::Double::Double(double _value)
- : ls_std::Class("Double"),
- epsilon(0.00000001),
- value(_value)
- {}
- ls_std::Double::operator double() const
- {
- return this->value;
- }
- ls_std::Double &ls_std::Double::operator=(double _value)
- {
- this->value = _value;
- return *this;
- }
- double ls_std::Double::operator-() const
- {
- return -this->value;
- }
- double ls_std::Double::operator+(const ls_std::Double &_double) const
- {
- return this->value + _double;
- }
- double ls_std::Double::operator+(double _value) const
- {
- return this->value + _value;
- }
- double ls_std::Double::operator*(const ls_std::Double &_double) const
- {
- return this->value * _double;
- }
- double ls_std::Double::operator*(double _value) const
- {
- return this->value * _value;
- }
- double ls_std::Double::operator-(const ls_std::Double &_double) const
- {
- return this->value - _double;
- }
- double ls_std::Double::operator-(double _value) const
- {
- return this->value - _value;
- }
- double ls_std::Double::operator/(const ls_std::Double &_double) const
- {
- return this->value / _double;
- }
- double ls_std::Double::operator/(double _value) const
- {
- return this->value / _value;
- }
- ls_std::Double &ls_std::Double::operator+=(const ls_std::Double &_double)
- {
- this->value += _double;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator+=(double _value)
- {
- this->value += _value;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator-=(const ls_std::Double &_double)
- {
- this->value -= _double;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator-=(double _value)
- {
- this->value -= _value;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator*=(const ls_std::Double &_double)
- {
- this->value *= _double;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator*=(double _value)
- {
- this->value *= _value;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator/=(const ls_std::Double &_double)
- {
- this->value /= _double;
- return *this;
- }
- ls_std::Double &ls_std::Double::operator/=(double _value)
- {
- this->value /= _value;
- return *this;
- }
- bool ls_std::Double::operator==(const ls_std::Double &_double) const
- {
- return std::fabs(this->value - _double) < this->epsilon;
- }
- bool ls_std::Double::operator==(double _value) const
- {
- return std::fabs(this->value - _value) < this->epsilon;
- }
- bool ls_std::Double::operator!=(const ls_std::Double &_double) const
- {
- return std::fabs(this->value - _double) >= this->epsilon;
- }
- bool ls_std::Double::operator!=(double _value) const
- {
- return std::fabs(this->value - _value) >= this->epsilon;
- }
- bool ls_std::Double::operator>(const ls_std::Double &_double) const
- {
- return this->value > _double;
- }
- bool ls_std::Double::operator>(double _value) const
- {
- return this->value > _value;
- }
- bool ls_std::Double::operator>=(const ls_std::Double &_double) const
- {
- return this->value >= _double;
- }
- bool ls_std::Double::operator>=(double _value) const
- {
- return this->value >= _value;
- }
- bool ls_std::Double::operator<(const ls_std::Double &_double) const
- {
- return this->value < _double;
- }
- bool ls_std::Double::operator<(double _value) const
- {
- return this->value < _value;
- }
- bool ls_std::Double::operator<=(const ls_std::Double &_double) const
- {
- return this->value <= _double;
- }
- bool ls_std::Double::operator<=(double _value) const
- {
- return this->value <= _value;
- }
- void ls_std::Double::operator++()
- {
- this->value += 1.0f;
- }
- void ls_std::Double::operator--()
- {
- this->value -= 1.0f;
- }
- ls_std::byte_field ls_std::Double::load()
- {
- ls_std::byte_field data{};
- if (this->storable != nullptr && this->serializable != nullptr)
- {
- data = this->storable->load();
- this->serializable->unmarshal(data);
- }
- return data;
- }
- ls_std::byte_field ls_std::Double::marshal()
- {
- ls_std::byte_field data{};
- if (this->serializable != nullptr)
- {
- data = this->serializable->marshal();
- }
- return data;
- }
- void ls_std::Double::parse(std::string _parseText)
- {
- this->value = std::stod(_parseText);
- }
- void ls_std::Double::save(const ls_std::byte_field &_data)
- {
- if (this->serializable != nullptr)
- {
- if (_data.empty())
- {
- this->storable->save(this->serializable->marshal());
- }
- else
- {
- this->storable->save(_data);
- }
- }
- }
- std::string ls_std::Double::toString()
- {
- return std::to_string(this->value);
- }
- void ls_std::Double::unmarshal(const ls_std::byte_field &_data)
- {
- if (this->serializable != nullptr)
- {
- this->serializable->unmarshal(_data);
- }
- }
- double ls_std::Double::getEpsilon()
- {
- return this->epsilon;
- }
- double ls_std::Double::getValue()
- {
- return this->value;
- }
- void ls_std::Double::setEpsilon(double _epsilon)
- {
- this->epsilon = _epsilon;
- }
- void ls_std::Double::setSerializable(std::shared_ptr<ISerializable> _serializable)
- {
- this->serializable = std::move(_serializable);
- }
- void ls_std::Double::setStorable(std::shared_ptr<IStorable> _storable)
- {
- this->storable = std::move(_storable);
- }
|