// 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) }