mirror of https://github.com/arendst/Tasmota.git
172 lines
4.8 KiB
Plaintext
172 lines
4.8 KiB
Plaintext
import string as s
|
|
|
|
assert(s.find('012345', '23') == 2)
|
|
assert(s.find('012345', '23', 1) == 2)
|
|
assert(s.find('012345', '23', 1, 3) == -1)
|
|
assert(s.find('012345', '23', 2, 4) == 2)
|
|
assert(s.find('012345', '23', 3) == -1)
|
|
|
|
assert(s.find('012345', '') == 0)
|
|
assert(s.find('012345', '', 0, 0) == 0)
|
|
assert(s.find('012345', '', 1) == 1)
|
|
assert(s.find('012345', '', 1, 1) == 1)
|
|
assert(s.find('012345', '', 1, 0) == -1)
|
|
assert(s.find('012345', '', 6) == 6)
|
|
assert(s.find('012345', '', 7) == -1)
|
|
|
|
assert(s.count('012345', '') == 7)
|
|
assert(s.count('012345', '', 2) == 5)
|
|
assert(s.count('012345', '', 6) == 1)
|
|
|
|
assert(s.count('121314', '1') == 3)
|
|
assert(s.count('121314', '1', 1) == 2)
|
|
assert(s.count('121314', '1', 2) == 2)
|
|
assert(s.count('121314', '1', 1, 2) == 0)
|
|
assert(s.count('121314', '1', 1, 3) == 1)
|
|
|
|
assert(s.split('a b c d e f', '1') == ['a b c d e f'])
|
|
assert(s.split('a b c d e f', ' ') == ['a', 'b', 'c', 'd', 'e', 'f'])
|
|
assert(s.split('a b c d e f', ' ', 2) == ['a', 'b', 'c d e f'])
|
|
assert(s.split('a b c d e f', '') == ['a b c d e f'])
|
|
|
|
assert(s.format("%%") == "%")
|
|
assert(s.format("%i%%", 12) == "12%")
|
|
assert(s.format("%i%%%i", 12, 13) == "12%13")
|
|
assert(s.format("%s%%", "foo") == "foo%")
|
|
assert(s.format("%.1f%%", 3.5) == "3.5%")
|
|
|
|
s="azerty"
|
|
assert(s[1..2] == "ze")
|
|
assert(s[1..] == "zerty")
|
|
assert(s[1..-1] == "zerty")
|
|
|
|
#- string ranges -#
|
|
s="azertyuiop"
|
|
assert(s[0] == "a")
|
|
assert(s[0..1] == "az")
|
|
assert(s[0..2] == "aze")
|
|
assert(s[0..10] == s)
|
|
assert(s[0..size(s)] == s)
|
|
assert(s[0..50] == s) #- upper limit is allowed to be out of range -#
|
|
|
|
#- negative indices start from the end -#
|
|
s="azertyuiop"
|
|
assert(s[-1] == "p")
|
|
assert(s[-2] == "o")
|
|
assert(s[0..-2] == "azertyuio")
|
|
assert(s[-4..-2] == "uio")
|
|
assert(s[-2..-4] == "") #- if range is in wrong order, returns empty string -#
|
|
assert(s[-40..-2] == "azertyuio") #- borders are allowed to be out of range -#
|
|
|
|
# escape
|
|
import string
|
|
assert(string.escape("A") == '"A"')
|
|
assert(string.escape("A", true) == "'A'")
|
|
assert(string.escape("\"") == '"\\""')
|
|
assert(string.escape("\"", true) == '\'"\'')
|
|
|
|
var s ='"a\'b"\''
|
|
assert(string.escape(s) == '"\\"a\'b\\"\'"')
|
|
assert(string.escape(s, true) == '\'"a\\\'b"\\\'\'')
|
|
|
|
# tr
|
|
assert(string.tr("azer", "abcde", "ABCDE") == 'AzEr')
|
|
assert(string.tr("azer", "", "") == 'azer')
|
|
assert(string.tr("azer", "aaa", "ABC") == 'Azer') # only first match works
|
|
assert(string.tr("A_b", "_", " ") == 'A b')
|
|
# tr used to remove characters
|
|
assert(string.tr("qwerty", "qwe", "_") == '_rty')
|
|
|
|
# the following should not crash
|
|
var s1 = 'A string of more than 128 bytes 012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789'
|
|
var s2 = string.format("%i, %s", 1, s1)
|
|
|
|
# replace
|
|
assert(string.replace("hello", "ll", "xx") == "hexxo")
|
|
assert(string.replace("hellollo", "ll", "xx") == "hexxoxxo")
|
|
assert(string.replace("hellollo", "aa", "xx") == "hellollo")
|
|
assert(string.replace("hello", "ll", "") == "heo")
|
|
assert(string.replace("hello", "", "xx") == "hello")
|
|
assert(string.replace("hello", "", "") == "hello")
|
|
|
|
# multi-line strings
|
|
var s = "a" "b""c"
|
|
assert(s == 'abc')
|
|
|
|
s = 'a'"b"'''c'
|
|
assert(s == 'abc')
|
|
|
|
s = "a"
|
|
'b'
|
|
""
|
|
"c"
|
|
assert(s == 'abc')
|
|
|
|
s = "a" #- b -# "b" #--# "c"
|
|
assert(s == 'abc')
|
|
|
|
s = "a"#
|
|
# "z"
|
|
"b" # zz
|
|
"c"
|
|
assert(s == 'abc')
|
|
|
|
# string.format with automatic conversion
|
|
import string
|
|
|
|
assert(string.format("%i", 3) == '3')
|
|
assert(string.format("%i", "3") == '3')
|
|
assert(string.format("%i", "03") == '3')
|
|
assert(string.format("%i", nil) == '')
|
|
|
|
class A def toint() return 42 end end
|
|
a=A()
|
|
class B end
|
|
b=B()
|
|
|
|
assert(string.format("%i", a) == '42')
|
|
assert(string.format("%i", b) == '')
|
|
|
|
assert(string.format("%i", nil) == '')
|
|
assert(string.format("%i", true) == '1')
|
|
assert(string.format("%i", false) == '0')
|
|
|
|
assert(string.format("%c", a) == '*')
|
|
|
|
assert(string.format("%f", 3.5) == '3.500000')
|
|
assert(string.format("%f", 3) == '3.000000')
|
|
assert(string.format("%.1f", 3) == '3.0')
|
|
assert(string.format("%.1f", nil) == '')
|
|
assert(string.format("%.1f", true) == '')
|
|
assert(string.format("%.1f", false) == '')
|
|
assert(string.format("%.1f", a) == '')
|
|
|
|
assert(string.format("%s", a) == '<instance: A()>')
|
|
assert(string.format("%s", 0) == '0')
|
|
assert(string.format("%s", nil) == 'nil')
|
|
assert(string.format("%s", true) == 'true')
|
|
assert(string.format("%s", false) == 'false')
|
|
|
|
# format is now synonym to string.format
|
|
assert(format == string.format)
|
|
assert(format("%.1f", 3) == '3.0')
|
|
|
|
# f-strings
|
|
assert(f"" == '')
|
|
assert(f'' == '')
|
|
assert(f"abc\n\r\t" == 'abc\n\r\t')
|
|
assert(f'{{a}}' == '{a}')
|
|
assert(f'\\\\' == '\\\\')
|
|
|
|
assert(f"A = {1+1}" == 'A = 2')
|
|
assert(f"A = {1+1:s}" == 'A = 2')
|
|
assert(f"A = {1+1:i}" == 'A = 2')
|
|
assert(f"A = {1+1:04i}" == 'A = 0002')
|
|
|
|
assert(f"P = {3.1415:.2f}" == 'P = 3.14')
|
|
|
|
var a = 'foobar{0}'
|
|
assert(f"S = {a}" == 'S = foobar{0}')
|
|
assert(f"S = {a:i}" == 'S = 0')
|
|
assert(f"{a=}" == 'a=foobar{0}')
|