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