Skip to content

Commit

Permalink
deploy: 6c0deac
Browse files Browse the repository at this point in the history
  • Loading branch information
martinjaeger committed Apr 3, 2024
0 parents commit ec88a74
Show file tree
Hide file tree
Showing 71 changed files with 9,171 additions and 0 deletions.
4 changes: 4 additions & 0 deletions .buildinfo
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# Sphinx build info version 1
# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
config: 7db4d84dc23f59e3467d9bb642c8d223
tags: 645f666f9bcd5a90fca523b33c5a78b7
Empty file added .nojekyll
Empty file.
Binary file added _images/cc-by-sa-centered.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
50 changes: 50 additions & 0 deletions _sources/index.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
==========================
ThingSet SDK Documentation
==========================

`ThingSet <https://thingset.io>`_ is a transport-agnostic and self-explanatory remote API for
embedded devices and humans.

The
`ThingSet software development (SDK) for Zephyr <https://github.com/ThingSet/thingset-zephyr-sdk>`_
leverages the Zephyr RTOS APIs to provide ready-to-use implementations for multiple different
interfaces / subsystems (see navigation at the left).

Further interfaces like MQTT and WebSocket over WiFi are currently under development.

The `ThingSet node library <https://github.com/ThingSet/thingset-node-c>`_ is used internally for
data processing.

This documentation is licensed under the Creative Commons Attribution-ShareAlike 4.0 International
(CC BY-SA 4.0) License.

.. image:: static/images/cc-by-sa-centered.png

The full license text is available at `<https://creativecommons.org/licenses/by-sa/4.0/>`_.

.. _Zephyr RTOS: https://zephyrproject.org
.. _ThingSet: https://thingset.io

.. toctree::
:caption: Interfaces
:hidden:

interfaces/serial
interfaces/shell
interfaces/ble
interfaces/can
interfaces/lorawan

.. toctree::
:caption: Subsystems
:hidden:

subsys/sdk
subsys/log_backend
subsys/storage

.. toctree::
:caption: Kconfig
:hidden:

kconfig
14 changes: 14 additions & 0 deletions _sources/interfaces/ble.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Bluetooth LE
############

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_BLE`
* :kconfig:option:`CONFIG_THINGSET_BLE_RX_BUF_SIZE`

API Reference
*************

.. doxygenfile:: include/thingset/ble.h
:project: app
15 changes: 15 additions & 0 deletions _sources/interfaces/can.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
CAN bus
#######

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_CAN`
* :kconfig:option:`CONFIG_THINGSET_CAN_THREAD_STACK_SIZE`
* :kconfig:option:`CONFIG_THINGSET_CAN_THREAD_PRIORITY`

API Reference
*************

.. doxygenfile:: include/thingset/can.h
:project: app
13 changes: 13 additions & 0 deletions _sources/interfaces/lorawan.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
LoRaWAN
#######

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_LORAWAN`

API Reference
*************

The LoRaWAN interface does not have any API functions. It runs in the background once enabled via
Kconfig.
16 changes: 16 additions & 0 deletions _sources/interfaces/serial.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
Serial
######

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_SERIAL`
* :kconfig:option:`CONFIG_THINGSET_SERIAL_RX_BUF_SIZE`
* :kconfig:option:`CONFIG_THINGSET_SERIAL_USE_CRC`
* :kconfig:option:`CONFIG_THINGSET_SERIAL_ENFORCE_CRC`

API Reference
*************

.. doxygenfile:: include/thingset/serial.h
:project: app
14 changes: 14 additions & 0 deletions _sources/interfaces/shell.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Shell
#####

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_SHELL`
* :kconfig:option:`CONFIG_THINGSET_SHELL_CMD_BUF_SIZE`

API Reference
*************

The Shell backend does not have any API functions. It runs in the background once enabled via
Kconfig.
8 changes: 8 additions & 0 deletions _sources/kconfig.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
:orphan:

.. _kconfig-search:

Kconfig Search
##############

.. kconfig:search::
14 changes: 14 additions & 0 deletions _sources/subsys/log_backend.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Log Backend
###########

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_LOG_BACKEND`
* :kconfig:option:`CONFIG_THINGSET_LOG_BACKEND_BUF_SIZE`

API Reference
*************

The log backend does not have any API functions. It runs in the background once enabled via
Kconfig.
31 changes: 31 additions & 0 deletions _sources/subsys/sdk.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
SDK
===

Configuration Options
*********************

The ThingSet SDK itself has to be enabled for all subsystems and interfaces:

* :kconfig:option:`CONFIG_THINGSET_SDK`

Below options define the general publication settings:

* :kconfig:option:`CONFIG_THINGSET_SUBSET_LIVE_METRICS`
* :kconfig:option:`CONFIG_THINGSET_REPORTING_LIVE_ENABLE_PRESET`
* :kconfig:option:`CONFIG_THINGSET_REPORTING_LIVE_PERIOD_PRESET`
* :kconfig:option:`CONFIG_THINGSET_SUBSET_SUMMARY_METRICS`
* :kconfig:option:`CONFIG_THINGSET_REPORTING_SUMMARY_ENABLE_PRESET`
* :kconfig:option:`CONFIG_THINGSET_REPORTING_SUMMARY_PERIOD_PRESET`

