]> Cypherpunks.ru repositories - gostls13.git/blobdiff - test/string_lit.go
cmd/compile/internal/inline: score call sites exposed by inlines
[gostls13.git] / test / string_lit.go
index f4f123c9c09009e8b041f39ec167d8384d5ab913..4751b82ccf49836ab17a2dfb345623f8afa6ec4f 100644 (file)
-// $G $F.go && $L $F.$A && ./$A.out
+// 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
 
-var ecode int;
+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);
+               ecode = 1
+               print("FAIL: ", c, ": ", a, "!=", b, "\n")
+               var max int = len(a)
                if len(b) > max {
-                       max = len(b);
+                       max = len(b)
                }
                for i := 0; i < max; i++ {
-                       ac := 0;
-                       bc := 0;
+                       ac := 0
+                       bc := 0
                        if i < len(a) {
-                               ac = int(a[i]);
+                               ac = int(a[i])
                        }
                        if i < len(b) {
-                               bc = int(b[i]);
+                               bc = int(b[i])
                        }
                        if ac != bc {
-                               print "\ta[", i, "] = ", ac, "; b[", i, "] =", bc, "\n";
+                               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;
+       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)");
+               "" +
+                       " " +
+                       "'`" +
+                       "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");
+               "\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)");
+               `\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");
+               "\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)");
-       sys.exit(ecode);
+               `\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)
 }