165 lines
5.7 KiB
Markdown
Raw Normal View History

2021-01-29 12:31:58 +01:00
[![Arduino CI](https://github.com/RobTillaart/XMLWriter/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
2021-12-29 16:27:03 +01:00
[![Arduino-lint](https://github.com/RobTillaart/XMLWriter/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/XMLWriter/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/XMLWriter/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/XMLWriter/actions/workflows/jsoncheck.yml)
2021-01-29 12:31:58 +01:00
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/XMLWriter/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/XMLWriter.svg?maxAge=3600)](https://github.com/RobTillaart/XMLWriter/releases)
2020-05-25 09:58:04 +02:00
# XMLWriter
2021-12-29 16:27:03 +01:00
Arduino Library to create simple XML (messages, files, print, ...).
2020-05-25 09:58:04 +02:00
2021-11-11 20:36:58 +01:00
2020-05-25 09:58:04 +02:00
## Description
The XMLWriter class supports generating XML files and send these over a stream
like Ethernet SD.File or Serial.
When instantiating an XMLWriter one can define the internal buffer size.
2020-11-27 11:33:55 +01:00
A bigger buffer will make the output faster, especially for Ethernet and SD.File.
The buffer size should be at least 2 bytes and max 250.
2021-01-29 12:31:58 +01:00
How much faster depends on the properties of the stream and the platform used.
2021-12-29 16:27:03 +01:00
E.g. the baud rate and internal buffer of Serial, packet behaviour of Ethernet,
2020-05-25 09:58:04 +02:00
or paging of SD cards.
2021-12-29 16:27:03 +01:00
If performance is low one should do test runs with different sizes for the buffer
2020-11-27 11:33:55 +01:00
and choose one that is appropriate.
2020-05-25 09:58:04 +02:00
Indicative sizes based upon the examples.
Run your tests to find your application optimum.
2022-11-27 12:54:57 +01:00
| STREAM | SIZE |
|:-----------|:-----------|
| Ethernet | 20-30 |
| Serial | 5 |
| SD File | 10-16 |
2020-05-25 09:58:04 +02:00
2021-01-29 12:31:58 +01:00
**IMPORTANT:** When using buffering you should always call **XML.flush()**
at the end of the XML generation. This will flush the last bytes in the internal buffer into the output stream.
2020-11-27 11:33:55 +01:00
## Interface
2021-11-11 20:36:58 +01:00
2021-01-29 12:31:58 +01:00
### Constructor
2021-11-11 20:36:58 +01:00
- **XMLWriter(Print\* stream = &Serial, uint8_t bufferSize = 10)** Constructor defines the stream and the buffer size
2020-11-27 11:33:55 +01:00
to optimize performance vs memory usage.
2021-11-11 20:36:58 +01:00
Note the default bufferSize of 10 can be optimized.
See table in description above.
2020-11-27 11:33:55 +01:00
2021-01-29 12:31:58 +01:00
### Functions for manual layout control
2021-11-11 20:36:58 +01:00
- **void setIndentSize(uint8_t size = 2)** preferred a multiple of 2; no limit.
- **uint8_t getIndentSize()** returns set indent.
- **void incrIndent()** increments indent by 2 spaces.
- **void decrIndent()** decrements indent by 2 spaces.
- **void indent()** manually indent output.
- **void raw(char\* str)** inject any string.
2020-11-27 11:33:55 +01:00
2021-01-29 12:31:58 +01:00
### General settings
2021-11-11 20:36:58 +01:00
- **void setConfig(uint8_t config)** used to show/strip comment, indent, newLine.
use **setConfig(0);** to minimize the output.
- **void newLine(uint8_t n)** add a number of newlines to the output, default = 1.
2020-11-27 11:33:55 +01:00
2021-01-29 12:31:58 +01:00
### Functions
2021-11-11 20:36:58 +01:00
- **void header()** injects standard XML header string, must be first line.
- **void reset()** resets internal state, to be called before new XML is written.
- **void comment(char\* text, bool multiLine = false)** \<!-- text --\>
2020-11-27 11:33:55 +01:00
if multiline == true it does not indent to allow bigger text blocks
2021-01-29 12:31:58 +01:00
multiline is default false.
2021-11-11 20:36:58 +01:00
- **void flush()** call flush() at the end of writing to empty the internal buffer. **!!**
2020-11-27 11:33:55 +01:00
2021-01-29 12:31:58 +01:00
### Functions to create simple tags with named fields
2021-11-11 20:36:58 +01:00
- **void tagOpen(char\* tag, bool newLine)** \<tag\>
- **void tagOpen(char\* tag, char\* name, bool newLine)** \<tag name="name"\>
- **void tagClose()** \</tag\>
2021-01-29 12:31:58 +01:00
### Functions to make up tags with multiple fields
2020-11-27 11:33:55 +01:00
2021-11-11 20:36:58 +01:00
- **void tagStart(char\* tag)** \<tag
- **void tagField(char\* field, char\* string)** field="string"
- **void tagField(char\* field, T value, uint8_t base = DEC)** standard math types, field="value"
- **void tagEnd(bool newline = true, bool addSlash = true);** /\>
2020-11-27 11:33:55 +01:00
2023-01-16 16:07:12 +01:00
2021-01-29 12:31:58 +01:00
### Functions to make a node
2021-11-11 20:36:58 +01:00
- **void writeNode(char\* tag, bool value);** \<tag\>value\</tag\>
- **void writeNode(char\* tag, T value, uint8_t base = DEC);** standard math types.
2020-11-27 11:33:55 +01:00
2023-01-16 16:07:12 +01:00
2021-01-29 12:31:58 +01:00
### Helper
2021-11-11 20:36:58 +01:00
- **void escape(char\* str)** expands the XML chars: \"\'\<\>\&
Note one need to set the **XMLWRITER_ESCAPE_SUPPORT** flag.
2020-11-27 11:33:55 +01:00
2021-01-29 12:31:58 +01:00
### Metrics and debug
2021-11-11 20:36:58 +01:00
To optimize buffer size in combination with timing.
2021-01-29 12:31:58 +01:00
2021-11-11 20:36:58 +01:00
- **uint8_t bufferIndex()** returns the size of the internal buffer.
- **uint32_t bytesWritten()** idem, since reset().
- **void version()** injects the **XMLWRITER_VERSION** as comment in output stream.
- **void debug()** injects comment with internal info.
2021-01-29 12:31:58 +01:00
2020-11-27 11:33:55 +01:00
## Print interface
XMLWriter 0.2.4 implements the Print interface, so at any moment one can use
**print()** or **println()** to inject specific information.
2021-01-29 12:31:58 +01:00
Note that **tagField()** and **writeNode()** do not support 64 bit integer
2020-11-27 11:33:55 +01:00
types and large values of double.
My **printHelpers library** helps to convert these to strings which can be printed.
See example.
The Print interface can also be used to print objects that
implement the **Printable** interface. See example.
With the support of the Print interface, **raw()** is becoming obsolete as it only
can inject strings.
2021-01-29 12:31:58 +01:00
2020-11-27 11:33:55 +01:00
## Configuration flags
2023-01-16 16:07:12 +01:00
| Flag | Value | Description |
2022-11-27 12:54:57 +01:00
|:--------------------|:--------|:--------------------|
| XMLWRITER_NONE | 0x00 | minimize output, smaller & faster |
| XMLWRITER_COMMENT | 0x01 | allow comments |
| XMLWRITER_INDENT | 0x02 | allow indentation |
| XMLWRITER_NEWLINE | 0x04 | allow newlines |
2021-12-29 16:27:03 +01:00
2020-11-27 11:33:55 +01:00
- **setConfig(XMLWRITER_NONE);** to minimize the output in bytes.
- **setConfig(XMLWRITER_NEWLINE);** to break an XML stream in lines.
- **setConfig(XMLWRITER_NEWLINE | XMLWRITER_INDENT);** to see XML structure.
- **setConfig(XMLWRITER_NEWLINE | XMLWRITER_INDENT | XMLWRITER_COMMENT);** to see XML structure + comments.
2020-05-25 09:58:04 +02:00
2021-01-29 12:31:58 +01:00
2020-05-25 09:58:04 +02:00
## Operation
See examples
2021-11-11 20:36:58 +01:00
## Future
2022-11-27 12:54:57 +01:00
#### must
2021-11-11 20:36:58 +01:00
- update documentation
2022-11-27 12:54:57 +01:00
#### should
#### could
- move code to .cpp
2021-12-29 16:27:03 +01:00