rusefi/firmware/util/datalogging.h

79 lines
1.7 KiB
C
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file datalogging.h
* @brief Buffered console output stream header
*
* @date Feb 25, 2013
2020-01-13 18:57:43 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2015-07-10 06:01:56 -07:00
*/
2020-04-01 18:32:21 -07:00
#pragma once
2015-07-10 06:01:56 -07:00
#include <cstdarg>
#include <cstdint>
#include <cstddef>
2015-07-10 06:01:56 -07:00
// todo: migrate to external buffer so that different instances have different
// size of buffers?
class Logging {
public:
Logging() = delete;
2015-07-10 06:01:56 -07:00
Logging(const char *name, char *buffer, int bufferSize);
void reset();
2018-08-31 18:38:14 -07:00
void append(const char *text);
void appendFast(const char *text);
void appendPrintf(const char *fmt, ...);
void appendFloat(float value, int precision);
void terminate() {
linePointer[0] = '\0';
}
/**
* This macro breaks the normal zero=termination constraint, please take care of this outside of this function
*/
void appendChar(char c) {
*linePointer = c;
linePointer++;
}
size_t loggingSize() const {
return (uintptr_t)linePointer - (uintptr_t)buffer;
}
size_t remainingSize() const {
return bufferSize - loggingSize();
}
//private:
bool validateBuffer(uint32_t extraLen);
const char* const name = nullptr;
2015-07-10 06:01:56 -07:00
/**
* Zero-terminated buffer of pending debug message
*
* Unless a larger external buffer is specified, this is just a pointer to DEFAULT_BUFFER
*/
char* const buffer = nullptr;
const int bufferSize = 0;
2015-07-10 06:01:56 -07:00
/**
* This pointer is always pointing at the position within the buffer into which next
* write operation would append additional data
*/
2019-10-07 22:26:35 -07:00
char *linePointer = nullptr;
2015-07-10 06:01:56 -07:00
};
class LoggingWithStorage : public Logging {
public:
explicit LoggingWithStorage(const char *name);
char DEFAULT_BUFFER[100];
2015-07-10 06:01:56 -07:00
};
void initLoggingExt(Logging *logging, const char *name, char *buffer, int bufferSize);
void appendMsgPrefix(Logging *logging);
void appendMsgPostfix(Logging *logging);