* [PATCH olang v1 0/2] docs: variables specification
@ 2024-03-27 3:21 Carlos Maniero
2024-03-27 3:21 ` [PATCH olang v1 1/2] docs: spec: rename program to translation-unit Carlos Maniero
2024-03-27 3:21 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Carlos Maniero
0 siblings, 2 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-03-27 3:21 UTC (permalink / raw)
To: ~johnnyrichard/olang-devel; +Cc: Carlos Maniero
This patchset specifies variables and constants. I would love to add
more information about how the labels could be generated for global
variables, but it depends on an agreement on the "[RFC] Namespaces in
OLANG".
Carlos Maniero (2):
docs: spec: rename program to translation-unit
docs: spec: add variables and constants specification
docs/pages/language-specification.md | 18 ++++++++++++++----
1 file changed, 14 insertions(+), 4 deletions(-)
--
2.34.1
^ permalink raw reply [flat|nested] 47+ messages in thread
* [PATCH olang v1 1/2] docs: spec: rename program to translation-unit
2024-03-27 3:21 [PATCH olang v1 0/2] docs: variables specification Carlos Maniero
@ 2024-03-27 3:21 ` Carlos Maniero
2024-03-27 21:20 ` Johnny Richard
2024-03-27 3:21 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Carlos Maniero
1 sibling, 1 reply; 47+ messages in thread
From: Carlos Maniero @ 2024-03-27 3:21 UTC (permalink / raw)
To: ~johnnyrichard/olang-devel; +Cc: Carlos Maniero
We started to rename the program node in AST to translation-unit. This
commit also makes a few refactors on spec such as:
- Makes EOF a end-of-statement
- create global-statements section to accommodate upcoming global
definitions.
Signed-off-by: Carlos Maniero <carlos@maniero.me>
---
docs/pages/language-specification.md | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
index 5769d95..4541ba8 100644
--- a/docs/pages/language-specification.md
+++ b/docs/pages/language-specification.md
@@ -22,7 +22,9 @@ language.
```
(* Entry Point *)
-<program> ::= <ows> <function-definition> <ows> <end-of-file>
+<translation-unit> ::= <ows> (<global-statements> <end-of-statement>)*
+
+<global-statements> ::= <function-definition>
(* Functions *)
<function-definition> ::= 'fn' <ws> <function-name> <ows>
@@ -35,7 +37,7 @@ language.
(* Statements *)
<block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
<ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
-<end-of-statement> ::= ';' | <line-break>
+<end-of-statement> ::= ';' | <line-break> | <end-of-file>
<statement> ::= <return-statement>
<return-statement> ::= 'return' <ws> <expression>
--
2.34.1
^ permalink raw reply [flat|nested] 47+ messages in thread
* [PATCH olang v1 2/2] docs: spec: add variables and constants specification
2024-03-27 3:21 [PATCH olang v1 0/2] docs: variables specification Carlos Maniero
2024-03-27 3:21 ` [PATCH olang v1 1/2] docs: spec: rename program to translation-unit Carlos Maniero
@ 2024-03-27 3:21 ` Carlos Maniero
2024-03-27 3:22 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-27 21:37 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Johnny Richard
1 sibling, 2 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-03-27 3:21 UTC (permalink / raw)
To: ~johnnyrichard/olang-devel; +Cc: Carlos Maniero
This commit introduces the specification for variables and constants. A
valid program under this specification is as follows:
var x: u32 = 1
const y: u32 = 2
x = 2
fn main(): u32 {
var x: u32 = 1; const y: u32 = 2
return x
}
Variables and Linkage:
----------------------
Variables can be defined globally or within a function. Variables
defined globally are added to the *.data* section. On the other hand,
variables defined within a function utilize the stack. Currently, the
specification does not provide a keyword for external linkage yet, hence
variables cannot be accessed outside their translation unit.
Constants and Linkage:
----------------------
Constants behave similarly to variables. Constants defined at the file
level are added to the *.rodata* section. Constants within functions are
subject to semantic checks. Attempting to bypass these checks to
reassign a global constant will result in a segmentation fault
(SEGFAULT) and will be accepted at the function level.
Example of bypassing semantic checks in C:
int a = 1;
const int b = 2;
int *c = &a + 1;
*c = 3;
assert(b == 3); // its true
Static variables in function level
----------------------------------
In C, static variables can be defined within the scope of a function.
These variables are added to the `*.data*` segment and are only
accessible within the function where they are defined. This is a unique
behavior of C that some might find unusual.
However, olang does not support this feature. In olang, if you need a
variable that retains its value across function calls (like a static
variable in C), you must define it at the file level.
Signed-off-by: Carlos Maniero <carlos@maniero.me>
---
docs/pages/language-specification.md | 14 +++++++++++---
1 file changed, 11 insertions(+), 3 deletions(-)
diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
index 4541ba8..708b679 100644
--- a/docs/pages/language-specification.md
+++ b/docs/pages/language-specification.md
@@ -24,7 +24,15 @@ language.
(* Entry Point *)
<translation-unit> ::= <ows> (<global-statements> <end-of-statement>)*
-<global-statements> ::= <function-definition>
+<global-statements> ::= <function-definition> | <variable-definition> | <variable-reassign> | <const-definition>
+
+(* Variables *)
+<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>?
+<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>
+
+<variable-name> ::= <identifier>
+<variable-assign> ::= '=' <ows> <expression>
+<variable-reassign> ::= <variable-name> <ows> <variable-assign> <end-of-statement>
(* Functions *)
<function-definition> ::= 'fn' <ws> <function-name> <ows>
@@ -38,11 +46,11 @@ language.
<block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
<ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
<end-of-statement> ::= ';' | <line-break> | <end-of-file>
-<statement> ::= <return-statement>
+<statement> ::= <return-statement> | <variable-definition> | <variable-reassign> | <const-definition>
<return-statement> ::= 'return' <ws> <expression>
(* Expressions *)
-<expression> ::= <integer>
+<expression> ::= <integer> | <identifier>
(* Identifiers *)
<type> ::= 'u32'
--
2.34.1
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-27 3:21 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Carlos Maniero
@ 2024-03-27 3:22 ` builds.sr.ht
2024-03-27 21:37 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Johnny Richard
1 sibling, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-03-27 3:22 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 35s
[docs: variables specification][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/50474
[1]: mailto:carlos@maniero.me
✗ #1179573 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1179573
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 1/2] docs: spec: rename program to translation-unit
2024-03-27 3:21 ` [PATCH olang v1 1/2] docs: spec: rename program to translation-unit Carlos Maniero
@ 2024-03-27 21:20 ` Johnny Richard
2024-03-28 13:50 ` Carlos Maniero
0 siblings, 1 reply; 47+ messages in thread
From: Johnny Richard @ 2024-03-27 21:20 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
On Wed, Mar 27, 2024 at 12:21:27AM -0300, Carlos Maniero wrote:
> We started to rename the program node in AST to translation-unit. This
Nitpick: Perhaps we can highlight the problem and solution better?
Today, the AST node "program" serves as the main entry point for the
grammar, potentially leading to confusion as the program ultimately
becomes the final ELF binary after linking all .o files. Therefore, we
have collectively decided to replace it with "translation-unit," which
more accurately conveys the concept of a singular unit being translated
into a single binary. This adjustment enables us to assert that a
translation-unit corresponds directly to the .ol source file on a
one-to-one basis.
> commit also makes a few refactors on spec such as:
>
> - Makes EOF a end-of-statement
This patch does the opposite. Make a end-of-statement a EOF as well,
which I not agree. See following comments...
> - create global-statements section to accommodate upcoming global
> definitions.
>
> Signed-off-by: Carlos Maniero <carlos@maniero.me>
> ---
> docs/pages/language-specification.md | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
> index 5769d95..4541ba8 100644
> --- a/docs/pages/language-specification.md
> +++ b/docs/pages/language-specification.md
> @@ -22,7 +22,9 @@ language.
>
> ```
> (* Entry Point *)
> -<program> ::= <ows> <function-definition> <ows> <end-of-file>
> +<translation-unit> ::= <ows> (<global-statements> <end-of-statement>)*
This change expect that every followed new statement has no optional
white space. According to your change the following expression is invalid:
|fn add(): u32 {
| return 0;
|}
|
^~~ this is a line-break (syntax error according to your grammar)
| fn main(): u32 {
^~~ this is a linear-space (syntax error according to your grammar)
| return 0;
|}
suggestion: This change fixes the problem.
<translation-unit> ::= (<ows> <global-statements> <ows> (<end-of-statement> | <end-of-file>))*
> +
> +<global-statements> ::= <function-definition>
This doesn't need to be plural if it has a single "statement".
>
> (* Functions *)
> <function-definition> ::= 'fn' <ws> <function-name> <ows>
> @@ -35,7 +37,7 @@ language.
> (* Statements *)
> <block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> -<end-of-statement> ::= ';' | <line-break>
> +<end-of-statement> ::= ';' | <line-break> | <end-of-file>
Hmmm... this is not true, this means the every end-of-statement can be a
end-of-file.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 2/2] docs: spec: add variables and constants specification
2024-03-27 3:21 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Carlos Maniero
2024-03-27 3:22 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-03-27 21:37 ` Johnny Richard
2024-03-28 14:11 ` Carlos Maniero
` (2 more replies)
1 sibling, 3 replies; 47+ messages in thread
From: Johnny Richard @ 2024-03-27 21:37 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
On Wed, Mar 27, 2024 at 12:21:28AM -0300, Carlos Maniero wrote:
> This commit introduces the specification for variables and constants. A
> valid program under this specification is as follows:
>
> var x: u32 = 1
Since this patch adds support to assignments, lets also add support to
all assignment operators like "-=" "+=" "<<=" and so on.
> const y: u32 = 2
This patch lacks support to the following valid assignment expression
(which I think adds flexibility to the language):
var x: u32 = a = b = c = 1
var y: u32
y = a = b = c = 1
> x = 2
>
> fn main(): u32 {
> var x: u32 = 1; const y: u32 = 2
> return x
> }
>
> Variables and Linkage:
> ----------------------
>
> Variables can be defined globally or within a function. Variables
> defined globally are added to the *.data* section. On the other hand,
> variables defined within a function utilize the stack. Currently, the
> specification does not provide a keyword for external linkage yet, hence
> variables cannot be accessed outside their translation unit.
>
> Constants and Linkage:
> ----------------------
>
> Constants behave similarly to variables. Constants defined at the file
> level are added to the *.rodata* section. Constants within functions are
> subject to semantic checks. Attempting to bypass these checks to
> reassign a global constant will result in a segmentation fault
> (SEGFAULT) and will be accepted at the function level.
>
> Example of bypassing semantic checks in C:
>
> int a = 1;
> const int b = 2;
> int *c = &a + 1;
> *c = 3;
> assert(b == 3); // its true
>
> Static variables in function level
> ----------------------------------
>
> In C, static variables can be defined within the scope of a function.
> These variables are added to the `*.data*` segment and are only
> accessible within the function where they are defined. This is a unique
> behavior of C that some might find unusual.
>
> However, olang does not support this feature. In olang, if you need a
> variable that retains its value across function calls (like a static
> variable in C), you must define it at the file level.
>
> Signed-off-by: Carlos Maniero <carlos@maniero.me>
> ---
> docs/pages/language-specification.md | 14 +++++++++++---
> 1 file changed, 11 insertions(+), 3 deletions(-)
>
> diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
> index 4541ba8..708b679 100644
> --- a/docs/pages/language-specification.md
> +++ b/docs/pages/language-specification.md
> @@ -24,7 +24,15 @@ language.
> (* Entry Point *)
> <translation-unit> ::= <ows> (<global-statements> <end-of-statement>)*
>
> -<global-statements> ::= <function-definition>
> +<global-statements> ::= <function-definition> | <variable-definition> | <variable-reassign> | <const-definition>
nitpick: maybe _external-declaration_ sounds better since definitions are
not statements?
> +
> +(* Variables *)
> +<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>?
> +<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>
We don't need to define twice the variable-definition for "var" and
"const", let's combine both in a single rule.
> +<variable-name> ::= <identifier>
> +<variable-assign> ::= '=' <ows> <expression>
> +<variable-reassign> ::= <variable-name> <ows> <variable-assign> <end-of-statement>
>
> (* Functions *)
> <function-definition> ::= 'fn' <ws> <function-name> <ows>
> @@ -38,11 +46,11 @@ language.
> <block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> <end-of-statement> ::= ';' | <line-break> | <end-of-file>
> -<statement> ::= <return-statement>
> +<statement> ::= <return-statement> | <variable-definition> | <variable-reassign> | <const-definition>
> <return-statement> ::= 'return' <ws> <expression>
>
> (* Expressions *)
> -<expression> ::= <integer>
> +<expression> ::= <integer> | <identifier>
>
> (* Identifiers *)
> <type> ::= 'u32'
> --
> 2.34.1
>
I have done few adjustments according to my feedback (I also fix the
unnecessary line breaks on function and block). Let me know what you
think about it.
---->8----
Subject: [PATCH olang] fixup! docs: spec: add variables and constants specification
diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
index 708b679..2650dd9 100644
--- a/docs/pages/language-specification.md
+++ b/docs/pages/language-specification.md
@@ -22,35 +22,45 @@ language.
```
(* Entry Point *)
-<translation-unit> ::= <ows> (<global-statements> <end-of-statement>)*
+<translation-unit> ::= (<ows> <external-declaration> <ows> (<end-of-statement> | <end-of-file>))*
-<global-statements> ::= <function-definition> | <variable-definition> | <variable-reassign> | <const-definition>
+<external-declaration> ::= <function-definition>
+ | <variable-definition>
+ | <assign-expression>
(* Variables *)
-<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>?
-<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>
-
-<variable-name> ::= <identifier>
-<variable-assign> ::= '=' <ows> <expression>
-<variable-reassign> ::= <variable-name> <ows> <variable-assign> <end-of-statement>
+<variable-definition> ::= <variable-qualifier> <ws> <variable-name> <ows> ':' <ows> <type> (<ows> <assign-operator> <ows> <expression>)?
+<variable-qualifier> ::= 'var'
+ | 'const'
+<variable-name> ::= <identifier>
(* Functions *)
-<function-definition> ::= 'fn' <ws> <function-name> <ows>
-<function-parameters> <ows> ':' <ows> <return-type> <ows> <function-body>
+<function-definition> ::= 'fn' <ws> <function-name> <ows> <function-parameters> <ows> ':' <ows> <return-type> <ows> <function-body>
<function-name> ::= <identifier>
<function-parameters> ::= '(' <ows> ')'
<return-type> ::= <type>
<function-body> ::= <block>
(* Statements *)
-<block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
-<ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
-<end-of-statement> ::= ';' | <line-break> | <end-of-file>
-<statement> ::= <return-statement> | <variable-definition> | <variable-reassign> | <const-definition>
+<block> ::= '{' <ows> <statement> <ows> (<end-of-statement> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
+<end-of-statement> ::= ';' | <line-break>
+<statement> ::= <return-statement> | <variable-definition> | <assign-expression>
<return-statement> ::= 'return' <ws> <expression>
(* Expressions *)
-<expression> ::= <integer> | <identifier>
+<expression> ::= <integer> | <identifier> | <assign-expression>
+<assign-expression> ::= <variable-name> <ows> <assign-operator> <ows> <expression>
+<assign-operator> ::= '='
+ | '*='
+ | '/='
+ | '%='
+ | '+='
+ | '-='
+ | '<<='
+ | '>>='
+ | '&='
+ | '^='
+ | '|='
(* Identifiers *)
<type> ::= 'u32'
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 1/2] docs: spec: rename program to translation-unit
2024-03-27 21:20 ` Johnny Richard
@ 2024-03-28 13:50 ` Carlos Maniero
0 siblings, 0 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-03-28 13:50 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
> > commit also makes a few refactors on spec such as:
> >
> > - Makes EOF a end-of-statement
>
> This patch does the opposite. Make a end-of-statement a EOF as well,
> which I not agree. See following comments...
>
...
>
> Hmmm... this is not true, this means the every end-of-statement can be a
> end-of-file.
I'll try a different approach and send a new patch, the challenge here
is that you should not be able to do that:
fn a(): u32 {} fn b(): u32 {}
fn a(): u32 {} var a: u32 fn b(): u32 {}
That's was the issue I was trying to address when I make EOF a EOS. To
allow multiple definitions that requires an new line in between.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 2/2] docs: spec: add variables and constants specification
2024-03-27 21:37 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Johnny Richard
@ 2024-03-28 14:11 ` Carlos Maniero
2024-04-01 17:48 ` Johnny Richard
2024-03-30 1:14 ` Carlos Maniero
2024-04-11 22:39 ` [PATCH] fixup! " ricardo_kagawa
2 siblings, 1 reply; 47+ messages in thread
From: Carlos Maniero @ 2024-03-28 14:11 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
On Wed Mar 27, 2024 at 6:37 PM -03, Johnny Richard wrote:
> On Wed, Mar 27, 2024 at 12:21:28AM -0300, Carlos Maniero wrote:
> > This commit introduces the specification for variables and constants. A
> > valid program under this specification is as follows:
> >
> > var x: u32 = 1
>
> Since this patch adds support to assignments, lets also add support to
> all assignment operators like "-=" "+=" "<<=" and so on.
>
> > const y: u32 = 2
>
> This patch lacks support to the following valid assignment expression
> (which I think adds flexibility to the language):
>
> var x: u32 = a = b = c = 1
> var y: u32
> y = a = b = c = 1
>
> > -<global-statements> ::= <function-definition>
> > +<global-statements> ::= <function-definition> | <variable-definition> | <variable-reassign> | <const-definition>
>
> nitpick: maybe _external-declaration_ sounds better since definitions are
> not statements?
What do you think about *file-declarations* a file declaration? Does not
mean that it is external. At least while we try to define a file.
>
> > +
> > +(* Variables *)
> > +<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>?
> > +<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>
>
> We don't need to define twice the variable-definition for "var" and
> "const", let's combine both in a single rule.
I don't know if you noticed, but variables has an optional assignment
while const has required assignment.
>
> > +<variable-name> ::= <identifier>
> > +<variable-assign> ::= '=' <ows> <expression>
> > +<variable-reassign> ::= <variable-name> <ows> <variable-assign> <end-of-statement>
> >
> > (* Functions *)
> > <function-definition> ::= 'fn' <ws> <function-name> <ows>
> > @@ -38,11 +46,11 @@ language.
> > <block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
> > <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> > <end-of-statement> ::= ';' | <line-break> | <end-of-file>
> > -<statement> ::= <return-statement>
> > +<statement> ::= <return-statement> | <variable-definition> | <variable-reassign> | <const-definition>
> > <return-statement> ::= 'return' <ws> <expression>
> >
> > (* Expressions *)
> > -<expression> ::= <integer>
> > +<expression> ::= <integer> | <identifier>
> >
> > (* Identifiers *)
> > <type> ::= 'u32'
> > --
> > 2.34.1
> >
>
> I have done few adjustments according to my feedback (I also fix the
> unnecessary line breaks on function and block). Let me know what you
> think about it.
>
> ---->8----
> Subject: [PATCH olang] fixup! docs: spec: add variables and constants specification
>
>
> diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
> index 708b679..2650dd9 100644
> --- a/docs/pages/language-specification.md
> +++ b/docs/pages/language-specification.md
> @@ -22,35 +22,45 @@ language.
>
> ```
> (* Entry Point *)
> -<translation-unit> ::= <ows> (<global-statements> <end-of-statement>)*
> +<translation-unit> ::= (<ows> <external-declaration> <ows> (<end-of-statement> | <end-of-file>))*
Way more elegant! Thanks.
>
> -<global-statements> ::= <function-definition> | <variable-definition> | <variable-reassign> | <const-definition>
> +<external-declaration> ::= <function-definition>
> + | <variable-definition>
> + | <assign-expression>
>
> (* Variables *)
> -<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>?
> -<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>
> -
> -<variable-name> ::= <identifier>
> -<variable-assign> ::= '=' <ows> <expression>
> -<variable-reassign> ::= <variable-name> <ows> <variable-assign> <end-of-statement>
> +<variable-definition> ::= <variable-qualifier> <ws> <variable-name> <ows> ':' <ows> <type> (<ows> <assign-operator> <ows> <expression>)?
This is invalid for const unless we want to allow unassigned constants.
It also can be interpreted as a semantic error, in that case I believe
the spec should not check for semantics.
> +<variable-qualifier> ::= 'var'
> + | 'const'
> +<variable-name> ::= <identifier>
>
> (* Functions *)
> -<function-definition> ::= 'fn' <ws> <function-name> <ows>
> -<function-parameters> <ows> ':' <ows> <return-type> <ows> <function-body>
> +<function-definition> ::= 'fn' <ws> <function-name> <ows> <function-parameters> <ows> ':' <ows> <return-type> <ows> <function-body>
> <function-name> ::= <identifier>
> <function-parameters> ::= '(' <ows> ')'
> <return-type> ::= <type>
> <function-body> ::= <block>
>
> (* Statements *)
> -<block> ::= '{' <ows> <statement> <ows> (<end-of-statement>
> -<ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> -<end-of-statement> ::= ';' | <line-break> | <end-of-file>
> -<statement> ::= <return-statement> | <variable-definition> | <variable-reassign> | <const-definition>
> +<block> ::= '{' <ows> <statement> <ows> (<end-of-statement> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> +<end-of-statement> ::= ';' | <line-break>
> +<statement> ::= <return-statement> | <variable-definition> | <assign-expression>
> <return-statement> ::= 'return' <ws> <expression>
>
> (* Expressions *)
> -<expression> ::= <integer> | <identifier>
> +<expression> ::= <integer> | <identifier> | <assign-expression>
> +<assign-expression> ::= <variable-name> <ows> <assign-operator> <ows> <expression>
> +<assign-operator> ::= '='
> + | '*='
> + | '/='
> + | '%='
> + | '+='
> + | '-='
> + | '<<='
> + | '>>='
> + | '&='
> + | '^='
> + | '|='
>
> (* Identifiers *)
> <type> ::= 'u32'
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 2/2] docs: spec: add variables and constants specification
2024-03-27 21:37 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Johnny Richard
2024-03-28 14:11 ` Carlos Maniero
@ 2024-03-30 1:14 ` Carlos Maniero
2024-04-01 17:54 ` Johnny Richard
2024-04-11 22:39 ` [PATCH] fixup! " ricardo_kagawa
2 siblings, 1 reply; 47+ messages in thread
From: Carlos Maniero @ 2024-03-30 1:14 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
> +<assign-operator> ::= '='
> + | '*='
> + | '/='
> + | '%='
> + | '+='
> + | '-='
> + | '<<='
> + | '>>='
> + | '&='
> + | '^='
> + | '|='
I believe we may need two non-terminals, one for assignment which is
just the '=' and other for reassignments.
The statements *const x: u32 += 1* is valid in the language but it is
not valid, but I'm not sure if it also isn't a semantic issue that most
ignored for the simplicity of the spec.
Anyway, since you already addressed most of the issues in the spec I
propose, few free to send a v2 or let me know what you think about the
points I raised so then I can proceed with a new version.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 2/2] docs: spec: add variables and constants specification
2024-03-28 14:11 ` Carlos Maniero
@ 2024-04-01 17:48 ` Johnny Richard
0 siblings, 0 replies; 47+ messages in thread
From: Johnny Richard @ 2024-04-01 17:48 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
On Thu, Mar 28, 2024 at 11:11:38AM -0300, Carlos Maniero wrote:
> On Wed Mar 27, 2024 at 6:37 PM -03, Johnny Richard wrote:
> > On Wed, Mar 27, 2024 at 12:21:28AM -0300, Carlos Maniero wrote:
> > > This commit introduces the specification for variables and constants. A
> > > valid program under this specification is as follows:
> > >
> > > var x: u32 = 1
> >
> > Since this patch adds support to assignments, lets also add support to
> > all assignment operators like "-=" "+=" "<<=" and so on.
> >
> > > const y: u32 = 2
> >
> > This patch lacks support to the following valid assignment expression
> > (which I think adds flexibility to the language):
> >
> > var x: u32 = a = b = c = 1
> > var y: u32
> > y = a = b = c = 1
> >
> > > -<global-statements> ::= <function-definition>
> > > +<global-statements> ::= <function-definition> | <variable-definition> | <variable-reassign> | <const-definition>
> >
> > nitpick: maybe _external-declaration_ sounds better since definitions are
> > not statements?
>
> What do you think about *file-declarations* a file declaration? Does not
> mean that it is external. At least while we try to define a file.
hmm.. It sounds weird mention file. Feels like you are going to declare
files... But I don't want to spend a lot of time on it. It was a
nitpick... If you think *external-declaration* is not good enough we can
keep *global-statement* (no blocking here).
> > > +
> > > +(* Variables *)
> > > +<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>?
> > > +<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-assign>
> >
> > We don't need to define twice the variable-definition for "var" and
> > "const", let's combine both in a single rule.
>
> I don't know if you noticed, but variables has an optional assignment
> while const has required assignment.
Sure, I noticed. I took a look to how C solve this problem and seems
like it allows defining a const without assignment (I don't know why...).
I would do the same to keep the gramma simple. And if we really want to
advice the developer about weird declaration, we could warning message
during semantics checking phase.
> > +<variable-definition> ::= <variable-qualifier> <ws> <variable-name> <ows> ':' <ows> <type> (<ows> <assign-operator> <ows> <expression>)?
>
> This is invalid for const unless we want to allow unassigned constants.
> It also can be interpreted as a semantic error, in that case I believe
> the spec should not check for semantics.
Let's handle it during semantics analysis.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH olang v1 2/2] docs: spec: add variables and constants specification
2024-03-30 1:14 ` Carlos Maniero
@ 2024-04-01 17:54 ` Johnny Richard
0 siblings, 0 replies; 47+ messages in thread
From: Johnny Richard @ 2024-04-01 17:54 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
On Fri, Mar 29, 2024 at 10:14:56PM -0300, Carlos Maniero wrote:
> > +<assign-operator> ::= '='
> > + | '*='
> > + | '/='
> > + | '%='
> > + | '+='
> > + | '-='
> > + | '<<='
> > + | '>>='
> > + | '&='
> > + | '^='
> > + | '|='
> I believe we may need two non-terminals, one for assignment which is
> just the '=' and other for reassignments.
>
> The statements *const x: u32 += 1* is valid in the language but it is
> not valid, but I'm not sure if it also isn't a semantic issue that most
> ignored for the simplicity of the spec.
Yeah, you are right. But I would love to catch this erro during syntax
analyses. This error looks like a grammatic problem. What do you think?
> Anyway, since you already addressed most of the issues in the spec I
> propose, few free to send a v2 or let me know what you think about the
> points I raised so then I can proceed with a new version.
I can wait for other revision from you, no problem at all. Only if you
really want me to do it.
^ permalink raw reply [flat|nested] 47+ messages in thread
* [PATCH] fixup! docs: spec: add variables and constants specification
2024-03-27 21:37 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Johnny Richard
2024-03-28 14:11 ` Carlos Maniero
2024-03-30 1:14 ` Carlos Maniero
@ 2024-04-11 22:39 ` ricardo_kagawa
2024-04-12 22:36 ` Johnny Richard
2 siblings, 1 reply; 47+ messages in thread
From: ricardo_kagawa @ 2024-04-11 22:39 UTC (permalink / raw)
To: johnny; +Cc: carlos, ~johnnyrichard/olang-devel, Ricardo Kagawa
From: Ricardo Kagawa <ricardo_kagawa@disroot.org>
> subject to semantic checks. Attempting to bypass these checks to
> reassign a global constant will result in a segmentation fault
> (SEGFAULT) and will be accepted at the function level.
I would be careful with the wording here. Are you absolutely sure you
can enforce this rule in case of a bypass attempt? If not, use something
like "should" or "may" instead of "will".
In the current version of the specification, it would be impossible to
bypass the `const` check, and it would be possible to enforce it at
compile-time. But depending on what you are planning to add to the
language, it might become impossible to do so later.
> Since this patch adds support to assignments, lets also add support to
> all assignment operators like "-=" "+=" "<<=" and so on.
I disagree. Support for those assignment operators should only be added
when both assignments and operators are defined, and none of these
operators are defined yet.
> This patch lacks support to the following valid assignment expression
> (which I think adds flexibility to the language):
>
> var x: u32 = a = b = c = 1
Personally, I don't like this idiom, but I wouldn't stop you from adding
it. Johnny's patch actually already enables this, and also the
following (for clarity, of course the `if` statement does not exist yet,
but it is included here as an example of what might come in the future):
```
var x
if (x = next()) {
return x
}
```
Which is something I don't like either, just as much.
> > > We don't need to define twice the variable-definition for "var" and
> > > "const", let's combine both in a single rule.
> >
> > I don't know if you noticed, but variables has an optional assignment
> > while const has required assignment.
>
> Sure, I noticed. I took a look to how C solve this problem and seems
> like it allows defining a const without assignment (I don't know why...).
>
> I would do the same to keep the gramma simple. And if we really want to
> advice the developer about weird declaration, we could warning message
> during semantics checking phase.
I agree with Carlos, unless you have plans to allow constants to be
initialized later (or not even initialized), which I don't like.
I don't know what your plans for the future are, but in the case of the
C language, I guess they didn't have a choice but allow for
uninitialized constants. The compiler can validate the immutability of
the constant, _as long as it is strictly accessed through its binding_.
But the C language allows for pointer arithmetics and inline assembly,
which allows the program to access memory positions in other ways
besides references to the variable name. So the immutability of `const`
variables is not a hard guarantee, but more like an advice, in this
case.
The compiler simply cannot make that many assumptions on what pointers
point to, or where your assembly code writes things to. This is so bad
that in legacy operating systems, it was possible to override kernel
instructions, as long as you knew where they were in the physical
memory.
In modern operating systems, processes never have access to physical
memory addresses, but they still have full access to their own memory.
In other words, a pointer can still mutate constant variables, and even
literal values in instructions (or the instructions themselves, which
means macros are not immune to mutation either).
Other languages can make stronger assumptions about constant variables,
as they do not allow for direct memory manipulation.
So, in my opinion, the decision should hinge on the compiler's ability
to properly validate the constant's immutability, and whether or not
late initialization should be allowed (complicating semantic checks).
> I believe we may need two non-terminals, one for assignment which is
> just the '=' and other for reassignments.
I sort of agree here. But I guess the non-terminal names are bit
confusing. The `=` sign in `const` and `var` declarations is _not_ an
assignment operation, but declares an initializer. The semantics are
subtly different, but still different, so assignment operators should
not be allowed in variable/constant declarations.
---
Discussions:
- Are you planning to hoist declarations, or are declarations required
to be placed before their use?
- Are you planning to include type inference for variable declarations?
If so, the variable type in variable and constant declarations could
be made optional.
-- >8 --
- Moved statements common to the translation unit and function bodies to
their own non-terminal.
- Restored Carlos' definition of variable and constant definitions, as
they are not quite the same, structurally and semantically.
Personally, I'd rather constants to be initialized immediately, but
you may have a different opinion on this.
- Moved some non-terminals from the "Statements" section to the
"Functions" section, as there will be some statements that are
function-body specific, some that are translation-unit specific, and
some that are common to both.
- Renamed "assign" to "assignment", for better wording.
- Renamed <variable-assign> from Carlos' patch to
<variable-initializer> (must not be used in <assignment-expression>).
Signed-off-by: Ricardo Kagawa <ricardo_kagawa@disroot.org>
---
docs/pages/language-specification.md | 36 ++++++++++------------------
1 file changed, 13 insertions(+), 23 deletions(-)
diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
index 2650dd9..b218462 100644
--- a/docs/pages/language-specification.md
+++ b/docs/pages/language-specification.md
@@ -24,15 +24,14 @@ language.
(* Entry Point *)
<translation-unit> ::= (<ows> <external-declaration> <ows> (<end-of-statement> | <end-of-file>))*
-<external-declaration> ::= <function-definition>
- | <variable-definition>
- | <assign-expression>
+(* Translation Unit *)
+<external-declaration> ::= <common-statement> | <function-definition>
(* Variables *)
-<variable-definition> ::= <variable-qualifier> <ws> <variable-name> <ows> ':' <ows> <type> (<ows> <assign-operator> <ows> <expression>)?
-<variable-qualifier> ::= 'var'
- | 'const'
-<variable-name> ::= <identifier>
+<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-initializer>?
+<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-initializer>
+<variable-name> ::= <identifier>
+<variable-initializer> ::= '=' <ows> <expression>
(* Functions *)
<function-definition> ::= 'fn' <ws> <function-name> <ows> <function-parameters> <ows> ':' <ows> <return-type> <ows> <function-body>
@@ -40,27 +39,18 @@ language.
<function-parameters> ::= '(' <ows> ')'
<return-type> ::= <type>
<function-body> ::= <block>
+<block> ::= '{' <ows> <statement> <ows> (<end-of-statement> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
+<statement> ::= <common-statement> | <return-statement>
+<return-statement> ::= 'return' <ws> <expression>
(* Statements *)
-<block> ::= '{' <ows> <statement> <ows> (<end-of-statement> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
<end-of-statement> ::= ';' | <line-break>
-<statement> ::= <return-statement> | <variable-definition> | <assign-expression>
-<return-statement> ::= 'return' <ws> <expression>
+<common-statement> ::= <variable-definition> | <const-definition> | <assignment-expression>
(* Expressions *)
-<expression> ::= <integer> | <identifier> | <assign-expression>
-<assign-expression> ::= <variable-name> <ows> <assign-operator> <ows> <expression>
-<assign-operator> ::= '='
- | '*='
- | '/='
- | '%='
- | '+='
- | '-='
- | '<<='
- | '>>='
- | '&='
- | '^='
- | '|='
+<expression> ::= <integer> | <variable-name> | <assignment-expression>
+<assignment-expression> ::= <variable-name> <ows> <assignment-operator> <ows> <expression>
+<assignment-operator> ::= '='
(* Identifiers *)
<type> ::= 'u32'
--
2.44.0
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH] fixup! docs: spec: add variables and constants specification
2024-04-11 22:39 ` [PATCH] fixup! " ricardo_kagawa
@ 2024-04-12 22:36 ` Johnny Richard
2024-04-13 2:18 ` Carlos Maniero
2024-04-16 19:01 ` Johnny Richard
0 siblings, 2 replies; 47+ messages in thread
From: Johnny Richard @ 2024-04-12 22:36 UTC (permalink / raw)
To: ricardo_kagawa; +Cc: carlos, ~johnnyrichard/olang-devel
Thanks a lot for your contribution, I very impressed you managed to send
a really nice PATCH.
Sorry for that, but there is another Patchset version which was applied
to the main branch. I think Carlos forgot to mention this Patchset was
SUPERSEDED[v2] by version 2.
v2: http://lists.johnnyrichard.com/olang/5fzsolce5h42aa6udppiwezgbzeqerkde3xvyilidnkcjaho2j@ygxd7ugzck4m/T/#m0f5cc6f2d49835ec83d4fd5c24d97d2597cb5363
However, I will leave my thoughts here but (we should try to address the
current implementation problems in a new patches).
On Thu, Apr 11, 2024 at 07:39:58PM -0300, ricardo_kagawa@disroot.org wrote:
> From: Ricardo Kagawa <ricardo_kagawa@disroot.org>
> > Since this patch adds support to assignments, lets also add support to
> > all assignment operators like "-=" "+=" "<<=" and so on.
>
> I disagree. Support for those assignment operators should only be added
> when both assignments and operators are defined, and none of these
> operators are defined yet.
Sure... Unfortunately we don't have the specification for operators but
they are already implemented into the language parser (I was planning to
submit the assignment operators spec after this patch get applied).
As soon as I send the Patch we can discuss on top of it anything related
to assignment operators.
> > This patch lacks support to the following valid assignment expression
> > (which I think adds flexibility to the language):
> >
> > var x: u32 = a = b = c = 1
>
> Personally, I don't like this idiom, but I wouldn't stop you from adding
> it. Johnny's patch actually already enables this, and also the
> following (for clarity, of course the `if` statement does not exist yet,
> but it is included here as an example of what might come in the future):
>
> ```
> var x
> if (x = next()) {
> return x
> }
> ```
>
> Which is something I don't like either, just as much.
Carlos and I discussed it and we also agreed on removing this assignment.
The patch v2 has removed it.
> So, in my opinion, the decision should hinge on the compiler's ability
> to properly validate the constant's immutability, and whether or not
> late initialization should be allowed (complicating semantic checks).
I prefer to not do a late initialization as well (it will make things
simpler). I prefer to make the assignment mandatory for constants.
> ---
> Discussions:
>
> - Are you planning to hoist declarations, or are declarations required
> to be placed before their use?
We are planning to have declarations being placed before their use.
> - Are you planning to include type inference for variable declarations?
No. Everything should be verbose and explicit.
> -- >8 --
>
> - Moved statements common to the translation unit and function bodies to
> their own non-terminal.
Good.
> - Restored Carlos' definition of variable and constant definitions, as
> they are not quite the same, structurally and semantically.
> Personally, I'd rather constants to be initialized immediately, but
> you may have a different opinion on this.
We also prefer to have the constants being initialized immediately.
> - Moved some non-terminals from the "Statements" section to the
> "Functions" section, as there will be some statements that are
> function-body specific, some that are translation-unit specific, and
> some that are common to both.
I liked it.
> - Renamed "assign" to "assignment", for better wording.
Nice.
> - Renamed <variable-assign> from Carlos' patch to
> <variable-initializer> (must not be used in <assignment-expression>).
Nice.
>
> Signed-off-by: Ricardo Kagawa <ricardo_kagawa@disroot.org>
> ---
> docs/pages/language-specification.md | 36 ++++++++++------------------
> 1 file changed, 13 insertions(+), 23 deletions(-)
>
> diff --git a/docs/pages/language-specification.md b/docs/pages/language-specification.md
> index 2650dd9..b218462 100644
> --- a/docs/pages/language-specification.md
> +++ b/docs/pages/language-specification.md
> @@ -24,15 +24,14 @@ language.
> (* Entry Point *)
> <translation-unit> ::= (<ows> <external-declaration> <ows> (<end-of-statement> | <end-of-file>))*
>
> -<external-declaration> ::= <function-definition>
> - | <variable-definition>
> - | <assign-expression>
> +(* Translation Unit *)
> +<external-declaration> ::= <common-statement> | <function-definition>
>
> (* Variables *)
> -<variable-definition> ::= <variable-qualifier> <ws> <variable-name> <ows> ':' <ows> <type> (<ows> <assign-operator> <ows> <expression>)?
> -<variable-qualifier> ::= 'var'
> - | 'const'
> -<variable-name> ::= <identifier>
> +<variable-definition> ::= 'var' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-initializer>?
> +<const-definition> ::= 'const' <ws> <variable-name> <ows> ':' <ows> <type> <ows> <variable-initializer>
After discussing with Carlos I regretted my suggestion about combining
_var_ and _const_. Today we have both combined. But separate them
makes a lot easier to implement.
Could you please prepare a new patch over the _main_ branch with this
change (if Carlos agree of course)?
> +<variable-name> ::= <identifier>
> +<variable-initializer> ::= '=' <ows> <expression>
> (* Functions *)
> <function-definition> ::= 'fn' <ws> <function-name> <ows> <function-parameters> <ows> ':' <ows> <return-type> <ows> <function-body>
> @@ -40,27 +39,18 @@ language.
> <function-parameters> ::= '(' <ows> ')'
> <return-type> ::= <type>
> <function-body> ::= <block>
> +<block> ::= '{' <ows> <statement> <ows> (<end-of-statement> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> +<statement> ::= <common-statement> | <return-statement>
> +<return-statement> ::= 'return' <ws> <expression>
>
> (* Statements *)
> -<block> ::= '{' <ows> <statement> <ows> (<end-of-statement> <ows> <statement> <ows>)* <end-of-statement>? <ows> '}'
> <end-of-statement> ::= ';' | <line-break>
> -<statement> ::= <return-statement> | <variable-definition> | <assign-expression>
> -<return-statement> ::= 'return' <ws> <expression>
> +<common-statement> ::= <variable-definition> | <const-definition> | <assignment-expression>
>
> (* Expressions *)
> -<expression> ::= <integer> | <identifier> | <assign-expression>
> -<assign-expression> ::= <variable-name> <ows> <assign-operator> <ows> <expression>
> -<assign-operator> ::= '='
> - | '*='
> - | '/='
> - | '%='
> - | '+='
> - | '-='
> - | '<<='
> - | '>>='
> - | '&='
> - | '^='
> - | '|='
As I said before, these _assignment operators_ are already implemented.
I have implemented it before we start the language spec. I will prepare
a patch to fix the spec.
> +<expression> ::= <integer> | <variable-name> | <assignment-expression>
> +<assignment-expression> ::= <variable-name> <ows> <assignment-operator> <ows> <expression>
> +<assignment-operator> ::= '='
>
> (* Identifiers *)
> <type> ::= 'u32'
> --
> 2.44.0
>
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH] fixup! docs: spec: add variables and constants specification
2024-04-12 22:36 ` Johnny Richard
@ 2024-04-13 2:18 ` Carlos Maniero
2024-04-16 19:01 ` Johnny Richard
1 sibling, 0 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-04-13 2:18 UTC (permalink / raw)
To: Johnny Richard, ricardo_kagawa; +Cc: ~johnnyrichard/olang-devel
> Thanks a lot for your contribution, I very impressed you managed to send
> a really nice PATCH.
>
> Sorry for that, but there is another Patchset version which was applied
> to the main branch. I think Carlos forgot to mention this Patchset was
> SUPERSEDED[v2] by version 2.
>
> v2: http://lists.johnnyrichard.com/olang/5fzsolce5h42aa6udppiwezgbzeqerkde3xvyilidnkcjaho2j@ygxd7ugzck4m/T/#m0f5cc6f2d49835ec83d4fd5c24d97d2597cb5363
Sorry Ricardo. My bad! I forgot to update the mailing list saying that
this patch was superseded.
> > ---
> > Discussions:
> >
> > - Are you planning to hoist declarations, or are declarations required
> > to be placed before their use?
>
> We are planning to have declarations being placed before their use.
Just an observation here, this is only valid for external declarations
and just inside a function scope.
valid:
1| fn main(): u8 {
2| return exit_success
3| }
4|
4| const exit_success: u8 = 0
invalid:
1| const a = b + 1
2| const b = 0
also invalid:
1| fn main(): u8 {
2| exit_success = 0
3|
4| var exit_success
4| return exit_success
5| }
> Could you please prepare a new patch over the _main_ branch with this
> change (if Carlos agree of course)?
LGTM! And thank you so much for your contributions Ricardo!
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH] fixup! docs: spec: add variables and constants specification
2024-04-12 22:36 ` Johnny Richard
2024-04-13 2:18 ` Carlos Maniero
@ 2024-04-16 19:01 ` Johnny Richard
1 sibling, 0 replies; 47+ messages in thread
From: Johnny Richard @ 2024-04-16 19:01 UTC (permalink / raw)
To: ricardo_kagawa; +Cc: carlos, ~johnnyrichard/olang-devel
On Sat, Apr 13, 2024 at 12:36:55AM +0200, Johnny Richard wrote:
> > > This patch lacks support to the following valid assignment expression
> > > (which I think adds flexibility to the language):
> > >
> > > var x: u32 = a = b = c = 1
> >
> > Personally, I don't like this idiom, but I wouldn't stop you from adding
> > it. Johnny's patch actually already enables this, and also the
> > following (for clarity, of course the `if` statement does not exist yet,
> > but it is included here as an example of what might come in the future):
> >
> > ```
> > var x
> > if (x = next()) {
> > return x
> > }
> > ```
> >
> > Which is something I don't like either, just as much.
>
> Carlos and I discussed it and we also agreed on removing this assignment.
> The patch v2 has removed it.
Made a mistake here. The current spec still have assignment
expressions. For context, we agreed on keep it because the only place
we would miss this feature would be on *if* and *while* statements.
But we also don't have strong option on keep it. Since it will be little
bit annoying of optimizing the binary.
In conclusion, I believe everyone is Okay on removing it.
PS. Carlos prefers being called Maniero haha :^)
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-10-17 2:49 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-10-17 2:52 ` Carlos Maniero
0 siblings, 0 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-10-17 2:52 UTC (permalink / raw)
To: builds.sr.ht; +Cc: ~johnnyrichard/olang-devel
I broke the format :(
I'll wait for the review before submitting a v2.
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-10-17 2:48 [PATCH olang v1 1/1] codegen: x64: deref returns pointer value Carlos Maniero
@ 2024-10-17 2:49 ` builds.sr.ht
2024-10-17 2:52 ` Carlos Maniero
0 siblings, 1 reply; 47+ messages in thread
From: builds.sr.ht @ 2024-10-17 2:49 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 20s
[deref operation returning value][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/55515
[1]: mailto:carlos@maniero.me
✗ #1352279 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1352279
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-10-15 12:14 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-10-15 23:03 ` Carlos Maniero
0 siblings, 0 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-10-15 23:03 UTC (permalink / raw)
To: builds.sr.ht; +Cc: ~johnnyrichard/olang-devel
There is an issue unrelated to my changes. The spec that does not allows
comments inside.
I sent another patch [1] that will fix the spec.
[1]: Message-ID: <20241015225750.211129-2-carlos@maniero.me>.
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-10-15 12:14 [PATCH olang] fix: codegen: prevent stack overwrite Carlos Maniero
@ 2024-10-15 12:14 ` builds.sr.ht
2024-10-15 23:03 ` Carlos Maniero
0 siblings, 1 reply; 47+ messages in thread
From: builds.sr.ht @ 2024-10-15 12:14 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 28s
[fix: codegen: prevent stack overwrite][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/55483
[1]: mailto:carlos@maniero.me
✗ #1350731 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1350731
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-10-11 3:42 [PATCH olang v1] fix: build: add missing dependencies for check-spec Johnny Richard
@ 2024-10-11 1:43 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-10-11 1:43 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 21s
[fix: build: add missing dependencies for check-spec][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/55427
[1]: mailto:johnny@johnnyrichard.com
✗ #1348643 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1348643
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-10-08 16:33 [PATCH olang] parser: conform block line feeds with the spec Carlos Maniero
@ 2024-10-08 16:33 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-10-08 16:33 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 18s
[parser: conform block line feeds with the spec][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/55389
[1]: mailto:carlos@maniero.me
✗ #1346505 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1346505
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-08-13 17:27 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-08-13 19:03 ` Johnny Richard
0 siblings, 0 replies; 47+ messages in thread
From: Johnny Richard @ 2024-08-13 19:03 UTC (permalink / raw)
To: builds.sr.ht; +Cc: ~johnnyrichard/olang-devel
My bad... I have made these changes on top of patches not applied on
main branch.
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-08-13 18:16 [PATCH olang v1 2/2] ast: inline ast_node_data_t union definition Johnny Richard
@ 2024-08-13 17:27 ` builds.sr.ht
2024-08-13 19:03 ` Johnny Richard
0 siblings, 1 reply; 47+ messages in thread
From: builds.sr.ht @ 2024-08-13 17:27 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 29s
[refactor: ast: inline union typedefs][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/54446
[1]: mailto:johnny@johnnyrichard.com
✗ #1302361 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1302361
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-04-20 13:54 [PATCH olang v1] build: rename linter to format to avoid confusion Johnny Richard
@ 2024-04-20 12:57 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-04-20 12:57 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 39s
[build: rename linter to format to avoid confusion][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/51175
[1]: mailto:johnny@johnnyrichard.com
✗ #1200225 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1200225
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-03-28 14:59 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-03-28 16:46 ` Johnny Richard
0 siblings, 0 replies; 47+ messages in thread
From: Johnny Richard @ 2024-03-28 16:46 UTC (permalink / raw)
To: builds.sr.ht; +Cc: ~johnnyrichard/olang-devel
On Thu, Mar 28, 2024 at 02:59:02PM +0000, builds.sr.ht wrote:
> olang/patches/.build.yml: FAILED in 36s
>
> [fe: lexer: add single line comments support][0] from [Johnny Richard][1]
>
> [0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/50503
> [1]: mailto:johnny@johnnyrichard.com
>
> ✗ #1181030 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1181030
This build is failing due to a clang bumped version on Arch Linux
repositories. It was a major bump from 16 to 17 (it has breaking
changes).
We can solve this problem by fixing the version or by bumping our clang
locally. I will upgrade my clang meanwhile.
Please, consider the patch to fix it.
---->8----
Subject: [PATCH olang] fixup! fe: lexer: add single line comments support
diff --git a/src/pretty_print_ast.c b/src/pretty_print_ast.c
index e950796..129f090 100644
--- a/src/pretty_print_ast.c
+++ b/src/pretty_print_ast.c
@@ -26,7 +26,7 @@
#define ANSI_COLOR_MAGENTA "\x1b[35m"
#define ANSI_COLOR_RESET "\x1b[0m"
-#define PP_IS_BIT_SET(data, index) ((data)&1 << index)
+#define PP_IS_BIT_SET(data, index) ((data) & 1 << index)
typedef struct pretty_print_node
{
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-28 15:58 [PATCH olang v1] fe: lexer: add single line comments support Johnny Richard
@ 2024-03-28 14:59 ` builds.sr.ht
2024-03-28 16:46 ` Johnny Richard
0 siblings, 1 reply; 47+ messages in thread
From: builds.sr.ht @ 2024-03-28 14:59 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 36s
[fe: lexer: add single line comments support][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/50503
[1]: mailto:johnny@johnnyrichard.com
✗ #1181030 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1181030
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-03-26 2:32 ` Carlos Maniero
@ 2024-03-26 2:35 ` Carlos Maniero
0 siblings, 0 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-03-26 2:35 UTC (permalink / raw)
To: Carlos Maniero, builds.sr.ht, Johnny Richard; +Cc: ~johnnyrichard/olang-devel
oops!
s/see/be
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-03-25 21:37 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-03-26 2:32 ` Carlos Maniero
2024-03-26 2:35 ` Carlos Maniero
0 siblings, 1 reply; 47+ messages in thread
From: Carlos Maniero @ 2024-03-26 2:32 UTC (permalink / raw)
To: builds.sr.ht, Johnny Richard; +Cc: ~johnnyrichard/olang-devel
The failed pipeline seems to see a sourcehut issue.
Tested locally and all fine.
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-25 22:36 [PATCH olang v1 2/2] cli: remove code duplication Johnny Richard
@ 2024-03-25 21:37 ` builds.sr.ht
2024-03-26 2:32 ` Carlos Maniero
0 siblings, 1 reply; 47+ messages in thread
From: builds.sr.ht @ 2024-03-25 21:37 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 40s
[Introduce CLI option for improved AST tree visualization][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/50448
[1]: mailto:johnny@johnnyrichard.com
✗ #1178386 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1178386
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-13 12:32 [PATCH olang v3] refactor: rename zero programming language to olang Fabio Maciel
@ 2024-03-13 12:33 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-03-13 12:33 UTC (permalink / raw)
To: Fabio Maciel; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 31s
[refactor: rename zero programming language to olang][0] v3 from [Fabio Maciel][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/50187
[1]: mailto:fabio@fabiomaciel.com
✗ #1167852 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1167852
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-08 20:52 [PATCH olang] parser: abort when parser identifies a syntax error Johnny Richard
@ 2024-03-08 19:54 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-03-08 19:54 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 30s
[parser: abort when parser identifies a syntax error][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/50088
[1]: mailto:johnny@johnnyrichard.com
✗ #1164684 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1164684
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-05 8:44 [PATCH olang v2 3/3] cli: add compilation -o option with --save-temps Johnny Richard
@ 2024-03-05 7:51 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-03-05 7:51 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 12s
[implement assembly linux x86_64 compiler][0] v2 from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49994
[1]: mailto:johnny@johnnyrichard.com
✗ #1162085 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1162085
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-03-04 19:39 ` Johnny Richard
@ 2024-03-05 2:05 ` Carlos Maniero
0 siblings, 0 replies; 47+ messages in thread
From: Carlos Maniero @ 2024-03-05 2:05 UTC (permalink / raw)
To: Johnny Richard, ~johnnyrichard/olang-devel
The checks passed just fine in my environment too.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [olang/patches/.build.yml] build failed
2024-03-04 18:33 ` [olang/patches/.build.yml] build failed builds.sr.ht
@ 2024-03-04 19:39 ` Johnny Richard
2024-03-05 2:05 ` Carlos Maniero
0 siblings, 1 reply; 47+ messages in thread
From: Johnny Richard @ 2024-03-04 19:39 UTC (permalink / raw)
To: ~johnnyrichard/olang-devel
On Mon, Mar 04, 2024 at 06:33:31PM +0000, builds.sr.ht wrote:
> olang/patches/.build.yml: FAILED in 12s
>
> [implement assembly linux x86_64 compiler][0] from [Johnny Richard][1]
>
> [0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49981
> [1]: mailto:johnny@johnnyrichard.com
>
> ✗ #1161742 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1161742
I not sure what is happening, the build works find on my machine. Looks
like the CI machines are failing to setup the environment, nothing to do
with my changes I believe:
[#1161745] 2024/03/04 18:36:41 Booting image archlinux (default) on port 22563
[#1161745] 2024/03/04 18:36:42 Waiting for guest to settle
[#1161745] 2024/03/04 18:36:49 Sending tasks
[#1161745] 2024/03/04 18:36:52 Sending build environment
[#1161745] 2024/03/04 18:36:53 Installing packages
Warning: Permanently added '[localhost]:22563' (ED25519) to the list of known hosts.
:: Synchronizing package databases...
core downloading...
extra downloading...
multilib downloading...
warning: archlinux-keyring-20240208-1 is up to date -- skipping
there is nothing to do
Warning: Permanently added '[localhost]:22563' (ED25519) to the list of known hosts.
error: missing dependency 'initramfs' for package 'linux'
linux: ignoring package upgrade (6.7.6.arch1-1 => 6.7.8.arch1-1)
mkinitcpio: ignoring package upgrade (37.3-1 => 38-3)
Resolving dependencies...
Checking package conflicts...
:: uninstalling package 'mkinitcpio-37.3-1' due to conflict with 'cryptsetup-2.7.0-3'
[#1161745] 2024/03/04 18:36:54 Processing post-failed triggers...
[#1161745] 2024/03/04 18:36:54 Sending webhook...
[#1161745] 2024/03/04 18:36:54 Webhook response: 200
[#1161745] 2024/03/04 18:36:54 Thanks!
[#1161745] 2024/03/04 18:36:54 Build failed.
[#1161745] 2024/03/04 18:36:54 The build environment will be kept alive for 10 minutes.
[#1161745] 2024/03/04 18:36:54 To log in with SSH and examine it, use the following command:
[#1161745] 2024/03/04 18:36:54
[#1161745] 2024/03/04 18:36:54 ssh -t builds@fra02.builds.sr.ht connect 1161745
[#1161745] 2024/03/04 18:36:54
[#1161745] 2024/03/04 18:36:54 After logging in, the deadline is increased to your remaining build time.
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-04 19:23 [PATCH olang v1 3/3] cli: add compilation -o option with --save-temps Johnny Richard
@ 2024-03-04 18:33 ` builds.sr.ht
2024-03-04 19:39 ` Johnny Richard
0 siblings, 1 reply; 47+ messages in thread
From: builds.sr.ht @ 2024-03-04 18:33 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 12s
[implement assembly linux x86_64 compiler][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49981
[1]: mailto:johnny@johnnyrichard.com
✗ #1161742 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1161742
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-02 20:01 [PATCH olang] string_view: fix stack buffer overflow on to_u32 Johnny Richard
@ 2024-03-02 19:02 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-03-02 19:02 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 36s
[string_view: fix stack buffer overflow on to_u32][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49949
[1]: mailto:johnny@johnnyrichard.com
✗ #1160713 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1160713
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-03-02 19:02 [PATCH olang] string_view: add n + 1 test to string_view_to_u32 function Johnny Richard
@ 2024-03-02 18:03 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-03-02 18:03 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 40s
[string_view: add n + 1 test to string_view_to_u32 function][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49946
[1]: mailto:johnny@johnnyrichard.com
✗ #1160663 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1160663
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-20 16:39 [PATCH olang v2] utils: add arena Carlos Maniero
@ 2024-02-20 16:45 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-20 16:45 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 36s
[utils: add arena][0] v2 from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49708
[1]: mailto:carlos@maniero.me
✗ #1154158 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1154158
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-20 16:10 [PATCH olang] utils: add arena Carlos Maniero
@ 2024-02-20 16:15 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-20 16:15 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 36s
[utils: add arena][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49707
[1]: mailto:carlos@maniero.me
✗ #1154146 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1154146
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-19 21:04 [PATCH olang v4 4/4] lexer: test: add integration tests for --dump-tokens Johnny Richard
@ 2024-02-19 20:07 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-19 20:07 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 42s
[Create --dump-tokens on compiler cli][0] v4 from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49682
[1]: mailto:johnny@johnnyrichard.com
✗ #1153624 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1153624
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-19 1:23 [PATCH olang v2 2/2] lexer: create --dump-tokens cli command Johnny Richard
@ 2024-02-19 0:27 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-19 0:27 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 34s
[Create --dump-tokens on compiler cli][0] v2 from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49641
[1]: mailto:johnny@johnnyrichard.com
✗ #1153051 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1153051
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-19 1:15 [PATCH olang 2/2] lexer: create --dump-tokens cli command Johnny Richard
@ 2024-02-19 0:20 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-19 0:20 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 31s
[Create --dump-tokens on compiler cli][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49640
[1]: mailto:johnny@johnnyrichard.com
✗ #1153048 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1153048
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-17 13:46 [PATCH olang 2/2] Revert "docs: add sphinx documentation support" Carlos Maniero
@ 2024-02-17 13:51 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-17 13:51 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 18s
[remove sphinx dependency][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49598
[1]: mailto:carlos@maniero.me
✗ #1151949 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1151949
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-17 4:23 [PATCH olang] docs: add HACKING documentation Carlos Maniero
@ 2024-02-17 4:23 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-17 4:23 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 19s
[docs: add HACKING documentation][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49586
[1]: mailto:carlos@maniero.me
✗ #1151773 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1151773
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-16 2:58 [PATCH olang v2 2/2] tests: add integration test setup Carlos Maniero
@ 2024-02-16 3:03 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-16 3:03 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 15s
[Add integration tests][0] v2 from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49556
[1]: mailto:carlos@maniero.me
✗ #1151085 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1151085
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-14 23:36 [PATCH olang] style: fix clang-format format indentation Carlos Maniero
@ 2024-02-14 23:41 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-14 23:41 UTC (permalink / raw)
To: Carlos Maniero; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 16s
[style: fix clang-format format indentation][0] from [Carlos Maniero][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49522
[1]: mailto:carlos@maniero.me
✗ #1150343 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1150343
^ permalink raw reply [flat|nested] 47+ messages in thread
* [olang/patches/.build.yml] build failed
2024-02-13 21:36 [PATCH olang] build: enable continuous integration through .build.yml Johnny Richard
@ 2024-02-13 20:34 ` builds.sr.ht
0 siblings, 0 replies; 47+ messages in thread
From: builds.sr.ht @ 2024-02-13 20:34 UTC (permalink / raw)
To: Johnny Richard; +Cc: ~johnnyrichard/olang-devel
olang/patches/.build.yml: FAILED in 13s
[build: enable continuous integration through .build.yml][0] from [Johnny Richard][1]
[0]: https://lists.sr.ht/~johnnyrichard/olang-devel/patches/49459
[1]: mailto:johnny@johnnyrichard.com
✗ #1149170 FAILED olang/patches/.build.yml https://builds.sr.ht/~johnnyrichard/job/1149170
^ permalink raw reply [flat|nested] 47+ messages in thread
end of thread, other threads:[~2024-10-17 2:53 UTC | newest]
Thread overview: 47+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-03-27 3:21 [PATCH olang v1 0/2] docs: variables specification Carlos Maniero
2024-03-27 3:21 ` [PATCH olang v1 1/2] docs: spec: rename program to translation-unit Carlos Maniero
2024-03-27 21:20 ` Johnny Richard
2024-03-28 13:50 ` Carlos Maniero
2024-03-27 3:21 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Carlos Maniero
2024-03-27 3:22 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-27 21:37 ` [PATCH olang v1 2/2] docs: spec: add variables and constants specification Johnny Richard
2024-03-28 14:11 ` Carlos Maniero
2024-04-01 17:48 ` Johnny Richard
2024-03-30 1:14 ` Carlos Maniero
2024-04-01 17:54 ` Johnny Richard
2024-04-11 22:39 ` [PATCH] fixup! " ricardo_kagawa
2024-04-12 22:36 ` Johnny Richard
2024-04-13 2:18 ` Carlos Maniero
2024-04-16 19:01 ` Johnny Richard
-- strict thread matches above, loose matches on Subject: below --
2024-10-17 2:48 [PATCH olang v1 1/1] codegen: x64: deref returns pointer value Carlos Maniero
2024-10-17 2:49 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-10-17 2:52 ` Carlos Maniero
2024-10-15 12:14 [PATCH olang] fix: codegen: prevent stack overwrite Carlos Maniero
2024-10-15 12:14 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-10-15 23:03 ` Carlos Maniero
2024-10-11 3:42 [PATCH olang v1] fix: build: add missing dependencies for check-spec Johnny Richard
2024-10-11 1:43 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-10-08 16:33 [PATCH olang] parser: conform block line feeds with the spec Carlos Maniero
2024-10-08 16:33 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-08-13 18:16 [PATCH olang v1 2/2] ast: inline ast_node_data_t union definition Johnny Richard
2024-08-13 17:27 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-08-13 19:03 ` Johnny Richard
2024-04-20 13:54 [PATCH olang v1] build: rename linter to format to avoid confusion Johnny Richard
2024-04-20 12:57 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-28 15:58 [PATCH olang v1] fe: lexer: add single line comments support Johnny Richard
2024-03-28 14:59 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-28 16:46 ` Johnny Richard
2024-03-25 22:36 [PATCH olang v1 2/2] cli: remove code duplication Johnny Richard
2024-03-25 21:37 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-26 2:32 ` Carlos Maniero
2024-03-26 2:35 ` Carlos Maniero
2024-03-13 12:32 [PATCH olang v3] refactor: rename zero programming language to olang Fabio Maciel
2024-03-13 12:33 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-08 20:52 [PATCH olang] parser: abort when parser identifies a syntax error Johnny Richard
2024-03-08 19:54 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-05 8:44 [PATCH olang v2 3/3] cli: add compilation -o option with --save-temps Johnny Richard
2024-03-05 7:51 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-04 19:23 [PATCH olang v1 3/3] cli: add compilation -o option with --save-temps Johnny Richard
2024-03-04 18:33 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-04 19:39 ` Johnny Richard
2024-03-05 2:05 ` Carlos Maniero
2024-03-02 20:01 [PATCH olang] string_view: fix stack buffer overflow on to_u32 Johnny Richard
2024-03-02 19:02 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-03-02 19:02 [PATCH olang] string_view: add n + 1 test to string_view_to_u32 function Johnny Richard
2024-03-02 18:03 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-20 16:39 [PATCH olang v2] utils: add arena Carlos Maniero
2024-02-20 16:45 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-20 16:10 [PATCH olang] utils: add arena Carlos Maniero
2024-02-20 16:15 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-19 21:04 [PATCH olang v4 4/4] lexer: test: add integration tests for --dump-tokens Johnny Richard
2024-02-19 20:07 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-19 1:23 [PATCH olang v2 2/2] lexer: create --dump-tokens cli command Johnny Richard
2024-02-19 0:27 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-19 1:15 [PATCH olang 2/2] lexer: create --dump-tokens cli command Johnny Richard
2024-02-19 0:20 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-17 13:46 [PATCH olang 2/2] Revert "docs: add sphinx documentation support" Carlos Maniero
2024-02-17 13:51 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-17 4:23 [PATCH olang] docs: add HACKING documentation Carlos Maniero
2024-02-17 4:23 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-16 2:58 [PATCH olang v2 2/2] tests: add integration test setup Carlos Maniero
2024-02-16 3:03 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-14 23:36 [PATCH olang] style: fix clang-format format indentation Carlos Maniero
2024-02-14 23:41 ` [olang/patches/.build.yml] build failed builds.sr.ht
2024-02-13 21:36 [PATCH olang] build: enable continuous integration through .build.yml Johnny Richard
2024-02-13 20:34 ` [olang/patches/.build.yml] build failed builds.sr.ht
Code repositories for project(s) associated with this public inbox
https://git.johnnyrichard.com/olang.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox