mirror of
https://github.com/krgamestudios/Toy.git
synced 2026-05-06 08:50:10 +10:00
b718b35097
I found this while writing unit tests for Toy_Function, where one (native) function was named 'identity' and another (custom) was named 'ident' to avoid a naming clash. The rename didn't resolve the clash, so after some digging, I found that strings compared to substrings would return a match, despite being different. This took some awkward corner-case handling, as it turns out 'deepCompareUtil' only returns zero when no differences have been found, not when a match has been found. I also added checks for this to Toy_String's unit test, with the parameters checked in both orders i.e. (a,b) and (b,a), because paranoia is your friend. The rope pattern is powerful, but also gives you enough rope to hang yourself.
23 lines
672 B
C
23 lines
672 B
C
#pragma once
|
|
|
|
#include "toy_value.h"
|
|
#include "toy_vm.h"
|
|
|
|
Toy_Value handleStringAttributes(Toy_VM* vm, Toy_Value compound, Toy_Value attribute);
|
|
Toy_Value handleArrayAttributes(Toy_VM* vm, Toy_Value compound, Toy_Value attribute);
|
|
Toy_Value handleTableAttributes(Toy_VM* vm, Toy_Value compound, Toy_Value attribute);
|
|
|
|
// [x] string.length
|
|
// [x] string.asUpper
|
|
// [x] string.asLower
|
|
// [x] array.length
|
|
// [x] array.pushBack(x)
|
|
// [x] array.popBack()
|
|
// [x] array.forEach(fn) // fn(x) -> void
|
|
// [ ] array.sort(fn) // fn(a,b) -> int
|
|
// [x] table.length
|
|
// [x] table.insert(x, y)
|
|
// [x] table.hasKey(x)
|
|
// [x] table.remove(x)
|
|
// [ ] table.forEach(fn) // fn(x,y) -> void
|