v2: xor, for x = ...
parent
c85ccad0a6
commit
e56bf42270
|
@ -108,7 +108,10 @@ fn (m mut map) set(key string, value voidptr) {
|
||||||
// Match is not possible anymore.
|
// Match is not possible anymore.
|
||||||
// Probe until an empty index is found.
|
// Probe until an empty index is found.
|
||||||
// Swap when probe count is higher/richer (Robin Hood).
|
// Swap when probe count is higher/richer (Robin Hood).
|
||||||
mut current_kv := KeyValue{key, malloc(m.value_bytes)}
|
mut current_kv := KeyValue{
|
||||||
|
key:key
|
||||||
|
value:malloc(m.value_bytes)
|
||||||
|
}
|
||||||
C.memcpy(current_kv.value, value, m.value_bytes)
|
C.memcpy(current_kv.value, value, m.value_bytes)
|
||||||
for m.probe_hash[index] != 0 {
|
for m.probe_hash[index] != 0 {
|
||||||
if probe_hash > m.probe_hash[index] {
|
if probe_hash > m.probe_hash[index] {
|
||||||
|
|
|
@ -917,6 +917,9 @@ fn (p mut Parser) for_statement() ast.Stmt {
|
||||||
if p.peek_tok.kind == .decl_assign {
|
if p.peek_tok.kind == .decl_assign {
|
||||||
init = p.var_decl()
|
init = p.var_decl()
|
||||||
}
|
}
|
||||||
|
else if p.peek_tok.kind == .assign {
|
||||||
|
init = p.assign_stmt()
|
||||||
|
}
|
||||||
else if p.tok.kind != .semicolon {}
|
else if p.tok.kind != .semicolon {}
|
||||||
// allow `for ;; i++ {`
|
// allow `for ;; i++ {`
|
||||||
// Allow `for i = 0; i < ...`
|
// Allow `for i = 0; i < ...`
|
||||||
|
|
|
@ -480,7 +480,7 @@ pub fn (k Kind) is_start_of_type() bool {
|
||||||
pub fn (kind Kind) is_infix() bool {
|
pub fn (kind Kind) is_infix() bool {
|
||||||
return kind in [.plus, .minus, .mod, .mul, .div, .eq, .ne, .gt, .lt, .key_in,
|
return kind in [.plus, .minus, .mod, .mul, .div, .eq, .ne, .gt, .lt, .key_in,
|
||||||
//
|
//
|
||||||
.key_as, .ge, .le, .logical_or,
|
.key_as, .ge, .le, .logical_or, .xor,
|
||||||
//
|
//
|
||||||
.and, .dot, .pipe, .amp, .left_shift, .right_shift]
|
.and, .dot, .pipe, .amp, .left_shift, .right_shift]
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue