mirror of
https://github.com/TxtDot/dalet.git
synced 2024-11-21 20:36:23 +03:00
doc: add daletl spec, paragraph, line break, unordered list
This commit is contained in:
parent
090052a6e0
commit
1b5b0c342f
4 changed files with 183 additions and 57 deletions
49
specification/daletl.md
Normal file
49
specification/daletl.md
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
# Daletl specification for Dalet v1.0-preview
|
||||||
|
|
||||||
|
## Data format
|
||||||
|
|
||||||
|
Daletl must be serialized as [MessagePack](https://github.com/msgpack/msgpack/blob/master/spec.md). All data transfer between server and client is done in this format.
|
||||||
|
|
||||||
|
## Data representation
|
||||||
|
|
||||||
|
### Root
|
||||||
|
|
||||||
|
Daletl root is array of tags. For convenience, we will use the json5 representation of the data.
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[]
|
||||||
|
```
|
||||||
|
|
||||||
|
### Tag
|
||||||
|
|
||||||
|
All tags specification is in [Tags](./tags.md).
|
||||||
|
|
||||||
|
Each tag is array of 1-3 elements.
|
||||||
|
|
||||||
|
1. Tag id
|
||||||
|
2. Tag body (optional)
|
||||||
|
3. Tag argument (optional)
|
||||||
|
|
||||||
|
Tag id is integer number.
|
||||||
|
|
||||||
|
Body can be only a string, null, or an array of tags.
|
||||||
|
|
||||||
|
Argument can be number or string.
|
||||||
|
|
||||||
|
#### Heading example
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[1, "This is heading", 1]
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Unordered list example
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[
|
||||||
|
4,
|
||||||
|
[
|
||||||
|
[0, "Item 1"],
|
||||||
|
[0, "Item 2"],
|
||||||
|
],
|
||||||
|
]
|
||||||
|
```
|
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
### Daletl
|
### Daletl
|
||||||
|
|
||||||
**Daletl** is a low-level language for machines. It is used in data transmission, processing and generation. It is specifically optimized to transfer as little data as possible using json, messagepack[^3] or daletpack[^2].
|
**Daletl** is a low-level language for machines. It is used in data transmission, processing and generation. It is specifically optimized to transfer as little data as possible using MessagePack.
|
||||||
|
|
||||||
## Stages
|
## Stages
|
||||||
|
|
||||||
|
@ -24,10 +24,9 @@ At this stage, only daletl is used. This stage is used by programs for generatio
|
||||||
|
|
||||||
## Specification
|
## Specification
|
||||||
|
|
||||||
[Tags](./tags/main.md)
|
[Tags](./tags.md)
|
||||||
|
[Daletl](./daletl.md)
|
||||||
|
|
||||||
## References
|
## References
|
||||||
|
|
||||||
[^1]: In the first versions only. Detranslation is planned for the future for the sake of devtools.
|
[^1]: In the first versions only. Detranslation is planned for the future for the sake of devtools.
|
||||||
[^2]: Daletpack is not created and is not used at the moment. It is planned for the future.
|
|
||||||
[^3]: Daletl can be used through a variety of serialization formats.
|
|
||||||
|
|
131
specification/tags.md
Normal file
131
specification/tags.md
Normal file
|
@ -0,0 +1,131 @@
|
||||||
|
# Tags specification for Dalet v1.0-preview
|
||||||
|
|
||||||
|
## Element
|
||||||
|
|
||||||
|
| Property | Description |
|
||||||
|
| -------- | ----------- |
|
||||||
|
| id | 0 |
|
||||||
|
| name | el |
|
||||||
|
| argument | no |
|
||||||
|
| body | text, tags |
|
||||||
|
|
||||||
|
Most primitive tag. Also used if no tag is specified.
|
||||||
|
|
||||||
|
**Daleth example**:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
el: I am Element
|
||||||
|
el: { h[1]: I am first level heading }
|
||||||
|
Element also used if no tag is specified.
|
||||||
|
```
|
||||||
|
|
||||||
|
**Daletl example (json5 representation)**:
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[0, "Dalet"]
|
||||||
|
```
|
||||||
|
|
||||||
|
## Heading
|
||||||
|
|
||||||
|
| Property | Description |
|
||||||
|
| -------- | ------------------- |
|
||||||
|
| id | 1 |
|
||||||
|
| name | h |
|
||||||
|
| argument | int x; 1 <= x <= 10 |
|
||||||
|
| body | text |
|
||||||
|
|
||||||
|
Heading is used for text formatting.
|
||||||
|
|
||||||
|
**Daleth example**:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
h[1]: Dalet
|
||||||
|
h[2]: Daleth
|
||||||
|
h[3]: High level
|
||||||
|
h[2]: Daletl
|
||||||
|
h[3]: Low level
|
||||||
|
```
|
||||||
|
|
||||||
|
**Daletl example (json5 representation)**:
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[1, "Dalet", 1]
|
||||||
|
```
|
||||||
|
|
||||||
|
## Paragraph
|
||||||
|
|
||||||
|
| Property | Description |
|
||||||
|
| -------- | ----------- |
|
||||||
|
| id | 2 |
|
||||||
|
| name | p |
|
||||||
|
| argument | no |
|
||||||
|
| body | text, tags |
|
||||||
|
|
||||||
|
Paragraph is used for text formatting.
|
||||||
|
|
||||||
|
**Daleth example**:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
p: This is a paragraph
|
||||||
|
```
|
||||||
|
|
||||||
|
**Daletl example (json5 representation)**:
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[2, "This is a paragraph"]
|
||||||
|
```
|
||||||
|
|
||||||
|
## Line break
|
||||||
|
|
||||||
|
| Property | Description |
|
||||||
|
| -------- | ----------- |
|
||||||
|
| id | 3 |
|
||||||
|
| name | br |
|
||||||
|
| argument | no |
|
||||||
|
| body | no |
|
||||||
|
|
||||||
|
Line break is used to insert a line break into the text.
|
||||||
|
|
||||||
|
**Daleth example**:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
br
|
||||||
|
```
|
||||||
|
|
||||||
|
**Daletl example (json5 representation)**:
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[3]
|
||||||
|
```
|
||||||
|
|
||||||
|
## Unordered list
|
||||||
|
|
||||||
|
| Property | Description |
|
||||||
|
| -------- | ----------- |
|
||||||
|
| id | 4 |
|
||||||
|
| name | ul |
|
||||||
|
| argument | no |
|
||||||
|
| body | tags |
|
||||||
|
|
||||||
|
Unordered list is used to create a list. Each list item is a tag.
|
||||||
|
|
||||||
|
**Daleth example**:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
ul: {
|
||||||
|
Item 1
|
||||||
|
Item 2,
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**Daletl example (json5 representation)**:
|
||||||
|
|
||||||
|
```json5
|
||||||
|
[
|
||||||
|
4,
|
||||||
|
[
|
||||||
|
[0, "Item 1"],
|
||||||
|
[0, "Item 2"],
|
||||||
|
],
|
||||||
|
]
|
||||||
|
```
|
|
@ -1,53 +0,0 @@
|
||||||
# Tags specification for Dalet v1.0-preview
|
|
||||||
|
|
||||||
## Element
|
|
||||||
|
|
||||||
| Property | Description |
|
|
||||||
| -------- | ----------- |
|
|
||||||
| id | 0 |
|
|
||||||
| name | element |
|
|
||||||
| argument | no |
|
|
||||||
| body | any |
|
|
||||||
|
|
||||||
Most primitive tag. Also used if no tag is specified.
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
element: Dalet
|
|
||||||
element: { h[1]: Daleth }
|
|
||||||
Daletl
|
|
||||||
```
|
|
||||||
|
|
||||||
Daletl json5 data representation:
|
|
||||||
|
|
||||||
```json5
|
|
||||||
[0, "Dalet"]
|
|
||||||
```
|
|
||||||
|
|
||||||
## Heading
|
|
||||||
|
|
||||||
| Property | Description |
|
|
||||||
| -------- | ------------------- |
|
|
||||||
| id | 1 |
|
|
||||||
| name | h |
|
|
||||||
| argument | int x; 1 <= x <= 10 |
|
|
||||||
| body | text |
|
|
||||||
|
|
||||||
Heading is used for text formatting.
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
h[1]: Dalet
|
|
||||||
h[2]: Daleth
|
|
||||||
h[3]: High level
|
|
||||||
h[2]: Daletl
|
|
||||||
h[3]: Low level
|
|
||||||
```
|
|
||||||
|
|
||||||
Daletl json5 representation:
|
|
||||||
|
|
||||||
```json5
|
|
||||||
[1, "Dalet", 1]
|
|
||||||
```
|
|
Loading…
Add table
Reference in a new issue