Common options for the SDK:

* :kconfig:option:`CONFIG_THINGSET_GENERATE_NODE_ID`
* :kconfig:option:`CONFIG_THINGSET_SHARED_TX_BUF_SIZE`
* :kconfig:option:`CONFIG_THINGSET_SDK_THREAD_STACK_SIZE`
* :kconfig:option:`CONFIG_THINGSET_SDK_THREAD_PRIORITY`

API Reference
*************

.. doxygenfile:: include/thingset/sdk.h
:project: app
19 changes: 19 additions & 0 deletions _sources/subsys/storage.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
Storage
#######

Configuration Options
*********************

* :kconfig:option:`CONFIG_THINGSET_STORAGE`
* :kconfig:option:`CONFIG_THINGSET_STORAGE_EEPROM`
* :kconfig:option:`CONFIG_THINGSET_STORAGE_FLASH`
* :kconfig:option:`CONFIG_THINGSET_STORAGE_CHANGE`
* :kconfig:option:`CONFIG_THINGSET_STORAGE_REGULAR`
* :kconfig:option:`CONFIG_THINGSET_STORAGE_INTERVAL`
* :kconfig:option:`CONFIG_THINGSET_STORAGE_DATA_VERSION`

API Reference
*************

.. doxygenfile:: include/thingset/storage.h
:project: app
123 changes: 123 additions & 0 deletions _static/_sphinx_javascript_frameworks_compat.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
/* Compatability shim for jQuery and underscores.js.
*
* Copyright Sphinx contributors
* Released under the two clause BSD licence
*/

/**
* small helper function to urldecode strings
*
* See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL
*/
jQuery.urldecode = function(x) {
if (!x) {
return x
}
return decodeURIComponent(x.replace(/\+/g, ' '));
};

/**
* small helper function to urlencode strings
*/
jQuery.urlencode = encodeURIComponent;

/**
* This function returns the parsed url parameters of the
* current request. Multiple values per key are supported,
* it will always return arrays of strings for the value parts.
*/
jQuery.getQueryParameters = function(s) {
if (typeof s === 'undefined')
s = document.location.search;
var parts = s.substr(s.indexOf('?') + 1).split('&');
var result = {};
for (var i = 0; i < parts.length; i++) {
var tmp = parts[i].split('=', 2);
var key = jQuery.urldecode(tmp[0]);
var value = jQuery.urldecode(tmp[1]);
if (key in result)
result[key].push(value);
else
result[key] = [value];
}
return result;
};

/**
* highlight a given string on a jquery object by wrapping it in
* span elements with the given class name.
*/
jQuery.fn.highlightText = function(text, className) {
function highlight(node, addItems) {
if (node.nodeType === 3) {
var val = node.nodeValue;
var pos = val.toLowerCase().indexOf(text);
if (pos >= 0 &&
!jQuery(node.parentNode).hasClass(className) &&
!jQuery(node.parentNode).hasClass("nohighlight")) {
var span;
var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg");
if (isInSVG) {
span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
} else {
span = document.createElement("span");
span.className = className;
}
span.appendChild(document.createTextNode(val.substr(pos, text.length)));
node.parentNode.insertBefore(span, node.parentNode.insertBefore(
document.createTextNode(val.substr(pos + text.length)),
node.nextSibling));
node.nodeValue = val.substr(0, pos);
if (isInSVG) {
var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
var bbox = node.parentElement.getBBox();
rect.x.baseVal.value = bbox.x;
rect.y.baseVal.value = bbox.y;
rect.width.baseVal.value = bbox.width;
rect.height.baseVal.value = bbox.height;
rect.setAttribute('class', className);
addItems.push({
"parent": node.parentNode,
"target": rect});
}
}
}
else if (!jQuery(node).is("button, select, textarea")) {
jQuery.each(node.childNodes, function() {
highlight(this, addItems);
});
}
}
var addItems = [];
var result = this.each(function() {
highlight(this, addItems);
});
for (var i = 0; i < addItems.length; ++i) {
jQuery(addItems[i].parent).before(addItems[i].target);
}
return result;
};

/*
* backward compatibility for jQuery.browser
* This will be supported until firefox bug is fixed.
*/
if (!jQuery.browser) {
jQuery.uaMatch = function(ua) {
ua = ua.toLowerCase();

var match = /(chrome)[ \/]([\w.]+)/.exec(ua) ||
/(webkit)[ \/]([\w.]+)/.exec(ua) ||
/(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) ||
/(msie) ([\w.]+)/.exec(ua) ||
ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec(ua) ||
[];

return {
browser: match[ 1 ] || "",
version: match[ 2 ] || "0"
};
};
jQuery.browser = {};
jQuery.browser[jQuery.uaMatch(navigator.userAgent).browser] = true;
}
Loading

0 comments on commit ec88a74

Please sign in to comment.