DTR is live and running!! think can say in a solid way this is a 1.X working version of it.
have all my data files in it now. this is how much i trust this rules.
How cool is just 4 rules to work width files?
My hopes is that this rules will allow the development of IDEs and managers of data in a much more easy.
Ill go throw the problems I encounter and how i solve them.
Lets assume a macros.txt file :
File settings
keys : language , frame , name, macro, description ;
mode : parent inherit ;
mode : repair keys - name, macro ;
First Example and problem
Our data should map to the keys correct? But having full fields created a problem, of excess data and typing needed.
python language , tkinter frame, label name, variable = (Label(root, text="info", width=20, font=("bold",15))) macro, needs parent element in here named root description;
,, open tab,
import webbrowser
webbrowser.open_new_tab(url) ;
The 2º field maps to 1º throw inheriting of parents if a field is empty and parent mode is enable it gets its values from the parent. Pretty good to work width algorithems in data? Which means we have X representations of data not real data. Makes the fields very small. Only first field on which section need to be fully complete.
Secound Example and problem
,, open tab,
import webbrowser
webbrowser.open_new_tab(url) ;
sdfsd -> ignored line , comments or erros
,, open tab,
import webbrowser
webbrowser.open_new_tab(url) ;
secound problem was the use of empty space which was way better then xml and jason heavy structured rules. This allow 2 uses : of manual editing files and auto entry width software . How this was achieved? width the simple ";" all lines have this character. this allow errors and broken data in lines. Much more loose then any thing we have today at least for public use.
Third Example and problem
and how about text we kind need to write things down not all data is linear.
,, open tab,
(tabs are cool, but not always);
This is achieved width parenthesis ( ) we can write blocks of text inside our rules. Allowing to use more , , , width out breaking the keys connection. this ensures that the text keys goes in to the proper field.
Fourth Example and problem
and how about we don't need "," character in the lines? we want empty fields. The conjugation of rules allows this. We set in the repair mode on, this will map empty fiels to a fields refered "mode : repair - name, macro ;" map the data in the fields to this format so we no longer need "," extra characters. If empty fields found map only to name and macro keys and then parent the rest of the data.
foreach loop, for index_key in array_name : ; -> only name and macro
the rest of the keys is re constructed width repair
the rest of the field is re constructed width parents
from this to :
python, thinker , foreach loop, for index_key in array_name : , description ;
The end Result
is something this simple, very modular.
Cursor , cursor="hand1" ;
button style ,
( relief='flat',
font=('Arial',10, "bold") ) ; -> modular lines
I mention 4 rules , and they are : ";" , parent inherit, repair mode, and ().
(when i was writting the article notice a error : and if we need empty space under parenthing inherit? kind need a character that represents it maybe "#" )
if you want to save a lot of characters you can do very strick rulling
macro 1, macro 2 , macro 3, ...
but this creates all the problems we saw before, no manual editing of files at least in a easy way. and so on... a lot of online and book examples do strick rulling of data or oposite heavy structure like in xml. this creates a easy and balanced way to do it.
Check the pic to see how simple and easy is to work width. At the pic was not using repair mode needed the extra ",, ".