improve generated code for godocability
R=rsc
DELTA=459 (168 added, 279 deleted, 12 changed)
OCL=34005
CL=34007
diff --git a/src/pkg/unicode/maketables.go b/src/pkg/unicode/maketables.go
index 1cdfed67..d1e599c 100644
--- a/src/pkg/unicode/maketables.go
+++ b/src/pkg/unicode/maketables.go
@@ -14,6 +14,7 @@
"http";
"log";
"os";
+ "sort";
"strconv";
"strings";
"regexp";
@@ -235,7 +236,7 @@
die.Log(err);
}
if resp.StatusCode != 200 {
- die.Log("bad GET status for UnicodeData.txt", resp.StatusCode);
+ die.Log("bad GET status for UnicodeData.txt", resp.Status);
}
input := bufio.NewReader(resp.Body);
for {
@@ -279,6 +280,8 @@
fmt.Printf("}\n\n");
}
+ decl := make(sort.StringArray, len(list));
+ ndecl := 0;
for _, name := range list {
if _, ok := category[name]; !ok {
die.Log("unknown category", name);
@@ -286,56 +289,52 @@
// We generate an UpperCase name to serve as concise documentation and an _UnderScored
// name to store the data. This stops godoc dumping all the tables but keeps them
// available to clients.
+ // Cases deserving special comments
+ varDecl := "";
+ switch name {
+ case "letter":
+ varDecl = "\tLetter = letter; // Letter is the set of Unicode letters.\n";
+ case "Nd":
+ varDecl = "\tDigit = _Nd; // Digit is the set of Unicode characters with the \"decimal digit\" property.\n";
+ case "Lu":
+ varDecl = "\tUpper = _Lu; // Upper is the set of Unicode upper case letters.\n";
+ case "Ll":
+ varDecl = "\tLower = _Ll; // Lower is the set of Unicode lower case letters.\n";
+ case "Lt":
+ varDecl = "\tTitle = _Lt; // Title is the set of Unicode title case letters.\n";
+ }
+ if name != "letter" {
+ varDecl += fmt.Sprintf(
+ "\t%s = _%s; // %s is the set of Unicode characters in category %s.\n",
+ name, name, name, name
+ );
+ }
+ decl[ndecl] = varDecl;
+ ndecl++;
if name == "letter" { // special case
dumpRange(
- "\n// Letter is the set of Unicode letters.\n"
- "var Letter = letter\n"
"var letter = []Range {\n",
- letterOp,
- "}\n"
+ letterOp
);
continue;
}
- // Cases deserving special comments
- switch name {
- case "Nd":
- fmt.Printf(
- "\n// Digit is the set of Unicode characters with the \"decimal digit\" property.\n"
- "var Digit = Nd\n\n"
- )
- case "Lu":
- fmt.Printf(
- "\n// Upper is the set of Unicode upper case letters.\n"
- "var Upper = Lu\n\n"
- )
- case "Ll":
- fmt.Printf(
- "\n// Lower is the set of Unicode lower case letters.\n"
- "var Lower = Ll\n\n"
- )
- case "Lt":
- fmt.Printf(
- "\n// Title is the set of Unicode title case letters.\n"
- "var Title = Lt\n\n"
- )
- }
dumpRange(
- fmt.Sprintf(
- "// %s is the set of Unicode characters in category %s.\n"
- "var %s = _%s\n"
- "var _%s = []Range {\n",
- name, name, name, name, name
- ),
- func(code int) bool { return chars[code].category == name },
- "}\n\n"
+ fmt.Sprintf("var _%s = []Range {\n", name),
+ func(code int) bool { return chars[code].category == name }
);
}
+ decl.Sort();
+ fmt.Println("var (");
+ for _, d := range decl {
+ fmt.Print(d);
+ }
+ fmt.Println(")\n");
}
type Op func(code int) bool
const format = "\tRange{0x%04x, 0x%04x, %d},\n";
-func dumpRange(header string, inCategory Op, trailer string) {
+func dumpRange(header string, inCategory Op) {
fmt.Print(header);
next := 0;
// one Range for each iteration
@@ -382,7 +381,7 @@
// next range: start looking where this range ends
next = hi + 1;
}
- fmt.Print(trailer);
+ fmt.Print("}\n\n");
}
func fullCategoryTest(list []string) {
@@ -510,19 +509,27 @@
fmt.Printf("}\n\n");
}
+ decl := make(sort.StringArray, len(list));
+ ndecl := 0;
for _, name := range list {
- fmt.Printf(
- "// %s is the set of Unicode characters in script %s.\n"
- "var %s = _%s\n"
- "var _%s = []Range {\n",
- name, name, name, name, name
+ decl[ndecl] = fmt.Sprintf(
+ "\t%s = _%s;\t// %s is the set of Unicode characters in script %s.\n",
+ name, name, name, name
);
+ ndecl++;
+ fmt.Printf("var _%s = []Range {\n", name);
ranges := foldAdjacent(scripts[name]);
for _, s := range ranges {
fmt.Printf(format, s.Lo, s.Hi, s.Stride);
}
fmt.Printf("}\n\n");
}
+ decl.Sort();
+ fmt.Println("var (");
+ for _, d := range decl {
+ fmt.Print(d);
+ }
+ fmt.Println(")\n");
}
// The script tables have a lot of adjacent elements. Fold them together.