<p>The general idea was to:</p>
<ul>
<li>Make it less dynamic</li>
<li>Make it so that it can map easily to file-like structure.</li>
</ul>
<p>The concrete changes are:</p>
<ul>
<li>There is a (static) array listing configuration variables along with their type.</li>
<li>This makes a "listing" (export) method unnecessary. It can still exist, but it is not per-setting but rather a generic helper.</li>
<li>The "set" method takes an already parsed value (via a union) instead of a string.
<ul>
<li>The parsing code is generic.</li>
</ul>
</li>
<li>It should be possible to create the config structures at compile time, in read-only memory.</li>
<li>Read-only data can also be presented via this interface.</li>
<li>The config system will look like a tree (but needs not be implemented as such)</li>
</ul>
<p>Also:</p>
<ul>
<li>It will be possible (by writing the appropriate glue code) to access config values via standard fopen(), read(). fwrite(). Think of <code>/sys/</code> and <code>/proc/</code>. The important thing here is that if done properly, there is minimal overhead.</li>
<li>This is related to sensors/saul: it will be convenient to expose sensor meta-data and adjust their setting via the config interface.</li>
</ul>
<p><a class="user-mention" data-hovercard-type="user" data-hovercard-url="/hovercards?user_id=5381296" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="https://github.com/leandrolanzieri">@leandrolanzieri</a>,</p>
<p>I just had another idea: what if we remove <code>commit()</code> method, instead having a "group/commit" config variable that causes a commit for "group" whenever <em>any</em> value is written to it. The main reason for doing this is that now the whole system fits under  fopen()/read()/fwrite().</p>

<p style="font-size:small;-webkit-text-size-adjust:none;color:#666;">—<br />You are receiving this because you are subscribed to this thread.<br />Reply to this email directly, <a href="https://github.com/RIOT-OS/RIOT/pull/10622?email_source=notifications&email_token=ABE7WYBYUHOUXQBJTI2QME3PZJMOVA5CNFSM4GK3DEE2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXFYLRY#issuecomment-499877319">view it on GitHub</a>, or <a href="https://github.com/notifications/unsubscribe-auth/ABE7WYE346KDBZYZL422IETPZJMOVANCNFSM4GK3DEEQ">mute the thread</a>.<img src="https://github.com/notifications/beacon/ABE7WYFOC3UZENMUNVKHAIDPZJMOVA5CNFSM4GK3DEE2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXFYLRY.gif" height="1" width="1" alt="" /></p>
<script type="application/ld+json">[
{
"@context": "http://schema.org",
"@type": "EmailMessage",
"potentialAction": {
"@type": "ViewAction",
"target": "https://github.com/RIOT-OS/RIOT/pull/10622?email_source=notifications\u0026email_token=ABE7WYBYUHOUXQBJTI2QME3PZJMOVA5CNFSM4GK3DEE2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXFYLRY#issuecomment-499877319",
"url": "https://github.com/RIOT-OS/RIOT/pull/10622?email_source=notifications\u0026email_token=ABE7WYBYUHOUXQBJTI2QME3PZJMOVA5CNFSM4GK3DEE2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXFYLRY#issuecomment-499877319",
"name": "View Pull Request"
},
"description": "View this Pull Request on GitHub",
"publisher": {
"@type": "Organization",
"name": "GitHub",
"url": "https://github.com"
}
}
]</script>