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