mirror of
https://github.com/esp8266/Arduino.git
synced 2025-04-22 21:23:07 +03:00
Added length and operator[] methods, added some constness, missed dirty clear (#3855)
* Added length and operator[] methods, added some constness, missed _dirty clear * Added forgotten const
This commit is contained in:
parent
1b76e9bf72
commit
422f35938a
@ -83,10 +83,11 @@ void EEPROMClass::end() {
|
|||||||
}
|
}
|
||||||
_data = 0;
|
_data = 0;
|
||||||
_size = 0;
|
_size = 0;
|
||||||
|
_dirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
uint8_t EEPROMClass::read(int address) {
|
uint8_t EEPROMClass::read(int const address) {
|
||||||
if (address < 0 || (size_t)address >= _size)
|
if (address < 0 || (size_t)address >= _size)
|
||||||
return 0;
|
return 0;
|
||||||
if(!_data)
|
if(!_data)
|
||||||
@ -95,7 +96,7 @@ uint8_t EEPROMClass::read(int address) {
|
|||||||
return _data[address];
|
return _data[address];
|
||||||
}
|
}
|
||||||
|
|
||||||
void EEPROMClass::write(int address, uint8_t value) {
|
void EEPROMClass::write(int const address, uint8_t const value) {
|
||||||
if (address < 0 || (size_t)address >= _size)
|
if (address < 0 || (size_t)address >= _size)
|
||||||
return;
|
return;
|
||||||
if(!_data)
|
if(!_data)
|
||||||
@ -136,7 +137,7 @@ uint8_t * EEPROMClass::getDataPtr() {
|
|||||||
return &_data[0];
|
return &_data[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t const * EEPROMClass::getConstDataPtr() {
|
uint8_t const * EEPROMClass::getConstDataPtr() const {
|
||||||
return &_data[0];
|
return &_data[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,16 +32,16 @@ public:
|
|||||||
EEPROMClass(void);
|
EEPROMClass(void);
|
||||||
|
|
||||||
void begin(size_t size);
|
void begin(size_t size);
|
||||||
uint8_t read(int address);
|
uint8_t read(int const address);
|
||||||
void write(int address, uint8_t val);
|
void write(int const address, uint8_t const val);
|
||||||
bool commit();
|
bool commit();
|
||||||
void end();
|
void end();
|
||||||
|
|
||||||
uint8_t * getDataPtr();
|
uint8_t * getDataPtr();
|
||||||
uint8_t const * getConstDataPtr();
|
uint8_t const * getConstDataPtr() const;
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
T &get(int address, T &t) {
|
T &get(int const address, T &t) {
|
||||||
if (address < 0 || address + sizeof(T) > _size)
|
if (address < 0 || address + sizeof(T) > _size)
|
||||||
return t;
|
return t;
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
const T &put(int address, const T &t) {
|
const T &put(int const address, const T &t) {
|
||||||
if (address < 0 || address + sizeof(T) > _size)
|
if (address < 0 || address + sizeof(T) > _size)
|
||||||
return t;
|
return t;
|
||||||
if (memcmp(_data + address, (const uint8_t*)&t, sizeof(T)) != 0) {
|
if (memcmp(_data + address, (const uint8_t*)&t, sizeof(T)) != 0) {
|
||||||
@ -61,6 +61,11 @@ public:
|
|||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t length() {return _size;}
|
||||||
|
|
||||||
|
uint8_t& operator[](int const address) {return getDataPtr()[address];}
|
||||||
|
uint8_t const & operator[](int const address) const {return getConstDataPtr()[address];}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
uint32_t _sector;
|
uint32_t _sector;
|
||||||
uint8_t* _data;
|
uint8_t* _data;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user