site/contents/learn-data-types.md
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 |
-----
content-type: "page"
title: "Learn: Data Types"
-----
{@ _defs_.md || 0 @}
The following data types are availanle in {{m}} (with the corresponding shorthand symbols used in operator signatures in brackets):
null (null)
: null value.
boolean (bool)
: **true** or **false**.
integer (int)
: A 64-bit integer number like 1, 27, or -15.
float (flt)
: A 64-bit floating-point number like 3.14 or -56.9876.
string (str)
: A series of characters wrapped in double quotes: "Hello, World!".
quotation (quot)
: A list of elements, which may also contain symbols. Quotations can be used to create heterogenous lists of elements of any data type, and also to create a block of code that will be evaluated later on (quoted program). Example: (1 2 3 + \*)
command (cmd)
: A command string wrapped in square brackets that will be immediately executed on the current shell and converted into the command standard output. Example: `[ls -a]`
dictionary (dict)
: A key/value table. Dictionaries are implemented as an immediately-dequoted quotation, are enclosed in curly braces, and are represented by their symbol definitions. Note that dictionary keys must start with `:`and be followed by a double-quoted string, or a single word (which can be written without double quotes). The {#link-module||dict#} provides some operators on dictionaries.
> %sidebar%
> Example
>
> The following is a simple dictionary containing three keys: *name*, *paradigm*, and *first-release-year*:
>
> {
> "min" :name
> "concatenative" :paradigm
> 2017 :"first release year"
> }
Additionally, dictionaries can also be typed to denote complex objects like sockets, errors, etc. For example, the following dictionary defines an error:
{
"MyError" :error
"An error occurred" :message
"symbol1" :symbol
"dir1/file1.min" :filename
3 :line
13 :column
;error
}
> %tip%
> Tip
>
> The {#link-operator||dict||dtype#} operator can be used to set the type of a dictionary.
The {#link-module||global#} provides predicate operators to check if an element belongs to a particular data type or pseudo-type (`boolean?`, `number?`, `integer?`, `float?`, ...).
Additionally, the {#link-module||global#} provides operators to convert values from a data type to another (e.g. {#link-global-operator||integer#}, {#link-global-operator||string#}, and so on).
> %note%
> Note
>
> Most of the operators defined in the {#link-module||num#} are able to operate on both integers and floats.
{#link-learn||operators||Operators#}
|