mirror of
https://github.com/esp8266/Arduino.git
synced 2025-04-22 21:23:07 +03:00
commit
39f36d4509
@ -59,7 +59,9 @@ public:
|
|||||||
int read() override;
|
int read() override;
|
||||||
int peek() override;
|
int peek() override;
|
||||||
void flush() override;
|
void flush() override;
|
||||||
|
size_t readBytes(char *buffer, size_t length) override {
|
||||||
|
return read((uint8_t*)buffer, length);
|
||||||
|
}
|
||||||
size_t read(uint8_t* buf, size_t size);
|
size_t read(uint8_t* buf, size_t size);
|
||||||
bool seek(uint32_t pos, SeekMode mode);
|
bool seek(uint32_t pos, SeekMode mode);
|
||||||
size_t position() const;
|
size_t position() const;
|
||||||
|
@ -23,6 +23,46 @@ void MD5Builder::addHexString(const char * data){
|
|||||||
free(tmp);
|
free(tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool MD5Builder::addStream(Stream & stream, const size_t total_len) {
|
||||||
|
const int buf_size = 512;
|
||||||
|
int bytesleft = total_len;
|
||||||
|
uint8_t * buf = (uint8_t*) malloc(buf_size);
|
||||||
|
if(buf) {
|
||||||
|
while((stream.available() > -1) && (bytesleft > 0)) {
|
||||||
|
|
||||||
|
// get available data size
|
||||||
|
int sizeAvailable = stream.available();
|
||||||
|
if(sizeAvailable) {
|
||||||
|
int readBytes = sizeAvailable;
|
||||||
|
|
||||||
|
// read only the asked bytes
|
||||||
|
if(readBytes > bytesleft) {
|
||||||
|
readBytes = bytesleft ;
|
||||||
|
}
|
||||||
|
|
||||||
|
// not read more the buffer can handle
|
||||||
|
if(readBytes > buf_size) {
|
||||||
|
readBytes = buf_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
// read data
|
||||||
|
int bytesread = stream.readBytes(buf, readBytes);
|
||||||
|
bytesleft -= bytesread;
|
||||||
|
if(bytesread > 0) {
|
||||||
|
MD5Update(&_ctx, buf, bytesread);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// time for network streams
|
||||||
|
delay(0);
|
||||||
|
}
|
||||||
|
// not free null ptr
|
||||||
|
free(buf);
|
||||||
|
return (bytesleft == 0);
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MD5Builder::calculate(void){
|
void MD5Builder::calculate(void){
|
||||||
MD5Final(_buf, &_ctx);
|
MD5Final(_buf, &_ctx);
|
||||||
}
|
}
|
||||||
|
@ -37,6 +37,7 @@ class MD5Builder {
|
|||||||
void addHexString(const char * data);
|
void addHexString(const char * data);
|
||||||
void addHexString(char * data){ addHexString((const char*)data); }
|
void addHexString(char * data){ addHexString((const char*)data); }
|
||||||
void addHexString(String data){ addHexString(data.c_str()); }
|
void addHexString(String data){ addHexString(data.c_str()); }
|
||||||
|
bool addStream(Stream & stream, const size_t total_len);
|
||||||
void calculate(void);
|
void calculate(void);
|
||||||
void getBytes(uint8_t * output);
|
void getBytes(uint8_t * output);
|
||||||
void getChars(char * output);
|
void getChars(char * output);
|
||||||
|
@ -87,8 +87,8 @@ class Stream: public Print {
|
|||||||
|
|
||||||
float parseFloat(); // float version of parseInt
|
float parseFloat(); // float version of parseInt
|
||||||
|
|
||||||
size_t readBytes(char *buffer, size_t length); // read chars from stream into buffer
|
virtual size_t readBytes(char *buffer, size_t length); // read chars from stream into buffer
|
||||||
size_t readBytes(uint8_t *buffer, size_t length) {
|
virtual size_t readBytes(uint8_t *buffer, size_t length) {
|
||||||
return readBytes((char *) buffer, length);
|
return readBytes((char *) buffer, length);
|
||||||
}
|
}
|
||||||
// terminates if length characters have been read or timeout (see setTimeout)
|
// terminates if length characters have been read or timeout (see setTimeout)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user