diff options
Diffstat (limited to '')
-rw-r--r-- | test/string_lit.go | 150 |
1 files changed, 150 insertions, 0 deletions
diff --git a/test/string_lit.go b/test/string_lit.go new file mode 100644 index 0000000..4751b82 --- /dev/null +++ b/test/string_lit.go @@ -0,0 +1,150 @@ +// run + +// Copyright 2009 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// Test string literal syntax. + +package main + +import "os" + +var ecode int + +func assert(a, b, c string) { + if a != b { + ecode = 1 + print("FAIL: ", c, ": ", a, "!=", b, "\n") + var max int = len(a) + if len(b) > max { + max = len(b) + } + for i := 0; i < max; i++ { + ac := 0 + bc := 0 + if i < len(a) { + ac = int(a[i]) + } + if i < len(b) { + bc = int(b[i]) + } + if ac != bc { + print("\ta[", i, "] = ", ac, "; b[", i, "] =", bc, "\n") + } + } + panic("string_lit") + } +} + +const ( + gx1 = "aä本☺" + gx2 = "aä\xFF\xFF本☺" + gx2fix = "aä\uFFFD\uFFFD本☺" +) + +var ( + gr1 = []rune(gx1) + gr2 = []rune(gx2) + gb1 = []byte(gx1) + gb2 = []byte(gx2) +) + +func main() { + ecode = 0 + s := + "" + + " " + + "'`" + + "a" + + "ä" + + "本" + + "\a\b\f\n\r\t\v\\\"" + + "\000\123\x00\xca\xFE\u0123\ubabe\U0000babe" + + + `` + + ` ` + + `'"` + + `a` + + `ä` + + `本` + + `\a\b\f\n\r\t\v\\\'` + + `\000\123\x00\xca\xFE\u0123\ubabe\U0000babe` + + `\x\u\U\` + + assert("", ``, "empty") + assert(" ", " ", "blank") + assert("\x61", "a", "lowercase a") + assert("\x61", `a`, "lowercase a (backquote)") + assert("\u00e4", "ä", "a umlaut") + assert("\u00e4", `ä`, "a umlaut (backquote)") + assert("\u672c", "本", "nihon") + assert("\u672c", `本`, "nihon (backquote)") + assert("\x07\x08\x0c\x0a\x0d\x09\x0b\x5c\x22", + "\a\b\f\n\r\t\v\\\"", + "backslashes") + assert("\\a\\b\\f\\n\\r\\t\\v\\\\\\\"", + `\a\b\f\n\r\t\v\\\"`, + "backslashes (backquote)") + assert("\x00\x53\000\xca\376S몾몾", + "\000\123\x00\312\xFE\u0053\ubabe\U0000babe", + "backslashes 2") + assert("\\000\\123\\x00\\312\\xFE\\u0123\\ubabe\\U0000babe", + `\000\123\x00\312\xFE\u0123\ubabe\U0000babe`, + "backslashes 2 (backquote)") + assert("\\x\\u\\U\\", `\x\u\U\`, "backslash 3 (backquote)") + + // test large and surrogate-half runes. perhaps not the most logical place for these tests. + var r int32 + r = 0x10ffff // largest rune value + s = string(r) + assert(s, "\xf4\x8f\xbf\xbf", "largest rune") + r = 0x10ffff + 1 + s = string(r) + assert(s, "\xef\xbf\xbd", "too-large rune") + r = 0xD800 + s = string(r) + assert(s, "\xef\xbf\xbd", "surrogate rune min") + r = 0xDFFF + s = string(r) + assert(s, "\xef\xbf\xbd", "surrogate rune max") + r = -1 + s = string(r) + assert(s, "\xef\xbf\xbd", "negative rune") + + // the large rune tests again, this time using constants instead of a variable. + // these conversions will be done at compile time. + s = string(0x10ffff) // largest rune value + assert(s, "\xf4\x8f\xbf\xbf", "largest rune constant") + s = string(0x10ffff + 1) + assert(s, "\xef\xbf\xbd", "too-large rune constant") + s = string(0xD800) + assert(s, "\xef\xbf\xbd", "surrogate rune min constant") + s = string(0xDFFF) + assert(s, "\xef\xbf\xbd", "surrogate rune max constant") + s = string(-1) + assert(s, "\xef\xbf\xbd", "negative rune") + + // the large rune tests yet again, with a slice. + rs := []rune{0x10ffff, 0x10ffff + 1, 0xD800, 0xDFFF, -1} + s = string(rs) + assert(s, "\xf4\x8f\xbf\xbf\xef\xbf\xbd\xef\xbf\xbd\xef\xbf\xbd\xef\xbf\xbd", "large rune slice") + + assert(string(gr1), gx1, "global ->[]rune") + assert(string(gr2), gx2fix, "global invalid ->[]rune") + assert(string(gb1), gx1, "->[]byte") + assert(string(gb2), gx2, "global invalid ->[]byte") + + var ( + r1 = []rune(gx1) + r2 = []rune(gx2) + b1 = []byte(gx1) + b2 = []byte(gx2) + ) + assert(string(r1), gx1, "->[]rune") + assert(string(r2), gx2fix, "invalid ->[]rune") + assert(string(b1), gx1, "->[]byte") + assert(string(b2), gx2, "invalid ->[]byte") + + os.Exit(ecode) +} |