2020-05-17 10:37:41 +02:00
|
|
|
#pragma once
|
|
|
|
//
|
|
|
|
// FILE: LineFormatter.h
|
|
|
|
// AUTHOR: Rob Tillaart
|
2023-01-31 13:39:06 +01:00
|
|
|
// VERSION: 0.2.0
|
2021-11-06 17:49:23 +01:00
|
|
|
// PURPOSE: Simple positioning wrapper class for Serial / Stream
|
2020-05-17 10:37:41 +02:00
|
|
|
// DATE: 2020-05-14
|
|
|
|
// URL: https://github.com/RobTillaart/LineFormatter
|
2023-01-31 13:39:06 +01:00
|
|
|
|
2020-05-17 10:37:41 +02:00
|
|
|
|
|
|
|
#include "Arduino.h"
|
|
|
|
#include "Print.h"
|
|
|
|
|
|
|
|
#ifndef MAX_TAB_STOPS
|
2023-01-31 13:39:06 +01:00
|
|
|
#define MAX_TAB_STOPS 12
|
2020-05-17 10:37:41 +02:00
|
|
|
#endif
|
|
|
|
|
2023-01-31 13:39:06 +01:00
|
|
|
#define LINEFORMATTER_LIB_VERSION (F("0.2.0"))
|
2021-11-06 17:49:23 +01:00
|
|
|
|
|
|
|
|
2020-05-17 10:37:41 +02:00
|
|
|
class LineFormatter: public Print
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
LineFormatter(Print* stream = &Serial);
|
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
void reset();
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
size_t write(uint8_t c);
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2022-11-14 20:50:36 +01:00
|
|
|
// set the maximum line length - bold cut off
|
2023-01-31 13:39:06 +01:00
|
|
|
void setMaxLength(uint8_t maxPos);
|
|
|
|
uint8_t getMaxLength();
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2022-11-14 20:50:36 +01:00
|
|
|
// if position is smaller than n, move to the right
|
2023-01-31 13:39:06 +01:00
|
|
|
uint8_t gotoPos(uint8_t pos);
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2022-11-14 20:50:36 +01:00
|
|
|
// repeat a char or a "string" n times
|
|
|
|
// followed by 0 or more newlines.
|
2021-01-29 12:31:58 +01:00
|
|
|
void repeat(uint8_t n, char c, uint8_t newLine = 0);
|
|
|
|
void repeat(uint8_t n, const char* str, uint8_t newLine = 0);
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2022-11-14 20:50:36 +01:00
|
|
|
// n = 0 switches autoNewLine off
|
2023-01-31 13:39:06 +01:00
|
|
|
void setAutoNewLine(uint8_t n = 1);
|
|
|
|
uint8_t getAutoNewLine();
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2022-11-14 20:50:36 +01:00
|
|
|
// Add a tab at (absolute/relative) position
|
|
|
|
// returns true on success
|
2023-01-31 13:39:06 +01:00
|
|
|
bool addTab(uint8_t pos);
|
2021-01-29 12:31:58 +01:00
|
|
|
bool addRelTab(uint8_t n);
|
2022-11-14 20:50:36 +01:00
|
|
|
// remove all the tabs,
|
2021-01-29 12:31:58 +01:00
|
|
|
void clearTabs();
|
2023-01-31 13:39:06 +01:00
|
|
|
// remove tab at position pos
|
|
|
|
// returns false if it does not exist.
|
|
|
|
bool removeTab(uint8_t pos);
|
|
|
|
bool existTab(uint8_t pos);
|
|
|
|
|
2022-11-14 20:50:36 +01:00
|
|
|
// print zero or more tabs, similar as e.g. "\t\t\t"
|
2023-01-31 13:39:06 +01:00
|
|
|
// optimized repeat
|
|
|
|
void tab(uint8_t n = 1);
|
|
|
|
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2023-01-31 13:39:06 +01:00
|
|
|
// MISCELLANEOUS
|
|
|
|
uint8_t getPos();
|
|
|
|
void resetLineCount();
|
|
|
|
uint32_t getLineCount();
|
|
|
|
uint8_t getTabCount();
|
|
|
|
uint8_t getTabStop(uint8_t n);
|
|
|
|
void printRuler(uint8_t length);
|
2020-05-17 10:37:41 +02:00
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2020-05-17 10:37:41 +02:00
|
|
|
private:
|
|
|
|
Print * _stream;
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
uint8_t _pos = 0;
|
|
|
|
uint8_t _maxPos = 0;
|
2023-01-31 13:39:06 +01:00
|
|
|
uint32_t _lineCount = 0;
|
|
|
|
uint8_t _anl = 0; // counter
|
|
|
|
uint8_t _autoNewLine = 0; // position for the newline.
|
2020-05-17 10:37:41 +02:00
|
|
|
|
|
|
|
uint8_t _tabStop[MAX_TAB_STOPS];
|
|
|
|
uint8_t _tabCount = 0;
|
|
|
|
};
|
|
|
|
|
2021-11-06 17:49:23 +01:00
|
|
|
|
2023-01-31 13:39:06 +01:00
|
|
|
// -- END OF FILE --
|
2021-11-06 17:49:23 +01:00
|
|
|
|