rusefi/firmware/util/datalogging.h

102 lines
2.6 KiB
C
Raw Normal View History

2014-08-29 07:52:33 -07:00
/**
* @file datalogging.h
* @brief Buffered console output stream header
*
* @date Feb 25, 2013
2015-01-12 15:04:10 -08:00
* @author Andrey Belomutskiy, (c) 2012-2015
2014-08-29 07:52:33 -07:00
*/
#ifndef DATALOGGING_H_
#define DATALOGGING_H_
#include "global.h"
#include <stdarg.h>
#define DELIMETER ","
// todo: migrate to external buffer so that different instances have different
// size of buffers?
2015-01-13 19:04:02 -08:00
class Logging {
public:
2014-08-29 07:52:33 -07:00
const char *name;
char SMALL_BUFFER[40];
2014-11-16 09:03:23 -08:00
/**
* Zero-terminated buffer of pending debug message
*
2015-01-13 19:04:02 -08:00
* Unless a larger external buffer is specified, this is just a pointer to DEFAULT_BUFFER
2014-11-16 09:03:23 -08:00
*/
2014-08-29 07:52:33 -07:00
char *buffer;
2014-11-16 09:03:23 -08:00
/**
* This pointer is always pointing at the position within the buffer into which next
* write operation would append additional data
*/
2014-08-29 07:52:33 -07:00
char *linePointer;
int bufferSize;
volatile int isInitialized;
2015-01-13 19:04:02 -08:00
};
class LoggingWithStorage : public Logging {
public:
LoggingWithStorage();
char DEFAULT_BUFFER[200];
};
2014-08-29 07:52:33 -07:00
#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */
bool lockOutputBuffer(void);
void unlockOutputBuffer(void);
void initIntermediateLoggingBuffer(void);
uint32_t remainingSize(Logging *logging);
#define loggingSize(logging) ((int) (logging)->linePointer - (int) ((logging)->buffer))
int isInitialized(Logging *logging);
2015-01-13 19:04:02 -08:00
void initLogging(LoggingWithStorage *logging, const char *name);
2014-08-29 07:52:33 -07:00
void initLoggingExt(Logging *logging, const char *name, char *buffer, int bufferSize);
void debugInt(Logging *logging, const char *caption, int value);
void debugFloat(Logging *logging, const char *text, float value, int precision);
void appendFloat(Logging *logging, float value, int precision);
void resetLogging(Logging *logging);
void printLine(Logging *logging);
void appendMsgPrefix(Logging *logging);
void appendMsgPostfix(Logging *logging);
void scheduleMsg(Logging *logging, const char *fmt, ...);
void printMsg(Logging *logging, const char *fmt, ...);
void appendPrintf(Logging *logging, const char *fmt, ...);
void vappendPrintf(Logging *logging, const char *fmt, va_list arg);
void append(Logging *logging, const char *text);
void appendFast(Logging *logging, const char *text);
2014-11-18 18:05:41 -08:00
/**
* This macro breaks the normal zero=termination constraint, please take care of this outside of this macro
*/
#define appendChar(logging, symbol) {(logging)->linePointer[0] = (symbol);(logging)->linePointer++;}
2014-08-29 07:52:33 -07:00
/**
* this method copies the line into the intermediate buffer for later output by
* the main thread
*/
void scheduleLogging(Logging *logging);
/**
* this should only be invoked by the 'main' thread in order to keep the console safe
*/
void printPending(void);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* DATALOGGING_H_ */