diff --git a/.github/workflows/check_make_parser.yml b/.github/workflows/check_make_parser.yml index bb9549fd180..cebb5f90c7a 100644 --- a/.github/workflows/check_make_parser.yml +++ b/.github/workflows/check_make_parser.yml @@ -7,13 +7,13 @@ jobs: runs-on: ubuntu-20.04 steps: + - name: Check out code + uses: actions/checkout@v4 + - name: Set up Go - uses: actions/setup-go@v3 + uses: actions/setup-go@v5 with: - go-version: 1.19 - - - name: Check out code - uses: actions/checkout@v3 + go-version-file: go.mod - name: Get dependencies run: | diff --git a/.github/workflows/unit.yml b/.github/workflows/unit.yml index 6f6b233e2e7..d5be053edf0 100644 --- a/.github/workflows/unit.yml +++ b/.github/workflows/unit.yml @@ -6,14 +6,13 @@ jobs: name: Build runs-on: ubuntu-20.04 steps: + - name: Check out code + uses: actions/checkout@v4 - name: Set up Go - uses: actions/setup-go@v3 + uses: actions/setup-go@v5 with: - go-version: 1.19 - - - name: Check out code - uses: actions/checkout@v3 + go-version-file: go.mod - name: Get dependencies run: | diff --git a/.github/workflows/unit_race.yml b/.github/workflows/unit_race.yml index 9d70bc79d20..ff6eea1d9d8 100644 --- a/.github/workflows/unit_race.yml +++ b/.github/workflows/unit_race.yml @@ -7,13 +7,13 @@ jobs: runs-on: ubuntu-20.04 steps: + - name: Check out code + uses: actions/checkout@v4 + - name: Set up Go - uses: actions/setup-go@v3 + uses: actions/setup-go@v5 with: - go-version: 1.19 - - - name: Check out code - uses: actions/checkout@v3 + go-version-file: go.mod - name: Get dependencies run: | diff --git a/go.mod b/go.mod index f2021b44435..09f3bbbe52c 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/dolthub/vitess -go 1.19 +go 1.22 require ( github.com/stretchr/testify v1.4.0 diff --git a/go.sum b/go.sum index 03c40223ccf..c372cca6e68 100644 --- a/go.sum +++ b/go.sum @@ -33,6 +33,7 @@ golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73r golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20211015210444-4f30a5c0130f h1:OfiFi4JbukWwe3lzw+xunroH1mnC1e2Gy5cxNJApiSY= +golang.org/x/net v0.0.0-20211015210444-4f30a5c0130f/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -43,6 +44,7 @@ golang.org/x/sys v0.6.0 h1:MVltZSvRTcU2ljQOhs94SXPftV6DCNnZViHeQps87pQ= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.7 h1:olpwvP2KacW1ZWvsR7uQhoyTYvKAupfQrRGBFM352Gk= +golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= @@ -51,6 +53,7 @@ golang.org/x/tools v0.1.9 h1:j9KsMiaP1c3B0OTQGth0/k+miLGTgLsAFUCrF2vLcF8= golang.org/x/tools v0.1.9/go.mod h1:nABZi5QlRsZVlzPpHl034qft6wpY4eDcsTt5AaioBiU= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= +golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= diff --git a/go/mysql/auth_server_static_linux_test.go b/go/mysql/auth_server_static_linux_test.go new file mode 100755 index 00000000000..7f175fc967c --- /dev/null +++ b/go/mysql/auth_server_static_linux_test.go @@ -0,0 +1,70 @@ +// Copyright 2023 Dolthub, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// +build linux + +package mysql + +import ( + "fmt" + "io/ioutil" + "os" + "syscall" + "testing" + "time" +) + +func TestStaticConfigHUP(t *testing.T) { + tmpFile, err := ioutil.TempFile("", "mysql_auth_server_static_file.json") + if err != nil { + t.Fatalf("couldn't create temp file: %v", err) + } + defer os.Remove(tmpFile.Name()) + oldStr := "str5" + jsonConfig := fmt.Sprintf("{\"%s\":[{\"Password\":\"%s\"}]}", oldStr, oldStr) + if err := ioutil.WriteFile(tmpFile.Name(), []byte(jsonConfig), 0600); err != nil { + t.Fatalf("couldn't write temp file: %v", err) + } + + aStatic := NewAuthServerStatic(tmpFile.Name(), "", 0) + defer aStatic.close() + + if aStatic.getEntries()[oldStr][0].Password != oldStr { + t.Fatalf("%s's Password should still be '%s'", oldStr, oldStr) + } + + hupTest(t, aStatic, tmpFile, oldStr, "str2") + hupTest(t, aStatic, tmpFile, "str2", "str3") // still handling the signal +} + +func hupTest(t *testing.T, aStatic *AuthServerStatic, tmpFile *os.File, oldStr, newStr string) { + jsonConfig := fmt.Sprintf("{\"%s\":[{\"Password\":\"%s\"}]}", newStr, newStr) + if err := ioutil.WriteFile(tmpFile.Name(), []byte(jsonConfig), 0600); err != nil { + t.Fatalf("couldn't overwrite temp file: %v", err) + } + + if aStatic.getEntries()[oldStr][0].Password != oldStr { + t.Fatalf("%s's Password should still be '%s'", oldStr, oldStr) + } + + syscall.Kill(syscall.Getpid(), syscall.SIGHUP) + time.Sleep(100 * time.Millisecond) // wait for signal handler + + if aStatic.getEntries()[oldStr] != nil { + t.Fatalf("Should not have old %s after config reload", oldStr) + } + if aStatic.getEntries()[newStr][0].Password != newStr { + t.Fatalf("%s's Password should be '%s'", newStr, newStr) + } +} \ No newline at end of file diff --git a/go/mysql/auth_server_static_test.go b/go/mysql/auth_server_static_test.go index 16b263b1e73..60630d31941 100644 --- a/go/mysql/auth_server_static_test.go +++ b/go/mysql/auth_server_static_test.go @@ -21,7 +21,6 @@ import ( "io/ioutil" "net" "os" - "syscall" "testing" "time" ) @@ -126,29 +125,6 @@ func TestHostMatcher(t *testing.T) { } } -func TestStaticConfigHUP(t *testing.T) { - tmpFile, err := ioutil.TempFile("", "mysql_auth_server_static_file.json") - if err != nil { - t.Fatalf("couldn't create temp file: %v", err) - } - defer os.Remove(tmpFile.Name()) - oldStr := "str5" - jsonConfig := fmt.Sprintf("{\"%s\":[{\"Password\":\"%s\"}]}", oldStr, oldStr) - if err := ioutil.WriteFile(tmpFile.Name(), []byte(jsonConfig), 0600); err != nil { - t.Fatalf("couldn't write temp file: %v", err) - } - - aStatic := NewAuthServerStatic(tmpFile.Name(), "", 0) - defer aStatic.close() - - if aStatic.getEntries()[oldStr][0].Password != oldStr { - t.Fatalf("%s's Password should still be '%s'", oldStr, oldStr) - } - - hupTest(t, aStatic, tmpFile, oldStr, "str2") - hupTest(t, aStatic, tmpFile, "str2", "str3") // still handling the signal -} - func TestStaticConfigHUPWithRotation(t *testing.T) { tmpFile, err := ioutil.TempFile("", "mysql_auth_server_static_file.json") if err != nil { @@ -180,27 +156,6 @@ func TestStaticConfigHUPWithRotation(t *testing.T) { aStatic.close() } -func hupTest(t *testing.T, aStatic *AuthServerStatic, tmpFile *os.File, oldStr, newStr string) { - jsonConfig := fmt.Sprintf("{\"%s\":[{\"Password\":\"%s\"}]}", newStr, newStr) - if err := ioutil.WriteFile(tmpFile.Name(), []byte(jsonConfig), 0600); err != nil { - t.Fatalf("couldn't overwrite temp file: %v", err) - } - - if aStatic.getEntries()[oldStr][0].Password != oldStr { - t.Fatalf("%s's Password should still be '%s'", oldStr, oldStr) - } - - syscall.Kill(syscall.Getpid(), syscall.SIGHUP) - time.Sleep(100 * time.Millisecond) // wait for signal handler - - if aStatic.getEntries()[oldStr] != nil { - t.Fatalf("Should not have old %s after config reload", oldStr) - } - if aStatic.getEntries()[newStr][0].Password != newStr { - t.Fatalf("%s's Password should be '%s'", newStr, newStr) - } -} - func hupTestWithRotation(t *testing.T, aStatic *AuthServerStatic, tmpFile *os.File, oldStr, newStr string) { jsonConfig := fmt.Sprintf("{\"%s\":[{\"Password\":\"%s\"}]}", newStr, newStr) if err := ioutil.WriteFile(tmpFile.Name(), []byte(jsonConfig), 0600); err != nil { diff --git a/go/mysql/binlog_dump.go b/go/mysql/binlog_dump.go new file mode 100644 index 00000000000..29363d2c427 --- /dev/null +++ b/go/mysql/binlog_dump.go @@ -0,0 +1,98 @@ +/* +Copyright 2022 The Vitess Authors. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +package mysql + +import ( + "encoding/binary" + vtrpcpb "github.com/dolthub/vitess/go/vt/proto/vtrpc" + "github.com/dolthub/vitess/go/vt/vterrors" + "io" +) + +var ( + // BinglogMagicNumber is 4-byte number at the beginning of every binary log + BinglogMagicNumber = []byte{0xfe, 0x62, 0x69, 0x6e} + readPacketErr = vterrors.Errorf(vtrpcpb.Code_INTERNAL, "error reading BinlogDumpGTID packet") +) + +const ( + BinlogDumpNonBlock = 0x01 + BinlogThroughPosition = 0x02 + BinlogThroughGTID = 0x04 +) + +func (c *Conn) parseComBinlogDump(data []byte) (logFile string, binlogPos uint32, err error) { + pos := 1 + + binlogPos, pos, ok := readUint32(data, pos) + if !ok { + return logFile, binlogPos, readPacketErr + } + + pos += 2 // flags + pos += 4 // server-id + + logFile = string(data[pos:]) + return logFile, binlogPos, nil +} + +func (c *Conn) parseComBinlogDumpGTID(data []byte) (logFile string, logPos uint64, position Position, err error) { + // see https://dev.mysql.com/doc/internals/en/com-binlog-dump-gtid.html + pos := 1 + + flags := binary.LittleEndian.Uint16(data[pos : pos+2]) + pos += 2 // flags + pos += 4 // server-id + + fileNameLen, pos, ok := readUint32(data, pos) + if !ok { + return logFile, logPos, position, readPacketErr + } + logFile = string(data[pos : pos+int(fileNameLen)]) + pos += int(fileNameLen) + + logPos, pos, ok = readUint64(data, pos) + if !ok { + return logFile, logPos, position, readPacketErr + } + + if flags&BinlogDumpNonBlock != 0 { + return logFile, logPos, position, io.EOF + } + if flags&BinlogThroughGTID != 0 { + dataSize, pos, ok := readUint32(data, pos) + if !ok { + return logFile, logPos, position, readPacketErr + } + + gtidBytes := data[pos : pos+int(dataSize)] + + // NOTE: A MySQL 8.0 replica sends the GTID set as binary data, not as a human-readable string. + // The main Vitess codebase was parsing a human-readable string and then using DecodePosition + // to parse it, but that doesn't seem to actually work with real MySQL replicas, so we + // diverge here from their implementation. + gtidSet, err := NewMysql56GTIDSetFromSIDBlock(gtidBytes) + if err != nil { + return logFile, logPos, position, err + } + position = Position{ + GTIDSet: gtidSet, + } + } + + return logFile, logPos, position, nil +} diff --git a/go/mysql/binlog_event.go b/go/mysql/binlog_event.go index cc201a9b6d9..cb60d5fb7bb 100644 --- a/go/mysql/binlog_event.go +++ b/go/mysql/binlog_event.go @@ -81,6 +81,8 @@ type BinlogEvent interface { // Timestamp returns the timestamp from the event header. Timestamp() uint32 + // Length returns the size in bytes of this binlog event from the event header. + Length() uint32 // Format returns a BinlogFormat struct based on the event data. // This is only valid if IsFormatDescription() returns true. @@ -122,6 +124,9 @@ type BinlogEvent interface { // IsPseudo is for custom implementations of GTID. IsPseudo() bool + + // Bytes returns the binary representation of the event + Bytes() []byte } // BinlogFormat contains relevant data from the FORMAT_DESCRIPTION_EVENT. @@ -169,8 +174,8 @@ type Query struct { // String pretty-prints a Query. func (q Query) String() string { - return fmt.Sprintf("{Database: %q, Charset: %v, SQL: %q}", - q.Database, q.Charset, q.SQL) + return fmt.Sprintf("{Database: %q, Charset: %v, SQL: %q, Options: %v, SqlMode: %v}", + q.Database, q.Charset, q.SQL, q.Options, q.SqlMode) } // TableMap contains data from a TABLE_MAP_EVENT. @@ -199,6 +204,12 @@ type TableMap struct { Metadata []uint16 } +// String implements the Stringer interface +func (t *TableMap) String() string { + return fmt.Sprintf("{Flags: %v, Database: %q, Name: %q, Types: %v, CanBeNull: %v, Metadata: %v}", + t.Flags, t.Database, t.Name, t.Types, t.CanBeNull, t.Metadata) +} + // Rows contains data from a {WRITE,UPDATE,DELETE}_ROWS_EVENT. type Rows struct { // Flags has the flags from the event. @@ -219,6 +230,21 @@ type Rows struct { Rows []Row } +// String implements the Stringer interface +func (r *Rows) String() string { + rows := "[]" + if r.Rows != nil { + rows = "[" + for _, row := range r.Rows { + rows += row.String() + ", " + } + rows += "]" + } + + return fmt.Sprintf("{Flags: %v, IdentifyColumns: %v, DataColumns: %v, Rows: %s}", + r.Flags, r.IdentifyColumns, r.DataColumns, rows) +} + // Row contains data for a single Row in a Rows event. type Row struct { // NullIdentifyColumns describes which of the identify columns are NULL. @@ -238,6 +264,12 @@ type Row struct { Data []byte } +// String implements the Stringer interface +func (r *Row) String() string { + return fmt.Sprintf("{NullIdentifyColumns: %v, NullColumns: %v, Identify: %v, Data: %v}", + r.NullIdentifyColumns, r.NullColumns, r.Identify, r.Data) +} + // Bitmap is used by the previous structures. type Bitmap struct { // data is the slice this is based on. diff --git a/go/mysql/binlog_event_filepos.go b/go/mysql/binlog_event_filepos.go index 9b2b6e1cef8..a5f49e616f4 100644 --- a/go/mysql/binlog_event_filepos.go +++ b/go/mysql/binlog_event_filepos.go @@ -87,6 +87,10 @@ type filePosQueryEvent struct { filePosFakeEvent } +func (ev filePosQueryEvent) Bytes() []byte { + panic("not implemented") +} + func newFilePosQueryEvent(query string, ts uint32) filePosQueryEvent { return filePosQueryEvent{ query: query, @@ -173,6 +177,10 @@ func (ev filePosFakeEvent) Timestamp() uint32 { return ev.timestamp } +func (ev filePosFakeEvent) Length() uint32 { + return 0 +} + func (ev filePosFakeEvent) Format() (BinlogFormat, error) { return BinlogFormat{}, nil } @@ -221,6 +229,10 @@ type filePosGTIDEvent struct { gtid filePosGTID } +func (ev filePosGTIDEvent) Bytes() []byte { + panic("not implemented") +} + func newFilePosGTIDEvent(file string, pos int, timestamp uint32) filePosGTIDEvent { return filePosGTIDEvent{ filePosFakeEvent: filePosFakeEvent{ diff --git a/go/mysql/binlog_event_json.go b/go/mysql/binlog_event_json.go index 4b371d3d581..fadf6fd02c4 100644 --- a/go/mysql/binlog_event_json.go +++ b/go/mysql/binlog_event_json.go @@ -50,6 +50,20 @@ const ( jsonFalseLiteral = '\x02' ) +// ConvertBinaryJSONToSQL converts the specified |data| in MySQL's internal binary encoding +// to a SQL expression that can be evaluated. +func ConvertBinaryJSONToSQL(data []byte) (string, error) { + bytes, err := printJSONData(data) + if err != nil { + return "", err + } + + if bytes == nil { + return "", nil + } + return string(bytes), nil +} + // printJSONData parses the MySQL binary format for JSON data, and prints // the result as a string. func printJSONData(data []byte) ([]byte, error) { diff --git a/go/mysql/binlog_event_make.go b/go/mysql/binlog_event_make.go index 3df5f3fb59d..fbbaaa11efd 100644 --- a/go/mysql/binlog_event_make.go +++ b/go/mysql/binlog_event_make.go @@ -18,6 +18,11 @@ package mysql import ( "encoding/binary" + "hash/crc32" +) + +const ( + FlagLogEventArtificial = 0x20 ) // This file contains utility methods to create binlog replication @@ -67,23 +72,23 @@ func NewMariaDBBinlogFormat() BinlogFormat { } } -// FakeBinlogStream is used to generate consistent BinlogEvent packets -// for a stream. It makes sure the ServerID and log positions are -// reasonable. -type FakeBinlogStream struct { +// BinlogStream is used to generate consistent BinlogEvent packets +// for a stream. It stores the ServerID, log position, and timestamp +// fields which are needed for a binlog event's outer packet. +type BinlogStream struct { // ServerID is the server ID of the originating mysql-server. ServerID uint32 // LogPosition is an incrementing log position. LogPosition uint32 - // Timestamp is a uint32 of when the events occur. It is not changed. + // Timestamp is a uint32 indicating when the events occurred. Timestamp uint32 } -// NewFakeBinlogStream returns a simple FakeBinlogStream. -func NewFakeBinlogStream() *FakeBinlogStream { - return &FakeBinlogStream{ +// NewFakeBinlogStream returns a simple BinlogStream with hardcoded values for testing. +func NewFakeBinlogStream() *BinlogStream { + return &BinlogStream{ ServerID: 1, LogPosition: 4, Timestamp: 1407805592, @@ -92,7 +97,7 @@ func NewFakeBinlogStream() *FakeBinlogStream { // Packetize adds the binlog event header to a packet, and optionally // the checksum. -func (s *FakeBinlogStream) Packetize(f BinlogFormat, typ byte, flags uint16, data []byte) []byte { +func (s *BinlogStream) Packetize(f BinlogFormat, typ byte, flags uint16, data []byte) []byte { length := int(f.HeaderLength) + len(data) if typ == eFormatDescriptionEvent || f.ChecksumAlgorithm == BinlogChecksumAlgCRC32 { // Just add 4 zeroes to the end. @@ -100,7 +105,12 @@ func (s *FakeBinlogStream) Packetize(f BinlogFormat, typ byte, flags uint16, dat } result := make([]byte, length) - binary.LittleEndian.PutUint32(result[0:4], s.Timestamp) + switch typ { + case eRotateEvent, eHeartbeatEvent: + // timestamp remains zero + default: + binary.LittleEndian.PutUint32(result[0:4], s.Timestamp) + } result[4] = typ binary.LittleEndian.PutUint32(result[5:9], s.ServerID) binary.LittleEndian.PutUint32(result[9:13], uint32(length)) @@ -109,6 +119,13 @@ func (s *FakeBinlogStream) Packetize(f BinlogFormat, typ byte, flags uint16, dat binary.LittleEndian.PutUint16(result[17:19], flags) } copy(result[f.HeaderLength:], data) + + switch f.ChecksumAlgorithm { + case BinlogChecksumAlgCRC32: + checksum := crc32.ChecksumIEEE(result[0 : length-4]) + binary.LittleEndian.PutUint32(result[length-4:], checksum) + } + return result } @@ -120,7 +137,7 @@ func NewInvalidEvent() BinlogEvent { // NewFormatDescriptionEvent creates a new FormatDescriptionEvent // based on the provided BinlogFormat. It uses a mysql56BinlogEvent // but could use a MariaDB one. -func NewFormatDescriptionEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent { +func NewFormatDescriptionEvent(f BinlogFormat, s *BinlogStream) BinlogEvent { length := 2 + // binlog-version 50 + // server version 4 + // create timestamp @@ -141,7 +158,7 @@ func NewFormatDescriptionEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent // NewInvalidFormatDescriptionEvent returns an invalid FormatDescriptionEvent. // The binlog version is set to 3. It IsValid() though. -func NewInvalidFormatDescriptionEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent { +func NewInvalidFormatDescriptionEvent(f BinlogFormat, s *BinlogStream) BinlogEvent { length := 75 data := make([]byte, length) data[0] = 3 @@ -152,27 +169,53 @@ func NewInvalidFormatDescriptionEvent(f BinlogFormat, s *FakeBinlogStream) Binlo // NewRotateEvent returns a RotateEvent. // The timestamp of such an event should be zero, so we patch it in. -func NewRotateEvent(f BinlogFormat, s *FakeBinlogStream, position uint64, filename string) BinlogEvent { +func NewRotateEvent(f BinlogFormat, s *BinlogStream, position uint64, filename string) BinlogEvent { length := 8 + // position len(filename) data := make([]byte, length) binary.LittleEndian.PutUint64(data[0:8], position) + copy(data[8:], filename) ev := s.Packetize(f, eRotateEvent, 0, data) - ev[0] = 0 - ev[1] = 0 - ev[2] = 0 - ev[3] = 0 + return NewMysql56BinlogEvent(ev) +} + +func NewFakeRotateEvent(f BinlogFormat, s *BinlogStream, filename string) BinlogEvent { + length := 8 + // position + len(filename) + data := make([]byte, length) + binary.LittleEndian.PutUint64(data[0:8], 4) + copy(data[8:], filename) + + ev := s.Packetize(f, eRotateEvent, FlagLogEventArtificial, data) + return NewMysql56BinlogEvent(ev) +} + +// NewHeartbeatEvent returns a HeartbeatEvent. +// see https://dev.mysql.com/doc/internals/en/heartbeat-event.html +func NewHeartbeatEvent(f BinlogFormat, s *BinlogStream) BinlogEvent { + ev := s.Packetize(f, eHeartbeatEvent, 0, []byte{}) + return NewMysql56BinlogEvent(ev) +} + +// NewHeartbeatEvent returns a HeartbeatEvent. +// see https://dev.mysql.com/doc/internals/en/heartbeat-event.html +func NewHeartbeatEventWithLogFile(f BinlogFormat, s *BinlogStream, filename string) BinlogEvent { + length := len(filename) + data := make([]byte, length) + copy(data, filename) + + ev := s.Packetize(f, eHeartbeatEvent, 0, data) return NewMysql56BinlogEvent(ev) } // NewQueryEvent makes up a QueryEvent based on the Query structure. -func NewQueryEvent(f BinlogFormat, s *FakeBinlogStream, q Query) BinlogEvent { +func NewQueryEvent(f BinlogFormat, s *BinlogStream, q Query) BinlogEvent { statusVarLength := 0 if q.Charset != nil { statusVarLength += 1 + 2 + 2 + 2 } - length := 4 + // slave proxy id + length := 4 + // proxy id 4 + // execution time 1 + // schema length 2 + // error code @@ -210,7 +253,7 @@ func NewQueryEvent(f BinlogFormat, s *FakeBinlogStream, q Query) BinlogEvent { // NewInvalidQueryEvent returns an invalid QueryEvent. IsValid is however true. // sqlPos is out of bounds. -func NewInvalidQueryEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent { +func NewInvalidQueryEvent(f BinlogFormat, s *BinlogStream) BinlogEvent { length := 100 data := make([]byte, length) data[4+4] = 200 // > 100 @@ -220,7 +263,7 @@ func NewInvalidQueryEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent { } // NewXIDEvent returns a XID event. We do not use the data, so keep it 0. -func NewXIDEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent { +func NewXIDEvent(f BinlogFormat, s *BinlogStream) BinlogEvent { length := 8 data := make([]byte, length) @@ -229,7 +272,7 @@ func NewXIDEvent(f BinlogFormat, s *FakeBinlogStream) BinlogEvent { } // NewIntVarEvent returns an IntVar event. -func NewIntVarEvent(f BinlogFormat, s *FakeBinlogStream, typ byte, value uint64) BinlogEvent { +func NewIntVarEvent(f BinlogFormat, s *BinlogStream, typ byte, value uint64) BinlogEvent { length := 9 data := make([]byte, length) @@ -248,8 +291,8 @@ func NewIntVarEvent(f BinlogFormat, s *FakeBinlogStream, typ byte, value uint64) } // NewMariaDBGTIDEvent returns a MariaDB specific GTID event. -// It ignores the Server in the gtid, instead uses the FakeBinlogStream.ServerID. -func NewMariaDBGTIDEvent(f BinlogFormat, s *FakeBinlogStream, gtid MariadbGTID, hasBegin bool) BinlogEvent { +// It ignores the Server in the gtid, instead uses the BinlogStream.ServerID. +func NewMariaDBGTIDEvent(f BinlogFormat, s *BinlogStream, gtid MariadbGTID, hasBegin bool) BinlogEvent { length := 8 + // sequence 4 + // domain 1 // flags2 @@ -279,9 +322,39 @@ func NewMariaDBGTIDEvent(f BinlogFormat, s *FakeBinlogStream, gtid MariadbGTID, return NewMariadbBinlogEvent(ev) } +// NewMySQLGTIDEvent returns a MySQL specific GTID event. +func NewMySQLGTIDEvent(f BinlogFormat, s *BinlogStream, gtid Mysql56GTID, hasBegin bool) BinlogEvent { + length := 1 + // flags + 16 + // SID (server UUID) + 8 // GNO (sequence number, signed int) + data := make([]byte, length) + + // flags + data[0] = 0 + + // SID (server UUID) + sid := gtid.Server + copy(data[1:17], sid[:]) + + // GNO (sequence number, signed int) + sequence := gtid.Sequence + binary.LittleEndian.PutUint64(data[17:25], uint64(sequence)) + + const FLStandalone = 1 + var flags2 byte + if !hasBegin { + flags2 |= FLStandalone + } + data[0] = flags2 + + ev := s.Packetize(f, eGTIDEvent, 0, data) + return NewMysql56BinlogEvent(ev) +} + + // NewTableMapEvent returns a TableMap event. // Only works with post_header_length=8. -func NewTableMapEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, tm *TableMap) BinlogEvent { +func NewTableMapEvent(f BinlogFormat, s *BinlogStream, tableID uint64, tm *TableMap) BinlogEvent { if f.HeaderSize(eTableMapEvent) != 8 { panic("Not implemented, post_header_length!=8") } @@ -296,9 +369,9 @@ func NewTableMapEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, tm *T 1 + // table name length len(tm.Name) + 1 + // [00] - 1 + // column-count FIXME(alainjobart) len enc + lenEncIntSize(uint64(len(tm.Types))) + // column-count len enc len(tm.Types) + - 1 + // lenenc-str column-meta-def FIXME(alainjobart) len enc + lenEncIntSize(uint64(metadataLength)) + // lenenc-str column-meta-def metadataLength + len(tm.CanBeNull.data) data := make([]byte, length) @@ -320,15 +393,10 @@ func NewTableMapEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, tm *T data[pos] = 0 pos++ - data[pos] = byte(len(tm.Types)) // FIXME(alainjobart) lenenc - pos++ - + pos = writeLenEncInt(data, pos, uint64(len(tm.Types))) pos += copy(data[pos:], tm.Types) - // Per-column meta data. Starting with len-enc length. - // FIXME(alainjobart) lenenc - data[pos] = byte(metadataLength) - pos++ + pos = writeLenEncInt(data, pos, uint64(metadataLength)) for c, typ := range tm.Types { pos = metadataWrite(data, pos, typ, tm.Metadata[c]) } @@ -343,17 +411,17 @@ func NewTableMapEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, tm *T } // NewWriteRowsEvent returns a WriteRows event. Uses v2. -func NewWriteRowsEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, rows Rows) BinlogEvent { +func NewWriteRowsEvent(f BinlogFormat, s *BinlogStream, tableID uint64, rows Rows) BinlogEvent { return newRowsEvent(f, s, eWriteRowsEventV2, tableID, rows) } // NewUpdateRowsEvent returns an UpdateRows event. Uses v2. -func NewUpdateRowsEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, rows Rows) BinlogEvent { +func NewUpdateRowsEvent(f BinlogFormat, s *BinlogStream, tableID uint64, rows Rows) BinlogEvent { return newRowsEvent(f, s, eUpdateRowsEventV2, tableID, rows) } // NewDeleteRowsEvent returns an DeleteRows event. Uses v2. -func NewDeleteRowsEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, rows Rows) BinlogEvent { +func NewDeleteRowsEvent(f BinlogFormat, s *BinlogStream, tableID uint64, rows Rows) BinlogEvent { return newRowsEvent(f, s, eDeleteRowsEventV2, tableID, rows) } @@ -361,15 +429,25 @@ func NewDeleteRowsEvent(f BinlogFormat, s *FakeBinlogStream, tableID uint64, row // eWriteRowsEventV1, eWriteRowsEventV2, // eUpdateRowsEventV1, eUpdateRowsEventV2, // eDeleteRowsEventV1, eDeleteRowsEventV2. -func newRowsEvent(f BinlogFormat, s *FakeBinlogStream, typ byte, tableID uint64, rows Rows) BinlogEvent { +func newRowsEvent(f BinlogFormat, s *BinlogStream, typ byte, tableID uint64, rows Rows) BinlogEvent { if f.HeaderSize(typ) == 6 { panic("Not implemented, post_header_length==6") } + hasIdentify := typ == eUpdateRowsEventV1 || typ == eUpdateRowsEventV2 || + typ == eDeleteRowsEventV1 || typ == eDeleteRowsEventV2 + hasData := typ == eWriteRowsEventV1 || typ == eWriteRowsEventV2 || + typ == eUpdateRowsEventV1 || typ == eUpdateRowsEventV2 + + rowLen := rows.DataColumns.Count() + if hasIdentify { + rowLen = rows.IdentifyColumns.Count() + } + length := 6 + // table id 2 + // flags 2 + // extra data length, no extra data. - 1 + // num columns FIXME(alainjobart) len enc + lenEncIntSize(uint64(rowLen)) + // num columns len(rows.IdentifyColumns.data) + // only > 0 for Update & Delete len(rows.DataColumns.data) // only > 0 for Write & Update for _, row := range rows.Rows { @@ -380,11 +458,6 @@ func newRowsEvent(f BinlogFormat, s *FakeBinlogStream, typ byte, tableID uint64, } data := make([]byte, length) - hasIdentify := typ == eUpdateRowsEventV1 || typ == eUpdateRowsEventV2 || - typ == eDeleteRowsEventV1 || typ == eDeleteRowsEventV2 - hasData := typ == eWriteRowsEventV1 || typ == eWriteRowsEventV2 || - typ == eUpdateRowsEventV1 || typ == eUpdateRowsEventV2 - data[0] = byte(tableID) data[1] = byte(tableID >> 8) data[2] = byte(tableID >> 16) @@ -396,12 +469,7 @@ func newRowsEvent(f BinlogFormat, s *FakeBinlogStream, typ byte, tableID uint64, data[8] = 0x02 data[9] = 0x00 - if hasIdentify { - data[10] = byte(rows.IdentifyColumns.Count()) // FIXME(alainjobart) len - } else { - data[10] = byte(rows.DataColumns.Count()) // FIXME(alainjobart) len - } - pos := 11 + pos := writeLenEncInt(data, 10, uint64(rowLen)) if hasIdentify { pos += copy(data[pos:], rows.IdentifyColumns.data) diff --git a/go/mysql/binlog_event_mysql56_test.go b/go/mysql/binlog_event_mysql56_test.go index 3e3dd6e88f9..5742704cb74 100644 --- a/go/mysql/binlog_event_mysql56_test.go +++ b/go/mysql/binlog_event_mysql56_test.go @@ -126,4 +126,4 @@ func TestMysql56ParsePosition(t *testing.T) { if !got.Equal(want) { t.Errorf("(&mysql56{}).ParsePosition(%#v) = %#v, want %#v", input, got, want) } -} +} \ No newline at end of file diff --git a/go/mysql/binlog_event_test.go b/go/mysql/binlog_event_test.go index 230bdf48e42..461a24dd040 100644 --- a/go/mysql/binlog_event_test.go +++ b/go/mysql/binlog_event_test.go @@ -34,7 +34,7 @@ func TestQueryString(t *testing.T) { Charset: charset, SQL: "sql", } - want := fmt.Sprintf(`{Database: "test_database", Charset: %s, SQL: "sql"}`, charset.String()) + want := fmt.Sprintf(`{Database: "test_database", Charset: %s, SQL: "sql", Options: 0, SqlMode: 0}`, charset.String()) if got := input.String(); got != want { t.Errorf("%#v.String() = %#v, want %#v", input, got, want) } @@ -46,7 +46,7 @@ func TestQueryStringNilCharset(t *testing.T) { Charset: nil, SQL: "sql", } - want := `{Database: "test_database", Charset: , SQL: "sql"}` + want := `{Database: "test_database", Charset: , SQL: "sql", Options: 0, SqlMode: 0}` if got := input.String(); got != want { t.Errorf("%#v.String() = %#v, want %#v", input, got, want) } diff --git a/go/mysql/conn.go b/go/mysql/conn.go index 439ff282608..6f127985ccb 100644 --- a/go/mysql/conn.go +++ b/go/mysql/conn.go @@ -266,6 +266,25 @@ func (c *Conn) startWriterBuffering() { c.bufferedWriter.Reset(c.Conn) } +// FlushBuffer flushes the buffered writer used by this connection, if one is currently in use. If no +// buffering is currently in use, this method is a no-op. Our fork of Vitess typically handles flushing +// buffers in a defer function, so callers generally don't need to manually flush the connection's +// buffer. The exception is for the COM_DUMP_BINLOG_GTID command – this command leaves the connection +// for the server to continue pushing events over, and the defer function set by the connection handling +// code won't get called until the stream is closed, which could be hours or days later. +// +// TODO: The latest Vitess code uses a flush timer that periodically flushes the buffer. We should +// switch over to that since it's a cleaner solution and could potentially benefit other commands +// as well, but it's a more invasive change, so we're starting with simply allowing the caller to +// explicitly flush the buffer. +func (c *Conn) FlushBuffer() error { + if c.bufferedWriter == nil { + return nil + } + + return c.bufferedWriter.Flush() +} + // flush flushes the written data to the socket. // This must be called to terminate startBuffering. func (c *Conn) flush() error { @@ -1347,7 +1366,11 @@ func (c *Conn) handleNextCommand(handler Handler) error { // Clean up and reset the connection c.recycleReadPacket() c.discardCursor() - handler.ComResetConnection(c) + err = handler.ComResetConnection(c) + if err != nil { + log.Errorf("Error resetting connection (ID %d): %v", c.ConnectionID, err) + c.writeErrorPacketFromError(err) + } // Reset prepared statements c.PrepareData = make(map[uint32]*PrepareData) err = c.writeOKPacket(0, 0, 0, 0) @@ -1355,6 +1378,20 @@ func (c *Conn) handleNextCommand(handler Handler) error { c.writeErrorPacketFromError(err) } + case ComBinlogDumpGTID: + ok := c.handleComBinlogDumpGTID(handler, data) + if !ok { + return fmt.Errorf("error handling ComBinlogDumpGTID packet: %v", data) + } + return nil + + case ComRegisterReplica: + ok := c.handleComRegisterReplica(handler, data) + if !ok { + return fmt.Errorf("error handling ComRegisterReplica packet: %v", data) + } + return nil + default: log.Errorf("Got unhandled packet (default) from %s, returning error: %v", c, data) c.recycleReadPacket() @@ -1367,6 +1404,61 @@ func (c *Conn) handleNextCommand(handler Handler) error { return nil } +func (c *Conn) handleComRegisterReplica(handler Handler, data []byte) (kontinue bool) { + binlogReplicaHandler, ok := handler.(BinlogReplicaHandler) + if !ok { + log.Warningf("received COM_REGISTER_REPLICA command, but handler does not implement BinlogReplicaHandler") + return true + } + + c.recycleReadPacket() + + replicaHost, replicaPort, replicaUser, replicaPassword, err := c.parseComRegisterReplica(data) + if err != nil { + log.Errorf("conn %v: parseComRegisterReplica failed: %v", c.ID(), err) + return false + } + if err := binlogReplicaHandler.ComRegisterReplica(c, replicaHost, replicaPort, replicaUser, replicaPassword); err != nil { + c.writeErrorPacketFromError(err) + return false + } + + if err := c.writeOKPacket(0, 0, c.StatusFlags, 0); err != nil { + c.writeErrorPacketFromError(err) + } + return true +} + +func (c *Conn) handleComBinlogDumpGTID(handler Handler, data []byte) (kontinue bool) { + binlogReplicaHandler, ok := handler.(BinlogReplicaHandler) + if !ok { + log.Warningf("received BINLOG_DUMP_GTID command, but handler does not implement BinlogReplicaHandler") + return true + } + + c.recycleReadPacket() + kontinue = true + + c.startWriterBuffering() + defer func() { + if err := c.flush(); err != nil { + log.Errorf("conn %v: flush() failed: %v", c.ID(), err) + kontinue = false + } + }() + + logFile, logPos, position, err := c.parseComBinlogDumpGTID(data) + if err != nil { + log.Errorf("conn %v: parseComBinlogDumpGTID failed: %v", c.ID(), err) + return false + } + if err := binlogReplicaHandler.ComBinlogDumpGTID(c, logFile, logPos, position.GTIDSet); err != nil { + log.Error(err.Error()) + return false + } + return kontinue +} + // writeNumRows writes the specified number of rows to the handler, the end result, and flushes func (c *Conn) writeNumRows(numRows int) (err error) { origRows := c.cs.pending.Rows diff --git a/go/mysql/constants.go b/go/mysql/constants.go index cbec47136b0..467768ebd26 100644 --- a/go/mysql/constants.go +++ b/go/mysql/constants.go @@ -232,6 +232,9 @@ const ( // ComBinlogDumpGTID is COM_BINLOG_DUMP_GTID. ComBinlogDumpGTID = 0x1e + // ComRegisterReplica is COM_REGISTER_REPLICA + ComRegisterReplica = 0x15 + // OKPacket is the header of the OK packet. OKPacket = 0x00 diff --git a/go/mysql/encoding.go b/go/mysql/encoding.go index 53b9e2efc73..c34a714b780 100644 --- a/go/mysql/encoding.go +++ b/go/mysql/encoding.go @@ -188,6 +188,11 @@ func readEOFString(data []byte, pos int) (string, int, bool) { return string(data[pos:]), len(data) - pos, true } +func readUint8(data []byte, pos int) (uint8, int, bool) { + b, pos, ok := readByte(data, pos) + return uint8(b), pos, ok +} + func readUint16(data []byte, pos int) (uint16, int, bool) { if pos+1 >= len(data) { return 0, 0, false diff --git a/go/mysql/filepos_gtid.go b/go/mysql/filepos_gtid.go index 9894e405494..92aa5d38e64 100644 --- a/go/mysql/filepos_gtid.go +++ b/go/mysql/filepos_gtid.go @@ -108,6 +108,10 @@ func (gtid filePosGTID) Contains(other GTIDSet) bool { return gtid.ContainsGTID(filePosOther) } +func (gtid filePosGTID) Subtract(GTIDSet) GTIDSet { + panic("not implemented") +} + // Equal implements GTIDSet.Equal(). func (gtid filePosGTID) Equal(other GTIDSet) bool { filePosOther, ok := other.(filePosGTID) diff --git a/go/mysql/flavor_mysql.go b/go/mysql/flavor_mysql.go index 6653d058887..377f3d774e9 100644 --- a/go/mysql/flavor_mysql.go +++ b/go/mysql/flavor_mysql.go @@ -38,7 +38,7 @@ func (mysqlFlavor) masterGTIDSet(c *Conn) (GTIDSet, error) { if len(qr.Rows) != 1 || len(qr.Rows[0]) != 1 { return nil, vterrors.Errorf(vtrpc.Code_INTERNAL, "unexpected result format for gtid_executed: %#v", qr) } - return parseMysql56GTIDSet(qr.Rows[0][0].ToString()) + return ParseMysql56GTIDSet(qr.Rows[0][0].ToString()) } func (mysqlFlavor) startSlaveCommand() string { @@ -109,7 +109,7 @@ func (mysqlFlavor) status(c *Conn) (SlaveStatus, error) { } status := parseSlaveStatus(resultMap) - status.Position.GTIDSet, err = parseMysql56GTIDSet(resultMap["Executed_Gtid_Set"]) + status.Position.GTIDSet, err = ParseMysql56GTIDSet(resultMap["Executed_Gtid_Set"]) if err != nil { return SlaveStatus{}, vterrors.Wrapf(err, "SlaveStatus can't parse MySQL 5.6 GTID (Executed_Gtid_Set: %#v)", resultMap["Executed_Gtid_Set"]) } diff --git a/go/mysql/gtid_set.go b/go/mysql/gtid_set.go index 7e2542165e6..0d43ee9a99d 100644 --- a/go/mysql/gtid_set.go +++ b/go/mysql/gtid_set.go @@ -40,6 +40,12 @@ type GTIDSet interface { // Contains returns true if the set is a superset of another set. Contains(GTIDSet) bool + // Subtract returns a new GTIDSet that is the difference between the receiver + // and the supplied GTIDSet. Note that interval end points in a GTID Set are *inclusive* at both + // ends of the interval, so a subtraction operation where intervals overlap will exclude the + // overlapping endpoint the interval in the new GTID Set. + Subtract(GTIDSet) GTIDSet + // Equal returns true if the set is equal to another set. Equal(GTIDSet) bool diff --git a/go/mysql/gtid_test.go b/go/mysql/gtid_test.go index ff811f6712e..c0d0f7ed48f 100644 --- a/go/mysql/gtid_test.go +++ b/go/mysql/gtid_test.go @@ -201,6 +201,7 @@ func (f fakeGTID) GTIDSet() GTIDSet { return nil } func (fakeGTID) ContainsGTID(GTID) bool { return false } func (fakeGTID) Contains(GTIDSet) bool { return false } +func (fakeGTID) Subtract(GTIDSet) GTIDSet { return nil } func (f fakeGTID) Equal(other GTIDSet) bool { otherFake, ok := other.(fakeGTID) if !ok { diff --git a/go/mysql/mariadb_gtid.go b/go/mysql/mariadb_gtid.go index 5b6bd6481cb..d8503081ab5 100644 --- a/go/mysql/mariadb_gtid.go +++ b/go/mysql/mariadb_gtid.go @@ -166,6 +166,10 @@ func (gtidSet MariadbGTIDSet) Contains(other GTIDSet) bool { return true } +func (gtidSet MariadbGTIDSet) Subtract(GTIDSet) GTIDSet { + panic("not implemented") +} + // Equal implements GTIDSet.Equal(). func (gtidSet MariadbGTIDSet) Equal(other GTIDSet) bool { mdbOther, ok := other.(MariadbGTIDSet) diff --git a/go/mysql/mysql56_gtid_set.go b/go/mysql/mysql56_gtid_set.go index 1c0c0ee7f20..8a219ac4908 100644 --- a/go/mysql/mysql56_gtid_set.go +++ b/go/mysql/mysql56_gtid_set.go @@ -35,6 +35,36 @@ func (iv interval) contains(other interval) bool { return iv.start <= other.start && other.end <= iv.end } +// overlaps returns true if any part of |other| overlaps with this interval. +func (iv interval) overlaps(other interval) bool { + return other.start >= iv.start && other.start <= iv.end || + other.end <= iv.end && other.end >= iv.start || + other.start == iv.start && other.end == iv.end +} + +// subtract returns a slice of intervals created by subtracting |other| from this interval. If this interval is +// completely contained by |other|, then nil is returned. If |other| overlaps with the middle of this interval, but +// not the start or end, then two intervals are returned. Note that interval end points are *inclusive* at both +// ends, so a subtraction operation will exclude both end points from any new intervals returned. +func (iv interval) subtract(other interval) []interval { + if iv.start < other.start { + if iv.end > other.end { + return []interval{ + {start: iv.start, end: other.start - 1}, + {start: other.end + 1, end: iv.end}, + } + } else { + return []interval{{start: iv.start, end: other.start - 1}} + } + } else { + if iv.end > other.end { + return []interval{{start: other.end + 1, end: iv.end}} + } else { + return nil + } + } +} + type intervalList []interval // Len implements sort.Interface. @@ -70,10 +100,10 @@ func parseInterval(s string) (interval, error) { } } -// parseMysql56GTIDSet is registered as a GTIDSet parser. +// ParseMysql56GTIDSet is registered as a GTIDSet parser. // // https://dev.mysql.com/doc/refman/5.6/en/replication-gtids-concepts.html -func parseMysql56GTIDSet(s string) (GTIDSet, error) { +func ParseMysql56GTIDSet(s string) (GTIDSet, error) { set := Mysql56GTIDSet{} // gtid_set: uuid_set [, uuid_set] ... @@ -231,6 +261,41 @@ func (set Mysql56GTIDSet) Contains(other GTIDSet) bool { return true } +func (set Mysql56GTIDSet) Subtract(arg GTIDSet) GTIDSet { + other, ok := arg.(Mysql56GTIDSet) + if !ok { + panic("can't compare GTID sets of different flavors") + } + + result := make(Mysql56GTIDSet) + for _, sid := range set.SIDs() { + if _, ok := other[sid]; ok { + leftIntervals := set[sid] + rightIntervals := other[sid] + for _, leftInterval := range leftIntervals { + found := false + for rightIntervalsIdx := 0; rightIntervalsIdx < len(rightIntervals); rightIntervalsIdx++ { + rightInterval := rightIntervals[rightIntervalsIdx] + if leftInterval.overlaps(rightInterval) { + found = true + newIntervals := leftInterval.subtract(rightInterval) + if newIntervals != nil { + result[sid] = append(result[sid], newIntervals...) + } + } + } + if !found { + result[sid] = append(result[sid], leftInterval) + } + } + } else { + result[sid] = set[sid] + } + } + + return result +} + // Equal implements GTIDSet. func (set Mysql56GTIDSet) Equal(other GTIDSet) bool { other56, ok := other.(Mysql56GTIDSet) @@ -408,5 +473,5 @@ func NewMysql56GTIDSetFromSIDBlock(data []byte) (Mysql56GTIDSet, error) { } func init() { - gtidSetParsers[mysql56FlavorID] = parseMysql56GTIDSet + gtidSetParsers[mysql56FlavorID] = ParseMysql56GTIDSet } diff --git a/go/mysql/mysql56_gtid_set_test.go b/go/mysql/mysql56_gtid_set_test.go index a52dc924349..19596ac5b82 100644 --- a/go/mysql/mysql56_gtid_set_test.go +++ b/go/mysql/mysql56_gtid_set_test.go @@ -91,13 +91,13 @@ func TestParseMysql56GTIDSet(t *testing.T) { } for input, want := range table { - got, err := parseMysql56GTIDSet(input) + got, err := ParseMysql56GTIDSet(input) if err != nil { t.Errorf("unexpected error: %v", err) continue } if !got.Equal(want) { - t.Errorf("parseMysql56GTIDSet(%#v) = %#v, want %#v", input, got, want) + t.Errorf("ParseMysql56GTIDSet(%#v) = %#v, want %#v", input, got, want) } } } @@ -116,9 +116,9 @@ func TestParseMysql56GTIDSetInvalid(t *testing.T) { } for _, input := range table { - _, err := parseMysql56GTIDSet(input) + _, err := ParseMysql56GTIDSet(input) if err == nil { - t.Errorf("parseMysql56GTIDSet(%#v) expected error, got none", err) + t.Errorf("ParseMysql56GTIDSet(%#v) expected error, got none", err) } } } @@ -417,6 +417,142 @@ func TestMysql56GTIDSetAddGTID(t *testing.T) { } } +func TestMysql56GTIDSetSubtract(t *testing.T) { + sid1 := SID{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15} + sid2 := SID{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16} + sid3 := SID{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 17} + + table := []struct { + name string + left, right, expected Mysql56GTIDSet + }{ + { + name: "non-overlapping GTIDSets don't subtract anything", + left: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + right: Mysql56GTIDSet{ + sid3: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{6, 10}, {51, 52}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + }, + { + name: "identical GTIDSets produce an empty GTIDSet", + left: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + expected: Mysql56GTIDSet{}, + }, + { + name: "simple subtraction: remove half of one interval", + left: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{20, 25}, {100, 102}}, + sid3: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{26, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + }, + { + name: "simple subtraction: remove one interval, split one interval", + left: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{20, 25}, {43, 44}}, + sid3: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{26, 30}, {35, 40}, {42, 42}, {45, 45}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + }, + { + name: "simple subtraction: unsorted intervals: remove one interval, split one interval", + left: Mysql56GTIDSet{ + sid1: []interval{{35, 40}, {42, 45}, {20, 30}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{20, 25}, {43, 44}}, + sid3: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{35, 40}, {42, 42}, {45, 45}, {26, 30}}, + sid2: []interval{{1, 5}, {50, 50}, {60, 70}}, + }, + }, + { + name: "simple subtraction: multiple SIDs", + left: Mysql56GTIDSet{ + sid1: []interval{{20, 30}, {35, 40}, {42, 45}}, + sid2: []interval{{2, 5}, {50, 50}, {60, 70}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{19, 29}, {43, 49}}, + sid2: []interval{{1, 5}, {64, 65}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{30, 30}, {35, 40}, {42, 42}}, + sid2: []interval{{50, 50}, {60, 63}, {66, 70}}, + }, + }, + { + name: "subtracting an interval that ends at the start of an interval", + left: Mysql56GTIDSet{ + sid1: []interval{{21, 57}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{20, 21}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{22, 57}}, + }, + }, + { + name: "subtracting an interval that starts at the end of an interval", + left: Mysql56GTIDSet{ + sid1: []interval{{21, 57}}, + }, + right: Mysql56GTIDSet{ + sid1: []interval{{57, 58}}, + }, + expected: Mysql56GTIDSet{ + sid1: []interval{{21, 56}}, + }, + }, + } + + for _, test := range table { + t.Run(test.name, func(t *testing.T) { + if got := test.left.Subtract(test.right); !got.Equal(test.expected) { + t.Errorf("failed test case:\n"+ + "left: %#v\n"+ + "right: %#v\n"+ + "expected: %#v\n"+ + "got: %#v", + test.left, test.right, test.expected, got) + } + }) + } +} + func TestMysql56GTIDSetSIDBlock(t *testing.T) { sid1 := SID{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15} sid2 := SID{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16} diff --git a/go/mysql/register-replica.go b/go/mysql/register-replica.go new file mode 100644 index 00000000000..3461d5c435e --- /dev/null +++ b/go/mysql/register-replica.go @@ -0,0 +1,72 @@ +/* +Copyright 2022 The Vitess Authors. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +package mysql + +import ( + vtrpcpb "github.com/dolthub/vitess/go/vt/proto/vtrpc" + "github.com/dolthub/vitess/go/vt/vterrors" +) + +var ( + comRegisterReplicaPacketErr = vterrors.Errorf(vtrpcpb.Code_INTERNAL, "error reading BinlogDumpGTID packet") +) + +func (c *Conn) parseComRegisterReplica(data []byte) ( + replicaHost string, + replicaPort uint16, + replicaUser string, + replicaPassword string, + err error, +) { + pos := 1 + pos += 4 // server-id + + // hostname + hostnameLen, pos, ok := readUint8(data, pos) + if !ok { + return replicaHost, replicaPort, replicaUser, replicaPassword, comRegisterReplicaPacketErr + } + replicaHost = string(data[pos : pos+int(hostnameLen)]) + pos += int(hostnameLen) + + // username + usernameLen, pos, ok := readUint8(data, pos) + if !ok { + return replicaHost, replicaPort, replicaUser, replicaPassword, comRegisterReplicaPacketErr + } + replicaUser = string(data[pos : pos+int(usernameLen)]) + pos += int(usernameLen) + + // password + passwordLen, pos, ok := readUint8(data, pos) + if !ok { + return replicaHost, replicaPort, replicaUser, replicaPassword, comRegisterReplicaPacketErr + } + replicaPassword = string(data[pos : pos+int(passwordLen)]) + pos += int(passwordLen) + + // port + replicaPort, _, ok = readUint16(data, pos) + if !ok { + return replicaHost, replicaPort, replicaUser, replicaPassword, comRegisterReplicaPacketErr + } + // remaining: (commented because of ineffectual assignment) + // pos += 4 // replication rank + // pos += 4 // master-id + + return replicaHost, replicaPort, replicaUser, replicaPassword, nil +} diff --git a/go/mysql/replication.go b/go/mysql/replication.go index dcc4c5e20c2..7393feeb5bf 100644 --- a/go/mysql/replication.go +++ b/go/mysql/replication.go @@ -77,3 +77,31 @@ func (c *Conn) SemiSyncExtensionLoaded() bool { } return len(qr.Rows) >= 1 } + +// WriteBinlogEvent writes a binlog event as part of a replication stream +// https://dev.mysql.com/doc/internals/en/binlog-network-stream.html +// https://dev.mysql.com/doc/internals/en/binlog-event.html +func (c *Conn) WriteBinlogEvent(ev BinlogEvent, semiSyncEnabled bool) error { + extraBytes := 1 // OK packet + if semiSyncEnabled { + extraBytes += 2 + } + + // NOTE: The latest Vitess code has changed startEphemeralPacket to startEphemeralPacketWithHeader, + // but we haven't ported that over yet, so instead, we use startEphemeralPacket and assign + // 0 to pos to indicate no header was included. + //data, pos := c.startEphemeralPacketWithHeader(len(ev.Bytes()) + extraBytes) + + data, pos := c.startEphemeralPacket(len(ev.Bytes()) + extraBytes), 0 + pos = writeByte(data, pos, 0) // "OK" prefix + if semiSyncEnabled { + pos = writeByte(data, pos, 0xef) // semi sync indicator + pos = writeByte(data, pos, 0) // no ack expected + } + _ = writeEOFString(data, pos, string(ev.Bytes())) + if err := c.writeEphemeralPacket(); err != nil { + return NewSQLError(CRServerGone, SSUnknownSQLState, "%v", err) + } + return nil +} + diff --git a/go/mysql/server.go b/go/mysql/server.go index 2f0129c1e0e..da20f54c1bf 100644 --- a/go/mysql/server.go +++ b/go/mysql/server.go @@ -90,7 +90,7 @@ type Handler interface { // ConnectionClosed is called when a connection is closed. ConnectionClosed(c *Conn) - // InitDB is called once at the beginning to set db name, + // ComInitDB is called once at the beginning to set db name, // and subsequently for every ComInitDB event. ComInitDB(c *Conn, schemaName string) error @@ -98,20 +98,13 @@ type Handler interface { // Note the contents of the query slice may change after // the first call to callback. So the Handler should not // hang on to the byte slice. - ComQuery(c *Conn, query string, callback func(res *sqltypes.Result, more bool) error) error - - // ComParsedQuery is called when a connection receives a - // query that has already been parsed. Note the contents - // of the query slice may change after the first call to - // callback. So the Handler should not hang on to the byte - // slice. - ComParsedQuery(c *Conn, query string, parsed sqlparser.Statement, callback func(res *sqltypes.Result, more bool) error) error - + ComQuery(c *Conn, query string, callback ResultSpoolFn) error + // ComMultiQuery is called when a connection receives a query and the // client supports MULTI_STATEMENT. It should process the first // statement in |query| and return the remainder. It will be called // multiple times until the remainder is |""|. - ComMultiQuery(c *Conn, query string, callback func(res *sqltypes.Result, more bool) error) (string, error) + ComMultiQuery(c *Conn, query string, callback ResultSpoolFn) (string, error) // ComPrepare is called when a connection receives a prepared // statement query. @@ -128,7 +121,12 @@ type Handler interface { // or after the last ComQuery call completes. WarningCount(c *Conn) uint16 - ComResetConnection(c *Conn) + // ComResetConnection is called when a connection receives a COM_RESET_CONNECTION signal. + // This is used to reset the session state (e.g. clearing user vars, resetting session vars, releasing + // locks, releasing cached prepared statements, etc). One of the primary use cases for COM_RESET_CONNECTION + // is to reset a pooled connection's session state so that it can be safely returned to the connection pool + // and given to another application process to reuse. + ComResetConnection(c *Conn) error // ParserOptionsForConnection returns any parser options that should be used for the given connection. For // example, if the connection has enabled ANSI_QUOTES or ANSI SQL_MODE, then the parser needs to know that @@ -138,6 +136,44 @@ type Handler interface { ParserOptionsForConnection(c *Conn) (sqlparser.ParserOptions, error) } +// BinlogReplicaHandler is an extension to the Handler interface, to add support for binlog replication server commands. +type BinlogReplicaHandler interface { + // ComRegisterReplica is called when a connection receives a ComRegisterReplica request + ComRegisterReplica(c *Conn, replicaHost string, replicaPort uint16, replicaUser string, replicaPassword string) error + + // ComBinlogDumpGTID is called when a connection receives a ComBinlogDumpGTID request + ComBinlogDumpGTID(c *Conn, logFile string, logPos uint64, gtidSet GTIDSet) error +} + +// ResultSpoolFn is the callback function used by ComQuery and related functions to handle rows returned by a query +type ResultSpoolFn func(res *sqltypes.Result, more bool) error + +// ExtendedHandler is an extension to Handler to support additional protocols on top of MySQL. +type ExtendedHandler interface { + // ComParsedQuery is called when a connection receives a query that has already been parsed. Note the contents + // of the query slice may change after the first call to callback. So the Handler should not hang on to the byte + // slice. + ComParsedQuery(c *Conn, query string, parsed sqlparser.Statement, callback ResultSpoolFn) error + + // ComPrepareParsed is called when a connection receives a prepared statement query that has already been parsed. + ComPrepareParsed(c *Conn, query string, parsed sqlparser.Statement, prepare *PrepareData) (ParsedQuery, []*querypb.Field, error) + + // ComBind is called when a connection receives a request to bind a prepared statement to a set of values. + ComBind(c *Conn, query string, parsedQuery ParsedQuery, prepare *PrepareData) (BoundQuery, []*querypb.Field, error) + + // ComExecuteBound is called when a connection receives a request to execute a prepared statement that has already + // bound to a set of values. + ComExecuteBound(c *Conn, query string, boundQuery BoundQuery, callback ResultSpoolFn) error +} + +// ParsedQuery is a marker type for communication between the ExtendedHandler interface and integrators, representing a +// query plan that can be examined or executed +type ParsedQuery any + +// BoundQuery is a marker type for communication between the ExtendedHandler interface and integrators, representing a +// query plan that has been bound to a set of values +type BoundQuery any + // Listener is the MySQL server protocol listener. type Listener struct { // Construction parameters, set by NewListener. diff --git a/go/mysql/server_test.go b/go/mysql/server_test.go index d7a7182f61b..80b04bb8423 100644 --- a/go/mysql/server_test.go +++ b/go/mysql/server_test.go @@ -122,12 +122,12 @@ func (th *testHandler) ComInitDB(c *Conn, schemaName string) error { return nil } -func (th *testHandler) ComMultiQuery(c *Conn, query string, callback func(res *sqltypes.Result, more bool) error) (string, error) { +func (th *testHandler) ComMultiQuery(c *Conn, query string, callback ResultSpoolFn) (string, error) { err := th.ComQuery(c, query, callback) return "", err } -func (th *testHandler) ComQuery(c *Conn, query string, callback func(res *sqltypes.Result, more bool) error) error { +func (th *testHandler) ComQuery(c *Conn, query string, callback ResultSpoolFn) error { if result := th.Result(); result != nil { callback(th.result, false) return nil @@ -305,8 +305,16 @@ func (th *testHandler) ComStmtExecute(c *Conn, prepare *PrepareData, callback fu } } -func (th *testHandler) ComResetConnection(c *Conn) { +func (th *testHandler) ComResetConnection(c *Conn) error { + return nil +} + +func (th *testHandler) ComRegisterReplica(c *Conn, replicaHost string, replicaPort uint16, replicaUser string, replicaPassword string) error { + return nil +} +func (th *testHandler) ComBinlogDumpGTID(c *Conn, logFile string, logPos uint64, gtidSet GTIDSet) error { + return nil } func (th *testHandler) WarningCount(c *Conn) uint16 { diff --git a/go/sqltypes/bind_variables.go b/go/sqltypes/bind_variables.go index 05e201f8d2b..600c46dc143 100644 --- a/go/sqltypes/bind_variables.go +++ b/go/sqltypes/bind_variables.go @@ -21,6 +21,7 @@ import ( "errors" "fmt" "strconv" + "time" "google.golang.org/protobuf/proto" @@ -120,6 +121,18 @@ func BuildBindVariable(v interface{}) (*querypb.BindVariable, error) { return Uint64BindVariable(v), nil case float64: return Float64BindVariable(v), nil + // TODO: fix this + //case decimal.Decimal: + // return &querypb.BindVariable{ + // Type: querypb.Type_DECIMAL, + // Value: []byte(v.String()), + // }, nil + case time.Time: + return &querypb.BindVariable{ + Type: querypb.Type_TIMESTAMP, + Value: []byte(v.String()), + }, nil + // TODO: somehow support types.Timespan case nil: return NullBindVariable, nil case Value: diff --git a/go/sqltypes/bind_variables_test.go b/go/sqltypes/bind_variables_test.go index b1042f2d59f..95aa2965fa9 100644 --- a/go/sqltypes/bind_variables_test.go +++ b/go/sqltypes/bind_variables_test.go @@ -21,6 +21,7 @@ import ( "reflect" "strings" "testing" + "time" "google.golang.org/protobuf/proto" @@ -84,163 +85,214 @@ func TestBuildBindVariable(t *testing.T) { in interface{} out *querypb.BindVariable err string - }{{ - in: "aa", - out: &querypb.BindVariable{ - Type: querypb.Type_VARCHAR, - Value: []byte("aa"), - }, - }, { - in: []byte("aa"), - out: &querypb.BindVariable{ - Type: querypb.Type_VARBINARY, - Value: []byte("aa"), - }, - }, { - in: true, - out: &querypb.BindVariable{ - Type: querypb.Type_INT8, - Value: []byte("1"), - }, - }, { - in: false, - out: &querypb.BindVariable{ - Type: querypb.Type_INT8, - Value: []byte("0"), - }, - }, { - in: int(1), - out: &querypb.BindVariable{ - Type: querypb.Type_INT64, - Value: []byte("1"), + }{ + { + in: "aa", + out: &querypb.BindVariable{ + Type: querypb.Type_VARCHAR, + Value: []byte("aa"), + }, }, - }, { - in: int64(1), - out: &querypb.BindVariable{ - Type: querypb.Type_INT64, - Value: []byte("1"), + { + in: []byte("aa"), + out: &querypb.BindVariable{ + Type: querypb.Type_VARBINARY, + Value: []byte("aa"), + }, }, - }, { - in: uint64(1), - out: &querypb.BindVariable{ - Type: querypb.Type_UINT64, - Value: []byte("1"), + { + in: true, + out: &querypb.BindVariable{ + Type: querypb.Type_INT8, + Value: []byte("1"), + }, }, - }, { - in: float64(1), - out: &querypb.BindVariable{ - Type: querypb.Type_FLOAT64, - Value: []byte("1"), + { + in: false, + out: &querypb.BindVariable{ + Type: querypb.Type_INT8, + Value: []byte("0"), + }, }, - }, { - in: nil, - out: NullBindVariable, - }, { - in: MakeTrusted(Int64, []byte("1")), - out: &querypb.BindVariable{ - Type: querypb.Type_INT64, - Value: []byte("1"), + { + in: int(1), + out: &querypb.BindVariable{ + Type: querypb.Type_INT64, + Value: []byte("1"), + }, }, - }, { - in: &querypb.BindVariable{ - Type: querypb.Type_INT64, - Value: []byte("1"), + { + in: int64(1), + out: &querypb.BindVariable{ + Type: querypb.Type_INT64, + Value: []byte("1"), + }, }, - out: &querypb.BindVariable{ - Type: querypb.Type_INT64, - Value: []byte("1"), + { + in: uint64(1), + out: &querypb.BindVariable{ + Type: querypb.Type_UINT64, + Value: []byte("1"), + }, }, - }, { - in: []interface{}{"aa", int64(1)}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ - Type: querypb.Type_VARCHAR, - Value: []byte("aa"), - }, { - Type: querypb.Type_INT64, + { + in: float64(1), + out: &querypb.BindVariable{ + Type: querypb.Type_FLOAT64, Value: []byte("1"), - }}, + }, }, - }, { - in: []string{"aa", "bb"}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ - Type: querypb.Type_VARCHAR, - Value: []byte("aa"), - }, { - Type: querypb.Type_VARCHAR, - Value: []byte("bb"), - }}, + // TODO: decimals lose precision + //{ + // in: decimal.NewFromInt(1), + // out: &querypb.BindVariable{ + // Type: querypb.Type_DECIMAL, + // Value: []byte("1"), + // }, + //}, + { + in: time.Time{}, + out: &querypb.BindVariable{ + Type: querypb.Type_TIMESTAMP, + Value: []byte("0001-01-01 00:00:00 +0000 UTC"), + }, }, - }, { - in: [][]byte{[]byte("aa"), []byte("bb")}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ - Type: querypb.Type_VARBINARY, - Value: []byte("aa"), - }, { - Type: querypb.Type_VARBINARY, - Value: []byte("bb"), - }}, + { + in: nil, + out: NullBindVariable, }, - }, { - in: []int{1, 2}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ + { + in: MakeTrusted(Int64, []byte("1")), + out: &querypb.BindVariable{ Type: querypb.Type_INT64, Value: []byte("1"), - }, { - Type: querypb.Type_INT64, - Value: []byte("2"), - }}, + }, }, - }, { - in: []int64{1, 2}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ + { + in: &querypb.BindVariable{ Type: querypb.Type_INT64, Value: []byte("1"), - }, { + }, + out: &querypb.BindVariable{ Type: querypb.Type_INT64, - Value: []byte("2"), - }}, - }, - }, { - in: []uint64{1, 2}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ - Type: querypb.Type_UINT64, Value: []byte("1"), - }, { - Type: querypb.Type_UINT64, - Value: []byte("2"), - }}, + }, }, - }, { - in: []float64{1, 2}, - out: &querypb.BindVariable{ - Type: querypb.Type_TUPLE, - Values: []*querypb.Value{{ - Type: querypb.Type_FLOAT64, - Value: []byte("1"), - }, { - Type: querypb.Type_FLOAT64, - Value: []byte("2"), - }}, + { + in: []interface{}{"aa", int64(1)}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{ + { + Type: querypb.Type_VARCHAR, + Value: []byte("aa"), + }, + { + Type: querypb.Type_INT64, + Value: []byte("1"), + }, + }, + }, + }, { + in: []string{"aa", "bb"}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{ + { + Type: querypb.Type_VARCHAR, + Value: []byte("aa"), + }, { + Type: querypb.Type_VARCHAR, + Value: []byte("bb"), + }, + }, + }, + }, { + in: [][]byte{[]byte("aa"), []byte("bb")}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{{ + Type: querypb.Type_VARBINARY, + Value: []byte("aa"), + }, { + Type: querypb.Type_VARBINARY, + Value: []byte("bb"), + }, + }, + }, }, - }, { - in: byte(1), - err: "type uint8 not supported as bind var: 1", - }, { - in: []interface{}{1, byte(1)}, - err: "type uint8 not supported as bind var: 1", - }} + { + in: []int{1, 2}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{ + { + Type: querypb.Type_INT64, + Value: []byte("1"), + }, + { + Type: querypb.Type_INT64, + Value: []byte("2"), + }, + }, + }, + }, + { + in: []int64{1, 2}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{ + { + Type: querypb.Type_INT64, + Value: []byte("1"), + }, { + Type: querypb.Type_INT64, + Value: []byte("2"), + }, + }, + }, + }, + { + in: []uint64{1, 2}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{ + { + Type: querypb.Type_UINT64, + Value: []byte("1"), + }, + { + Type: querypb.Type_UINT64, + Value: []byte("2"), + }, + }, + }, + }, + { + in: []float64{1, 2}, + out: &querypb.BindVariable{ + Type: querypb.Type_TUPLE, + Values: []*querypb.Value{ + { + Type: querypb.Type_FLOAT64, + Value: []byte("1"), + }, + { + Type: querypb.Type_FLOAT64, + Value: []byte("2"), + }, + }, + }, + }, + { + in: byte(1), + err: "type uint8 not supported as bind var: 1", + }, + { + in: []interface{}{1, byte(1)}, + err: "type uint8 not supported as bind var: 1", + }, + } for _, tcase := range tcases { bv, err := BuildBindVariable(tcase.in) if err != nil { diff --git a/go/vt/sqlparser/ast.go b/go/vt/sqlparser/ast.go index a6acc892db1..14fd404952e 100644 --- a/go/vt/sqlparser/ast.go +++ b/go/vt/sqlparser/ast.go @@ -24,6 +24,8 @@ import ( "errors" "fmt" "io" + "sort" + "strconv" "strings" "sync" "unicode" @@ -160,24 +162,39 @@ func parseTokenizer(sql string, tokenizer *Tokenizer) (Statement, error) { return tokenizer.ParseTree, nil } -// For select statements, capture the verbatim select expressions from the original query text +// For select statements, capture the verbatim select expressions from the original query text. +// It searches select expressions in walkable nodes. func captureSelectExpressions(sql string, tokenizer *Tokenizer) { - if s, ok := tokenizer.ParseTree.(SelectStatement); ok { - s.walkSubtree(func(node SQLNode) (bool, error) { - if node, ok := node.(*AliasedExpr); ok && node.EndParsePos > node.StartParsePos { - _, ok := node.Expr.(*ColName) - if ok { - // column names don't need any special handling to capture the input expression - return false, nil - } else { - node.InputExpression = trimQuotes(strings.Trim(sql[node.StartParsePos:node.EndParsePos], " \n\t")) - } + if s, isSelect := tokenizer.ParseTree.(SelectStatement); isSelect { + walkSelectExpressions(s, sql) + } else if w, ok := tokenizer.ParseTree.(WalkableSQLNode); ok { + w.walkSubtree(func(node SQLNode) (bool, error) { + if s, isSelect = node.(SelectStatement); isSelect { + walkSelectExpressions(s, sql) } return true, nil }) } } +// walkSelectExpressions fills in `InputExpression` of `AliasedExpr` if it's not a column name. +// This is used to display the result as defined original query text. This function gets called +// by captureSelectExpressions. +func walkSelectExpressions(s SelectStatement, sql string) { + s.walkSubtree(func(node SQLNode) (bool, error) { + if node, ok := node.(*AliasedExpr); ok && node.EndParsePos > node.StartParsePos { + _, ok := node.Expr.(*ColName) + if ok { + // column names don't need any special handling to capture the input expression + return false, nil + } else { + node.InputExpression = trimQuotes(strings.Trim(sql[node.StartParsePos:node.EndParsePos], " \n\t")) + } + } + return true, nil + }) +} + // For DDL statements that capture the position of a sub-statement (create view and others), we need to adjust these // indexes if they occurred inside a MySQL special comment (/*! */) because we sometimes inappropriately capture the // comment ending characters in such cases. @@ -872,8 +889,11 @@ func (node *Load) Format(buf *TrackedBuffer) { ignoreOrReplace += " " } - buf.Myprintf("load data %sinfile '%s' %sinto table %s%v%s%v%v%s%v", local, node.Infile, ignoreOrReplace, node.Table.String(), - node.Partition, charset, node.Fields, node.Lines, ignoreNum, node.Columns) + buf.Myprintf("load data %sinfile '%s' %sinto table %s", local, node.Infile, ignoreOrReplace, node.Table.String()) + if len(node.Partition) > 0 { + buf.Myprintf(" partition (%v)", node.Partition) + } + buf.Myprintf("%s%v%v%s%v", charset, node.Fields, node.Lines, ignoreNum, node.Columns) } func (node *Load) walkSubtree(visit Visit) error { @@ -894,8 +914,8 @@ func (node *Load) walkSubtree(visit Visit) error { type Fields struct { TerminatedBy *SQLVal - *EnclosedBy - EscapedBy *SQLVal + EnclosedBy *EnclosedBy + EscapedBy *SQLVal SQLNode } @@ -903,18 +923,14 @@ func (node *Fields) Format(buf *TrackedBuffer) { if node == nil { return } - - terminated := "" + buf.Myprintf(" fields") if node.TerminatedBy != nil { - terminated = "terminated by " + "'" + string(node.TerminatedBy.Val) + "'" + buf.Myprintf(" terminated by '%s'", node.TerminatedBy.Val) } - - escaped := "" + buf.Myprintf("%v", node.EnclosedBy) if node.EscapedBy != nil { - escaped = " escaped by " + "'" + string(node.EscapedBy.Val) + "'" + buf.Myprintf(" escaped by '%s'", node.EscapedBy.Val) } - - buf.Myprintf(" fields %s%v%s", terminated, node.EnclosedBy, escaped) } type EnclosedBy struct { @@ -927,15 +943,10 @@ func (node *EnclosedBy) Format(buf *TrackedBuffer) { if node == nil { return } - - enclosed := "enclosed by " + "'" + string(node.Delim.Val) + "'" if node.Optionally { - enclosed = " optionally " + enclosed - } else { - enclosed = " " + enclosed + buf.Myprintf(" optionally") } - - buf.Myprintf(enclosed) + buf.Myprintf(" enclosed by '%s'", node.Delim.Val) } type Lines struct { @@ -948,18 +959,13 @@ func (node *Lines) Format(buf *TrackedBuffer) { if node == nil { return } - - starting := "" + buf.Myprintf(" lines") if node.StartingBy != nil { - starting = " starting by " + "'" + string(node.StartingBy.Val) + "'" + buf.Myprintf(" starting by '%s'", node.StartingBy.Val) } - - terminated := "" if node.TerminatedBy != nil { - terminated = " terminated by " + "'" + string(node.TerminatedBy.Val) + "'" + buf.Myprintf(" terminated by '%s'", node.TerminatedBy.Val) } - - buf.Myprintf(" lines%s%s", starting, terminated) } // BeginEndBlock represents a BEGIN .. END block with one or more statements nested within @@ -1612,11 +1618,15 @@ const ( // Format formats the node. func (node *Insert) Format(buf *TrackedBuffer) { - buf.Myprintf("%v%s %v%sinto %v%v%v %v%v", + buf.Myprintf("%v%s %v%sinto %v", node.With, node.Action, node.Comments, node.Ignore, - node.Table, node.Partitions, node.Columns, node.Rows, node.OnDup) + node.Table) + if len(node.Partitions) > 0 { + buf.Myprintf(" partition (%v)", node.Partitions) + } + buf.Myprintf("%v %v%v", node.Columns, node.Rows, node.OnDup) } func (node *Insert) walkSubtree(visit Visit) error { @@ -1640,10 +1650,11 @@ type InsertRows interface { SQLNode } -func (*Select) iInsertRows() {} -func (*SetOp) iInsertRows() {} -func (Values) iInsertRows() {} -func (*ParenSelect) iInsertRows() {} +func (*Select) iInsertRows() {} +func (*SetOp) iInsertRows() {} +func (AliasedValues) iInsertRows() {} +func (Values) iInsertRows() {} +func (*ParenSelect) iInsertRows() {} // Update represents an UPDATE statement. // If you add fields here, consider adding them to calls to validateUnshardedRoute. @@ -1700,7 +1711,11 @@ func (node *Delete) Format(buf *TrackedBuffer) { if node.Targets != nil { buf.Myprintf("%v ", node.Targets) } - buf.Myprintf("from %v%v%v%v%v", node.TableExprs, node.Partitions, node.Where, node.OrderBy, node.Limit) + buf.Myprintf("from %v", node.TableExprs) + if len(node.Partitions) > 0 { + buf.Myprintf(" partition (%v)", node.Partitions) + } + buf.Myprintf("%v%v%v", node.Where, node.OrderBy, node.Limit) } func (node *Delete) walkSubtree(visit Visit) error { @@ -1773,11 +1788,12 @@ type CharsetAndCollate struct { // DBDDL represents a CREATE, DROP database statement. type DBDDL struct { - Action string - DBName string - IfNotExists bool - IfExists bool - CharsetCollate []*CharsetAndCollate + Action string + SchemaOrDatabase string + DBName string + IfNotExists bool + IfExists bool + CharsetCollate []*CharsetAndCollate } // Format formats the node. @@ -1802,23 +1818,32 @@ func (node *DBDDL) Format(buf *TrackedBuffer) { charsetCollateStr += fmt.Sprintf("%s %s %s", charsetDef, typeStr, obj.Value) } - buf.WriteString(fmt.Sprintf("%s database%s%s%s", node.Action, exists, dbname, charsetCollateStr)) + buf.WriteString(fmt.Sprintf("%s %s%s%s%s", node.Action, node.SchemaOrDatabase, exists, dbname, charsetCollateStr)) case DropStr: exists := "" if node.IfExists { exists = " if exists" } - buf.WriteString(fmt.Sprintf("%s database%s %v", node.Action, exists, node.DBName)) + buf.WriteString(fmt.Sprintf("%s %s%s %v", node.Action, node.SchemaOrDatabase, exists, node.DBName)) } } +type ViewCheckOption string + +const ( + ViewCheckOptionUnspecified ViewCheckOption = "" + ViewCheckOptionCascaded ViewCheckOption = "cascaded" + ViewCheckOptionLocal ViewCheckOption = "local" +) + type ViewSpec struct { - ViewName TableName - Columns Columns - Algorithm string - Definer string - Security string - ViewExpr SelectStatement + ViewName TableName + Columns Columns + Algorithm string + Definer string + Security string + ViewExpr SelectStatement + CheckOption ViewCheckOption } type TriggerSpec struct { @@ -1961,8 +1986,9 @@ func (c Characteristic) String() string { // AlterTable represents an ALTER table statement, which can include multiple DDL clauses. type AlterTable struct { - Table TableName - Statements []*DDL + Table TableName + Statements []*DDL + PartitionSpecs []*PartitionSpec } var _ SQLNode = (*AlterTable)(nil) @@ -1976,6 +2002,12 @@ func (m *AlterTable) Format(buf *TrackedBuffer) { } ddl.alterFormat(buf) } + for i, partitionSpec := range m.PartitionSpecs { + if i > 0 { + buf.Myprintf(" ") + } + buf.Myprintf("%v", partitionSpec) + } } // walkSubtree implements SQLNode. @@ -2027,6 +2059,9 @@ type DDL struct { SpecialCommentMode bool SubStatementPositionStart int SubStatementPositionEnd int + // SubStatementStr will have the sub statement as a string rather than having to slice the original query. + // If it's empty, then use the position start and end values to slice the sub statement out of the original query. + SubStatementStr string // FromViews is set if Action is DropStr. FromViews TableNames @@ -2067,6 +2102,12 @@ type DDL struct { // OptSelect is set for CREATE TABLE <> AS SELECT operations. OptSelect *OptSelect + + // User is set for ALTER USER operations. + User AccountName + + // Authentication is set for ALTER USER operations. + Authentication *Authentication } // ColumnOrder is used in some DDL statements to specify or change the order of a column in a schema. @@ -2113,6 +2154,7 @@ func (node *DDL) Format(buf *TrackedBuffer) { if node.ViewSpec != nil { view := node.ViewSpec afterCreate := "" + checkOpt := "" if node.OrReplace { afterCreate = "or replace " } @@ -2125,7 +2167,10 @@ func (node *DDL) Format(buf *TrackedBuffer) { if view.Security != "" { afterCreate = fmt.Sprintf("%ssql security %s ", afterCreate, strings.ToLower(view.Security)) } - buf.Myprintf("%s %sview %v%v as %v", node.Action, afterCreate, view.ViewName, view.Columns, view.ViewExpr) + if view.CheckOption != ViewCheckOptionUnspecified { + checkOpt = fmt.Sprintf(" with %s check option", view.CheckOption) + } + buf.Myprintf("%s %sview %v%v as %v%s", node.Action, afterCreate, view.ViewName, view.Columns, view.ViewExpr, checkOpt) } else if node.TriggerSpec != nil { trigger := node.TriggerSpec triggerDef := "" @@ -2295,9 +2340,19 @@ func (node *DDL) Format(buf *TrackedBuffer) { } else { buf.Myprintf("%s", sb.String()) } - } else { + } else if node.Table.IsEmpty() == false { buf.Myprintf("%s table %v", node.Action, node.Table) node.alterFormat(buf) + } else if node.User.IsEmpty() == false { + ifExists := "" + if node.IfExists { + ifExists = "if exists " + } + buf.Myprintf("%s user %s%s %s", node.Action, ifExists, node.User.String(), node.Authentication.String()) + node.alterFormat(buf) + } else { + buf.Myprintf(fmt.Sprintf("unsupported alter command: %v", node)) + node.alterFormat(buf) } case FlushStr: buf.Myprintf("%s", node.Action) @@ -2317,6 +2372,12 @@ func (node *DDL) walkSubtree(visit Visit) error { return err } } + + if node.ViewSpec != nil { + err := Walk(visit, node.ViewSpec.ViewExpr) + return err + } + // TODO: add missing nodes that are walkable return nil } @@ -2368,6 +2429,17 @@ func (node *DDL) alterFormat(buf *TrackedBuffer) { default: buf.Myprintf(" drop constraint %s", node.TableSpec.Constraints[0].Name) } + } else if node.ConstraintAction == RenameStr && node.TableSpec != nil && len(node.TableSpec.Constraints) == 2 { + buf.Myprintf(" rename constraint") + switch node.TableSpec.Constraints[0].Details.(type) { + case *ForeignKeyDefinition: + buf.Myprintf(" foreign key %s to", node.TableSpec.Constraints[0].Name) + case *CheckConstraintDefinition: + buf.Myprintf(" check %s to", node.TableSpec.Constraints[0].Name) + default: + buf.Myprintf(" %s to", node.TableSpec.Constraints[0].Name) + } + buf.Myprintf(" %s", node.TableSpec.Constraints[1].Name) } else if node.DefaultSpec != nil { buf.Myprintf(" %v", node.DefaultSpec) } else if node.AlterCollationSpec != nil { @@ -2394,6 +2466,16 @@ func (node *DDL) AffectedTables() TableNames { // Partition strings const ( ReorganizeStr = "reorganize partition" + DiscardStr = "discard" + ImportStr = "import" + CoalesceStr = "coalesce" + ExchangeStr = "exchange" + AnalyzeStr = "analyze" + CheckStr = "check" + OptimizeStr = "optimize" + RebuildStr = "rebuild" + RepairStr = "repair" + RemoveStr = "remove" ) // OptLike works for create table xxx like xxx @@ -2431,24 +2513,58 @@ func (node *OptSelect) walkSubtree(visit Visit) error { // PartitionSpec describe partition actions (for alter and create) type PartitionSpec struct { - Action string - Name ColIdent - Definitions []*PartitionDefinition + Action string + IsAll bool + Names Partitions + Definitions []*PartitionDefinition + WithValidation bool + TableName TableName + Number *SQLVal } // Format formats the node. func (node *PartitionSpec) Format(buf *TrackedBuffer) { switch node.Action { - case ReorganizeStr: - buf.Myprintf("%s %v into (", node.Action, node.Name) - var prefix string + case AddStr: + buf.Myprintf(" %s partition (", node.Action) for _, pd := range node.Definitions { - buf.Myprintf("%s%v", prefix, pd) - prefix = ", " + buf.Myprintf("%v", pd) } buf.Myprintf(")") + case DropStr, AnalyzeStr, OptimizeStr, RebuildStr, RepairStr: + if node.IsAll { + buf.Myprintf(" %s partition all", node.Action) + } else { + buf.Myprintf(" %s partition %v", node.Action, node.Names) + } + case DiscardStr, ImportStr, TruncateStr: + if node.IsAll { + buf.Myprintf(" %s partition all tablespace", node.Action) + } else { + buf.Myprintf(" %s partition %v tablespace", node.Action, node.Names) + } + case ReorganizeStr: + buf.Myprintf(" %s %v into (", node.Action, node.Names) + for i, pd := range node.Definitions { + if i > 0 { + buf.Myprintf(", ") + } + buf.Myprintf("%v", pd) + } + buf.Myprintf(")") + case CoalesceStr: + buf.Myprintf(" %s partition %v", node.Action, node.Number) + case ExchangeStr: + buf.Myprintf(" %s partition %v with table %v", node.Action, node.Names, node.TableName) + if node.WithValidation { + buf.Myprintf(" with validation") + } else { + buf.Myprintf(" without validation") + } + case RemoveStr: + buf.Myprintf(" %s partitioning", node.Action) default: - panic("unimplemented") + //panic("unimplemented") } } @@ -2456,7 +2572,7 @@ func (node *PartitionSpec) walkSubtree(visit Visit) error { if node == nil { return nil } - if err := Walk(visit, node.Name); err != nil { + if err := Walk(visit, node.Names); err != nil { return err } for _, def := range node.Definitions { @@ -2496,10 +2612,11 @@ func (node *PartitionDefinition) walkSubtree(visit Visit) error { // TableSpec describes the structure of a table from a CREATE TABLE statement type TableSpec struct { - Columns []*ColumnDefinition - Indexes []*IndexDefinition - Constraints []*ConstraintDefinition - Options string + Columns []*ColumnDefinition + Indexes []*IndexDefinition + Constraints []*ConstraintDefinition + TableOpts []*TableOption + PartitionOpt *PartitionOption } // Format formats the node. @@ -2518,13 +2635,25 @@ func (ts *TableSpec) Format(buf *TrackedBuffer) { for _, c := range ts.Constraints { buf.Myprintf(",\n\t%v", c) } + buf.Myprintf("\n)") + for _, tblOpt := range ts.TableOpts { + buf.Myprintf(" %s %s", tblOpt.Name, tblOpt.Value) + } + if ts.PartitionOpt != nil { + buf.Myprintf(" %v", ts.PartitionOpt) + } - buf.Myprintf("\n)%s", strings.Replace(ts.Options, ", ", ",\n ", -1)) + //buf.Myprintf("\n)%s", strings.Replace(ts.TableOpts, ", ", ",\n ", -1)) } // AddColumn appends the given column to the list in the spec func (ts *TableSpec) AddColumn(cd *ColumnDefinition) { ts.Columns = append(ts.Columns, cd) + + // Move any inline check constraints up from the column definition to the table spec + if cd.Type.Constraint != nil { + ts.Constraints = append(ts.Constraints, cd.Type.Constraint) + } } // AddIndex appends the given index to the list in the spec @@ -2537,6 +2666,11 @@ func (ts *TableSpec) AddConstraint(cd *ConstraintDefinition) { ts.Constraints = append(ts.Constraints, cd) } +// AddOption appends the given option to the list in the spec +func (ts *TableSpec) AddTableOption(to *TableOption) { + ts.TableOpts = append(ts.TableOpts, to) +} + func (ts *TableSpec) walkSubtree(visit Visit) error { if ts == nil { return nil @@ -2591,6 +2725,9 @@ type ColumnType struct { // The base type string Type string + // The base type if it has already been resolved + ResolvedType any + // Generic field options. Null BoolVal NotNull BoolVal @@ -2621,6 +2758,9 @@ type ColumnType struct { // Foreign key specification ForeignKeyDef *ForeignKeyDefinition + // Check constraint specification + Constraint *ConstraintDefinition + // Generated columns GeneratedExpr Expr // The expression used to generate this column Stored BoolVal // Default is Virtual (not stored) @@ -2659,10 +2799,22 @@ func (ct *ColumnType) merge(other ColumnType) error { } if other.KeyOpt != colKeyNone { - if ct.KeyOpt != colKeyNone { + keyOptions := []ColumnKeyOption{ct.KeyOpt, other.KeyOpt} + sort.Slice(keyOptions, func(i, j int) bool { return keyOptions[i] < keyOptions[j] }) + if other.KeyOpt == ct.KeyOpt { + // MySQL will deduplicate key options when they are repeated. + } else if keyOptions[0] == colKeyPrimary && (keyOptions[1] == colKeyUnique || keyOptions[1] == colKeyUniqueKey) { + // If UNIQUE is specified with PRIMARY KEY, we ignore UNIQUE for now since + // the PRIMARY KEY option will ensure uniqueness already. MySQL does still + // generate a UNIQUE index for the column, but we can add that later if needed. + ct.KeyOpt = colKeyPrimary + } else if ct.KeyOpt == colKeyNone { + // If this column doesn't have a key option yet, just use the new one. + ct.KeyOpt = other.KeyOpt + } else { + // Otherwise throw an error if there are multiple key options that need to be applied. return errors.New("cannot include more than one key option for a column definition") } - ct.KeyOpt = other.KeyOpt } if other.ForeignKeyDef != nil { @@ -2672,6 +2824,13 @@ func (ct *ColumnType) merge(other ColumnType) error { ct.ForeignKeyDef = other.ForeignKeyDef } + if other.Constraint != nil { + if ct.Constraint != nil { + return errors.New("cannot include more than one check constraint in a column definition") + } + ct.Constraint = other.Constraint + } + if other.Comment != nil { if ct.Comment != nil { return errors.New("cannot include more than one comment for a column definition") @@ -2727,17 +2886,19 @@ func (ct *ColumnType) merge(other ColumnType) error { // Format returns a canonical string representation of the type and all relevant options func (ct *ColumnType) Format(buf *TrackedBuffer) { - buf.Myprintf("%s", ct.Type) - - if ct.Length != nil && ct.Scale != nil { - buf.Myprintf("(%v,%v)", ct.Length, ct.Scale) - - } else if ct.Length != nil { - buf.Myprintf("(%v)", ct.Length) - } + if stringer, ok := ct.ResolvedType.(fmt.Stringer); ok { + buf.WriteString(stringer.String()) + } else { + buf.Myprintf("%s", ct.Type) + if ct.Length != nil && ct.Scale != nil { + buf.Myprintf("(%v,%v)", ct.Length, ct.Scale) - if len(ct.EnumValues) > 0 { - buf.Myprintf("('%s')", strings.Join(ct.EnumValues, "', '")) + } else if ct.Length != nil { + buf.Myprintf("(%v)", ct.Length) + } + if len(ct.EnumValues) > 0 { + buf.Myprintf("('%s')", strings.Join(ct.EnumValues, "', '")) + } } opts := make([]string, 0, 16) @@ -2881,25 +3042,33 @@ func (ct *ColumnType) SQLType() querypb.Type { return sqltypes.Int64 case keywordStrings[BOOL], keywordStrings[BOOLEAN]: return sqltypes.Uint8 - case keywordStrings[TEXT]: - return sqltypes.Text - case keywordStrings[TINYTEXT]: + case keywordStrings[TEXT], + keywordStrings[TINYTEXT], + keywordStrings[MEDIUMTEXT], + keywordStrings[LONGTEXT], + keywordStrings[LONG], + "long varchar": return sqltypes.Text - case keywordStrings[MEDIUMTEXT]: - return sqltypes.Text - case keywordStrings[LONGTEXT]: - return sqltypes.Text - case keywordStrings[BLOB]: - return sqltypes.Blob - case keywordStrings[TINYBLOB]: - return sqltypes.Blob - case keywordStrings[MEDIUMBLOB]: + case keywordStrings[BLOB], + keywordStrings[TINYBLOB], + keywordStrings[MEDIUMBLOB], + keywordStrings[LONGBLOB]: return sqltypes.Blob - case keywordStrings[LONGBLOB]: - return sqltypes.Blob - case keywordStrings[CHAR]: + case keywordStrings[CHAR], + keywordStrings[CHARACTER], + keywordStrings[NCHAR], + "national char", + "national character": return sqltypes.Char - case keywordStrings[VARCHAR]: + case keywordStrings[VARCHAR], + keywordStrings[NVARCHAR], + "char varying", + "character varying", + "nchar varchar", + "nchar varying", + "national varchar", + "national char varying", + "national character varying": return sqltypes.VarChar case keywordStrings[BINARY]: return sqltypes.Binary @@ -2917,9 +3086,14 @@ func (ct *ColumnType) SQLType() querypb.Type { return sqltypes.Year case keywordStrings[FLOAT_TYPE]: return sqltypes.Float32 - case keywordStrings[DOUBLE]: + case keywordStrings[DOUBLE], + keywordStrings[REAL], + "double precision": return sqltypes.Float64 - case keywordStrings[DECIMAL]: + case keywordStrings[DECIMAL], + keywordStrings[DEC], + keywordStrings[FIXED], + keywordStrings[NUMERIC]: return sqltypes.Decimal case keywordStrings[BIT]: return sqltypes.Bit @@ -2929,21 +3103,14 @@ func (ct *ColumnType) SQLType() querypb.Type { return sqltypes.Set case keywordStrings[JSON]: return sqltypes.TypeJSON - case keywordStrings[GEOMETRY]: - return sqltypes.Geometry - case keywordStrings[POINT]: - return sqltypes.Geometry - case keywordStrings[LINESTRING]: - return sqltypes.Geometry - case keywordStrings[POLYGON]: - return sqltypes.Geometry - case keywordStrings[GEOMETRYCOLLECTION]: - return sqltypes.Geometry - case keywordStrings[MULTIPOINT]: - return sqltypes.Geometry - case keywordStrings[MULTILINESTRING]: - return sqltypes.Geometry - case keywordStrings[MULTIPOLYGON]: + case keywordStrings[GEOMETRY], + keywordStrings[POINT], + keywordStrings[LINESTRING], + keywordStrings[POLYGON], + keywordStrings[GEOMETRYCOLLECTION], + keywordStrings[MULTIPOINT], + keywordStrings[MULTILINESTRING], + keywordStrings[MULTIPOLYGON]: return sqltypes.Geometry } panic("unimplemented type " + ct.Type) @@ -3260,6 +3427,89 @@ type IndexOption struct { Using string } +// TableOption describes a table option in a CREATE TABLE statement +type TableOption struct { + Name string + Value string +} + +// PartitionOption describes a partition option in a CREATE TABLE statement +type PartitionOption struct { + PartitionType string // HASH, KEY, RANGE, LIST + IsLinear bool + KeyAlgorithm string + ColList Columns + Expr Expr + Partitions *SQLVal + SubPartition *SubPartition + Definitions []*PartitionDefinition +} + +// Format formats the node. +func (node *PartitionOption) Format(buf *TrackedBuffer) { + buf.Myprintf("partition by") + if node.IsLinear { + buf.Myprintf(" linear") + } + buf.Myprintf(" %s", node.PartitionType) + if node.KeyAlgorithm != "" { + buf.Myprintf(" %s", node.KeyAlgorithm) + } + if node.ColList != nil { + buf.Myprintf(" %v", node.ColList) + } + if node.Expr != nil { + buf.Myprintf(" (%v)", node.Expr) + } + if node.Partitions != nil { + buf.Myprintf(" partitions %v", node.Partitions) + } + if node.SubPartition != nil { + buf.Myprintf("%v", node.SubPartition) + } + if len(node.Definitions) > 0 { + buf.Myprintf(" (\n") + for i, def := range node.Definitions { + if i != 0 { + buf.Myprintf(",\n") + } + buf.Myprintf("%v", def) + } + buf.Myprintf("\n)") + } +} + +// SubPartition describes subpartitions control +type SubPartition struct { + PartitionType string + IsLinear bool + KeyAlgorithm string + ColList Columns + Expr Expr + SubPartitions *SQLVal +} + +// Format formats the node. +func (node *SubPartition) Format(buf *TrackedBuffer) { + buf.Myprintf(" subpartition by") + if node.IsLinear { + buf.Myprintf(" linear") + } + buf.Myprintf(" %s", node.PartitionType) + if node.KeyAlgorithm != "" { + buf.Myprintf(" %s", node.KeyAlgorithm) + } + if node.ColList != nil { + buf.Myprintf(" %v", node.ColList) + } + if node.Expr != nil { + buf.Myprintf(" (%v)", node.Expr) + } + if node.SubPartitions != nil { + buf.Myprintf(" subpartitions %v", node.SubPartitions) + } +} + // ColumnKeyOption indicates whether or not the given column is defined as an // index element and contains the type of the option type ColumnKeyOption int @@ -3503,7 +3753,7 @@ func (node *Show) Format(buf *TrackedBuffer) { node.ShowTablesOpt.Format(buf) return } - case "triggers", "events": + case "triggers", "events", "plugins": if node.ShowTablesOpt != nil { buf.Myprintf("show ") buf.Myprintf("%s", loweredType) @@ -3708,8 +3958,10 @@ func (node *Rollback) Format(buf *TrackedBuffer) { // FlushOption is used for trailing options for flush statement type FlushOption struct { - Name string - Channel string + Name string + Channel string + Tables []TableName + ReadLock bool } // Flush represents a Flush statement. @@ -3726,11 +3978,24 @@ func (node *Flush) Format(buf *TrackedBuffer) { buf.Myprintf(" %s", strings.ToLower(node.Type)) } - if node.Option.Name == "RELAY LOGS" && node.Option.Channel != "" { + if strings.EqualFold(node.Option.Name, "relay logs") && node.Option.Channel != "" { buf.Myprintf(" %s for channel %s", strings.ToLower(node.Option.Name), strings.ToLower(node.Option.Channel)) } else { buf.Myprintf(" %s", strings.ToLower(node.Option.Name)) } + + if len(node.Option.Tables) > 0 { + for i, tableName := range node.Option.Tables { + if i > 0 { + buf.Myprintf(",") + } + buf.Myprintf(" %s", strings.ToLower(tableName.String())) + } + + if node.Option.ReadLock { + buf.Myprintf(" with read lock") + } + } } // ChangeReplicationSource represents a "CHANGE REPLICATION SOURCE TO" statement. @@ -4047,12 +4312,12 @@ func (node Partitions) Format(buf *TrackedBuffer) { if node == nil { return } - prefix := " partition (" - for _, n := range node { - buf.Myprintf("%s%v", prefix, n) - prefix = ", " + for i, n := range node { + if i > 0 { + buf.Myprintf(", ") + } + buf.Myprintf("%v", n) } - buf.WriteString(")") } func (node Partitions) walkSubtree(visit Visit) error { @@ -4177,7 +4442,10 @@ func (node *AliasedTableExpr) Format(buf *TrackedBuffer) { case *ValuesStatement: buf.Myprintf("(%v)", node.Expr) default: - buf.Myprintf("%v%v", node.Expr, node.Partitions) + buf.Myprintf("%v", node.Expr) + if len(node.Partitions) > 0 { + buf.Myprintf(" partition (%v)", node.Partitions) + } } if node.AsOf != nil { @@ -4261,8 +4529,12 @@ func (w *With) walkSubtree(visit Visit) error { type Into struct { Variables Variables - Outfile string Dumpfile string + + Outfile string + Charset string + Fields *Fields + Lines *Lines } func (i *Into) Format(buf *TrackedBuffer) { @@ -4271,14 +4543,17 @@ func (i *Into) Format(buf *TrackedBuffer) { } buf.Myprintf(" into ") - if i.Variables != nil { - buf.Myprintf("%v", i.Variables) + buf.Myprintf("%v", i.Variables) + if i.Dumpfile != "" { + buf.Myprintf("dumpfile '%s'", i.Dumpfile) } if i.Outfile != "" { buf.Myprintf("outfile '%s'", i.Outfile) - } - if i.Dumpfile != "" { - buf.Myprintf("dumpfile '%s'", i.Dumpfile) + if i.Charset != "" { + buf.Myprintf(" character set %s", i.Charset) + } + buf.Myprintf("%v", i.Fields) + buf.Myprintf("%v", i.Lines) } } @@ -4446,12 +4721,15 @@ func (node EventName) IsEmpty() bool { } // TableName represents a table name. -// Qualifier, if specified, represents a database or keyspace. +// DbQualifier, if specified, represents a database or keyspace. // TableName is a value struct whose fields are case sensitive. // This means two TableName vars can be compared for equality // and a TableName can also be used as key in a map. +// SchemaQualifier, if specified, represents a schema name, which is an additional level of namespace supported in +// other dialects. Supported here so that this AST can act as a translation layer for those dialects, but is unused in +// MySQL. type TableName struct { - Name, Qualifier TableIdent + Name, DbQualifier, SchemaQualifier TableIdent } // Format formats the node. @@ -4459,8 +4737,8 @@ func (node TableName) Format(buf *TrackedBuffer) { if node.IsEmpty() { return } - if !node.Qualifier.IsEmpty() { - buf.Myprintf("%v.", node.Qualifier) + if !node.DbQualifier.IsEmpty() { + buf.Myprintf("%v.", node.DbQualifier) } buf.Myprintf("%v", node.Name) } @@ -4470,8 +4748,8 @@ func (node TableName) String() string { if node.IsEmpty() { return "" } - if !node.Qualifier.IsEmpty() { - return fmt.Sprintf("%s.%s", node.Qualifier.String(), node.Name) + if !node.DbQualifier.IsEmpty() { + return fmt.Sprintf("%s.%s", node.DbQualifier.String(), node.Name) } return node.Name.String() } @@ -4480,7 +4758,7 @@ func (node TableName) walkSubtree(visit Visit) error { return Walk( visit, node.Name, - node.Qualifier, + node.DbQualifier, ) } @@ -4492,11 +4770,11 @@ func (node TableName) IsEmpty() bool { // ToViewName returns a TableName acceptable for use as a VIEW. VIEW names are // always lowercase, so ToViewName lowercasese the name. Databases are case-sensitive -// so Qualifier is left untouched. +// so DbQualifier is left untouched. func (node TableName) ToViewName() TableName { return TableName{ - Qualifier: node.Qualifier, - Name: NewTableIdent(strings.ToLower(node.Name.v)), + DbQualifier: node.DbQualifier, + Name: NewTableIdent(strings.ToLower(node.Name.v)), } } @@ -4735,13 +5013,13 @@ func (*CollateExpr) iExpr() {} func (*FuncExpr) iExpr() {} func (*TimestampFuncExpr) iExpr() {} func (*ExtractFuncExpr) iExpr() {} -func (*CurTimeFuncExpr) iExpr() {} func (*CaseExpr) iExpr() {} func (*ValuesFuncExpr) iExpr() {} func (*ConvertExpr) iExpr() {} func (*SubstrExpr) iExpr() {} func (*TrimExpr) iExpr() {} func (*ConvertUsingExpr) iExpr() {} +func (*CharExpr) iExpr() {} func (*MatchExpr) iExpr() {} func (*GroupConcatExpr) iExpr() {} func (*Default) iExpr() {} @@ -5121,7 +5399,16 @@ func ExprFromValue(value sqltypes.Value) (Expr, error) { return &NullVal{}, nil case value.IsIntegral(): return NewIntVal(value.ToBytes()), nil - case value.IsFloat() || value.Type() == sqltypes.Decimal: + case value.IsFloat(): + // Ensure that the resulting expression will be parsed back as a float, not a decimal. + // We do this by parsing the float, then reserializing it with exponential notation. + floatValue, err := strconv.ParseFloat(string(value.ToBytes()), 64) + if err != nil { + return nil, err + } + newValue := sqltypes.MakeTrusted(sqltypes.Float64, strconv.AppendFloat(nil, floatValue, 'e', -1, 64)) + return NewFloatVal(newValue.ToBytes()), nil + case value.Type() == sqltypes.Decimal: return NewFloatVal(value.ToBytes()), nil case value.IsQuoted(): return NewStrVal(value.ToBytes()), nil @@ -5185,6 +5472,10 @@ func NewBitVal(in []byte) *SQLVal { return &SQLVal{Type: BitVal, Val: in} } +// TODO: implement a NewDateVal() +// TODO: implement a NewTimeVal() +// TODO: implement a NewTimestampVal() + // NewValArg builds a new ValArg. func NewValArg(in []byte) *SQLVal { return &SQLVal{Type: ValArg, Val: in} @@ -5597,41 +5888,15 @@ func (node *TimestampFuncExpr) replace(from, to Expr) bool { return false } -// CurTimeFuncExpr represents the function and arguments for CURRENT DATE/TIME functions -// supported functions are documented in the grammar -type CurTimeFuncExpr struct { - Name ColIdent - Fsp Expr // fractional seconds precision, integer from 0 to 6 -} - -// Format formats the node. -func (node *CurTimeFuncExpr) Format(buf *TrackedBuffer) { - buf.Myprintf("%s(%v)", node.Name.String(), node.Fsp) -} - -func (node *CurTimeFuncExpr) walkSubtree(visit Visit) error { - if node == nil { - return nil - } - return Walk( - visit, - node.Fsp, - ) -} - -func (node *CurTimeFuncExpr) replace(from, to Expr) bool { - return replaceExprs(from, to, &node.Fsp) -} - // CollateExpr represents dynamic collate operator. type CollateExpr struct { - Expr Expr - Charset string + Expr Expr + Collation string } // Format formats the node. func (node *CollateExpr) Format(buf *TrackedBuffer) { - buf.Myprintf("%v collate %s", node.Expr, node.Charset) + buf.Myprintf("%v collate %s", node.Expr, node.Collation) } func (node *CollateExpr) walkSubtree(visit Visit) error { @@ -5950,6 +6215,32 @@ func (node *ConvertUsingExpr) replace(from, to Expr) bool { return replaceExprs(from, to, &node.Expr) } +// CharExpr represents a call to CHAR(expr1, expr2, ... using charset) +type CharExpr struct { + Exprs SelectExprs + Type string +} + +// Format formats the node. +func (node *CharExpr) Format(buf *TrackedBuffer) { + if node.Type == "" { + buf.Myprintf("CHAR(%v)", node.Exprs) + return + } + buf.Myprintf("CHAR(%v USING %s)", node.Exprs, node.Type) +} + +func (node *CharExpr) walkSubtree(visit Visit) error { + if node == nil { + return nil + } + return Walk(visit, node.Exprs) +} + +func (node *CharExpr) replace(from, to Expr) bool { + return replaceExprs(from, to) +} + // ConvertType represents the type in call to CONVERT(expr, type) type ConvertType struct { Type string @@ -6424,6 +6715,21 @@ func (node Values) walkSubtree(visit Visit) error { return nil } +// AliasedValues represents a VALUES clause with an optional `AS name(colnames...)` +type AliasedValues struct { + Values + As TableIdent + Columns Columns +} + +// Format formats the node. +func (node AliasedValues) Format(buf *TrackedBuffer) { + node.Values.Format(buf) + if node.As.v != "" { + buf.Myprintf(" AS %v%v", node.As, node.Columns) + } +} + // AssignmentExprs represents a list of assignment expressions. type AssignmentExprs []*AssignmentExpr @@ -6500,113 +6806,118 @@ const ( SetScope_User SetScope = "user" ) -// VarScopeForColName returns the SetScope of the given ColName, along with a new ColName without the scope information. -func VarScopeForColName(colName *ColName) (*ColName, SetScope, error) { +// VarScopeForColName returns the SetScope of the given ColName, along with a new ColName without the scope information, +// and a string indicating the exact scope that was specified in the original query or "" if no scope was explicitly +// specified. +func VarScopeForColName(colName *ColName) (*ColName, SetScope, string, error) { if colName.Qualifier.IsEmpty() { // Forms are like `@@x` and `@x` if strings.HasPrefix(colName.Name.val, "@") && strings.Index(colName.Name.val, ".") != -1 { - varName, scope, err := VarScope(strings.Split(colName.Name.val, ".")...) + varName, scope, specifiedScope, err := VarScope(strings.Split(colName.Name.val, ".")...) if err != nil { - return nil, SetScope_None, err + return nil, SetScope_None, "", err } if scope == SetScope_None { - return colName, scope, nil + return colName, scope, "", nil } - return &ColName{Name: ColIdent{val: varName}}, scope, nil + return &ColName{Name: ColIdent{val: varName}}, scope, specifiedScope, nil } else { - varName, scope, err := VarScope(colName.Name.val) + varName, scope, specifiedScope, err := VarScope(colName.Name.val) if err != nil { - return nil, SetScope_None, err + return nil, SetScope_None, "", err } if scope == SetScope_None { - return colName, scope, nil + return colName, scope, "", nil } - return &ColName{Name: ColIdent{val: varName}}, scope, nil + return &ColName{Name: ColIdent{val: varName}}, scope, specifiedScope, nil } - } else if colName.Qualifier.Qualifier.IsEmpty() { // Forms are like `@@GLOBAL.x` and `@@SESSION.x` - varName, scope, err := VarScope(colName.Qualifier.Name.v, colName.Name.val) + } else if colName.Qualifier.DbQualifier.IsEmpty() { // Forms are like `@@GLOBAL.x` and `@@SESSION.x` + varName, scope, specifiedScope, err := VarScope(colName.Qualifier.Name.v, colName.Name.val) if err != nil { - return nil, SetScope_None, err + return nil, SetScope_None, "", err } if scope == SetScope_None { - return colName, scope, nil + return colName, scope, "", nil } - return &ColName{Name: ColIdent{val: varName}}, scope, nil + return &ColName{Name: ColIdent{val: varName}}, scope, specifiedScope, nil } else { // Forms are like `@@GLOBAL.validate_password.length`, which is currently unsupported - _, _, err := VarScope(colName.Qualifier.Qualifier.v, colName.Qualifier.Name.v, colName.Name.val) - return colName, SetScope_None, err + _, _, _, err := VarScope(colName.Qualifier.DbQualifier.v, colName.Qualifier.Name.v, colName.Name.val) + return colName, SetScope_None, "", err } } // VarScope returns the SetScope of the given name, broken into parts. For example, `@@GLOBAL.sys_var` would become // `[]string{"@@GLOBAL", "sys_var"}`. Returns the variable name without any scope specifiers, so the aforementioned -// variable would simply return "sys_var". `[]string{"@@other_var"}` would return "other_var". If the name parts do not -// specify a variable (returns SetScope_None), then it is recommended to use the original non-broken string, as this -// will always only return the last part. `[]string{"my_db", "my_tbl", "my_col"}` will return "my_col" with SetScope_None. -func VarScope(nameParts ...string) (string, SetScope, error) { +// variable would simply return "sys_var". `[]string{"@@other_var"}` would return "other_var". If a scope is not +// explicitly specified, then the requestedScope string will be empty, otherwise it will be the exact +// scope that was explicitly specified, which can differ from the returned scope, when the returned scope is +// inferred. If the name parts do not specify a variable (returns SetScope_None), then it is recommended to use the original non-broken string, as this will always only return the last part. +// `[]string{"my_db", "my_tbl", "my_col"}` will return "my_col" with SetScope_None. +func VarScope(nameParts ...string) (string, SetScope, string, error) { switch len(nameParts) { case 0: - return "", SetScope_None, nil + return "", SetScope_None, "", nil case 1: // First case covers `@@@`, `@@@@`, etc. if strings.HasPrefix(nameParts[0], "@@@") { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[0]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[0]) } else if strings.HasPrefix(nameParts[0], "@@") { dotIdx := strings.Index(nameParts[0], ".") if dotIdx != -1 { return VarScope(nameParts[0][:dotIdx], nameParts[0][dotIdx+1:]) } - return nameParts[0][2:], SetScope_Session, nil + // Session scope is inferred here, but not explicitly requested + return nameParts[0][2:], SetScope_Session, "", nil } else if strings.HasPrefix(nameParts[0], "@") { - return nameParts[0][1:], SetScope_User, nil + return nameParts[0][1:], SetScope_User, "", nil } else { - return nameParts[0], SetScope_None, nil + return nameParts[0], SetScope_None, "", nil } case 2: // `@user.var` is valid, so we check for it here. if len(nameParts[0]) >= 2 && nameParts[0][0] == '@' && nameParts[0][1] != '@' && !strings.HasPrefix(nameParts[1], "@") { // `@user.@var` is invalid though. - return fmt.Sprintf("%s.%s", nameParts[0][1:], nameParts[1]), SetScope_User, nil + return fmt.Sprintf("%s.%s", nameParts[0][1:], nameParts[1]), SetScope_User, "", nil } // We don't support variables such as `@@validate_password.length` right now, only `@@GLOBAL.sys_var`, etc. // The `@` symbols are only valid on the first name_part. First case also catches `@@@`, etc. if strings.HasPrefix(nameParts[1], "@@") { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } else if strings.HasPrefix(nameParts[1], "@") { - return "", SetScope_None, fmt.Errorf("invalid user variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid user variable declaration `%s`", nameParts[1]) } switch strings.ToLower(nameParts[0]) { case "@@global": if strings.HasPrefix(nameParts[1], `"`) || strings.HasPrefix(nameParts[1], `'`) { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } - return nameParts[1], SetScope_Global, nil + return nameParts[1], SetScope_Global, nameParts[0][2:], nil case "@@persist": if strings.HasPrefix(nameParts[1], `"`) || strings.HasPrefix(nameParts[1], `'`) { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } - return nameParts[1], SetScope_Persist, nil + return nameParts[1], SetScope_Persist, nameParts[0][2:], nil case "@@persist_only": if strings.HasPrefix(nameParts[1], `"`) || strings.HasPrefix(nameParts[1], `'`) { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } - return nameParts[1], SetScope_PersistOnly, nil + return nameParts[1], SetScope_PersistOnly, nameParts[0][2:], nil case "@@session": if strings.HasPrefix(nameParts[1], `"`) || strings.HasPrefix(nameParts[1], `'`) { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } - return nameParts[1], SetScope_Session, nil + return nameParts[1], SetScope_Session, nameParts[0][2:], nil case "@@local": if strings.HasPrefix(nameParts[1], `"`) || strings.HasPrefix(nameParts[1], `'`) { - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } - return nameParts[1], SetScope_Session, nil + return nameParts[1], SetScope_Session, nameParts[0][2:], nil default: // This catches `@@@GLOBAL.sys_var`. Due to the earlier check, this does not error on `@user.var`. if strings.HasPrefix(nameParts[0], "@") { // Last value is column name, so we return that in the error - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[1]) } - return nameParts[1], SetScope_None, nil + return nameParts[1], SetScope_None, "", nil } default: // `@user.var.name` is valid, so we check for it here. @@ -6615,20 +6926,20 @@ func VarScope(nameParts ...string) (string, SetScope, error) { for i := 1; i < len(nameParts); i++ { if strings.HasPrefix(nameParts[i], "@") { // Last value is column name, so we return that in the error - return "", SetScope_None, fmt.Errorf("invalid user variable declaration `%s`", nameParts[len(nameParts)-1]) + return "", SetScope_None, "", fmt.Errorf("invalid user variable declaration `%s`", nameParts[len(nameParts)-1]) } } - return strings.Join(append([]string{nameParts[0][1:]}, nameParts[1:]...), "."), SetScope_User, nil + return strings.Join(append([]string{nameParts[0][1:]}, nameParts[1:]...), "."), SetScope_User, "", nil } // As we don't support `@@GLOBAL.validate_password.length` or anything potentially longer, we error if any part // starts with either `@@` or `@`. We can just check for `@` though. for _, namePart := range nameParts { if strings.HasPrefix(namePart, "@") { // Last value is column name, so we return that in the error - return "", SetScope_None, fmt.Errorf("invalid system variable declaration `%s`", nameParts[len(nameParts)-1]) + return "", SetScope_None, "", fmt.Errorf("invalid system variable declaration `%s`", nameParts[len(nameParts)-1]) } } - return nameParts[len(nameParts)-1], SetScope_None, nil + return nameParts[len(nameParts)-1], SetScope_None, "", nil } } @@ -6866,6 +7177,15 @@ func (node *TableFuncExpr) UnmarshalJSON(b []byte) error { return nil } +func (node *TableFuncExpr) walkSubtree(visit Visit) error { + if node == nil { + return nil + } + return Walk( + visit, + node.Exprs) +} + // TableIdent is a case sensitive SQL identifier. It will be escaped with // backquotes if necessary. type TableIdent struct { @@ -7193,3 +7513,34 @@ func (node *SrsAttribute) Format(buf *TrackedBuffer) { buf.Myprintf("organization '%s' identified by %v\n", node.Organization, node.OrgID) buf.Myprintf("description '%s'", node.Description) } + +// InjectableExpression is an expression that can accept a set of analyzed/resolved children. Used within InjectedExpr. +type InjectableExpression interface { + WithResolvedChildren(children []any) (any, error) +} + +// InjectedExpr allows bypassing AST analysis. This is used by projects that rely on Vitess, but may not implement +// MySQL's dialect. +type InjectedExpr struct { + Expression InjectableExpression + Children []Expr +} + +var _ Expr = InjectedExpr{} + +// iExpr implements the Expr interface. +func (d InjectedExpr) iExpr() {} + +// replace implements the Expr interface. +func (d InjectedExpr) replace(from, to Expr) bool { + return false +} + +// Format implements the Expr interface. +func (d InjectedExpr) Format(buf *TrackedBuffer) { + if stringer, ok := d.Expression.(fmt.Stringer); ok { + buf.WriteString(stringer.String()) + } else { + buf.WriteString("InjectedExpr") + } +} diff --git a/go/vt/sqlparser/ast_permissions.go b/go/vt/sqlparser/ast_permissions.go index 92192d570a1..ccd028b5dba 100644 --- a/go/vt/sqlparser/ast_permissions.go +++ b/go/vt/sqlparser/ast_permissions.go @@ -37,6 +37,11 @@ func (an *AccountName) String() string { strings.ReplaceAll(an.Name, "`", "``"), strings.ReplaceAll(host, "`", "``")) } +// IsEmpty returns true if any of the fields in this AccountName are set. +func (an *AccountName) IsEmpty() bool { + return an.Name == "" && an.Host == "" +} + // AccountRename represents an account changing its name. type AccountRename struct { From AccountName diff --git a/go/vt/sqlparser/ast_test.go b/go/vt/sqlparser/ast_test.go index 459c26d265b..1e77968826a 100644 --- a/go/vt/sqlparser/ast_test.go +++ b/go/vt/sqlparser/ast_test.go @@ -24,6 +24,7 @@ import ( "testing" "unsafe" + "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" "github.com/dolthub/vitess/go/sqltypes" @@ -632,7 +633,7 @@ func TestExprFromValue(t *testing.T) { out: NewIntVal([]byte("1")), }, { in: sqltypes.NewFloat64(1.1), - out: NewFloatVal([]byte("1.1")), + out: NewFloatVal([]byte("1.1e+00")), }, { in: sqltypes.MakeTrusted(sqltypes.Decimal, []byte("1.1")), out: NewFloatVal([]byte("1.1")), @@ -884,6 +885,74 @@ func TestSplitStatementToPieces(t *testing.T) { } } +func TestVarScopeForColName(t *testing.T) { + testcases := []struct { + colName ColName + expectedName ColName + expectedScope string + expectedSpecifiedScope string + }{ + { + // Regular column name + colName: ColName{Name: ColIdent{val: "a"}}, + expectedName: ColName{Name: ColIdent{val: "a"}}, + expectedSpecifiedScope: "", + }, + { + // User variable + colName: ColName{Name: ColIdent{val: "@aaa"}}, + expectedName: ColName{Name: ColIdent{val: "aaa"}}, + expectedSpecifiedScope: "", + expectedScope: "user", + }, + { + // System variable without an explicit scope (defaults to session) + colName: ColName{Name: ColIdent{val: "@@max_allowed_packets"}}, + expectedName: ColName{Name: ColIdent{val: "max_allowed_packets"}}, + expectedSpecifiedScope: "", + expectedScope: "session", + }, + { + // System variable with an explicit session scope + colName: ColName{Name: ColIdent{val: "@@session.max_allowed_packets"}}, + expectedName: ColName{Name: ColIdent{val: "max_allowed_packets"}}, + expectedSpecifiedScope: "session", + expectedScope: "session", + }, + { + // System variable with an explicit global scope + colName: ColName{Name: ColIdent{val: "@@global.max_allowed_packets"}}, + expectedName: ColName{Name: ColIdent{val: "max_allowed_packets"}}, + expectedSpecifiedScope: "global", + expectedScope: "global", + }, + { + // System variable with an explicit global scope (in all caps) + colName: ColName{Name: ColIdent{val: "@@GLOBAL.max_allowed_packets"}}, + expectedName: ColName{Name: ColIdent{val: "max_allowed_packets"}}, + expectedSpecifiedScope: "GLOBAL", + expectedScope: "global", + }, + { + // System variable with an explicit persist scope + colName: ColName{Name: ColIdent{val: "@@persist.max_allowed_packets"}}, + expectedName: ColName{Name: ColIdent{val: "max_allowed_packets"}}, + expectedSpecifiedScope: "persist", + expectedScope: "persist", + }, + } + + for _, tt := range testcases { + t.Run(tt.colName.String(), func(t *testing.T) { + name, scope, specifiedScope, err := VarScopeForColName(&tt.colName) + assert.NoError(t, err) + assert.Equal(t, tt.expectedName, *name) + assert.Equal(t, tt.expectedScope, string(scope)) + assert.Equal(t, tt.expectedSpecifiedScope, specifiedScope) + }) + } +} + func TestWindowErrors(t *testing.T) { testcases := []struct { input string diff --git a/go/vt/sqlparser/keywords.go b/go/vt/sqlparser/keywords.go index 026945a1401..59cbc6aa5cd 100755 --- a/go/vt/sqlparser/keywords.go +++ b/go/vt/sqlparser/keywords.go @@ -92,6 +92,7 @@ var keywords = map[string]int{ "audit_admin": AUDIT_ADMIN, "authentication": AUTHENTICATION, "authentication_policy_admin": AUTHENTICATION_POLICY_ADMIN, + "autoextend_size": AUTOEXTEND_SIZE, "auto_increment": AUTO_INCREMENT, "avg": AVG, "avg_row_length": AVG_ROW_LENGTH, @@ -114,6 +115,7 @@ var keywords = map[string]int{ "by": BY, "call": CALL, "cascade": CASCADE, + "cascaded": CASCADED, "case": CASE, "cast": CAST, "catalog_name": CATALOG_NAME, @@ -130,6 +132,7 @@ var keywords = map[string]int{ "client": CLIENT, "clone_admin": CLONE_ADMIN, "close": CLOSE, + "coalesce": COALESCE, "collate": COLLATE, "collation": COLLATION, "column": COLUMN, @@ -153,6 +156,7 @@ var keywords = map[string]int{ "contained": CONTAINED, "continue": CONTINUE, "convert": CONVERT, + "copy": COPY, "count": COUNT, "create": CREATE, "cross": CROSS, @@ -192,6 +196,7 @@ var keywords = map[string]int{ "deterministic": DETERMINISTIC, "directory": DIRECTORY, "disable": DISABLE, + "discard": DISCARD, "disk": DISK, "distinct": DISTINCT, "distinctrow": DISTINCTROW, @@ -226,6 +231,8 @@ var keywords = map[string]int{ "events": EVENTS, "every": EVERY, "except": EXCEPT, + "exchange": EXCHANGE, + "exclusive": EXCLUSIVE, "execute": EXECUTE, "exists": EXISTS, "exit": EXIT, @@ -293,6 +300,7 @@ var keywords = map[string]int{ "identified": IDENTIFIED, "if": IF, "ignore": IGNORE, + "import": IMPORT, "in": IN, "index": INDEX, "indexes": INDEXES, @@ -305,6 +313,8 @@ var keywords = map[string]int{ "insensitive": INSENSITIVE, "insert": INSERT, "insert_method": INSERT_METHOD, + "inplace": INPLACE, + "instant": INSTANT, "int": INT, "int1": INT1, "int2": INT2, @@ -356,12 +366,14 @@ var keywords = map[string]int{ "localtimestamp": LOCALTIMESTAMP, "lock": LOCK, "locked": LOCKED, + "log": LOG, "logs": LOGS, "long": LONG, "longblob": LONGBLOB, "longtext": LONGTEXT, "loop": LOOP, "low_priority": LOW_PRIORITY, + "master": MASTER, "master_bind": MASTER_BIND, "master_ssl_verify_server_cert": MASTER_SSL_VERIFY_SERVER_CERT, "match": MATCH, @@ -375,6 +387,7 @@ var keywords = map[string]int{ "mediumblob": MEDIUMBLOB, "mediumint": MEDIUMINT, "mediumtext": MEDIUMTEXT, + "memory": MEMORY, "merge": MERGE, "message_text": MESSAGE_TEXT, "middleint": MIDDLEINT, @@ -434,6 +447,7 @@ var keywords = map[string]int{ "over": OVER, "pack_keys": PACK_KEYS, "partition": PARTITION, + "partitioning": PARTITIONING, "partitions": PARTITIONS, "password": PASSWORD, "password_lock_time": PASSWORD_LOCK_TIME, @@ -446,6 +460,7 @@ var keywords = map[string]int{ "plugins": PLUGINS, "point": POINT, "polygon": POLYGON, + "position": POSITION, "precedes": PRECEDES, "preceding": PRECEDING, "precision": PRECISION, @@ -463,6 +478,7 @@ var keywords = map[string]int{ "random": RANDOM, "range": RANGE, "rank": RANK, + "rebuild": REBUILD, "read": READ, "read_write": READ_WRITE, "reads": READS, @@ -475,6 +491,7 @@ var keywords = map[string]int{ "relay": RELAY, "release": RELEASE, "reload": RELOAD, + "remove": REMOVE, "rename": RENAME, "reorganize": REORGANIZE, "repair": REPAIR, @@ -482,6 +499,7 @@ var keywords = map[string]int{ "repeatable": REPEATABLE, "replace": REPLACE, "replica": REPLICA, + "replicas": REPLICAS, "replicate_do_table": REPLICATE_DO_TABLE, "replicate_ignore_table": REPLICATE_IGNORE_TABLE, "replication": REPLICATION, @@ -528,6 +546,7 @@ var keywords = map[string]int{ "set": SET, "set_user_id": SET_USER_ID, "share": SHARE, + "shared": SHARED, "show": SHOW, "show_routine": SHOW_ROUTINE, "shutdown": SHUTDOWN, @@ -539,6 +558,7 @@ var keywords = map[string]int{ "slow": SLOW, "smallint": SMALLINT, "source": SOURCE, + "source_auto_position": SOURCE_AUTO_POSITION, "source_connect_retry": SOURCE_CONNECT_RETRY, "source_host": SOURCE_HOST, "source_password": SOURCE_PASSWORD, @@ -631,6 +651,7 @@ var keywords = map[string]int{ "utc_date": UTC_DATE, "utc_time": UTC_TIME, "utc_timestamp": UTC_TIMESTAMP, + "validation": VALIDATION, "value": VALUE, "values": VALUES, "var_pop": VAR_POP, @@ -653,6 +674,7 @@ var keywords = map[string]int{ "while": WHILE, "window": WINDOW, "with": WITH, + "without": WITHOUT, "work": WORK, "write": WRITE, "x509": X509, diff --git a/go/vt/sqlparser/parse_test.go b/go/vt/sqlparser/parse_test.go index dbb280bba53..8a104e4b23a 100644 --- a/go/vt/sqlparser/parse_test.go +++ b/go/vt/sqlparser/parse_test.go @@ -39,10 +39,30 @@ type parseTest struct { var ( validSQL = []parseTest{ + { + input: "SELECT * FROM base.version;", + output: "select * from base.`version`", + }, + { + input: "CREATE VIEW version AS SELECT * FROM base.version;", + output: "create view `version` as select * from base.`version`", + }, + { + input: "create table t123 (c1 varchar(5) check (c1 in ('v1', 'v2')) NOT NULL);", + output: "create table t123 (\n\tc1 varchar(5) not null,\n\tcheck (c1 in ('v1', 'v2'))\n)", + }, { input: "INSERT INTO hourly_logins (applications_id, count, hour) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE count = count + VALUES(count)", output: "insert into hourly_logins(applications_id, `count`, `hour`) values (:v1, :v2, :v3) on duplicate key update count = `count` + values(`count`)", }, + { + input: "INSERT INTO hourly_logins (applications_id, count, hour) VALUES (?, ?, ?) AS dt ON DUPLICATE KEY UPDATE count = count + dt.count", + output: "insert into hourly_logins(applications_id, `count`, `hour`) values (:v1, :v2, :v3) AS dt on duplicate key update count = `count` + dt.`count`", + }, + { + input: "INSERT INTO hourly_logins (applications_id, count, hour) VALUES (?, ?, ?) AS dt(new_id, new_count, new_hour) ON DUPLICATE KEY UPDATE count = count + dt.count", + output: "insert into hourly_logins(applications_id, `count`, `hour`) values (:v1, :v2, :v3) AS dt(new_id, new_count, new_hour) on duplicate key update count = `count` + dt.`count`", + }, { input: "INSERT INTO hourly_logins (applications_id, count, hour) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE account = account + VALUES(account)", output: "insert into hourly_logins(applications_id, `count`, `hour`) values (:v1, :v2, :v3) on duplicate key update account = `account` + values(`account`)", @@ -105,6 +125,19 @@ var ( input: "SET @@GLOBAL.GTID_PURGED:= /*!80000 '+'*/ 'beabe64c-9dc6-11ed-8021-a0f9021e8e70:1-126';", output: "set global GTID_PURGED = '+beabe64c-9dc6-11ed-8021-a0f9021e8e70:1-126'", }, + { + input: "show replicas", + }, + { + input: "show binary logs", + }, + { + input: "show binary log status", + }, + { + input: "SHOW MASTER STATUS", + output: "show binary log status", + }, { input: "start replica", }, @@ -118,6 +151,10 @@ var ( input: "change replication source to SOURCE_HOST = 'Host'", output: "change replication source to source_host = Host", }, + { + input: "change replication source to SOURCE_HOST = 'Host', SOURCE_AUTO_POSITION=0", + output: "change replication source to source_host = Host, source_auto_position = 0", + }, { input: "change replication source to SOURCE_HOST = 'host', SOURCE_PASSWORD='PaSSword', SOURCE_PORT=12345, source_user='root', SOURCE_CONNECT_RETRY=60, SOURCE_RETRY_COUNT=3", output: "change replication source to source_host = host, source_password = PaSSword, source_port = 12345, source_user = root, source_connect_retry = 60, source_retry_count = 3", @@ -344,6 +381,18 @@ var ( }, { input: "select a from (select 1 as a from tbl1 union select 2 from tbl2) as t (a, b)", }, + { + input: "select a from (values (1, 2), ('a', 'b')) as t (a, b)", + output: "select a from (values row(1, 2), row('a', 'b')) as t (a, b)", + }, + { + input: "select a from (values (1, 2), row('a', 'b')) as t (a, b)", + output: "select a from (values row(1, 2), row('a', 'b')) as t (a, b)", + }, + { + input: "select a from (values row(1, 2), ('a', 'b')) as t (a, b)", + output: "select a from (values row(1, 2), row('a', 'b')) as t (a, b)", + }, { input: "select a from (values row(1, 2), row('a', 'b')) as t (a, b)", }, @@ -678,6 +727,9 @@ var ( input: "with recursive cte1 as (select a from b) insert into c select * from cte1", }, { input: "select /* s.t */ 1 from s.t", + }, { + input: "select /* s.keyword */ 1 from s.account", + output: "select /* s.keyword */ 1 from s.`account`", }, { input: "select /* keyword schema & table name */ 1 from `By`.`bY`", }, { @@ -834,51 +886,88 @@ var ( input: "select /* function with distinct */ count(distinct a) from t", }, { input: "select /* if as func */ 1 from t where a = if(b)", - }, { - input: "select /* current_timestamp */ current_timestamp() from t", - }, { - input: "select /* current_timestamp as func */ current_timestamp() from t", - }, { - input: "select /* current_timestamp with fsp */ current_timestamp(3) from t", - }, { - input: "select /* current_date */ current_date() from t", - }, { + }, + { + input: "select /* current_date */ current_date from t", + output: "select /* current_date */ current_date() from t", + }, + { input: "select /* current_date as func */ current_date() from t", - }, { - input: "select /* current_time */ current_time() from t", - }, { - input: "select /* current_time as func */ current_time() from t", - }, { + }, + { + input: "select /* current_time */ current_time from t", + output: "select /* current_time */ current_time(0) from t", + }, + { + input: "select /* current_time as func */ current_time() from t", + output: "select /* current_time as func */ current_time(0) from t", + }, + { input: "select /* current_time with fsp */ current_time(1) from t", - }, { - input: "select /* utc_timestamp */ utc_timestamp() from t", - }, { - input: "select /* utc_timestamp as func */ utc_timestamp() from t", - }, { - input: "select /* utc_timestamp with fsp */ utc_timestamp(0) from t", - }, { - input: "select /* utc_time */ utc_time() from t", - }, { - input: "select /* utc_time as func */ utc_time() from t", - }, { - input: "select /* utc_time with fsp */ utc_time(4) from t", - }, { - input: "select /* utc_date */ utc_date() from t", - }, { - input: "select /* utc_date as func */ utc_date() from t", - }, { - input: "select /* localtime */ localtime() from t", - }, { - input: "select /* localtime as func */ localtime() from t", - }, { + }, + { + input: "select /* current_timestamp */ current_timestamp from t", + output: "select /* current_timestamp */ current_timestamp(0) from t", + }, + { + input: "select /* current_timestamp as func */ current_timestamp() from t", + output: "select /* current_timestamp as func */ current_timestamp(0) from t", + }, + { + input: "select /* current_timestamp with fsp */ current_timestamp(3) from t", + }, + { + input: "select /* localtime */ localtime from t", + output: "select /* localtime */ localtime(0) from t", + }, + { + input: "select /* localtime as func */ localtime() from t", + output: "select /* localtime as func */ localtime(0) from t", + }, + { input: "select /* localtime with fsp */ localtime(5) from t", - }, { - input: "select /* localtimestamp */ localtimestamp() from t", - }, { - input: "select /* localtimestamp as func */ localtimestamp() from t", - }, { + }, + { + input: "select /* localtimestamp */ localtimestamp from t", + output: "select /* localtimestamp */ localtimestamp(0) from t", + }, + { + input: "select /* localtimestamp as func */ localtimestamp() from t", + output: "select /* localtimestamp as func */ localtimestamp(0) from t", + }, + { input: "select /* localtimestamp with fsp */ localtimestamp(7) from t", - }, { + }, + { + input: "select /* utc_date */ utc_date from t", + output: "select /* utc_date */ utc_date() from t", + }, + { + input: "select /* utc_date as func */ utc_date() from t", + }, + { + input: "select /* utc_time */ utc_time from t", + output: "select /* utc_time */ utc_time(0) from t", + }, + { + input: "select /* utc_time as func */ utc_time() from t", + output: "select /* utc_time as func */ utc_time(0) from t", + }, + { + input: "select /* utc_time with fsp */ utc_time(4) from t", + }, + { + input: "select /* utc_timestamp */ utc_timestamp from t", + output: "select /* utc_timestamp */ utc_timestamp(0) from t", + }, + { + input: "select /* utc_timestamp as func */ utc_timestamp() from t", + output: "select /* utc_timestamp as func */ utc_timestamp(0) from t", + }, + { + input: "select /* utc_timestamp with fsp */ utc_timestamp(0) from t", + }, + { input: "select /* mod as func */ a from tab where mod(b, 2) = 0", }, { input: "select /* database as func no param */ database() from t", @@ -1129,10 +1218,36 @@ var ( }, { input: "insert into a(a, b) value (1, ifnull(null, default(b)))", output: "insert into a(a, b) values (1, ifnull(null, default(b)))", - }, { + }, + { input: "insert into a value (1, ifnull(null, default(b)))", output: "insert into a values (1, ifnull(null, default(b)))", - }, { + }, + { + input: "insert into xy values row (1, 1)", + output: "insert into xy values (1, 1)", + }, + { + input: "insert into xy values row (1, 1), row (2, 2)", + output: "insert into xy values (1, 1), (2, 2)", + }, + { + input: "insert into xy values (1, 1), row (2, 2)", + output: "insert into xy values (1, 1), (2, 2)", + }, + { + input: "insert into xy values row (1, 1), (2, 2)", + output: "insert into xy values (1, 1), (2, 2)", + }, + { + input: "insert into xy ((( values row (1, 1), row (2, 2) )))", + output: "insert into xy values (1, 1), (2, 2)", + }, + { + input: "insert into xy values row()", + output: "insert into xy values ()", + }, + { input: "insert /* qualified column list */ into a(a, b) values (1, 2)", }, { input: "insert /* qualified columns */ into t (t.a, t.b) values (1, 2)", @@ -1500,10 +1615,76 @@ var ( }, { input: "alter table a rename key foo to bar", output: "alter table a rename index foo to bar", - }, { + }, + { + input: "alter table a add partition (partition p values less than (val))", + }, + { + input: "alter table a drop partition p", + }, + { + input: "alter table a discard partition p tablespace", + }, + { + input: "alter table a discard partition all tablespace", + }, + { + input: "alter table a import partition p tablespace", + }, + { + input: "alter table a import partition all tablespace", + }, + { + input: "alter table a truncate partition p tablespace", + }, + { + input: "alter table a truncate partition all tablespace", + }, + { + input: "alter table a coalesce partition 5", + }, + { input: "alter table a reorganize partition b into (partition c values less than (?), partition d values less than (maxvalue))", output: "alter table a reorganize partition b into (partition c values less than (:v1), partition d values less than (maxvalue))", - }, { + }, + { + input: "alter table a exchange partition p with table t", + output: "alter table a exchange partition p with table t without validation", + }, + { + input: "alter table a exchange partition p with table t with validation", + }, + { + input: "alter table a exchange partition p with table t without validation", + }, + { + input: "alter table a analyze partition p", + }, + { + input: "alter table a analyze partition all", + }, + { + input: "alter table a optimize partition p", + }, + { + input: "alter table a optimize partition all", + }, + { + input: "alter table a rebuild partition p", + }, + { + input: "alter table a rebuild partition all", + }, + { + input: "alter table a repair partition p", + }, + { + input: "alter table a repair partition all", + }, + { + input: "alter table a remove partitioning", + }, + { input: "alter table a add column id int", output: "alter table a add column (\n\tid int\n)", }, { @@ -1562,11 +1743,23 @@ var ( input: "alter table a drop check status", }, { input: "alter table a drop constraint status", - }, { + }, + { input: "alter table a drop foreign key fk_something", - }, { + }, + { input: "alter table a drop constraint b", - }, { + }, + { + input: "alter table a rename constraint foreign key oldfk to newfk", + }, + { + input: "alter table a rename constraint check oldchk to newchk", + }, + { + input: "alter table a rename constraint oldcon to newcon", + }, + { input: "alter table a drop id", output: "alter table a drop column id", }, { @@ -1591,6 +1784,21 @@ var ( }, { input: "alter table a rename column a as b", output: "alter table a rename column a to b", + }, { + input: "create table t1 (id serial primary key, c1 text not null);", + output: "create table t1 (\n\tid bigint not null auto_increment primary key,\n\tc1 text not null\n)", + }, { + input: "create table t1 (id int primary key unique, c1 varchar(111) not null);", + output: "create table t1 (\n\tid int primary key,\n\tc1 varchar(111) not null\n)", + }, { + input: "create table t1 (id int primary key unique key, c1 varchar(111) not null);", + output: "create table t1 (\n\tid int primary key,\n\tc1 varchar(111) not null\n)", + }, { + input: "create table t1 (id int primary key primary key, c1 varchar(111) not null);", + output: "create table t1 (\n\tid int primary key,\n\tc1 varchar(111) not null\n)", + }, { + input: "create table t1 (id int unique unique unique unique, c1 varchar(111) not null);", + output: "create table t1 (\n\tid int unique,\n\tc1 varchar(111) not null\n)", }, { input: "create table a (b1 bool not null primary key, b2 boolean not null)", output: "create table a (\n\tb1 bool not null primary key,\n\tb2 boolean not null\n)", @@ -1635,61 +1843,77 @@ var ( output: "alter table b add spatial index a using btree (id)", }, { input: "create ALGORITHM=UNDEFINED DEFINER=`UserName`@`localhost` SQL SECURITY DEFINER view a as select current_timestamp()", - output: "create algorithm = undefined definer = `UserName`@`localhost` sql security definer view a as select current_timestamp()", + output: "create algorithm = undefined definer = `UserName`@`localhost` sql security definer view a as select current_timestamp(0)", }, { input: "create ALGORITHM=UNDEFINED SQL SECURITY DEFINER view a as select current_timestamp()", - output: "create algorithm = undefined sql security definer view a as select current_timestamp()", + output: "create algorithm = undefined sql security definer view a as select current_timestamp(0)", }, { input: "create ALGORITHM=UNDEFINED DEFINER=UserName@localhost view a as select current_timestamp()", - output: "create algorithm = undefined definer = `UserName`@`localhost` view a as select current_timestamp()", + output: "create algorithm = undefined definer = `UserName`@`localhost` view a as select current_timestamp(0)", }, { input: "create ALGORITHM=MERGE DEFINER=UserName@localhost SQL SECURITY INVOKER view a as select current_timestamp()", - output: "create algorithm = merge definer = `UserName`@`localhost` sql security invoker view a as select current_timestamp()", + output: "create algorithm = merge definer = `UserName`@`localhost` sql security invoker view a as select current_timestamp(0)", }, { input: "create ALGORITHM=TEMPTABLE DEFINER=UserName@localhost SQL SECURITY DEFINER view a as select current_timestamp()", - output: "create algorithm = temptable definer = `UserName`@`localhost` sql security definer view a as select current_timestamp()", + output: "create algorithm = temptable definer = `UserName`@`localhost` sql security definer view a as select current_timestamp(0)", }, { input: "create DEFINER=`nameUser`@`localhost` SQL SECURITY DEFINER view a as select current_timestamp()", - output: "create definer = `nameUser`@`localhost` sql security definer view a as select current_timestamp()", + output: "create definer = `nameUser`@`localhost` sql security definer view a as select current_timestamp(0)", }, { input: "create SQL SECURITY INVOKER view a as select current_timestamp()", - output: "create sql security invoker view a as select current_timestamp()", + output: "create sql security invoker view a as select current_timestamp(0)", }, { input: "CREATE VIEW a AS SELECT current_timestamp()", - output: "create view a as select current_timestamp()", + output: "create view a as select current_timestamp(0)", }, { input: "create view a_view as select * from table_1 join table_2 on table_1.table_2_id_fk = table_2.id where city = 'my city'", output: "create view a_view as select * from table_1 join table_2 on table_1.table_2_id_fk = table_2.id where city = 'my city'", }, { input: "CREATE OR REPLACE VIEW a AS SELECT current_timestamp()", - output: "create or replace view a as select current_timestamp()", - }, { + output: "create or replace view a as select current_timestamp(0)", + }, + { input: "create trigger t1 before update on foo for each row precedes bar update xxy set baz = 1 where a = b", - }, { + }, + { input: "create trigger t2 before update on foo for each row precedes bar call myStoredProc(foo)", - }, { + }, + { input: "create trigger dbName.trigger1 before update on foo for each row precedes bar update xxy set baz = 1 where a = b", - }, { + }, + { input: "create trigger t1 after delete on foo for each row delete from xxy where old.y = z", - }, { //TODO: figure out why `SET SESSION sys_var = x` does not work when set directly on the trigger (works in BEGIN/END block) + }, + { //TODO: figure out why `SET SESSION sys_var = x` does not work when set directly on the trigger (works in BEGIN/END block) input: "create trigger t1 after delete on foo for each row set @@sum = @@sum + old.b", output: "create trigger t1 after delete on foo for each row set session sum = @@sum + old.b", - }, { + }, + { input: "create trigger t1 before insert on foo for each row set new.x = new.x + 1", - }, { + }, + { input: "create trigger t1 after insert on foo for each row update xxy set y = new.x", - }, { + }, + { input: "create trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", - }, { + }, + { + input: "create trigger t1 before insert on foo for each row begin end", + output: "create trigger t1 before insert on foo for each row begin\nend", + }, + { input: "create DEFINER=`root`@`localhost` trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", output: "create definer = `root`@`localhost` trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", - }, { + }, + { input: "create definer = me trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", output: "create definer = `me`@`%` trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", - }, { + }, + { input: "create definer=me trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", output: "create definer = `me`@`%` trigger t1 before delete on foo for each row follows baz update xxy set x = old.y", - }, { + }, + { input: "rename table a to b", output: "rename table a to b", }, { @@ -2454,10 +2678,8 @@ var ( input: "create database test_db", }, { input: "create schema test_db", - output: "create database test_db", }, { input: "create database if not exists test_db", - output: "create database if not exists test_db", }, { input: "alter database test_db character set utf8mb3", }, { @@ -2474,10 +2696,8 @@ var ( input: "drop database test_db", }, { input: "drop schema test_db", - output: "drop database test_db", }, { input: "drop database if exists test_db", - output: "drop database if exists test_db", }, { input: "drop trigger trigger1", }, { @@ -2488,57 +2708,57 @@ var ( input: "drop trigger if exists dbName.trigger3", }, { input: "create table t (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique)", - output: "create table t (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "create table t (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "create table t (c int null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique)", - output: "create table t (\n\tc int default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "create table t (\n\tc int default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "create table t (c INT NOT NULL DEFAULT 0 ON UPDATE current_timestamp() AUTO_INCREMENT COMMENT 'a comment here' UNIQUE)", - output: "create table t (\n\tc INT not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "create table t (\n\tc INT not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { // Same input with options backwards. input: "create table t (c int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null)", - output: "create table t (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "create table t (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { // Transpose pairs in original input: "create table t (c int default 0 not null auto_increment on update current_timestamp() unique comment 'a comment here')", - output: "create table t (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "create table t (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { // Transpose pairs in reversed input: "create table t (c int comment 'a comment here' unique on update current_timestamp() auto_increment not null default 0)", - output: "create table t (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "create table t (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { // Those tests for ALTER TABLE ADD (... input: "alter table t add (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique)", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t add (c int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null)", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t add (c int default 0 not null auto_increment on update current_timestamp() unique comment 'a comment here')", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t add (c int comment 'a comment here' unique on update current_timestamp() auto_increment not null default 0)", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { // Those tests for ALTER TABLE ADD COLUMN name ... input: "alter table t add column c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t add column c int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t add column c int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null after foo", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n) after foo", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n) after foo", }, { input: "alter table t add column c int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null first", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n) first", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n) first", }, { input: "alter table t add column c int default 0 not null auto_increment on update current_timestamp() unique comment 'a comment here'", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t add column c int comment 'a comment here' unique on update current_timestamp() auto_increment not null default 0", - output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n)", + output: "alter table t add column (\n\tc int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n)", }, { input: "alter table t change foo bar int not null auto_increment first", output: "alter table t change column foo (\n\tbar int not null auto_increment\n) first", @@ -2547,17 +2767,7 @@ var ( output: "alter table test change column v1 (\n\tv2 varchar(255) character set utf8mb4 binary not null\n)", }, { input: "alter table a modify foo int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null after bar", - output: "alter table a modify column foo (\n\tfoo int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique\n) after bar", - }, { - input: "alter table t add column c int unique comment 'a comment here' auto_increment on update current_timestamp() default 0 not null," + - " change foo bar int not null auto_increment first," + - " reorganize partition b into (partition c values less than (:v1), partition d values less than (maxvalue))," + - " add spatial index idx (id)", - output: `alter table t add column ( - c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique -), change column foo ( - bar int not null auto_increment -) first, reorganize partition b into (partition c values less than (:v1), partition d values less than (maxvalue)), add spatial index idx (id)`, + output: "alter table a modify column foo (\n\tfoo int not null default 0 on update current_timestamp(0) auto_increment comment 'a comment here' unique\n) after bar", }, { input: "alter table t alter foo set default 5", output: "alter table t alter column foo set default 5", @@ -2680,6 +2890,21 @@ var ( }, { input: "CREATE USER UserName@localhost ATTRIBUTE '{\"attr\": \"attr_text\"}'", output: "create user `UserName`@`localhost` attribute '{\"attr\": \"attr_text\"}'", + }, { + input: "ALTER USER IF EXISTS foo@bar IDENTIFIED BY 'password1';", + output: "alter user if exists `foo`@`bar` identified by 'password1'", + }, { + input: "ALTER USER foo@bar IDENTIFIED BY 'password1';", + output: "alter user `foo`@`bar` identified by 'password1'", + }, { + input: "ALTER USER foo@bar IDENTIFIED BY RANDOM PASSWORD;", + output: "alter user `foo`@`bar` identified by random password", + }, { + input: "ALTER USER foo@bar IDENTIFIED WITH some_plugin;", + output: "alter user `foo`@`bar` identified with some_plugin", + }, { + input: "ALTER USER foo@bar IDENTIFIED WITH some_plugin BY 'auth_string';", + output: "alter user `foo`@`bar` identified with some_plugin by 'auth_string'", }, { input: "RENAME USER UserName1@localhost TO UserName2@localhost, UserName3 TO UserName4", output: "rename user `UserName1`@`localhost` to `UserName2`@`localhost`, `UserName3`@`%` to `UserName4`@`%`", @@ -2907,12 +3132,30 @@ var ( }, { input: "FLUSH LOCAL RELAY LOGS FOR CHANNEL 'connections'", output: "flush local relay logs for channel connections", + }, { + input: "FLUSH LOCAL reLay lOgs FOR CHANNEL 'connections'", + output: "flush local relay logs for channel connections", }, { input: "FLUSH LOCAL OPTIMIZER_COSTS", output: "flush local optimizer_costs", }, { input: "FLUSH NO_WRITE_TO_BINLOG HOSTS", output: "flush no_write_to_binlog hosts", + }, { + input: "FLUSH TABLE `inventory`.`customers` WITH READ LOCK", + output: "flush table inventory.customers with read lock", + }, { + input: "FLUSH TABLES `inventory`.`customers` WITH READ LOCK", + output: "flush tables inventory.customers with read lock", + }, { + input: "FLUSH TABLES `inventory`.`customers`", + output: "flush tables inventory.customers", + }, { + input: "FLUSH TABLE table1, foo.table2 WITH READ LOCK", + output: "flush table table1, foo.table2 with read lock", + }, { + input: "FLUSH TABLES table1, foo.table2 WITH READ LOCK", + output: "flush tables table1, foo.table2 with read lock", }, { input: "SHOW GRANTS", output: "show grants", @@ -2979,6 +3222,36 @@ var ( }, { input: "create table test (pk varchar(255)) collate utf8_unicode_ci", output: "create table test (\n\tpk varchar(255)\n) collate utf8_unicode_ci", + }, { + input: "create table test (pk varchar(255) charset binary)", + output: "create table test (\n\tpk varchar(255) character set binary\n)", + }, { + input: "create table test (pk varchar(255) charset utf8mb4)", + output: "create table test (\n\tpk varchar(255) character set utf8mb4\n)", + }, { + input: "create table test (pk varchar(255) character set binary)", + output: "create table test (\n\tpk varchar(255) character set binary\n)", + }, { + input: "create table test (pk varchar(255) character set utf8mb4)", + output: "create table test (\n\tpk varchar(255) character set utf8mb4\n)", + }, { + input: "create table test (pk varchar(255) collate binary)", + output: "create table test (\n\tpk varchar(255) collate binary\n)", + }, { + input: "create table test (pk varchar(255) collate utf8_unicode_ci)", + output: "create table test (\n\tpk varchar(255) collate utf8_unicode_ci\n)", + }, { + input: "create table test (pk varchar(255) charset binary collate binary)", + output: "create table test (\n\tpk varchar(255) character set binary collate binary\n)", + }, { + input: "create table test (pk varchar(255) charset utf8mb4 collate utf8_unicode_ci)", + output: "create table test (\n\tpk varchar(255) character set utf8mb4 collate utf8_unicode_ci\n)", + }, { + input: "create table test (pk varchar(255) character set binary collate binary)", + output: "create table test (\n\tpk varchar(255) character set binary collate binary\n)", + }, { + input: "create table test (pk varchar(255) character set utf8mb4 collate utf8_unicode_ci)", + output: "create table test (\n\tpk varchar(255) character set utf8mb4 collate utf8_unicode_ci\n)", }, { input: "select * from current", output: "select * from `current`", @@ -3006,28 +3279,48 @@ var ( }, { input: "create table t (pk int not null, constraint `mykey` primary key `pk_id` (`pk`))", output: "create table t (\n\tpk int not null,\n\tprimary key (pk)\n)", - }, { + }, + { input: "alter table t default character set utf8mb4", output: "alter table t character set utf8mb4", - }, { + }, + { input: "alter table t character set = utf8mb4", output: "alter table t character set utf8mb4", - }, { + }, + { input: "alter table t character set := utf8mb4", output: "alter table t character set utf8mb4", - }, { + }, + { input: "alter table t character set utf8mb4 collate utf8mb4_0900_bin", output: "alter table t character set utf8mb4 collate utf8mb4_0900_bin", - }, { + }, + { input: "alter table t character set 'utf8mb4' collate = 'utf8mb4_0900_bin'", output: "alter table t character set utf8mb4 collate utf8mb4_0900_bin", - }, { + }, + { input: "alter table t collate utf8mb4_0900_bin", output: "alter table t collate utf8mb4_0900_bin", - }, { + }, + { input: "alter table t collate = 'utf8mb4_0900_bin'", output: "alter table t collate utf8mb4_0900_bin", - }, { + }, + { + input: "alter table t collate = 'utf8mb4_0900_bin'", + output: "alter table t collate utf8mb4_0900_bin", + }, + { + input: "alter table t convert to character set utf8mb4", + output: "alter table t character set utf8mb4", + }, + { + input: "alter table t convert to character set utf8mb4 collate utf8mb4_0900_bin", + output: "alter table t character set utf8mb4 collate utf8mb4_0900_bin", + }, + { input: "SELECT _utf8mb4'abc'", output: "select _utf8mb4 'abc'", }, { @@ -3045,6 +3338,18 @@ var ( }, { input: "create view v_today(today) as select CURRENT_DATE()", output: "create view v_today(today) as select CURRENT_DATE()", + }, { + input: "create or replace view v_today(today) as select CURRENT_DATE()", + output: "create or replace view v_today(today) as select CURRENT_DATE()", + }, { + input: "create view v_today(today) as select CURRENT_DATE() WITH CHECK OPTION", + output: "create view v_today(today) as select CURRENT_DATE() with cascaded check option", + }, { + input: "create view v_today(today) as select CURRENT_DATE() WITH CASCADED CHECK OPTION", + output: "create view v_today(today) as select CURRENT_DATE() with cascaded check option", + }, { + input: "create view v_today(today) as select CURRENT_DATE() WITH LOCAL CHECK OPTION", + output: "create view v_today(today) as select CURRENT_DATE() with local check option", }, { input: "select 1 into @aaa", }, { @@ -3053,13 +3358,28 @@ var ( }, { input: "SELECT now() WHERE now() > '2019-04-04 13:25:44' INTO @late", output: "select now() where now() > '2019-04-04 13:25:44' into @late", - }, { + }, + { input: "SELECT * FROM (VALUES ROW(2,4,8)) AS t INTO @x,@y,@z", output: "select * from (values row(2, 4, 8)) as t into @x, @y, @z", - }, { + }, + { input: "SELECT * FROM (VALUES ROW(2,4,8)) AS t(a,b,c) INTO @x,@y,@z", output: "select * from (values row(2, 4, 8)) as t (a, b, c) into @x, @y, @z", - }, { + }, + { + input: "SELECT * FROM (VALUES (2,4,8)) AS t INTO @x,@y,@z", + output: "select * from (values row(2, 4, 8)) as t into @x, @y, @z", + }, + { + input: "SELECT * FROM (VALUES (2,4,8)) AS t(a,b,c) INTO @x,@y,@z", + output: "select * from (values row(2, 4, 8)) as t (a, b, c) into @x, @y, @z", + }, + { + input: "SELECT * FROM (VALUES (1, 2, 3), (4, 5, 6), (7, 8, 9)) t", + output: "select * from (values row(1, 2, 3), row(4, 5, 6), row(7, 8, 9)) as t", + }, + { input: "SELECT id FROM mytable ORDER BY id DESC LIMIT 1 INTO @myvar", output: "select id from mytable order by id desc limit 1 into @myvar", }, { @@ -3068,28 +3388,90 @@ var ( }, { input: "SELECT m.id, t.category FROM mytable m JOIN testtable t on m.id = t.id LIMIT 1 INTO @myId, @myCategory", output: "select m.id, t.category from mytable as m join testtable as t on m.id = t.id limit 1 into @myId, @myCategory", + }, { + input: "select * from foo limit a", + output: "select * from foo limit a", + }, { + input: "select * from foo limit a ,a", + output: "select * from foo limit a, a", + }, { + input: "select * from foo limit a offset a", + output: "select * from foo limit a, a", }, { input: "SELECT id FROM mytable UNION select id FROM testtable LIMIT 1 INTO @myId", output: "select id from mytable union select id from testtable limit 1 into @myId", }, { input: "SELECT id FROM mytable UNION select id FROM testtable UNION select id FROM othertable LIMIT 1 INTO @myId", output: "select id from mytable union select id from testtable union select id from othertable limit 1 into @myId", - }, { + }, + { input: "SELECT 1 INTO OUTFILE 'x.txt'", output: "select 1 into outfile 'x.txt'", - }, { + }, + { input: "SELECT * FROM (VALUES ROW(2,4,8),ROW(1,2,3)) AS t(a,b,c) INTO OUTFILE 'myfile.txt'", output: "select * from (values row(2, 4, 8), row(1, 2, 3)) as t (a, b, c) into outfile 'myfile.txt'", - }, { + }, + { input: "SELECT id INTO OUTFILE 'myfile.txt' FROM mytable ORDER BY id DESC", output: "select id from mytable order by id desc into outfile 'myfile.txt'", - }, { + }, + { input: "SELECT * FROM (VALUES ROW(2,4,8)) AS t INTO DUMPFILE 'even.dump'", output: "select * from (values row(2, 4, 8)) as t into dumpfile 'even.dump'", - }, { + }, + { input: "SELECT id INTO DUMPFILE 'dump.txt' FROM mytable ORDER BY id DESC LIMIT 15", output: "select id from mytable order by id desc limit 15 into dumpfile 'dump.txt'", - }, { + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' columns terminated by 'a'", + output: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' enclosed by 'b'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' optionally enclosed by 'b'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' escaped by 'c'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' enclosed by 'b' escaped by 'c'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' optionally enclosed by 'b' escaped by 'c'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' lines terminated by 'd'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' lines starting by 'd' terminated by 'e'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' lines terminated by 'd'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' enclosed by 'b' lines terminated by 'd'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' escaped by 'c' lines terminated by 'd'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' optionally enclosed by 'b' escaped by 'c' lines terminated by 'd'", + }, + { + input: "select * from tbl into outfile 'outfile.txt' character set binary fields terminated by 'a'", + }, + { + input: "table tbl into outfile 'outfile.txt' fields terminated by 'a' optionally enclosed by 'b' escaped by 'c' lines terminated by 'd'", + output: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' optionally enclosed by 'b' escaped by 'c' lines terminated by 'd'", + }, + { input: "CREATE PROCEDURE proc (IN p_store_id INT, OUT current INT) SELECT COUNT(*) INTO current FROM inventory WHERE store_id = p_store_id", output: "create procedure proc (in p_store_id INT, out current INT) select COUNT(*) from inventory where store_id = p_store_id into `current`", }, { @@ -3119,19 +3501,24 @@ var ( }, { input: "CREATE TABLE t (id INT PRIMARY KEY, col1 GEOMETRYCOLLECTION NOT NULL SRID 0)", output: "create table t (\n\tid INT primary key,\n\tcol1 GEOMETRYCOLLECTION not null srid 0\n)", - }, { + }, + { input: "ALTER TABLE t ADD COLUMN col1 POINT NOT NULL SRID 0 DEFAULT (POINT(1, 2))", output: "alter table t add column (\n\tcol1 POINT not null srid 0 default (POINT(1, 2))\n)", - }, { + }, + { input: "ALTER TABLE t MODIFY COLUMN col1 POINT NOT NULL DEFAULT (POINT(1, 2)) SRID 1234", output: "alter table t modify column col1 (\n\tcol1 POINT not null srid 1234 default (POINT(1, 2))\n)", - }, { + }, + { input: "ALTER TABLE t modify col1 varchar(255) NOT NULL COLLATE 'utf8mb4_0900_ai_ci'", output: "alter table t modify column col1 (\n\tcol1 varchar(255) collate utf8mb4_0900_ai_ci not null\n)", - }, { + }, + { input: "ALTER TABLE t modify col1 varchar(255) COLLATE 'utf8mb4_0900_ai_ci' NOT NULL", output: "alter table t modify column col1 (\n\tcol1 varchar(255) collate utf8mb4_0900_ai_ci not null\n)", - }, { + }, + { input: "CREATE TABLE t (col1 BIGINT PRIMARY KEY, col2 DOUBLE DEFAULT -1.1)", output: "create table t (\n\tcol1 BIGINT primary key,\n\tcol2 DOUBLE default -1.1\n)", }, { @@ -3143,12 +3530,22 @@ var ( }, { input: "DROP TABLE `dual`", output: "drop table `dual`", - }, { + }, + { input: "CREATE TABLE `t4` (`pk` int NOT NULL, `_tinytext` tinytext, `_text` text, `_longtext` longtext, `_mediumtext` mediumtext, PRIMARY KEY (`pk`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;", - output: "create table t4 (\n\tpk int not null,\n\t_tinytext tinytext,\n\t_text text,\n\t_longtext longtext,\n\t_mediumtext mediumtext,\n\tPRIMARY KEY (pk)\n) ENGINE InnoDB DEFAULT CHARSET utf8mb3", - }, { + output: "create table t4 (\n\tpk int not null,\n\t_tinytext tinytext,\n\t_text text,\n\t_longtext longtext,\n\t_mediumtext mediumtext,\n\tPRIMARY KEY (pk)\n) ENGINE InnoDB CHARACTER SET utf8mb3", + }, + { + input: "CREATE TABLE `t` (pk int) ENGINE=InnoDB DEFAULT CHARSET=binary;", + output: "create table t (\n\tpk int\n) ENGINE InnoDB CHARACTER SET binary", + }, + { + input: "CREATE TABLE `t` (pk int) ENGINE=InnoDB CHARACTER SET=binary;", + output: "create table t (\n\tpk int\n) ENGINE InnoDB CHARACTER SET binary", + }, + { input: "CREATE TABLE test (\n data varchar(5) NULL DEFAULT _utf8 \"KZPVD\"\n) ENGINE = InnoDB DEFAULT CHARACTER SET = utf8mb4 DEFAULT COLLATE = UTF8MB4_BIN;", - output: "create table test (\n\t`data` varchar(5) default _utf8mb3 'KZPVD'\n) ENGINE InnoDB DEFAULT CHARACTER SET utf8mb4 DEFAULT COLLATE UTF8MB4_BIN", + output: "create table test (\n\t`data` varchar(5) default _utf8mb3 'KZPVD'\n) ENGINE InnoDB CHARACTER SET utf8mb4 COLLATE UTF8MB4_BIN", }, { input: "select EXTRACT(DAY from '2020-10-1')", }, { @@ -3160,25 +3557,32 @@ var ( }, { input: "CREATE EVENT event1 ON SCHEDULE AT '2006-02-10 23:59:00' DO INSERT INTO test.totals VALUES (NOW())", output: "create event event1 on schedule at '2006-02-10 23:59:00' do insert into test.totals values (NOW())", - }, { + }, + { input: "CREATE DEFINER = `root`@`localhost` EVENT event1 ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 3 WEEK + INTERVAL 2 DAY DO INSERT INTO mytable VALUES (NOW())", - output: "create definer = `root`@`localhost` event event1 on schedule at CURRENT_TIMESTAMP() + interval 3 WEEK + interval 2 DAY do insert into mytable values (NOW())", - }, { + output: "create definer = `root`@`localhost` event event1 on schedule at CURRENT_TIMESTAMP(0) + interval 3 WEEK + interval 2 DAY do insert into mytable values (NOW())", + }, + { input: "CREATE EVENT event1 ON SCHEDULE EVERY 1 MINUTE ENDS CURRENT_TIMESTAMP + INTERVAL 3 HOUR ON COMPLETION PRESERVE disable COMMENT 'new event' DO INSERT INTO mytable VALUES (1)", - output: "create event event1 on schedule every 1 MINUTE ends CURRENT_TIMESTAMP() + interval 3 HOUR on completion preserve disable comment 'new event' do insert into mytable values (1)", - }, { + output: "create event event1 on schedule every 1 MINUTE ends CURRENT_TIMESTAMP(0) + interval 3 HOUR on completion preserve disable comment 'new event' do insert into mytable values (1)", + }, + { input: "CREATE EVENT event1 ON SCHEDULE EVERY 1 MINUTE STARTS CURRENT_TIMESTAMP + INTERVAL 2 HOUR ENDS CURRENT_TIMESTAMP + INTERVAL 3 HOUR ON COMPLETION NOT PRESERVE enable DO INSERT INTO mytable VALUES (1)", - output: "create event event1 on schedule every 1 MINUTE starts CURRENT_TIMESTAMP() + interval 2 HOUR ends CURRENT_TIMESTAMP() + interval 3 HOUR enable do insert into mytable values (1)", - }, { + output: "create event event1 on schedule every 1 MINUTE starts CURRENT_TIMESTAMP(0) + interval 2 HOUR ends CURRENT_TIMESTAMP(0) + interval 3 HOUR enable do insert into mytable values (1)", + }, + { input: "CREATE EVENT e_call_myproc ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 DAY disable on slave DO CALL myproc(5, 27)", - output: "create event e_call_myproc on schedule at CURRENT_TIMESTAMP() + interval 1 DAY disable on slave do call myproc(5, 27)", - }, { + output: "create event e_call_myproc on schedule at CURRENT_TIMESTAMP(0) + interval 1 DAY disable on slave do call myproc(5, 27)", + }, + { input: "CREATE EVENT e_call_myproc ON SCHEDULE AT CURRENT_TIMESTAMP DO CALL myproc(5, 27)", - output: "create event e_call_myproc on schedule at CURRENT_TIMESTAMP() do call myproc(5, 27)", - }, { + output: "create event e_call_myproc on schedule at CURRENT_TIMESTAMP(0) do call myproc(5, 27)", + }, + { input: "CREATE EVENT e_call_myproc ON SCHEDULE AT CURRENT_TIMESTAMP DISABLE DO CALL myproc(5, 27)", - output: "create event e_call_myproc on schedule at CURRENT_TIMESTAMP() disable do call myproc(5, 27)", - }, { + output: "create event e_call_myproc on schedule at CURRENT_TIMESTAMP(0) disable do call myproc(5, 27)", + }, + { input: "SHOW EVENTS", output: "show events", }, { @@ -3198,7 +3602,7 @@ var ( output: "show create event myevent", }, { input: "ALTER EVENT myevent ON SCHEDULE AT CURRENT_TIMESTAMP;", - output: "alter event myevent on schedule at CURRENT_TIMESTAMP()", + output: "alter event myevent on schedule at CURRENT_TIMESTAMP(0)", }, { input: "ALTER EVENT myevent ON COMPLETION NOT PRESERVE", output: "alter event myevent on completion not preserve", @@ -3219,7 +3623,7 @@ var ( output: "alter event myevent do insert into mytable values (1)", }, { input: "ALTER EVENT myevent ON SCHEDULE EVERY 1 MINUTE STARTS CURRENT_TIMESTAMP DO INSERT INTO mytable values (1)", - output: "alter event myevent on schedule every 1 MINUTE starts CURRENT_TIMESTAMP() do insert into mytable values (1)", + output: "alter event myevent on schedule every 1 MINUTE starts CURRENT_TIMESTAMP(0) do insert into mytable values (1)", }, { input: "ALTER EVENT myevent RENAME TO new_event DISABLE COMMENT 'renaming and disabling the event'", output: "alter event myevent rename to new_event disable comment 'renaming and disabling the event'", @@ -3294,6 +3698,203 @@ var ( "\ti int\n" + ") secondary_engine NULL", }, + // No-op alter statements + { + input: "alter table t alter constraint name enforced", + output: "alter table t", + }, + { + input: "alter table t alter check name enforced", + output: "alter table t", + }, + { + input: "alter table t alter constraint name not enforced", + output: "alter table t", + }, + { + input: "alter table t alter check name not enforced", + output: "alter table t", + }, + { + input: "alter table t algorithm default", + output: "alter table t", + }, + { + input: "alter table t algorithm instant", + output: "alter table t", + }, + { + input: "alter table t algorithm inplace", + output: "alter table t", + }, + { + input: "alter table t algorithm copy", + output: "alter table t", + }, + { + input: "alter table t algorithm = default", + output: "alter table t", + }, + { + input: "alter table t algorithm = instant", + output: "alter table t", + }, + { + input: "alter table t algorithm = inplace", + output: "alter table t", + }, + { + input: "alter table t algorithm = copy", + output: "alter table t", + }, + { + input: "alter table t alter index name visible", + output: "alter table t", + }, + { + input: "alter table t alter index name invisible", + output: "alter table t", + }, + { + input: "alter table t discard tablespace", + output: "alter table t", + }, + { + input: "alter table t import tablespace", + output: "alter table t", + }, + { + input: "alter table t force", + output: "alter table t", + }, + { + input: "alter table t lock default", + output: "alter table t", + }, + { + input: "alter table t lock none", + output: "alter table t", + }, + { + input: "alter table t lock shared", + output: "alter table t", + }, + { + input: "alter table t lock exclusive", + output: "alter table t", + }, + { + input: "alter table t lock = default", + output: "alter table t", + }, + { + input: "alter table t lock = none", + output: "alter table t", + }, + { + input: "alter table t lock = shared", + output: "alter table t", + }, + { + input: "alter table t lock = exclusive", + output: "alter table t", + }, + { + input: "alter table t autoextend_size='asdf'", + output: "alter table t", + }, + { + input: "alter table t auto_increment=1", + output: "alter table t", + }, + { + input: "alter table t avg_row_length=1", + output: "alter table t", + }, + { + input: "alter table t checksum 1", + output: "alter table t", + }, + { + input: "alter table t checksum = 1", + output: "alter table t", + }, + { + input: "alter table t table_checksum 1", + output: "alter table t", + }, + { + input: "alter table t table_checksum = 1", + output: "alter table t", + }, + { + input: "alter table t comment='asdf'", + output: "alter table t", + }, + { + input: "alter table t compression='asdf'", + output: "alter table t", + }, + { + input: "alter table t connection='asdf'", + output: "alter table t", + }, + { + input: "alter table t data directory = 'asdf'", + output: "alter table t", + }, + { + input: "alter table t index directory = 'asdf'", + output: "alter table t", + }, + { + input: "alter table t delay_key_write = 123", + output: "alter table t", + }, + { + input: "alter table t encryption='asdf'", + output: "alter table t", + }, + { + input: "alter table t engine=eng", + output: "alter table t", + }, + { + input: "alter table t engine_attribute='asdf'", + output: "alter table t", + }, + { + input: "alter table t insert_method last", + output: "alter table t", + }, + { + input: "alter table t insert_method=last", + output: "alter table t", + }, + { + input: "alter table t key_block_size='asdf'", + output: "alter table t", + }, + { + input: "alter table t max_rows='asdf'", + output: "alter table t", + }, + { + input: "alter table t min_rows='asdf'", + output: "alter table t", + }, + { + input: "alter table t pack_keys=123", + output: "alter table t", + }, + { + input: "alter table t password='asdf'", + output: "alter table t", + }, + { + input: "alter table t row_format=dynamic", + output: "alter table t", + }, { input: "alter table t secondary_engine=rapid", output: "alter table t", @@ -3314,13 +3915,13 @@ var ( input: "create table t (i int) secondary_engine_attribute='rapid'", output: "create table t (\n" + "\ti int\n" + - ") secondary_engine_attribute 'rapid'", + ") secondary_engine_attribute rapid", }, { input: "create table t (i int) secondary_engine_attribute='rapid'", output: "create table t (\n" + "\ti int\n" + - ") secondary_engine_attribute 'rapid'", + ") secondary_engine_attribute rapid", }, { input: "alter table t secondary_engine_attribute='rapid'", @@ -3330,6 +3931,41 @@ var ( input: "alter table t secondary_engine_attribute 'rapid'", output: "alter table t", }, + { + input: "alter table t stats_auto_recalc = default", + output: "alter table t", + }, + { + input: "alter table t stats_persistent = default", + output: "alter table t", + }, + { + input: "alter table t stats_sample_pages = 'asdf'", + output: "alter table t", + }, + { + input: "alter table t tablespace asdf", + output: "alter table t", + }, + { + input: "alter table t tablespace asdf storage disk", + output: "alter table t", + }, + { + input: "alter table t tablespace asdf storage memory", + output: "alter table t", + }, + { + input: "alter table t union = (a, b, c)", + output: "alter table t", + }, + + { + input: "alter table t modify col varchar(20) not null, algorithm = inplace, lock = none;", + output: "alter table t modify column col (\n" + + "\tcol varchar(20) not null\n" + + "),,", + }, { input: "table t", output: "select * from t", @@ -3346,14 +3982,6 @@ var ( "\ti int\n" + ") checksum 100", }, - { - input: "alter table t checksum 1", - output: "alter table t", - }, - { - input: "alter table t checksum = 1", - output: "alter table t", - }, { input: "create table t (i int) table_checksum=0", output: "create table t (\n" + @@ -3366,14 +3994,6 @@ var ( "\ti int\n" + ") CHECKSUM 100", }, - { - input: "alter table t table_checksum 1", - output: "alter table t", - }, - { - input: "alter table t table_checksum = 1", - output: "alter table t", - }, { input: "create table t (i int) union (a, b, c)", output: "create table t (\n" + @@ -3402,13 +4022,54 @@ var ( "\ti int\n" + ") insert_method last", }, + + // Date, Time, and Timestamp literals { - input: "alter table t insert_method last", - output: "alter table t", + input: "select date '2020-10-01'", + output: "select '2020-10-01'", }, { - input: "alter table t insert_method=last", - output: "alter table t", + input: "select time '2020-10-01'", + output: "select '2020-10-01'", + }, + { + input: "select timestamp '2020-10-01'", + output: "select '2020-10-01'", + }, + + { + input: "select date'2020-10-01'", + output: "select '2020-10-01'", + }, + { + input: "select time'2020-10-01'", + output: "select '2020-10-01'", + }, + { + input: "select timestamp'2020-10-01'", + output: "select '2020-10-01'", + }, + + { + input: "select (date '2020-10-01')", + output: "select ('2020-10-01')", + }, + { + input: "select (time '2020-10-01')", + output: "select ('2020-10-01')", + }, + { + input: "select (timestamp '2020-10-01')", + output: "select ('2020-10-01')", + }, + + { + input: "insert into t values (date '2020-10-01'), (time '2020-10-01'), (timestamp '2020-10-01')", + output: "insert into t values ('2020-10-01'), ('2020-10-01'), ('2020-10-01')", + }, + { + input: "select * from (values row(date '2020-10-01', time '12:34:56', timestamp '2001-02-03 12:34:56')) t;", + output: "select * from (values row('2020-10-01', '12:34:56', '2001-02-03 12:34:56')) as t", }, } @@ -4400,34 +5061,76 @@ func TestInvalid(t *testing.T) { invalidSQL := []struct { input string err string - }{{ - input: "SET @foo = `o` `ne`;", - err: "syntax error", - }, { - input: "select '1' '2", - err: "syntax error", - }, { - input: "CHANGE REPLICATION FILTER", - err: "syntax error", - }, { - input: "change replication filter REPLICATE_DO_TABLE=()", - err: "syntax error", - }, { - input: "CHANGE REPLICATION SOURCE TO", - err: "syntax error", - }, { - input: "select a from (select * from tbl)", - err: "Every derived table must have its own alias", - }, { - input: "select a, b from (select * from tbl) sort by a", - err: "syntax error", - }, { - input: "with test as (select 1), test_two as (select 2) select * from test, test_two union all with b as (select 1, 2) select * from b", - err: "syntax error", - }, { - input: "select * from test order by a union select * from test", - err: "syntax error", - }, + skip bool + }{ + { + input: "SET @foo = `o` `ne`;", + err: "syntax error", + }, + { + input: "select '1' '2", + err: "syntax error", + }, + { + input: "CHANGE REPLICATION FILTER", + err: "syntax error", + }, + { + input: "change replication filter REPLICATE_DO_TABLE=()", + err: "syntax error", + }, + { + input: "CHANGE REPLICATION SOURCE TO", + err: "syntax error", + }, + { + input: "select a from (select * from tbl)", + err: "Every derived table must have its own alias", + }, + { + input: "select a, b from (select * from tbl) sort by a", + err: "syntax error", + }, + { + input: "with test as (select 1), test_two as (select 2) select * from test, test_two union all with b as (select 1, 2) select * from b", + err: "syntax error", + }, + { + input: "select * from test order by a union select * from test", + err: "syntax error", + }, + { + input: "select current_timestamp(-1)", + err: "syntax error", + }, + { + input: "select current_timestamp(1 + 1)", + err: "syntax error", + }, + { + input: "select current_timestamp('abc')", + err: "syntax error", + }, + { + input: "select current_timestamp(1.0)", + err: "syntax error", + }, + { + input: "select current_timestamp(now())", + err: "syntax error", + }, + { + input: "select current_timestamp(i)", + err: "syntax error", + }, + { + input: "select current_timestamp(@a)", + err: "syntax error", + }, + { + input: "select current_timestamp(null)", + err: "syntax error", + }, { input: "create spatial reference system 1234\n" + "name 'name'\n" + @@ -4480,6 +5183,65 @@ func TestInvalid(t *testing.T) { input: "select sql_cache sql_no_cache * from t", err: "incorrect usage of SQL_CACHE and SQL_NO_CACHE", }, + { + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' fields terminated by 'a'", + err: "syntax error", + }, + { + input: "select * from tbl into outfile 'outfile.txt' enclosed by 'b'", + err: "syntax error", + }, + { + input: "select * from tbl into outfile 'outfile.txt' escaped by 'c'", + err: "syntax error", + }, + { + input: "select * from tbl into outfile 'outfile.txt' enclosed by 'b' fields terminated by 'a'", + err: "syntax error", + }, + { + input: "select * from tbl into outfile 'outfile.txt' escaped by 'c' fields terminated by 'a'", + err: "syntax error", + }, + { + input: "select * from tbl into outfile 'outfile.txt' lines terminated by 'd' fields terminated by 'a'", + err: "syntax error", + }, + + { + // TODO: should work + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' enclosed by 'b' enclosed by 'b'", + err: "syntax error", + }, + { + // TODO: should work + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' optionally enclosed by 'b' optionally enclosed by 'b'", + err: "syntax error", + }, + { + // TODO: should work + input: "select * from tbl into outfile 'outfile.txt' fields terminated by 'a' escaped by 'c' escaped by 'c'", + err: "syntax error", + }, + { + // TODO: should work + input: "select * from tbl into outfile 'outfile.txt' lines terminated by 'e' starting by 'd'", + err: "syntax error", + }, + { + // TODO: should work + input: "select * from tbl into outfile 'outfile.txt' lines starting by 'd' terminated by 'e' starting by 'd' terminated by 'e'", + err: "syntax error", + }, + + { + input: "select date 20010203", + err: "syntax error", + }, + { + input: "select date concat('2001-', '02-', '03')", + err: "syntax error", + }, } for _, tcase := range invalidSQL { @@ -4498,8 +5260,8 @@ func TestInvalid(t *testing.T) { input string err string }{{ - input: "create table t (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique primary key)", - err: "cannot include more than one key option for a column definition at position 130 near 'key'", + input: "create table t (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' fulltext key primary key)", + err: "cannot include more than one key option for a column definition at position 136 near 'key'", }, { input: "create table t (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique comment 'another')", err: "cannot include more than one comment for a column definition at position 136 near 'another'", @@ -4508,7 +5270,7 @@ func TestInvalid(t *testing.T) { err: "cannot include AUTO_INCREMENT more than once at position 133 near 'auto_increment'", }, { input: "create table t (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique on update utc_timestamp())", - err: "cannot include ON UPDATE more than once at position 144", + err: "syntax error at position 142 near 'utc_timestamp'", }, { input: "create table t (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique default 1)", err: "cannot include DEFAULT more than once at position 128", @@ -4519,8 +5281,8 @@ func TestInvalid(t *testing.T) { input: "create table t (c default 0 int on update current_timestamp() auto_increment comment 'a comment here' unique)", err: "syntax error at position 26 near 'default'", }, { - input: "alter table t add (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique primary key)", - err: "cannot include more than one key option for a column definition at position 133 near 'key'", + input: "alter table t add (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' fulltext key primary key)", + err: "cannot include more than one key option for a column definition at position 139 near 'key'", }, { input: "alter table t add (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique comment 'another')", err: "cannot include more than one comment for a column definition at position 139 near 'another'", @@ -4529,7 +5291,7 @@ func TestInvalid(t *testing.T) { err: "cannot include AUTO_INCREMENT more than once at position 136 near 'auto_increment'", }, { input: "alter table t add (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique on update utc_timestamp())", - err: "cannot include ON UPDATE more than once at position 147", + err: "syntax error at position 145 near 'utc_timestamp'", }, { input: "alter table t add (c int not null default 0 on update current_timestamp() auto_increment comment 'a comment here' unique default 1)", err: "cannot include DEFAULT more than once at position 131", @@ -4622,7 +5384,7 @@ func TestCaseSensitivity(t *testing.T) { input: "insert into A(A, B) values (1, 2)", }, { input: "create view A as select current_timestamp()", - output: "create view a as select current_timestamp()", + output: "create view a as select current_timestamp(0)", }, { input: "drop view A", output: "drop view a", @@ -4649,16 +5411,21 @@ func TestKeywords(t *testing.T) { validSQL := []parseTest{ { input: "select current_timestamp", - output: "select current_timestamp()", - }, { + output: "select current_timestamp(0)", + }, + { input: "select current_TIMESTAMP", - output: "select current_TIMESTAMP()", + output: "select current_TIMESTAMP(0)", useSelectExpressionLiteral: true, - }, { - input: "update t set a = current_timestamp()", - }, { + }, + { + input: "update t set a = current_timestamp()", + output: "update t set a = current_timestamp(0)", + }, + { input: "update t set a = current_timestamp(5)", - }, { + }, + { input: "select a, current_date from t", output: "select a, current_date() from t", }, { @@ -4694,23 +5461,23 @@ func TestKeywords(t *testing.T) { input: "select * from t where a > utc_timestamp(4)", }, { input: "update t set b = utc_timestamp + 5", - output: "update t set b = utc_timestamp() + 5", + output: "update t set b = utc_timestamp(0) + 5", }, { input: "select utc_time, utc_date, utc_time(6)", - output: "select utc_time(), utc_date(), utc_time(6)", + output: "select utc_time(0), utc_date(), utc_time(6)", }, { input: "select utc_TIME, UTC_date, utc_time(6)", - output: "select utc_TIME(), UTC_date(), utc_time(6)", + output: "select utc_TIME(0), UTC_date(), utc_time(6)", useSelectExpressionLiteral: true, }, { input: "select 1 from dual where localtime > utc_time", - output: "select 1 where localtime() > utc_time()", + output: "select 1 where localtime(0) > utc_time(0)", }, { input: "select 1 from dual where localtime(2) > utc_time(1)", output: "select 1 where localtime(2) > utc_time(1)", }, { input: "update t set a = localtimestamp(), b = utc_timestamp", - output: "update t set a = localtimestamp(), b = utc_timestamp()", + output: "update t set a = localtimestamp(0), b = utc_timestamp(0)", }, { input: "update t set a = localtimestamp(10), b = utc_timestamp(13)", output: "update t set a = localtimestamp(10), b = utc_timestamp(13)", @@ -4815,9 +5582,6 @@ func runParseTestCaseWithParserOptions(t *testing.T, tcase parseTest, options Pa tcase.output = tcase.input } tree, err := ParseWithOptions(tcase.input, options) - if err != nil { - panic(tcase.input) - } require.NoError(t, err) assertTestcaseOutput(t, tcase, tree) @@ -4892,8 +5656,8 @@ func TestFunctionCalls(t *testing.T) { "select CURDATE() from dual", "select CURRENT_DATE() from dual", "select CURRENT_ROLE() from dual", - "select CURRENT_TIME() from dual", - "select CURRENT_TIMESTAMP() from dual", + "select CURRENT_TIME(0) from dual", + "select CURRENT_TIMESTAMP(0) from dual", "select CURRENT_USER() from dual", "select CURTIME() from dual", "select DATABASE() from dual", @@ -5020,8 +5784,8 @@ func TestFunctionCalls(t *testing.T) { "select LineString() from dual", "select LN() from dual", "select LOAD_FILE() from dual", - "select LOCALTIME() from dual", - "select LOCALTIMESTAMP() from dual", + "select LOCALTIME(0) from dual", + "select LOCALTIMESTAMP(0) from dual", "select LOCATE() from dual", "select LOG() from dual", "select LOG10() from dual", @@ -5069,7 +5833,6 @@ func TestFunctionCalls(t *testing.T) { "select PI() from dual", "select Point() from dual", "select Polygon() from dual", - "select POSITION() from dual", "select POW() from dual", "select POWER() from dual", "select PS_CURRENT_THREAD_ID() from dual", @@ -5231,8 +5994,8 @@ func TestFunctionCalls(t *testing.T) { "select UPPER() from dual", "select USER() from dual", "select UTC_DATE() from dual", - "select UTC_TIME() from dual", - "select UTC_TIMESTAMP() from dual", + "select UTC_TIME(0) from dual", + "select UTC_TIMESTAMP(0) from dual", "select UUID() from dual", "select UUID_SHORT() from dual", "select UUID_TO_BIN() from dual", @@ -5249,6 +6012,7 @@ func TestFunctionCalls(t *testing.T) { "select WEIGHT_STRING() from dual", "select YEAR() from dual", "select YEARWEEK() from dual", + "select CHAR(77, 121, 83, 81, '76' USING utf8mb4) from dual", } // Functions where the input doesn't match the output. Prefer query tests above when possible. @@ -5259,24 +6023,44 @@ func TestFunctionCalls(t *testing.T) { }, { input: "select LOCALTIMESTAMP from dual", - output: "select LOCALTIMESTAMP()", + output: "select LOCALTIMESTAMP(0)", }, { input: "SELECT CAST(foo AS DOUBLE)", output: "select CAST(foo as DOUBLE)", }, + { + input: "SELECT CAST(foo AS DOUBLE PRECISION)", + output: "select CAST(foo as DOUBLE)", + }, + { + input: "SELECT CAST(foo AS REAL)", + output: "select CAST(foo as REAL)", + }, { input: "SELECT CAST(foo AS FLOAT)", output: "select CAST(foo as FLOAT)", }, + { + input: "SELECT CAST(foo AS CHARACTER)", + output: "select CAST(foo as CHAR)", + }, + { + input: "SELECT CAST(foo AS CHARACTER(100))", + output: "select CAST(foo as CHAR(100))", + }, + { + input: "SELECT POSITION('abc' in 'xyz')", + output: "select LOCATE('abc', 'xyz')", + }, + { + input: "SELECT POSITION(1 + 1 in foo)", + output: "select LOCATE(1 + 1, foo)", + }, } // Unimplemented or broken functionality skippedTestCases := []parseTest{ - { - // USING syntax parsed but not captured - input: "select CHAR(77,121,83,81,'76' USING utf8mb4) from dual", - }, { // INTERVAL function produces a grammar conflict input: "select INTERVAL(col1, col2) from dual", @@ -5286,8 +6070,10 @@ func TestFunctionCalls(t *testing.T) { input: `select SELECT 17 MEMBER OF('[23, "abc", 17, "ab", 10]'); from dual`, }, { - // not implemented - input: "select JSON_TABLE('') from dual", + input: "alter table a check partition p", + }, + { + input: "alter table a check partition all", }, } @@ -5314,64 +6100,97 @@ func TestConvert(t *testing.T) { validSQL := []parseTest{ { input: "select cast('abc' as date) from t", - }, { + }, + { + input: "select cast('abc' as year) from t", + }, + { input: "select cast('abc' as date) from t", useSelectExpressionLiteral: true, - }, { + }, + { input: "select convert('abc', binary(4)) from t", - }, { + }, + { input: "select convert('abc', binary) from t", - }, { + }, + { input: "select convert('abc', char character set binary) from t", - }, { + }, + { input: "select convert('abc', char(4) ascii) from t", - }, { + }, + { input: "select convert('abc', char unicode) from t", - }, { + }, + { input: "select convert('abc', char(4)) from t", - }, { + }, + { input: "select convert('abc', char) from t", - }, { + }, + { input: "select convert('abc', nchar(4)) from t", - }, { + }, + { input: "select convert('abc', nchar) from t", - }, { + }, + { input: "select convert('abc', signed) from t", - }, { + }, + { input: "select convert('abc', signed integer) from t", output: "select convert('abc', signed) from t", - }, { + }, + { input: "select convert('abc', signed) from t", output: "select convert('abc', signed) from t", - }, { + }, + { input: "select convert('abc', unsigned) from t", - }, { + }, + { input: "select convert('abc', unsigned integer) from t", output: "select convert('abc', unsigned) from t", - }, { + }, + { input: "select convert('abc', unsigned) from t", output: "select convert('abc', unsigned) from t", - }, { + }, + { input: "select convert('abc', decimal(3, 4)) from t", - }, { + }, + { input: "select convert('abc', decimal(4)) from t", - }, { + }, + { input: "select convert('abc', decimal) from t", - }, { + }, + { input: "select convert('abc', date) from t", - }, { + }, + { input: "select convert('abc', time(4)) from t", - }, { + }, + { input: "select convert('abc', time) from t", - }, { + }, + { input: "select convert('abc', datetime(9)) from t", - }, { + }, + { input: "select convert('abc', datetime) from t", - }, { + }, + { input: "select convert('abc', json) from t", - }, { + }, + { input: "select convert('abc' using ascii) from t", - }} + }, + { + input: "select convert('abc', year) from t", + }, + } for _, tcase := range validSQL { runParseTestCase(t, tcase) @@ -5453,633 +6272,760 @@ func TestSubStr(t *testing.T) { output: `select substr(substr('foo', 1, 2), 1, 2) from t`, }, { input: `select substr(substr("foo" from 1 for 2), 1, 2) from t`, - output: "select substr(substr('foo', 1, 2), 1, 2) from t", - useSelectExpressionLiteral: true, - }, { - input: `select substr(substring("foo", 1, 2), 3, 4) from t`, - output: `select substr(substring('foo', 1, 2), 3, 4) from t`, - }, { - input: `select substr(substr("foo", 1), 2) from t`, - output: `select substr(substr('foo', 1), 2) from t`, - }} - - for _, tcase := range validSQL { - runParseTestCase(t, tcase) - } -} - -func TestCreateTable(t *testing.T) { - validSQL := []string{ - // test all the data types and options - "create table t (\n" + - " col_bit bit,\n" + - " col_tinyint tinyint auto_increment,\n" + - " col_tinyint3 tinyint(3) unsigned,\n" + - " col_smallint smallint,\n" + - " col_smallint4 smallint(4) zerofill,\n" + - " col_mediumint mediumint,\n" + - " col_mediumint5 mediumint(5) unsigned not null,\n" + - " col_int int,\n" + - " col_int10 int(10) not null,\n" + - " col_integer integer comment 'this is an integer',\n" + - " col_bigint bigint,\n" + - " col_bigint10 bigint(10) zerofill not null default 10,\n" + - " col_real real,\n" + - " col_real2 real(1,2) not null default 1.23,\n" + - " col_double double,\n" + - " col_double2 double(3,4) not null default 1.23,\n" + - " col_double3 double precision not null default 1.23,\n" + - " col_float float,\n" + - " col_float2 float(3,4) not null default 1.23,\n" + - " col_float3 float(3) not null default 1.23,\n" + - " col_decimal decimal,\n" + - " col_decimal2 decimal(2),\n" + - " col_decimal3 decimal(2,3),\n" + - " col_dec dec,\n" + - " col_dec2 dec(2),\n" + - " col_dec3 dec(2,3),\n" + - " col_fixed fixed,\n" + - " col_fixed2 fixed(2),\n" + - " col_fixed3 fixed(2,3),\n" + - " col_numeric numeric,\n" + - " col_numeric2 numeric(2),\n" + - " col_numeric3 numeric(2,3),\n" + - " col_date date,\n" + - " col_time time,\n" + - " col_timestamp timestamp,\n" + - " col_datetime datetime,\n" + - " col_year year,\n" + - " col_char char,\n" + - " col_char2 char(2),\n" + - " col_char3 char(3) character set ascii,\n" + - " col_char4 char(4) character set ascii collate ascii_bin,\n" + - " col_character character,\n" + - " col_character2 character(2),\n" + - " col_character3 character(3) character set ascii,\n" + - " col_character4 character(4) character set ascii collate ascii_bin,\n" + - " col_char_varying char varying(2),\n" + - " col_char_varying2 char varying(10) character set utf8,\n" + - " col_nchar nchar,\n" + - " col_nchar2 nchar(2),\n" + - " col_nchar_varchar nchar varchar(2),\n" + - " col_nchar_varying nchar varying(2),\n" + - " col_national_char national char,\n" + - " col_national_char2 national char(2),\n" + - " col_national_character national character,\n" + - " col_national_character2 national character(2),\n" + - " col_national_char_varying national char varying(2),\n" + - " col_varchar varchar,\n" + - " col_varchar2 varchar(2),\n" + - " col_varchar3 varchar(3) character set ascii,\n" + - " col_varchar4 varchar(4) character set ascii collate ascii_bin,\n" + - " col_varchar5 varchar(5) character set ascii binary,\n" + - " col_varcharMax varchar(MAX),\n" + - " col_character_varying character varying,\n" + - " col_character_varying2 character varying(2),\n" + - " col_character_varying3 character varying(3) character set ascii,\n" + - " col_character_varying4 character varying(4) character set ascii collate ascii_bin,\n" + - " col_nvarchar nvarchar,\n" + - " col_nvarchar2 nvarchar(2),\n" + - " col_national_varchar national varchar,\n" + - " col_national_varchar2 national varchar(2),\n" + - " col_national_character_varying national character varying,\n" + - " col_national_character_varying2 national character varying(2),\n" + - " col_binary binary,\n" + - " col_varbinary varbinary(10),\n" + - " col_tinyblob tinyblob,\n" + - " col_blob blob,\n" + - " col_mediumblob mediumblob,\n" + - " col_longblob longblob,\n" + - " col_tinytext tinytext,\n" + - " col_text text,\n" + - " col_mediumtext mediumtext,\n" + - " col_long long,\n" + - " col_long_varchar long varchar,\n" + - " col_longtext longtext,\n" + - " col_text text character set ascii collate ascii_bin,\n" + - " col_json json,\n" + - " col_enum enum('a', 'b', 'c', 'd'),\n" + - " col_enum2 enum('a', 'b', 'c', 'd') character set ascii,\n" + - " col_enum3 enum('a', 'b', 'c', 'd') collate ascii_bin,\n" + - " col_enum4 enum('a', 'b', 'c', 'd') character set ascii collate ascii_bin,\n" + - " col_set set('a', 'b', 'c', 'd'),\n" + - " col_set2 set('a', 'b', 'c', 'd') character set ascii,\n" + - " col_set3 set('a', 'b', 'c', 'd') collate ascii_bin,\n" + - " col_set4 set('a', 'b', 'c', 'd') character set ascii collate ascii_bin,\n" + - " col_geometry1 geometry,\n" + - " col_geometry2 geometry not null,\n" + - " col_point1 point,\n" + - " col_point2 point not null,\n" + - " col_linestring1 linestring,\n" + - " col_linestring2 linestring not null,\n" + - " col_polygon1 polygon,\n" + - " col_polygon2 polygon not null,\n" + - " col_geometrycollection1 geometrycollection,\n" + - " col_geometrycollection2 geometrycollection not null,\n" + - " col_multipoint1 multipoint,\n" + - " col_multipoint2 multipoint not null,\n" + - " col_multilinestring1 multilinestring,\n" + - " col_multilinestring2 multilinestring not null,\n" + - " col_multipolygon1 multipolygon,\n" + - " col_multipolygon2 multipolygon not null\n" + - ")", - - // test defining indexes separately - "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " email varchar,\n" + - " full_name varchar,\n" + - " geom point not null,\n" + - " status_nonkeyword varchar,\n" + - " primary key (id),\n" + - " spatial key geom (geom),\n" + - " fulltext key fts (full_name),\n" + - " unique key by_username (username),\n" + - " unique by_username2 (username),\n" + - " unique index by_username3 (username),\n" + - " index by_status (status_nonkeyword),\n" + - " key by_full_name (full_name)\n" + - ")", - - // test that indexes support USING - "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " email varchar,\n" + - " full_name varchar,\n" + - " status_nonkeyword varchar,\n" + - " primary key (id) using BTREE,\n" + - " unique key by_username (username) using HASH,\n" + - " unique by_username2 (username) using OTHER,\n" + - " unique index by_username3 (username) using XYZ,\n" + - " index by_status (status_nonkeyword) using PDQ,\n" + - " key by_full_name (full_name) using OTHER\n" + - ")", - // test other index options - "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " email varchar,\n" + - " primary key (id) comment 'hi',\n" + - " unique key by_username (username) key_block_size 8,\n" + - " unique index by_username4 (username) comment 'hi' using BTREE,\n" + - " unique index by_username4 (username) using BTREE key_block_size 4 comment 'hi'\n" + - ")", - - // multi-column indexes - "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " email varchar,\n" + - " full_name varchar,\n" + - " a int,\n" + - " b int,\n" + - " c int,\n" + - " primary key (id, username),\n" + - " unique key by_abc (a, b, c),\n" + - " unique key (a, b, c),\n" + - " key by_email (email(10), username)\n" + - ")", - - // foreign keys - "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " k int,\n" + - " Z int,\n" + - " primary key (id, username),\n" + - " key by_email (email(10), username),\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b),\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete restrict,\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete no action,\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete cascade on update set default,\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete set default on update set null,\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete set null on update restrict,\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on update no action,\n" + - " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on update cascade\n" + - ")", - - // check constraint - "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " a int,\n" + - " b int,\n" + - " check (b in (0, 1)),\n" + - " constraint a_positive check (a > 0),\n" + - " check (a > b)\n" + - ")", - - // table options - "create table t (\n" + - " id int auto_increment\n" + - ") engine InnoDB,\n" + - " auto_increment 123,\n" + - " avg_row_length 1,\n" + - " default character set utf8mb4,\n" + - " character set latin1,\n" + - " checksum 0,\n" + - " default collate binary,\n" + - " collate ascii_bin,\n" + - " comment 'this is a comment',\n" + - " compression 'zlib',\n" + - " connection 'connect_string',\n" + - " data directory 'absolute path to directory',\n" + - " delay_key_write 1,\n" + - " encryption 'n',\n" + - " index directory 'absolute path to directory',\n" + - " insert_method no,\n" + - " key_block_size 1024,\n" + - " max_rows 100,\n" + - " min_rows 10,\n" + - " pack_keys 0,\n" + - " password 'sekret',\n" + - " row_format default,\n" + - " stats_auto_recalc default,\n" + - " stats_persistent 0,\n" + - " stats_sample_pages 1,\n" + - " tablespace tablespace_name storage disk,\n" + - " tablespace tablespace_name\n", - - // passing hex nums to table options - "create table t (\n" + - " id int auto_increment\n" + - ") engine InnoDB,\n" + - " auto_increment 0x1,\n" + - " avg_row_length 0x2,\n" + - " checksum 0x3,\n" + - " delay_key_write 0x4,\n" + - " key_block_size 0x5,\n" + - " max_rows 0x6,\n" + - " min_rows 0x7,\n" + - " pack_keys 0x8,\n" + - " stats_persistent 0x9,\n" + - " stats_sample_pages 0x10\n", - - // passing floats to table options - "create table t (\n" + - " id int auto_increment\n" + - ") engine InnoDB,\n" + - " auto_increment 4.1,\n" + - " avg_row_length 4.2,\n" + - " checksum 4.3,\n" + - " delay_key_write 4.4,\n" + - " key_block_size 4.5,\n" + - " max_rows 4.6,\n" + - " min_rows 4.7,\n" + - " pack_keys 4.8,\n" + - " stats_persistent 4.9,\n" + - " stats_sample_pages 4.01\n", - - // boolean columns - "create table t (\n" + - " bi bigint not null primary key,\n" + - " b1 bool not null,\n" + - " b2 boolean\n" + - ")", - // generated by serial - "create table t (\n" + - " id bigint not null auto_increment unique,\n" + - " a bigint not null\n" + - ")", - } - for _, sql := range validSQL { - t.Run(sql, func(t *testing.T) { - sql = strings.TrimSpace(sql) - tree, err := Parse(sql) - if err != nil { - t.Errorf("input: %s, err: %v", sql, err) - return - } - got := String(tree.(*DDL)) - - if sql != got { - t.Errorf("want:\n%s\ngot:\n%s", sql, got) - } - }) - } - - sql := "create table t garbage" - tree, err := Parse(sql) - if tree != nil || err == nil { - t.Errorf("Parse unexpectedly accepted input %s", sql) - } - - testCases := []struct { - input string - output string - }{{ - // Tet varchar (MAX) syntax - input: "create table t (username varchar(MAX))", - output: "create table t (\n\tusername varchar(MAX)\n)", - }, { - // Test the signed keyword – as the default for numeric types, it is a no-op - input: "create table t (pk int signed primary key)", - output: "create table t (\n\tpk int primary key\n)", - }, { - // test key_block_size - input: "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " unique key by_username (username) key_block_size 8,\n" + - " unique key by_username2 (username) key_block_size=8,\n" + - " unique by_username3 (username) key_block_size = 4\n" + - ")", - output: "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " unique key by_username (username) key_block_size 8,\n" + - " unique key by_username2 (username) key_block_size 8,\n" + - " unique by_username3 (username) key_block_size 4\n" + - ")", - }, { - // test defaults - input: "create table t (\n" + - " i1 int default 1,\n" + - " i2 int default null,\n" + - " f1 float default 1.23,\n" + - " s1 varchar default 'c',\n" + - " s2 varchar default 'this is a string',\n" + - " s3 varchar default null,\n" + - " s4 timestamp default current_timestamp,\n" + - " s5 bit(1) default B'0'\n" + - ")", - output: "create table t (\n" + - " i1 int default 1,\n" + - " i2 int default null,\n" + - " f1 float default 1.23,\n" + - " s1 varchar default 'c',\n" + - " s2 varchar default 'this is a string',\n" + - " s3 varchar default null,\n" + - " s4 timestamp default current_timestamp(),\n" + - " s5 bit(1) default B'0'\n" + - ")", - }, { - // test key field options - input: "create table t (\n" + - " id int auto_increment primary key,\n" + - " username varchar unique key,\n" + - " email varchar unique,\n" + - " full_name varchar key,\n" + - " time1 timestamp on update current_timestamp,\n" + - " time2 timestamp default current_timestamp on update current_timestamp\n" + - ")", - output: "create table t (\n" + - " id int auto_increment primary key,\n" + - " username varchar unique key,\n" + - " email varchar unique,\n" + - " full_name varchar key,\n" + - " time1 timestamp on update current_timestamp(),\n" + - " time2 timestamp default current_timestamp() on update current_timestamp()\n" + - ")", - }, { - // test alternate key syntax - input: "create table t (\n" + - " id int,\n" + - " full_name varchar,\n" + - " constraint unique key (full_name),\n" + - " constraint unique index named (full_name),\n" + - " constraint namedx unique (full_name),\n" + - " constraint pk primary key (id)\n" + - ")", - output: "create table t (\n" + - " id int,\n" + - " full_name varchar,\n" + - " unique key (full_name),\n" + - " unique index named (full_name),\n" + - " unique namedx (full_name),\n" + - " primary key (id)\n" + - ")", - }, { - // test current_timestamp with and without () - input: "create table t (\n" + - " time1 timestamp default current_timestamp,\n" + - " time2 timestamp default current_timestamp(),\n" + - " time3 timestamp default current_timestamp on update current_timestamp,\n" + - " time4 timestamp default current_timestamp() on update current_timestamp(),\n" + - " time5 timestamp(3) default current_timestamp(3) on update current_timestamp(3)\n" + - ")", - output: "create table t (\n" + - " time1 timestamp default current_timestamp(),\n" + - " time2 timestamp default current_timestamp(),\n" + - " time3 timestamp default current_timestamp() on update current_timestamp(),\n" + - " time4 timestamp default current_timestamp() on update current_timestamp(),\n" + - " time5 timestamp(3) default current_timestamp(3) on update current_timestamp(3)\n" + - ")", - }, { - // test inline check constraint - input: "create table t (\n" + - " a int,\n" + - " b int constraint b_positive check (b > 0)\n" + - ")", - output: "create table t (\n" + - " a int,\n" + - " b int,\n" + - " constraint b_positive check (b > 0)\n" + - ")", - }, { - // test initial table constraint - input: "create table t (\n" + - " check (a <> b),\n" + - " a int,\n" + - " b int\n" + - ")", - output: "create table t (\n" + - " a int,\n" + - " b int,\n" + - " check (a != b)\n" + - ")", - }, { - input: "create table t (\n" + - " id int,\n" + - " status int,\n" + - " constraint status check (a > 0)\n" + - ")", - output: "create table t (\n" + - " id int,\n" + - " `status` int,\n" + - " constraint status check (a > 0)\n" + - ")", - }, { - input: "create table t (\n" + - " id int,\n" + - " status int,\n" + - " constraint status check (status in (0, 1))\n" + - ")", - output: "create table t (\n" + - " id int,\n" + - " `status` int,\n" + - " constraint status check (`status` in (0, 1))\n" + - ")", - }, { - // we don't support named primary keys currently - input: "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " a int,\n" + - " b int,\n" + - " constraint a_positive primary key (a, b)\n" + - ")", - output: "create table t (\n" + - " id int auto_increment,\n" + - " username varchar,\n" + - " a int,\n" + - " b int,\n" + - " primary key (a, b)\n" + - ")", - }, { - // test localtime with and without () - input: "create table t (\n" + - " time1 timestamp default localtime,\n" + - " time2 timestamp default localtime(),\n" + - " time3 timestamp default localtime on update localtime,\n" + - " time4 timestamp default localtime() on update localtime(),\n" + - " time5 timestamp(6) default localtime(6) on update localtime(6)\n" + - ")", - output: "create table t (\n" + - " time1 timestamp default localtime(),\n" + - " time2 timestamp default localtime(),\n" + - " time3 timestamp default localtime() on update localtime(),\n" + - " time4 timestamp default localtime() on update localtime(),\n" + - " time5 timestamp(6) default localtime(6) on update localtime(6)\n" + - ")", + output: "select substr(substr('foo', 1, 2), 1, 2) from t", + useSelectExpressionLiteral: true, }, { - // test localtimestamp with and without () - input: "create table t (\n" + - " time1 timestamp default localtimestamp,\n" + - " time2 timestamp default localtimestamp(),\n" + - " time3 timestamp default localtimestamp on update localtimestamp,\n" + - " time4 timestamp default localtimestamp() on update localtimestamp(),\n" + - " time5 timestamp(1) default localtimestamp(1) on update localtimestamp(1)\n" + - ")", - output: "create table t (\n" + - " time1 timestamp default localtimestamp(),\n" + - " time2 timestamp default localtimestamp(),\n" + - " time3 timestamp default localtimestamp() on update localtimestamp(),\n" + - " time4 timestamp default localtimestamp() on update localtimestamp(),\n" + - " time5 timestamp(1) default localtimestamp(1) on update localtimestamp(1)\n" + - ")", + input: `select substr(substring("foo", 1, 2), 3, 4) from t`, + output: `select substr(substring('foo', 1, 2), 3, 4) from t`, }, { - input: "create table t (\n" + - " id serial not null,\n" + - " a bigint not null\n" + - ")", - output: "create table t (\n" + - " id bigint not null auto_increment unique,\n" + - " a bigint not null\n" + - ")", - }, + input: `select substr(substr("foo", 1), 2) from t`, + output: `select substr(substr('foo', 1), 2) from t`, + }} - // partition options + for _, tcase := range validSQL { + runParseTestCase(t, tcase) + } +} + +var sampleColumns = []string{ + " col_bit bit", + " col_tinyint tinyint auto_increment", + " col_tinyint3 tinyint(3) unsigned", + " col_smallint smallint", + " col_smallint4 smallint(4) zerofill", + " col_mediumint mediumint", + " col_mediumint5 mediumint(5) unsigned not null", + " col_int int", + " col_int10 int(10) not null", + " col_integer integer comment 'this is an integer'", + " col_bigint bigint", + " col_bigint10 bigint(10) zerofill not null default 10", + " col_real real", + " col_real2 real(1,2) not null default 1.23", + " col_double double", + " col_double2 double(3,4) not null default 1.23", + " col_double3 double precision not null default 1.23", + " col_float float", + " col_float2 float(3,4) not null default 1.23", + " col_float3 float(3) not null default 1.23", + " col_decimal decimal", + " col_decimal2 decimal(2)", + " col_decimal3 decimal(2,3)", + " col_dec dec", + " col_dec2 dec(2)", + " col_dec3 dec(2,3)", + " col_fixed fixed", + " col_fixed2 fixed(2)", + " col_fixed3 fixed(2,3)", + " col_numeric numeric", + " col_numeric2 numeric(2)", + " col_numeric3 numeric(2,3)", + " col_date date", + " col_time time", + " col_timestamp timestamp", + " col_datetime datetime", + " col_year year", + " col_char char", + " col_char2 char(2)", + " col_char3 char(3) character set ascii", + " col_char4 char(4) character set ascii collate ascii_bin", + " col_character character", + " col_character2 character(2)", + " col_character3 character(3) character set ascii", + " col_character4 character(4) character set ascii collate ascii_bin", + " col_char_varying char varying(2)", + " col_char_varying2 char varying(10) character set utf8", + " col_nchar nchar", + " col_nchar2 nchar(2)", + " col_nchar_varchar nchar varchar(2)", + " col_nchar_varying nchar varying(2)", + " col_national_char national char", + " col_national_char2 national char(2)", + " col_national_character national character", + " col_national_character2 national character(2)", + " col_national_char_varying national char varying(2)", + " col_varchar varchar", + " col_varchar2 varchar(2)", + " col_varchar3 varchar(3) character set ascii", + " col_varchar4 varchar(4) character set ascii collate ascii_bin", + " col_varchar5 varchar(5) character set ascii binary", + " col_varcharMax varchar(MAX)", + " col_character_varying character varying", + " col_character_varying2 character varying(2)", + " col_character_varying3 character varying(3) character set ascii", + " col_character_varying4 character varying(4) character set ascii collate ascii_bin", + " col_nvarchar nvarchar", + " col_nvarchar2 nvarchar(2)", + " col_national_varchar national varchar", + " col_national_varchar2 national varchar(2)", + " col_national_character_varying national character varying", + " col_national_character_varying2 national character varying(2)", + " col_binary binary", + " col_varbinary varbinary(10)", + " col_tinyblob tinyblob", + " col_blob blob", + " col_mediumblob mediumblob", + " col_longblob longblob", + " col_tinytext tinytext", + " col_text text", + " col_mediumtext mediumtext", + " col_long long", + " col_long_varchar long varchar", + " col_longtext longtext", + " col_text text character set ascii collate ascii_bin", + " col_json json", + " col_enum enum('a', 'b', 'c', 'd')", + " col_enum2 enum('a', 'b', 'c', 'd') character set ascii", + " col_enum3 enum('a', 'b', 'c', 'd') collate ascii_bin", + " col_enum4 enum('a', 'b', 'c', 'd') character set ascii collate ascii_bin", + " col_set set('a', 'b', 'c', 'd')", + " col_set2 set('a', 'b', 'c', 'd') character set ascii", + " col_set3 set('a', 'b', 'c', 'd') collate ascii_bin", + " col_set4 set('a', 'b', 'c', 'd') character set ascii collate ascii_bin", +} + +var sampleGeoColumns = []string{ + " col_geometry1 geometry", + " col_geometry2 geometry not null", + " col_point1 point", + " col_point2 point not null", + " col_linestring1 linestring", + " col_linestring2 linestring not null", + " col_polygon1 polygon", + " col_polygon2 polygon not null", + " col_geometrycollection1 geometrycollection", + " col_geometrycollection2 geometrycollection not null", + " col_multipoint1 multipoint", + " col_multipoint2 multipoint not null", + " col_multilinestring1 multilinestring", + " col_multilinestring2 multilinestring not null", + " col_multipolygon1 multipolygon", + " col_multipolygon2 multipolygon not null", +} + +func TestCreateTable(t *testing.T) { + var createStatement strings.Builder + createStatement.WriteString("create table t (\n") + first := true + for _, col := range sampleColumns { + if !first { + createStatement.WriteString(",\n") + } + first = false + createStatement.WriteString(col) + } + for _, col := range sampleGeoColumns { + createStatement.WriteString(",\n") + createStatement.WriteString(col) + } + createStatement.WriteString("\n)") + + sql := "create table t garbage" + tree, err := Parse(sql) + if tree != nil || err == nil { + t.Errorf("Parse unexpectedly accepted input %s", sql) + } + + testCases := []parseTest{ + // test all the data types and options + { + input: createStatement.String(), + }, { + // test defining indexes separately input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY RANGE (store_id) (\n" + - "PARTITION p0 VALUES LESS THAN (6),\n" + - "PARTITION p1 VALUES LESS THAN (11),\n" + - "PARTITION p2 VALUES LESS THAN (16),\n" + - "PARTITION p3 VALUES LESS THAN (21)\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " email varchar,\n" + + " full_name varchar,\n" + + " geom point not null,\n" + + " status_nonkeyword varchar,\n" + + " primary key (id),\n" + + " spatial key geom (geom),\n" + + " fulltext key fts (full_name),\n" + + " unique key by_username (username),\n" + + " unique by_username2 (username),\n" + + " unique index by_username3 (username),\n" + + " index by_status (status_nonkeyword),\n" + + " key by_full_name (full_name)\n" + + ")", + }, + { + // test that indexes support USING + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " email varchar,\n" + + " full_name varchar,\n" + + " status_nonkeyword varchar,\n" + + " primary key (id) using BTREE,\n" + + " unique key by_username (username) using HASH,\n" + + " unique by_username2 (username) using OTHER,\n" + + " unique index by_username3 (username) using XYZ,\n" + + " index by_status (status_nonkeyword) using PDQ,\n" + + " key by_full_name (full_name) using OTHER\n" + + ")", + }, + { + // test other index options + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " email varchar,\n" + + " primary key (id) comment 'hi',\n" + + " unique key by_username (username) key_block_size 8,\n" + + " unique index by_username4 (username) comment 'hi' using BTREE,\n" + + " unique index by_username4 (username) using BTREE key_block_size 4 comment 'hi'\n" + + ")", + }, + { + // multi-column indexes + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " email varchar,\n" + + " full_name varchar,\n" + + " a int,\n" + + " b int,\n" + + " c int,\n" + + " primary key (id, username),\n" + + " unique key by_abc (a, b, c),\n" + + " unique key (a, b, c),\n" + + " key by_email (email(10), username)\n" + + ")", + }, + { + // foreign keys + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " k int,\n" + + " Z int,\n" + + " primary key (id, username),\n" + + " key by_email (email(10), username),\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b),\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete restrict,\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete no action,\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete cascade on update set default,\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete set default on update set null,\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on delete set null on update restrict,\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on update no action,\n" + + " constraint second_ibfk_1 foreign key (k, j) references simple (a, b) on update cascade\n" + + ")", + }, + { + // check constraint + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " a int,\n" + + " b int,\n" + + " check (b in (0, 1)),\n" + + " constraint a_positive check (a > 0),\n" + + " check (a > b)\n" + ")", + }, + { + // table options + input: "create table t (\n" + + "\tid int auto_increment\n" + + ") engine InnoDB" + + " auto_increment 123" + + " avg_row_length 1" + + " character set utf8mb4" + + " character set latin1" + + " checksum 0" + + " default collate binary" + + " collate ascii_bin" + + " comment 'this is a comment'" + + " compression 'zlib'" + + " connection 'connect_string'" + + " data directory 'absolute path to directory'" + + " delay_key_write 1" + + " encryption 'n'" + + " index directory 'absolute path to directory'" + + " insert_method no" + + " key_block_size 1024" + + " max_rows 100" + + " min_rows 10" + + " pack_keys 0" + + " password 'sekret'" + + " row_format default" + + " stats_auto_recalc default" + + " stats_persistent 0" + + " stats_sample_pages 1" + + " tablespace tablespace_name storage disk" + + " tablespace tablespace_name", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY RANGE (store_id)(partition_definitions)", + "\tid int auto_increment\n" + + ") engine InnoDB" + + " auto_increment 123" + + " avg_row_length 1" + + " character set utf8mb4" + + " character set latin1" + + " checksum 0" + + " collate binary" + + " collate ascii_bin" + + " comment this is a comment" + + " compression zlib" + + " connection connect_string" + + " data directory absolute path to directory" + + " delay_key_write 1" + + " encryption n" + + " index directory absolute path to directory" + + " insert_method no" + + " key_block_size 1024" + + " max_rows 100" + + " min_rows 10" + + " pack_keys 0" + + " password sekret" + + " row_format default" + + " stats_auto_recalc default" + + " stats_persistent 0" + + " stats_sample_pages 1" + + " tablespace tablespace_name storage disk" + + " tablespace tablespace_name", + }, + { + // table options out of order + input: "create table t (\n" + + " id int auto_increment\n" + + ") engine InnoDB" + + " avg_row_length 1" + + " character set utf8mb4" + + " auto_increment 123" + + " character set latin1", }, { + // passing hex nums to table options input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY HASH ('values')", + " id int auto_increment\n" + + ") engine InnoDB,\n" + + " auto_increment 0x1,\n" + + " avg_row_length 0x2,\n" + + " checksum 0x3,\n" + + " delay_key_write 0x4,\n" + + " key_block_size 0x5,\n" + + " max_rows 0x6,\n" + + " min_rows 0x7,\n" + + " pack_keys 0x8,\n" + + " stats_auto_recalc 0x1,\n" + + " stats_persistent 0x9,\n" + + " stats_sample_pages 0x10\n", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY HASH (value)", + "\tid int auto_increment\n" + + ") engine InnoDB" + + " auto_increment 0x1" + + " avg_row_length 0x2" + + " checksum 0x3" + + " delay_key_write 0x4" + + " key_block_size 0x5" + + " max_rows 0x6" + + " min_rows 0x7" + + " pack_keys 0x8" + + " stats_auto_recalc 0x1" + + " stats_persistent 0x9" + + " stats_sample_pages 0x10", + }, + { + // passing floats to table options + input: "create table t (\n" + + " id int auto_increment\n" + + ") engine InnoDB,\n" + + " auto_increment 4.1,\n" + + " avg_row_length 4.2,\n" + + " checksum 4.3,\n" + + " delay_key_write 4.4,\n" + + " key_block_size 4.5,\n" + + " max_rows 4.6,\n" + + " min_rows 4.7,\n" + + " pack_keys 4.8,\n" + + " stats_persistent 4.9,\n" + + " stats_sample_pages 4.01\n", + output: "create table t (\n" + + "\tid int auto_increment\n" + + ") engine InnoDB" + + " auto_increment 4.1" + + " avg_row_length 4.2" + + " checksum 4.3" + + " delay_key_write 4.4" + + " key_block_size 4.5" + + " max_rows 4.6" + + " min_rows 4.7" + + " pack_keys 4.8" + + " stats_persistent 4.9" + + " stats_sample_pages 4.01", + }, + { + // boolean columns + input: "create table t (\n" + + " bi bigint not null primary key,\n" + + " b1 bool not null,\n" + + " b2 boolean\n" + + ")", }, { + // generated by serial input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY HASH (col)", + " id bigint not null auto_increment unique,\n" + + " a bigint not null\n" + + ")", + }, + { + // Tet varchar (MAX) syntax + input: "create table t (username varchar(MAX))", + output: "create table t (\n\tusername varchar(MAX)\n)", + }, + { + // Test the signed keyword – as the default for numeric types, it is a no-op + input: "create table t (pk int signed primary key)", + output: "create table t (\n\tpk int primary key\n)", + }, + { + // test key_block_size + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " unique key by_username (username) key_block_size 8,\n" + + " unique key by_username2 (username) key_block_size=8,\n" + + " unique by_username3 (username) key_block_size = 4\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY HASH (col)", + " id int auto_increment,\n" + + " username varchar,\n" + + " unique key by_username (username) key_block_size 8,\n" + + " unique key by_username2 (username) key_block_size 8,\n" + + " unique by_username3 (username) key_block_size 4\n" + + ")", }, { + // test defaults input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR HASH (col)", + " i1 int default 1,\n" + + " i2 int default null,\n" + + " f1 float default 1.23,\n" + + " s1 varchar default 'c',\n" + + " s2 varchar default 'this is a string',\n" + + " s3 varchar default null,\n" + + " s4 timestamp default current_timestamp,\n" + + " s5 bit(1) default B'0'\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR HASH (col)", + " i1 int default 1,\n" + + " i2 int default null,\n" + + " f1 float default 1.23,\n" + + " s1 varchar default 'c',\n" + + " s2 varchar default 'this is a string',\n" + + " s3 varchar default null,\n" + + " s4 timestamp default current_timestamp(0),\n" + + " s5 bit(1) default B'0'\n" + + ")", }, { + // test key field options input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY KEY (col)", + " id int auto_increment primary key,\n" + + " username varchar unique key,\n" + + " email varchar unique,\n" + + " full_name varchar key,\n" + + " time1 timestamp on update current_timestamp,\n" + + " time2 timestamp default current_timestamp on update current_timestamp\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY KEY (column_list)", + " id int auto_increment primary key,\n" + + " username varchar unique key,\n" + + " email varchar unique,\n" + + " full_name varchar key,\n" + + " time1 timestamp on update current_timestamp(0),\n" + + " time2 timestamp default current_timestamp(0) on update current_timestamp(0)\n" + + ")", }, { + // test alternate key syntax input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY KEY ALGORITHM = 7 (col)", + " id int,\n" + + " full_name varchar,\n" + + " constraint unique key (full_name),\n" + + " constraint unique index named (full_name),\n" + + " constraint namedx unique (full_name),\n" + + " constraint pk primary key (id)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY KEY ALGORITHM 7 (column_list)", + " id int,\n" + + " full_name varchar,\n" + + " unique key (full_name),\n" + + " unique index named (full_name),\n" + + " unique namedx (full_name),\n" + + " primary key (id)\n" + + ")", }, { input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR KEY ALGORITHM = 7 (col)", + " id int,\n" + + " constraint primary key (id)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR KEY ALGORITHM 7 (column_list)", + " id int,\n" + + " primary key (id)\n" + + ")", }, { input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY RANGE (column)", + " id int,\n" + + " constraint abc primary key def (id)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY RANGE (column)", + " id int,\n" + + " primary key (id)\n" + + ")", }, { + // test now input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY RANGE COLUMNS (c1, c2, c3)", + " time1 timestamp default now(),\n" + + " time2 timestamp default now() on update now(),\n" + + " time3 timestamp(3) default now(3) on update now(3)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY RANGE COLUMNS (column_list)", + " time1 timestamp default now(),\n" + + " time2 timestamp default now() on update now(),\n" + + " time3 timestamp(3) default now(3) on update now(3)\n" + + ")", }, { + // test current_timestamp with and without () input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LIST (column)", + " time1 timestamp default current_timestamp,\n" + + " time2 timestamp default current_timestamp(),\n" + + " time3 timestamp default current_timestamp on update current_timestamp,\n" + + " time4 timestamp default current_timestamp() on update current_timestamp(),\n" + + " time5 timestamp(3) default current_timestamp(3) on update current_timestamp(3)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LIST (column)", + " time1 timestamp default current_timestamp(0),\n" + + " time2 timestamp default current_timestamp(0),\n" + + " time3 timestamp default current_timestamp(0) on update current_timestamp(0),\n" + + " time4 timestamp default current_timestamp(0) on update current_timestamp(0),\n" + + " time5 timestamp(3) default current_timestamp(3) on update current_timestamp(3)\n" + + ")", }, { + // test inline check constraint input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LIST COLUMNS (c1, c2, c3)", + " a int,\n" + + " b int constraint b_positive check (b > 0)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LIST COLUMNS (column_list)", + " a int,\n" + + " b int,\n" + + " constraint b_positive check (b > 0)\n" + + ")", }, { + // test initial table constraint input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR HASH (a) PARTITIONS 20", + " check (a <> b),\n" + + " a int,\n" + + " b int\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR HASH (a)PARTITIONS 20 ", + " a int,\n" + + " b int,\n" + + " check (a != b)\n" + + ")", }, { input: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR HASH (a) PARTITIONS 10 SUBPARTITION BY LINEAR HASH (b) SUBPARTITIONS 20", + " id int,\n" + + " status int,\n" + + " constraint status check (a > 0)\n" + + ")", output: "create table t (\n" + - "\ti int\n)" + - "PARTITION BY LINEAR HASH (a)PARTITIONS 10 SUBPARTITION BY LINEAR HASH (b) SUBPARTITIONS 20 ", + " id int,\n" + + " `status` int,\n" + + " constraint status check (a > 0)\n" + + ")", + }, + { + input: "create table t (\n" + + " id int,\n" + + " status int,\n" + + " constraint status check (status in (0, 1))\n" + + ")", + output: "create table t (\n" + + " id int,\n" + + " `status` int,\n" + + " constraint status check (`status` in (0, 1))\n" + + ")", + }, + { + // we don't support named primary keys currently + input: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " a int,\n" + + " b int,\n" + + " constraint a_positive primary key (a, b)\n" + + ")", + output: "create table t (\n" + + " id int auto_increment,\n" + + " username varchar,\n" + + " a int,\n" + + " b int,\n" + + " primary key (a, b)\n" + + ")", + }, + { + // test localtime with and without () + input: "create table t (\n" + + " time1 timestamp default localtime,\n" + + " time2 timestamp default localtime(),\n" + + " time3 timestamp default localtime on update localtime,\n" + + " time4 timestamp default localtime() on update localtime(),\n" + + " time5 timestamp(6) default localtime(6) on update localtime(6)\n" + + ")", + output: "create table t (\n" + + " time1 timestamp default localtime(0),\n" + + " time2 timestamp default localtime(0),\n" + + " time3 timestamp default localtime(0) on update localtime(0),\n" + + " time4 timestamp default localtime(0) on update localtime(0),\n" + + " time5 timestamp(6) default localtime(6) on update localtime(6)\n" + + ")", + }, + { + // test localtimestamp with and without () + input: "create table t (\n" + + " time1 timestamp default localtimestamp,\n" + + " time2 timestamp default localtimestamp(),\n" + + " time3 timestamp default localtimestamp on update localtimestamp,\n" + + " time4 timestamp default localtimestamp() on update localtimestamp(),\n" + + " time5 timestamp(1) default localtimestamp(1) on update localtimestamp(1)\n" + + ")", + output: "create table t (\n" + + " time1 timestamp default localtimestamp(0),\n" + + " time2 timestamp default localtimestamp(0),\n" + + " time3 timestamp default localtimestamp(0) on update localtimestamp(0),\n" + + " time4 timestamp default localtimestamp(0) on update localtimestamp(0),\n" + + " time5 timestamp(1) default localtimestamp(1) on update localtimestamp(1)\n" + + ")", + }, + { + input: "create table t (\n" + + " id serial not null,\n" + + " a bigint not null\n" + + ")", + output: "create table t (\n" + + " id bigint not null auto_increment unique,\n" + + " a bigint not null\n" + + ")", + }, + + // partition options + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by range (store_id) (\n" + + "partition p0 values less than (6),\n" + + "partition p1 values less than (11),\n" + + "partition p2 values less than (16),\n" + + "partition p3 values less than (21)\n" + + ")", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by hash ('values')", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by hash (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by linear hash (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by KEY (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by KEY ALGORITHM = 7 (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by linear KEY ALGORITHM = 7 (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by RANGE (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by RANGE (i + j)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by RANGE (month(i))", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by RANGE (concat(i))", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by RANGE COLUMNS (c1, c2, c3)", + output: "create table t (\n" + + "\ti int\n" + + ") partition by RANGE (c1, c2, c3)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by LIST (col)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by LIST (i + j)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by LIST (month(i))", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by LIST (concat(i))", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by LIST COLUMNS (c1, c2, c3)", + output: "create table t (\n" + + "\ti int\n" + + ") partition by LIST (c1, c2, c3)", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by linear hash (a) partitions 20", + }, + { + input: "create table t (\n" + + "\ti int\n" + + ") partition by linear hash (a) partitions 10 subpartition by linear hash (b) subpartitions 20", }, { input: "create table t (\n" + @@ -6091,21 +7037,13 @@ func TestCreateTable(t *testing.T) { }, { input: "create table t (\n" + - "\ti int\n)" + - "engine = innodb\n" + - "auto_increment 123,\n" + - "avg_row_length 1,\n" + - "default character set utf8mb4\n" + - "PARTITION BY LINEAR HASH (a) " + - "PARTITIONS 10 SUBPARTITION BY LINEAR HASH (b) SUBPARTITIONS 20", - output: "create table t (\n" + - "\ti int\n) " + - "engine innodb " + - "auto_increment 123,\n" + - " avg_row_length 1,\n" + - " default character set utf8mb4" + - "PARTITION BY LINEAR HASH (a)" + - "PARTITIONS 10 SUBPARTITION BY LINEAR HASH (b) SUBPARTITIONS 20 ", + "\ti int\n" + + ") engine innodb " + + "auto_increment 123 " + + "avg_row_length 1 " + + "character set utf8mb4 " + + "partition by linear hash (a) partitions 10 " + + "subpartition by linear hash (b) subpartitions 20", }, { input: "create table t (\n" + @@ -6134,20 +7072,15 @@ func TestCreateTable(t *testing.T) { }, } for _, tcase := range testCases { - t.Run(tcase.input, func(t *testing.T) { - tree, err := Parse(tcase.input) - if err != nil { - t.Errorf("input: %s, err: %v", tcase.input, err) - return - } - if got, want := String(tree.(*DDL)), tcase.output; got != want { - t.Errorf("Parse(%s):\nGot:%s\nWant:%s", tcase.input, got, want) - } - }) + runParseTestCase(t, tcase) } + // these are keywords in our grammar due to their special syntax, but they should parse unquoted in MySQL nonsupportedKeywords := []string{ "comment", + "cast", + "position", + "trim", } nonsupported := map[string]bool{} for _, x := range nonsupportedKeywords { @@ -6155,12 +7088,12 @@ func TestCreateTable(t *testing.T) { } for key := range keywords { - //input := fmt.Sprintf("create table t {key} bigint)") input := fmt.Sprintf("create table t (\n\t`%s` bigint\n)", key) output := fmt.Sprintf("create table t (\n\t`%s` bigint\n)", key) t.Run(input, func(t *testing.T) { if _, ok := nonsupported[key]; ok { - t.Skipf("Keyword currently not supported as a column name: %s", key) + input = fmt.Sprintf("create table %s (\n\t%s bigint\n)", key, key) + output = fmt.Sprintf("create table `%s` (\n\t`%s` bigint\n)", key, key) } tree, err := Parse(input) if err != nil { @@ -6665,9 +7598,6 @@ var ( }, { input: "select * from foo limit 1+1", output: "syntax error at position 27 near '1'", - }, { - input: "select * from foo limit a", - output: "syntax error at position 26 near 'a'", }, { input: "select * from foo limit '100'", output: "syntax error at position 30 near '100'", @@ -6746,9 +7676,6 @@ var ( }, { input: "insert into a select * into @a from b", output: "INTO clause is not allowed at position 38 near 'b'", - }, { - input: "create table t (id int primary key, col1 FLOAT SRID 0)", - output: "cannot define SRID for non spatial types at position 55 near '0'", }, { input: "create table t (id int primary key, col1 geometry SRID -1)", output: "syntax error at position 57 near 'SRID'", @@ -6786,6 +7713,20 @@ var ( }, } + invalidSRIDQueries = func() (queries []parseTest) { + for _, column := range sampleColumns { + var statement strings.Builder + statement.WriteString("create table t (id int primary key, ") + statement.WriteString(column) + statement.WriteString(" SRID 0)") + queries = append(queries, parseTest{ + input: statement.String(), + output: "cannot define SRID for non spatial types", + }) + } + return + }() + // invalidAnsiQuotesSQL contains invalid SQL statements that use ANSI_QUOTES mode. invalidAnsiQuotesSQL = []parseTest{ { @@ -6813,6 +7754,12 @@ func TestErrors(t *testing.T) { assert.Equal(t, tcase.output, err.Error()) }) } + for _, tcase := range invalidSRIDQueries { + t.Run(tcase.input, func(t *testing.T) { + _, err := Parse(tcase.input) + assert.Contains(t, err.Error(), tcase.output) + }) + } } // TestSkipToEnd tests that the skip to end functionality diff --git a/go/vt/sqlparser/sql.go b/go/vt/sqlparser/sql.go index c40b8780a52..0cbf2b110ce 100755 --- a/go/vt/sqlparser/sql.go +++ b/go/vt/sqlparser/sql.go @@ -92,6 +92,7 @@ type yySymType struct { sqlVal *SQLVal colTuple ColTuple values Values + aliasedvalues AliasedValues valTuple ValTuple whens []*When when *When @@ -131,11 +132,17 @@ type yySymType struct { indexColumns []*IndexColumn constraintDefinition *ConstraintDefinition constraintInfo ConstraintInfo + tableOption *TableOption + tableOptions []*TableOption + partOption *PartitionOption + subpart *SubPartition ReferenceAction ReferenceAction partDefs []*PartitionDefinition partDef *PartitionDefinition partSpec *PartitionSpec + partSpecs []*PartitionSpec viewSpec *ViewSpec + viewCheckOption ViewCheckOption showFilter *ShowFilter frame *Frame frameExtent *FrameExtent @@ -193,712 +200,735 @@ type yySymType struct { srsAttr *SrsAttribute } -const LEX_ERROR = 57346 -const FOR_SYSTEM_TIME = 57347 -const FOR_VERSION = 57348 -const EXCEPT = 57349 -const UNION = 57350 -const INTERSECT = 57351 -const SELECT = 57352 -const STREAM = 57353 -const INSERT = 57354 -const UPDATE = 57355 -const DELETE = 57356 -const FROM = 57357 -const WHERE = 57358 -const GROUP = 57359 -const HAVING = 57360 -const ORDER = 57361 -const BY = 57362 -const LIMIT = 57363 -const OFFSET = 57364 -const FOR = 57365 -const CALL = 57366 -const ALL = 57367 -const ANY = 57368 -const SOME = 57369 -const DISTINCT = 57370 -const AS = 57371 -const EXISTS = 57372 -const ASC = 57373 -const DESC = 57374 -const DUPLICATE = 57375 -const DEFAULT = 57376 -const SET = 57377 -const LOCK = 57378 -const UNLOCK = 57379 -const KEYS = 57380 -const OF = 57381 -const OUTFILE = 57382 -const DUMPFILE = 57383 -const DATA = 57384 -const LOAD = 57385 -const LINES = 57386 -const TERMINATED = 57387 -const ESCAPED = 57388 -const ENCLOSED = 57389 -const OPTIONALLY = 57390 -const STARTING = 57391 -const UNIQUE = 57392 -const KEY = 57393 -const SYSTEM_TIME = 57394 -const CONTAINED = 57395 -const VERSION = 57396 -const VERSIONS = 57397 -const VALUES = 57398 -const LAST_INSERT_ID = 57399 -const SQL_CALC_FOUND_ROWS = 57400 -const NEXT = 57401 -const VALUE = 57402 -const SHARE = 57403 -const MODE = 57404 -const SQL_NO_CACHE = 57405 -const SQL_CACHE = 57406 -const JOIN = 57407 -const STRAIGHT_JOIN = 57408 -const LEFT = 57409 -const RIGHT = 57410 -const INNER = 57411 -const OUTER = 57412 -const CROSS = 57413 -const NATURAL = 57414 -const USE = 57415 -const FORCE = 57416 -const ON = 57417 -const USING = 57418 -const ID = 57419 -const HEX = 57420 -const STRING = 57421 -const INTEGRAL = 57422 -const FLOAT = 57423 -const HEXNUM = 57424 -const VALUE_ARG = 57425 -const LIST_ARG = 57426 -const COMMENT = 57427 -const COMMENT_KEYWORD = 57428 -const BIT_LITERAL = 57429 -const NULL = 57430 -const TRUE = 57431 -const FALSE = 57432 -const OFF = 57433 -const INTO = 57434 -const OR = 57435 -const XOR = 57436 -const AND = 57437 -const NOT = 57438 -const BETWEEN = 57439 -const CASE = 57440 -const WHEN = 57441 -const THEN = 57442 -const ELSE = 57443 -const ELSEIF = 57444 -const END = 57445 -const LE = 57446 -const GE = 57447 -const NE = 57448 -const NULL_SAFE_EQUAL = 57449 -const IS = 57450 -const LIKE = 57451 -const REGEXP = 57452 -const IN = 57453 -const ASSIGNMENT_OP = 57454 -const UNBOUNDED = 57455 -const PARTITION = 57456 -const RANGE = 57457 -const ROWS = 57458 -const GROUPS = 57459 -const PRECEDING = 57460 -const FOLLOWING = 57461 -const SHIFT_LEFT = 57462 -const SHIFT_RIGHT = 57463 -const DIV = 57464 -const MOD = 57465 -const UNARY = 57466 -const COLLATE = 57467 -const BINARY = 57468 -const UNDERSCORE_ARMSCII8 = 57469 -const UNDERSCORE_ASCII = 57470 -const UNDERSCORE_BIG5 = 57471 -const UNDERSCORE_BINARY = 57472 -const UNDERSCORE_CP1250 = 57473 -const UNDERSCORE_CP1251 = 57474 -const UNDERSCORE_CP1256 = 57475 -const UNDERSCORE_CP1257 = 57476 -const UNDERSCORE_CP850 = 57477 -const UNDERSCORE_CP852 = 57478 -const UNDERSCORE_CP866 = 57479 -const UNDERSCORE_CP932 = 57480 -const UNDERSCORE_DEC8 = 57481 -const UNDERSCORE_EUCJPMS = 57482 -const UNDERSCORE_EUCKR = 57483 -const UNDERSCORE_GB18030 = 57484 -const UNDERSCORE_GB2312 = 57485 -const UNDERSCORE_GBK = 57486 -const UNDERSCORE_GEOSTD8 = 57487 -const UNDERSCORE_GREEK = 57488 -const UNDERSCORE_HEBREW = 57489 -const UNDERSCORE_HP8 = 57490 -const UNDERSCORE_KEYBCS2 = 57491 -const UNDERSCORE_KOI8R = 57492 -const UNDERSCORE_KOI8U = 57493 -const UNDERSCORE_LATIN1 = 57494 -const UNDERSCORE_LATIN2 = 57495 -const UNDERSCORE_LATIN5 = 57496 -const UNDERSCORE_LATIN7 = 57497 -const UNDERSCORE_MACCE = 57498 -const UNDERSCORE_MACROMAN = 57499 -const UNDERSCORE_SJIS = 57500 -const UNDERSCORE_SWE7 = 57501 -const UNDERSCORE_TIS620 = 57502 -const UNDERSCORE_UCS2 = 57503 -const UNDERSCORE_UJIS = 57504 -const UNDERSCORE_UTF16 = 57505 -const UNDERSCORE_UTF16LE = 57506 -const UNDERSCORE_UTF32 = 57507 -const UNDERSCORE_UTF8 = 57508 -const UNDERSCORE_UTF8MB3 = 57509 -const UNDERSCORE_UTF8MB4 = 57510 -const INTERVAL = 57511 -const JSON_EXTRACT_OP = 57512 -const JSON_UNQUOTE_EXTRACT_OP = 57513 -const CREATE = 57514 -const ALTER = 57515 -const DROP = 57516 -const RENAME = 57517 -const ANALYZE = 57518 -const ADD = 57519 -const MODIFY = 57520 -const CHANGE = 57521 -const SCHEMA = 57522 -const TABLE = 57523 -const INDEX = 57524 -const INDEXES = 57525 -const VIEW = 57526 -const TO = 57527 -const IGNORE = 57528 -const IF = 57529 -const PRIMARY = 57530 -const COLUMN = 57531 -const SPATIAL = 57532 -const FULLTEXT = 57533 -const KEY_BLOCK_SIZE = 57534 -const CHECK = 57535 -const ACTION = 57536 -const CASCADE = 57537 -const CONSTRAINT = 57538 -const FOREIGN = 57539 -const NO = 57540 -const REFERENCES = 57541 -const RESTRICT = 57542 -const FIRST = 57543 -const AFTER = 57544 -const LAST = 57545 -const SHOW = 57546 -const DESCRIBE = 57547 -const EXPLAIN = 57548 -const DATE = 57549 -const ESCAPE = 57550 -const REPAIR = 57551 -const OPTIMIZE = 57552 -const TRUNCATE = 57553 -const FORMAT = 57554 -const EXTENDED = 57555 -const MAXVALUE = 57556 -const REORGANIZE = 57557 -const LESS = 57558 -const THAN = 57559 -const PROCEDURE = 57560 -const TRIGGER = 57561 -const TRIGGERS = 57562 -const FUNCTION = 57563 -const STATUS = 57564 -const VARIABLES = 57565 -const WARNINGS = 57566 -const ERRORS = 57567 -const KILL = 57568 -const CONNECTION = 57569 -const SEQUENCE = 57570 -const ENABLE = 57571 -const DISABLE = 57572 -const EACH = 57573 -const ROW = 57574 -const BEFORE = 57575 -const FOLLOWS = 57576 -const PRECEDES = 57577 -const DEFINER = 57578 -const INVOKER = 57579 -const INOUT = 57580 -const OUT = 57581 -const DETERMINISTIC = 57582 -const CONTAINS = 57583 -const READS = 57584 -const MODIFIES = 57585 -const SQL = 57586 -const SECURITY = 57587 -const TEMPORARY = 57588 -const ALGORITHM = 57589 -const MERGE = 57590 -const TEMPTABLE = 57591 -const UNDEFINED = 57592 -const EVENT = 57593 -const EVENTS = 57594 -const SCHEDULE = 57595 -const EVERY = 57596 -const STARTS = 57597 -const ENDS = 57598 -const COMPLETION = 57599 -const PRESERVE = 57600 -const CLASS_ORIGIN = 57601 -const SUBCLASS_ORIGIN = 57602 -const MESSAGE_TEXT = 57603 -const MYSQL_ERRNO = 57604 -const CONSTRAINT_CATALOG = 57605 -const CONSTRAINT_SCHEMA = 57606 -const CONSTRAINT_NAME = 57607 -const CATALOG_NAME = 57608 -const SCHEMA_NAME = 57609 -const TABLE_NAME = 57610 -const COLUMN_NAME = 57611 -const CURSOR_NAME = 57612 -const SIGNAL = 57613 -const RESIGNAL = 57614 -const SQLSTATE = 57615 -const DECLARE = 57616 -const CONDITION = 57617 -const CURSOR = 57618 -const CONTINUE = 57619 -const EXIT = 57620 -const UNDO = 57621 -const HANDLER = 57622 -const FOUND = 57623 -const SQLWARNING = 57624 -const SQLEXCEPTION = 57625 -const FETCH = 57626 -const OPEN = 57627 -const CLOSE = 57628 -const LOOP = 57629 -const LEAVE = 57630 -const ITERATE = 57631 -const REPEAT = 57632 -const UNTIL = 57633 -const WHILE = 57634 -const DO = 57635 -const RETURN = 57636 -const USER = 57637 -const IDENTIFIED = 57638 -const ROLE = 57639 -const REUSE = 57640 -const GRANT = 57641 -const GRANTS = 57642 -const REVOKE = 57643 -const NONE = 57644 -const ATTRIBUTE = 57645 -const RANDOM = 57646 -const PASSWORD = 57647 -const INITIAL = 57648 -const AUTHENTICATION = 57649 -const SSL = 57650 -const X509 = 57651 -const CIPHER = 57652 -const ISSUER = 57653 -const SUBJECT = 57654 -const ACCOUNT = 57655 -const EXPIRE = 57656 -const NEVER = 57657 -const OPTION = 57658 -const OPTIONAL = 57659 -const ADMIN = 57660 -const PRIVILEGES = 57661 -const MAX_QUERIES_PER_HOUR = 57662 -const MAX_UPDATES_PER_HOUR = 57663 -const MAX_CONNECTIONS_PER_HOUR = 57664 -const MAX_USER_CONNECTIONS = 57665 -const FLUSH = 57666 -const FAILED_LOGIN_ATTEMPTS = 57667 -const PASSWORD_LOCK_TIME = 57668 -const REQUIRE = 57669 -const PROXY = 57670 -const ROUTINE = 57671 -const TABLESPACE = 57672 -const CLIENT = 57673 -const SLAVE = 57674 -const EXECUTE = 57675 -const FILE = 57676 -const RELOAD = 57677 -const REPLICATION = 57678 -const SHUTDOWN = 57679 -const SUPER = 57680 -const USAGE = 57681 -const LOGS = 57682 -const ENGINE = 57683 -const ERROR = 57684 -const GENERAL = 57685 -const HOSTS = 57686 -const OPTIMIZER_COSTS = 57687 -const RELAY = 57688 -const SLOW = 57689 -const USER_RESOURCES = 57690 -const NO_WRITE_TO_BINLOG = 57691 -const CHANNEL = 57692 -const APPLICATION_PASSWORD_ADMIN = 57693 -const AUDIT_ABORT_EXEMPT = 57694 -const AUDIT_ADMIN = 57695 -const AUTHENTICATION_POLICY_ADMIN = 57696 -const BACKUP_ADMIN = 57697 -const BINLOG_ADMIN = 57698 -const BINLOG_ENCRYPTION_ADMIN = 57699 -const CLONE_ADMIN = 57700 -const CONNECTION_ADMIN = 57701 -const ENCRYPTION_KEY_ADMIN = 57702 -const FIREWALL_ADMIN = 57703 -const FIREWALL_EXEMPT = 57704 -const FIREWALL_USER = 57705 -const FLUSH_OPTIMIZER_COSTS = 57706 -const FLUSH_STATUS = 57707 -const FLUSH_TABLES = 57708 -const FLUSH_USER_RESOURCES = 57709 -const GROUP_REPLICATION_ADMIN = 57710 -const GROUP_REPLICATION_STREAM = 57711 -const INNODB_REDO_LOG_ARCHIVE = 57712 -const INNODB_REDO_LOG_ENABLE = 57713 -const NDB_STORED_USER = 57714 -const PASSWORDLESS_USER_ADMIN = 57715 -const PERSIST_RO_VARIABLES_ADMIN = 57716 -const REPLICATION_APPLIER = 57717 -const REPLICATION_SLAVE_ADMIN = 57718 -const RESOURCE_GROUP_ADMIN = 57719 -const RESOURCE_GROUP_USER = 57720 -const ROLE_ADMIN = 57721 -const SENSITIVE_VARIABLES_OBSERVER = 57722 -const SESSION_VARIABLES_ADMIN = 57723 -const SET_USER_ID = 57724 -const SHOW_ROUTINE = 57725 -const SKIP_QUERY_REWRITE = 57726 -const SYSTEM_VARIABLES_ADMIN = 57727 -const TABLE_ENCRYPTION_ADMIN = 57728 -const TP_CONNECTION_ADMIN = 57729 -const VERSION_TOKEN_ADMIN = 57730 -const XA_RECOVER_ADMIN = 57731 -const REPLICA = 57732 -const SOURCE = 57733 -const STOP = 57734 -const RESET = 57735 -const FILTER = 57736 -const SOURCE_HOST = 57737 -const SOURCE_USER = 57738 -const SOURCE_PASSWORD = 57739 -const SOURCE_PORT = 57740 -const SOURCE_CONNECT_RETRY = 57741 -const SOURCE_RETRY_COUNT = 57742 -const REPLICATE_DO_TABLE = 57743 -const REPLICATE_IGNORE_TABLE = 57744 -const BEGIN = 57745 -const START = 57746 -const TRANSACTION = 57747 -const COMMIT = 57748 -const ROLLBACK = 57749 -const SAVEPOINT = 57750 -const WORK = 57751 -const RELEASE = 57752 -const CHAIN = 57753 -const BIT = 57754 -const TINYINT = 57755 -const SMALLINT = 57756 -const MEDIUMINT = 57757 -const INT = 57758 -const INTEGER = 57759 -const BIGINT = 57760 -const INTNUM = 57761 -const SERIAL = 57762 -const INT1 = 57763 -const INT2 = 57764 -const INT3 = 57765 -const INT4 = 57766 -const INT8 = 57767 -const REAL = 57768 -const DOUBLE = 57769 -const FLOAT_TYPE = 57770 -const DECIMAL = 57771 -const NUMERIC = 57772 -const DEC = 57773 -const FIXED = 57774 -const PRECISION = 57775 -const TIME = 57776 -const TIMESTAMP = 57777 -const DATETIME = 57778 -const CHAR = 57779 -const VARCHAR = 57780 -const BOOL = 57781 -const CHARACTER = 57782 -const VARBINARY = 57783 -const NCHAR = 57784 -const NVARCHAR = 57785 -const NATIONAL = 57786 -const VARYING = 57787 -const VARCHARACTER = 57788 -const TEXT = 57789 -const TINYTEXT = 57790 -const MEDIUMTEXT = 57791 -const LONGTEXT = 57792 -const LONG = 57793 -const BLOB = 57794 -const TINYBLOB = 57795 -const MEDIUMBLOB = 57796 -const LONGBLOB = 57797 -const JSON = 57798 -const ENUM = 57799 -const GEOMETRY = 57800 -const POINT = 57801 -const LINESTRING = 57802 -const POLYGON = 57803 -const GEOMETRYCOLLECTION = 57804 -const MULTIPOINT = 57805 -const MULTILINESTRING = 57806 -const MULTIPOLYGON = 57807 -const LOCAL = 57808 -const LOW_PRIORITY = 57809 -const SKIP = 57810 -const LOCKED = 57811 -const NULLX = 57812 -const AUTO_INCREMENT = 57813 -const APPROXNUM = 57814 -const SIGNED = 57815 -const UNSIGNED = 57816 -const ZEROFILL = 57817 -const SRID = 57818 -const COLLATION = 57819 -const DATABASES = 57820 -const SCHEMAS = 57821 -const TABLES = 57822 -const FULL = 57823 -const PROCESSLIST = 57824 -const COLUMNS = 57825 -const FIELDS = 57826 -const ENGINES = 57827 -const PLUGINS = 57828 -const NAMES = 57829 -const CHARSET = 57830 -const GLOBAL = 57831 -const SESSION = 57832 -const ISOLATION = 57833 -const LEVEL = 57834 -const READ = 57835 -const WRITE = 57836 -const ONLY = 57837 -const REPEATABLE = 57838 -const COMMITTED = 57839 -const UNCOMMITTED = 57840 -const SERIALIZABLE = 57841 -const ENCRYPTION = 57842 -const CURRENT_TIMESTAMP = 57843 -const NOW = 57844 -const DATABASE = 57845 -const CURRENT_DATE = 57846 -const CURRENT_USER = 57847 -const CURRENT_TIME = 57848 -const LOCALTIME = 57849 -const LOCALTIMESTAMP = 57850 -const UTC_DATE = 57851 -const UTC_TIME = 57852 -const UTC_TIMESTAMP = 57853 -const REPLACE = 57854 -const CONVERT = 57855 -const CAST = 57856 -const SUBSTR = 57857 -const SUBSTRING = 57858 -const TRIM = 57859 -const LEADING = 57860 -const TRAILING = 57861 -const BOTH = 57862 -const GROUP_CONCAT = 57863 -const SEPARATOR = 57864 -const TIMESTAMPADD = 57865 -const TIMESTAMPDIFF = 57866 -const EXTRACT = 57867 -const OVER = 57868 -const WINDOW = 57869 -const GROUPING = 57870 -const CURRENT = 57871 -const AVG = 57872 -const BIT_AND = 57873 -const BIT_OR = 57874 -const BIT_XOR = 57875 -const COUNT = 57876 -const JSON_ARRAYAGG = 57877 -const JSON_OBJECTAGG = 57878 -const MAX = 57879 -const MIN = 57880 -const STDDEV_POP = 57881 -const STDDEV = 57882 -const STD = 57883 -const STDDEV_SAMP = 57884 -const SUM = 57885 -const VAR_POP = 57886 -const VARIANCE = 57887 -const VAR_SAMP = 57888 -const CUME_DIST = 57889 -const DENSE_RANK = 57890 -const FIRST_VALUE = 57891 -const LAG = 57892 -const LAST_VALUE = 57893 -const LEAD = 57894 -const NTH_VALUE = 57895 -const NTILE = 57896 -const ROW_NUMBER = 57897 -const PERCENT_RANK = 57898 -const RANK = 57899 -const DUAL = 57900 -const JSON_TABLE = 57901 -const PATH = 57902 -const AVG_ROW_LENGTH = 57903 -const CHECKSUM = 57904 -const TABLE_CHECKSUM = 57905 -const COMPRESSION = 57906 -const DIRECTORY = 57907 -const DELAY_KEY_WRITE = 57908 -const ENGINE_ATTRIBUTE = 57909 -const INSERT_METHOD = 57910 -const MAX_ROWS = 57911 -const MIN_ROWS = 57912 -const PACK_KEYS = 57913 -const ROW_FORMAT = 57914 -const SECONDARY_ENGINE = 57915 -const SECONDARY_ENGINE_ATTRIBUTE = 57916 -const STATS_AUTO_RECALC = 57917 -const STATS_PERSISTENT = 57918 -const STATS_SAMPLE_PAGES = 57919 -const STORAGE = 57920 -const DISK = 57921 -const MEMORY = 57922 -const DYNAMIC = 57923 -const COMPRESSED = 57924 -const REDUNDANT = 57925 -const COMPACT = 57926 -const LIST = 57927 -const HASH = 57928 -const PARTITIONS = 57929 -const SUBPARTITION = 57930 -const SUBPARTITIONS = 57931 -const PREPARE = 57932 -const DEALLOCATE = 57933 -const MATCH = 57934 -const AGAINST = 57935 -const BOOLEAN = 57936 -const LANGUAGE = 57937 -const WITH = 57938 -const QUERY = 57939 -const EXPANSION = 57940 -const MICROSECOND = 57941 -const SECOND = 57942 -const MINUTE = 57943 -const HOUR = 57944 -const DAY = 57945 -const WEEK = 57946 -const MONTH = 57947 -const QUARTER = 57948 -const YEAR = 57949 -const SECOND_MICROSECOND = 57950 -const MINUTE_MICROSECOND = 57951 -const MINUTE_SECOND = 57952 -const HOUR_MICROSECOND = 57953 -const HOUR_SECOND = 57954 -const HOUR_MINUTE = 57955 -const DAY_MICROSECOND = 57956 -const DAY_SECOND = 57957 -const DAY_MINUTE = 57958 -const DAY_HOUR = 57959 -const YEAR_MONTH = 57960 -const NAME = 57961 -const SYSTEM = 57962 -const ACCESSIBLE = 57963 -const ASENSITIVE = 57964 -const CUBE = 57965 -const DELAYED = 57966 -const DISTINCTROW = 57967 -const EMPTY = 57968 -const FLOAT4 = 57969 -const FLOAT8 = 57970 -const GET = 57971 -const HIGH_PRIORITY = 57972 -const INSENSITIVE = 57973 -const IO_AFTER_GTIDS = 57974 -const IO_BEFORE_GTIDS = 57975 -const LINEAR = 57976 -const MASTER_BIND = 57977 -const MASTER_SSL_VERIFY_SERVER_CERT = 57978 -const MIDDLEINT = 57979 -const PURGE = 57980 -const READ_WRITE = 57981 -const RLIKE = 57982 -const SENSITIVE = 57983 -const SPECIFIC = 57984 -const SQL_BIG_RESULT = 57985 -const SQL_SMALL_RESULT = 57986 -const UNUSED = 57987 -const DESCRIPTION = 57988 -const LATERAL = 57989 -const MEMBER = 57990 -const RECURSIVE = 57991 -const BUCKETS = 57992 -const CLONE = 57993 -const COMPONENT = 57994 -const DEFINITION = 57995 -const ENFORCED = 57996 -const EXCLUDE = 57997 -const GEOMCOLLECTION = 57998 -const GET_MASTER_PUBLIC_KEY = 57999 -const HISTOGRAM = 58000 -const HISTORY = 58001 -const INACTIVE = 58002 -const INVISIBLE = 58003 -const MASTER_COMPRESSION_ALGORITHMS = 58004 -const MASTER_PUBLIC_KEY_PATH = 58005 -const MASTER_TLS_CIPHERSUITES = 58006 -const MASTER_ZSTD_COMPRESSION_LEVEL = 58007 -const NESTED = 58008 -const NETWORK_NAMESPACE = 58009 -const NOWAIT = 58010 -const NULLS = 58011 -const OJ = 58012 -const OLD = 58013 -const ORDINALITY = 58014 -const ORGANIZATION = 58015 -const OTHERS = 58016 -const PERSIST = 58017 -const PERSIST_ONLY = 58018 -const PRIVILEGE_CHECKS_USER = 58019 -const PROCESS = 58020 -const REFERENCE = 58021 -const REQUIRE_ROW_FORMAT = 58022 -const RESOURCE = 58023 -const RESPECT = 58024 -const RESTART = 58025 -const RETAIN = 58026 -const SECONDARY = 58027 -const SECONDARY_LOAD = 58028 -const SECONDARY_UNLOAD = 58029 -const THREAD_PRIORITY = 58030 -const TIES = 58031 -const VCPU = 58032 -const VISIBLE = 58033 -const INFILE = 58034 -const ACTIVE = 58035 -const AGGREGATE = 58036 -const ARRAY = 58037 -const ASCII = 58038 -const AT = 58039 -const AUTOEXTEND_SIZE = 58040 -const GENERATED = 58041 -const ALWAYS = 58042 -const STORED = 58043 -const VIRTUAL = 58044 -const NVAR = 58045 -const PASSWORD_LOCK = 58046 +const STRING_TYPE_PREFIX_NON_KEYWORD = 57346 +const LEX_ERROR = 57347 +const FOR_SYSTEM_TIME = 57348 +const FOR_VERSION = 57349 +const EXCEPT = 57350 +const UNION = 57351 +const INTERSECT = 57352 +const SELECT = 57353 +const STREAM = 57354 +const INSERT = 57355 +const UPDATE = 57356 +const DELETE = 57357 +const FROM = 57358 +const WHERE = 57359 +const GROUP = 57360 +const HAVING = 57361 +const ORDER = 57362 +const BY = 57363 +const LIMIT = 57364 +const OFFSET = 57365 +const FOR = 57366 +const CALL = 57367 +const ALL = 57368 +const ANY = 57369 +const SOME = 57370 +const DISTINCT = 57371 +const AS = 57372 +const EXISTS = 57373 +const ASC = 57374 +const DESC = 57375 +const DUPLICATE = 57376 +const DEFAULT = 57377 +const SET = 57378 +const LOCK = 57379 +const UNLOCK = 57380 +const KEYS = 57381 +const OF = 57382 +const OUTFILE = 57383 +const DUMPFILE = 57384 +const DATA = 57385 +const LOAD = 57386 +const LINES = 57387 +const TERMINATED = 57388 +const ESCAPED = 57389 +const ENCLOSED = 57390 +const OPTIONALLY = 57391 +const STARTING = 57392 +const UNIQUE = 57393 +const KEY = 57394 +const SYSTEM_TIME = 57395 +const CONTAINED = 57396 +const VERSION = 57397 +const VERSIONS = 57398 +const VALUES = 57399 +const LAST_INSERT_ID = 57400 +const SQL_CALC_FOUND_ROWS = 57401 +const NEXT = 57402 +const VALUE = 57403 +const SHARE = 57404 +const MODE = 57405 +const SQL_NO_CACHE = 57406 +const SQL_CACHE = 57407 +const JOIN = 57408 +const STRAIGHT_JOIN = 57409 +const LEFT = 57410 +const RIGHT = 57411 +const INNER = 57412 +const OUTER = 57413 +const CROSS = 57414 +const NATURAL = 57415 +const USE = 57416 +const FORCE = 57417 +const ON = 57418 +const USING = 57419 +const STRING = 57420 +const ID = 57421 +const HEX = 57422 +const INTEGRAL = 57423 +const FLOAT = 57424 +const HEXNUM = 57425 +const VALUE_ARG = 57426 +const LIST_ARG = 57427 +const COMMENT = 57428 +const COMMENT_KEYWORD = 57429 +const BIT_LITERAL = 57430 +const NULL = 57431 +const TRUE = 57432 +const FALSE = 57433 +const OFF = 57434 +const INTO = 57435 +const OR = 57436 +const XOR = 57437 +const AND = 57438 +const NOT = 57439 +const BETWEEN = 57440 +const CASE = 57441 +const WHEN = 57442 +const THEN = 57443 +const ELSE = 57444 +const ELSEIF = 57445 +const END = 57446 +const LE = 57447 +const GE = 57448 +const NE = 57449 +const NULL_SAFE_EQUAL = 57450 +const IS = 57451 +const LIKE = 57452 +const REGEXP = 57453 +const IN = 57454 +const ASSIGNMENT_OP = 57455 +const UNBOUNDED = 57456 +const PARTITION = 57457 +const RANGE = 57458 +const ROWS = 57459 +const GROUPS = 57460 +const PRECEDING = 57461 +const FOLLOWING = 57462 +const SHIFT_LEFT = 57463 +const SHIFT_RIGHT = 57464 +const DIV = 57465 +const MOD = 57466 +const UNARY = 57467 +const COLLATE = 57468 +const BINARY = 57469 +const UNDERSCORE_ARMSCII8 = 57470 +const UNDERSCORE_ASCII = 57471 +const UNDERSCORE_BIG5 = 57472 +const UNDERSCORE_BINARY = 57473 +const UNDERSCORE_CP1250 = 57474 +const UNDERSCORE_CP1251 = 57475 +const UNDERSCORE_CP1256 = 57476 +const UNDERSCORE_CP1257 = 57477 +const UNDERSCORE_CP850 = 57478 +const UNDERSCORE_CP852 = 57479 +const UNDERSCORE_CP866 = 57480 +const UNDERSCORE_CP932 = 57481 +const UNDERSCORE_DEC8 = 57482 +const UNDERSCORE_EUCJPMS = 57483 +const UNDERSCORE_EUCKR = 57484 +const UNDERSCORE_GB18030 = 57485 +const UNDERSCORE_GB2312 = 57486 +const UNDERSCORE_GBK = 57487 +const UNDERSCORE_GEOSTD8 = 57488 +const UNDERSCORE_GREEK = 57489 +const UNDERSCORE_HEBREW = 57490 +const UNDERSCORE_HP8 = 57491 +const UNDERSCORE_KEYBCS2 = 57492 +const UNDERSCORE_KOI8R = 57493 +const UNDERSCORE_KOI8U = 57494 +const UNDERSCORE_LATIN1 = 57495 +const UNDERSCORE_LATIN2 = 57496 +const UNDERSCORE_LATIN5 = 57497 +const UNDERSCORE_LATIN7 = 57498 +const UNDERSCORE_MACCE = 57499 +const UNDERSCORE_MACROMAN = 57500 +const UNDERSCORE_SJIS = 57501 +const UNDERSCORE_SWE7 = 57502 +const UNDERSCORE_TIS620 = 57503 +const UNDERSCORE_UCS2 = 57504 +const UNDERSCORE_UJIS = 57505 +const UNDERSCORE_UTF16 = 57506 +const UNDERSCORE_UTF16LE = 57507 +const UNDERSCORE_UTF32 = 57508 +const UNDERSCORE_UTF8 = 57509 +const UNDERSCORE_UTF8MB3 = 57510 +const UNDERSCORE_UTF8MB4 = 57511 +const INTERVAL = 57512 +const JSON_EXTRACT_OP = 57513 +const JSON_UNQUOTE_EXTRACT_OP = 57514 +const CREATE = 57515 +const ALTER = 57516 +const DROP = 57517 +const RENAME = 57518 +const ANALYZE = 57519 +const ADD = 57520 +const MODIFY = 57521 +const CHANGE = 57522 +const SCHEMA = 57523 +const TABLE = 57524 +const INDEX = 57525 +const INDEXES = 57526 +const VIEW = 57527 +const TO = 57528 +const IGNORE = 57529 +const IF = 57530 +const PRIMARY = 57531 +const COLUMN = 57532 +const SPATIAL = 57533 +const FULLTEXT = 57534 +const KEY_BLOCK_SIZE = 57535 +const CHECK = 57536 +const ACTION = 57537 +const CASCADE = 57538 +const CONSTRAINT = 57539 +const FOREIGN = 57540 +const NO = 57541 +const REFERENCES = 57542 +const RESTRICT = 57543 +const FIRST = 57544 +const AFTER = 57545 +const LAST = 57546 +const SHOW = 57547 +const DESCRIBE = 57548 +const EXPLAIN = 57549 +const DATE = 57550 +const ESCAPE = 57551 +const REPAIR = 57552 +const OPTIMIZE = 57553 +const TRUNCATE = 57554 +const FORMAT = 57555 +const EXTENDED = 57556 +const MAXVALUE = 57557 +const REORGANIZE = 57558 +const LESS = 57559 +const THAN = 57560 +const PROCEDURE = 57561 +const TRIGGER = 57562 +const TRIGGERS = 57563 +const FUNCTION = 57564 +const STATUS = 57565 +const VARIABLES = 57566 +const WARNINGS = 57567 +const ERRORS = 57568 +const KILL = 57569 +const CONNECTION = 57570 +const SEQUENCE = 57571 +const ENABLE = 57572 +const DISABLE = 57573 +const EACH = 57574 +const ROW = 57575 +const BEFORE = 57576 +const FOLLOWS = 57577 +const PRECEDES = 57578 +const DEFINER = 57579 +const INVOKER = 57580 +const INOUT = 57581 +const OUT = 57582 +const DETERMINISTIC = 57583 +const CONTAINS = 57584 +const READS = 57585 +const MODIFIES = 57586 +const SQL = 57587 +const SECURITY = 57588 +const TEMPORARY = 57589 +const ALGORITHM = 57590 +const MERGE = 57591 +const TEMPTABLE = 57592 +const UNDEFINED = 57593 +const EVENT = 57594 +const EVENTS = 57595 +const SCHEDULE = 57596 +const EVERY = 57597 +const STARTS = 57598 +const ENDS = 57599 +const COMPLETION = 57600 +const PRESERVE = 57601 +const CASCADED = 57602 +const INSTANT = 57603 +const INPLACE = 57604 +const COPY = 57605 +const DISCARD = 57606 +const IMPORT = 57607 +const SHARED = 57608 +const EXCLUSIVE = 57609 +const WITHOUT = 57610 +const VALIDATION = 57611 +const COALESCE = 57612 +const EXCHANGE = 57613 +const REBUILD = 57614 +const REMOVE = 57615 +const PARTITIONING = 57616 +const CLASS_ORIGIN = 57617 +const SUBCLASS_ORIGIN = 57618 +const MESSAGE_TEXT = 57619 +const MYSQL_ERRNO = 57620 +const CONSTRAINT_CATALOG = 57621 +const CONSTRAINT_SCHEMA = 57622 +const CONSTRAINT_NAME = 57623 +const CATALOG_NAME = 57624 +const SCHEMA_NAME = 57625 +const TABLE_NAME = 57626 +const COLUMN_NAME = 57627 +const CURSOR_NAME = 57628 +const SIGNAL = 57629 +const RESIGNAL = 57630 +const SQLSTATE = 57631 +const DECLARE = 57632 +const CONDITION = 57633 +const CURSOR = 57634 +const CONTINUE = 57635 +const EXIT = 57636 +const UNDO = 57637 +const HANDLER = 57638 +const FOUND = 57639 +const SQLWARNING = 57640 +const SQLEXCEPTION = 57641 +const FETCH = 57642 +const OPEN = 57643 +const CLOSE = 57644 +const LOOP = 57645 +const LEAVE = 57646 +const ITERATE = 57647 +const REPEAT = 57648 +const UNTIL = 57649 +const WHILE = 57650 +const DO = 57651 +const RETURN = 57652 +const USER = 57653 +const IDENTIFIED = 57654 +const ROLE = 57655 +const REUSE = 57656 +const GRANT = 57657 +const GRANTS = 57658 +const REVOKE = 57659 +const NONE = 57660 +const ATTRIBUTE = 57661 +const RANDOM = 57662 +const PASSWORD = 57663 +const INITIAL = 57664 +const AUTHENTICATION = 57665 +const SSL = 57666 +const X509 = 57667 +const CIPHER = 57668 +const ISSUER = 57669 +const SUBJECT = 57670 +const ACCOUNT = 57671 +const EXPIRE = 57672 +const NEVER = 57673 +const OPTION = 57674 +const OPTIONAL = 57675 +const ADMIN = 57676 +const PRIVILEGES = 57677 +const MAX_QUERIES_PER_HOUR = 57678 +const MAX_UPDATES_PER_HOUR = 57679 +const MAX_CONNECTIONS_PER_HOUR = 57680 +const MAX_USER_CONNECTIONS = 57681 +const FLUSH = 57682 +const FAILED_LOGIN_ATTEMPTS = 57683 +const PASSWORD_LOCK_TIME = 57684 +const REQUIRE = 57685 +const PROXY = 57686 +const ROUTINE = 57687 +const TABLESPACE = 57688 +const CLIENT = 57689 +const SLAVE = 57690 +const EXECUTE = 57691 +const FILE = 57692 +const RELOAD = 57693 +const REPLICATION = 57694 +const SHUTDOWN = 57695 +const SUPER = 57696 +const USAGE = 57697 +const LOGS = 57698 +const ENGINE = 57699 +const ERROR = 57700 +const GENERAL = 57701 +const HOSTS = 57702 +const OPTIMIZER_COSTS = 57703 +const RELAY = 57704 +const SLOW = 57705 +const USER_RESOURCES = 57706 +const NO_WRITE_TO_BINLOG = 57707 +const CHANNEL = 57708 +const APPLICATION_PASSWORD_ADMIN = 57709 +const AUDIT_ABORT_EXEMPT = 57710 +const AUDIT_ADMIN = 57711 +const AUTHENTICATION_POLICY_ADMIN = 57712 +const BACKUP_ADMIN = 57713 +const BINLOG_ADMIN = 57714 +const BINLOG_ENCRYPTION_ADMIN = 57715 +const CLONE_ADMIN = 57716 +const CONNECTION_ADMIN = 57717 +const ENCRYPTION_KEY_ADMIN = 57718 +const FIREWALL_ADMIN = 57719 +const FIREWALL_EXEMPT = 57720 +const FIREWALL_USER = 57721 +const FLUSH_OPTIMIZER_COSTS = 57722 +const FLUSH_STATUS = 57723 +const FLUSH_TABLES = 57724 +const FLUSH_USER_RESOURCES = 57725 +const GROUP_REPLICATION_ADMIN = 57726 +const GROUP_REPLICATION_STREAM = 57727 +const INNODB_REDO_LOG_ARCHIVE = 57728 +const INNODB_REDO_LOG_ENABLE = 57729 +const NDB_STORED_USER = 57730 +const PASSWORDLESS_USER_ADMIN = 57731 +const PERSIST_RO_VARIABLES_ADMIN = 57732 +const REPLICATION_APPLIER = 57733 +const REPLICATION_SLAVE_ADMIN = 57734 +const RESOURCE_GROUP_ADMIN = 57735 +const RESOURCE_GROUP_USER = 57736 +const ROLE_ADMIN = 57737 +const SENSITIVE_VARIABLES_OBSERVER = 57738 +const SESSION_VARIABLES_ADMIN = 57739 +const SET_USER_ID = 57740 +const SHOW_ROUTINE = 57741 +const SKIP_QUERY_REWRITE = 57742 +const SYSTEM_VARIABLES_ADMIN = 57743 +const TABLE_ENCRYPTION_ADMIN = 57744 +const TP_CONNECTION_ADMIN = 57745 +const VERSION_TOKEN_ADMIN = 57746 +const XA_RECOVER_ADMIN = 57747 +const REPLICA = 57748 +const REPLICAS = 57749 +const SOURCE = 57750 +const STOP = 57751 +const RESET = 57752 +const FILTER = 57753 +const LOG = 57754 +const MASTER = 57755 +const SOURCE_HOST = 57756 +const SOURCE_USER = 57757 +const SOURCE_PASSWORD = 57758 +const SOURCE_PORT = 57759 +const SOURCE_CONNECT_RETRY = 57760 +const SOURCE_RETRY_COUNT = 57761 +const SOURCE_AUTO_POSITION = 57762 +const REPLICATE_DO_TABLE = 57763 +const REPLICATE_IGNORE_TABLE = 57764 +const BEGIN = 57765 +const START = 57766 +const TRANSACTION = 57767 +const COMMIT = 57768 +const ROLLBACK = 57769 +const SAVEPOINT = 57770 +const WORK = 57771 +const RELEASE = 57772 +const CHAIN = 57773 +const BIT = 57774 +const TINYINT = 57775 +const SMALLINT = 57776 +const MEDIUMINT = 57777 +const INT = 57778 +const INTEGER = 57779 +const BIGINT = 57780 +const INTNUM = 57781 +const SERIAL = 57782 +const INT1 = 57783 +const INT2 = 57784 +const INT3 = 57785 +const INT4 = 57786 +const INT8 = 57787 +const REAL = 57788 +const DOUBLE = 57789 +const FLOAT_TYPE = 57790 +const DECIMAL = 57791 +const NUMERIC = 57792 +const DEC = 57793 +const FIXED = 57794 +const PRECISION = 57795 +const TIME = 57796 +const TIMESTAMP = 57797 +const DATETIME = 57798 +const CHAR = 57799 +const VARCHAR = 57800 +const BOOL = 57801 +const CHARACTER = 57802 +const VARBINARY = 57803 +const NCHAR = 57804 +const NVARCHAR = 57805 +const NATIONAL = 57806 +const VARYING = 57807 +const VARCHARACTER = 57808 +const TEXT = 57809 +const TINYTEXT = 57810 +const MEDIUMTEXT = 57811 +const LONGTEXT = 57812 +const LONG = 57813 +const BLOB = 57814 +const TINYBLOB = 57815 +const MEDIUMBLOB = 57816 +const LONGBLOB = 57817 +const JSON = 57818 +const ENUM = 57819 +const GEOMETRY = 57820 +const POINT = 57821 +const LINESTRING = 57822 +const POLYGON = 57823 +const GEOMETRYCOLLECTION = 57824 +const MULTIPOINT = 57825 +const MULTILINESTRING = 57826 +const MULTIPOLYGON = 57827 +const LOCAL = 57828 +const LOW_PRIORITY = 57829 +const SKIP = 57830 +const LOCKED = 57831 +const NULLX = 57832 +const AUTO_INCREMENT = 57833 +const APPROXNUM = 57834 +const SIGNED = 57835 +const UNSIGNED = 57836 +const ZEROFILL = 57837 +const SRID = 57838 +const COLLATION = 57839 +const DATABASES = 57840 +const SCHEMAS = 57841 +const TABLES = 57842 +const FULL = 57843 +const PROCESSLIST = 57844 +const COLUMNS = 57845 +const FIELDS = 57846 +const ENGINES = 57847 +const PLUGINS = 57848 +const NAMES = 57849 +const CHARSET = 57850 +const GLOBAL = 57851 +const SESSION = 57852 +const ISOLATION = 57853 +const LEVEL = 57854 +const READ = 57855 +const WRITE = 57856 +const ONLY = 57857 +const REPEATABLE = 57858 +const COMMITTED = 57859 +const UNCOMMITTED = 57860 +const SERIALIZABLE = 57861 +const ENCRYPTION = 57862 +const CURRENT_TIMESTAMP = 57863 +const NOW = 57864 +const DATABASE = 57865 +const CURRENT_DATE = 57866 +const CURRENT_USER = 57867 +const CURRENT_TIME = 57868 +const LOCALTIME = 57869 +const LOCALTIMESTAMP = 57870 +const UTC_DATE = 57871 +const UTC_TIME = 57872 +const UTC_TIMESTAMP = 57873 +const REPLACE = 57874 +const CONVERT = 57875 +const CAST = 57876 +const POSITION = 57877 +const SUBSTR = 57878 +const SUBSTRING = 57879 +const TRIM = 57880 +const LEADING = 57881 +const TRAILING = 57882 +const BOTH = 57883 +const GROUP_CONCAT = 57884 +const SEPARATOR = 57885 +const TIMESTAMPADD = 57886 +const TIMESTAMPDIFF = 57887 +const EXTRACT = 57888 +const OVER = 57889 +const WINDOW = 57890 +const GROUPING = 57891 +const CURRENT = 57892 +const AVG = 57893 +const BIT_AND = 57894 +const BIT_OR = 57895 +const BIT_XOR = 57896 +const COUNT = 57897 +const JSON_ARRAYAGG = 57898 +const JSON_OBJECTAGG = 57899 +const MAX = 57900 +const MIN = 57901 +const STDDEV_POP = 57902 +const STDDEV = 57903 +const STD = 57904 +const STDDEV_SAMP = 57905 +const SUM = 57906 +const VAR_POP = 57907 +const VARIANCE = 57908 +const VAR_SAMP = 57909 +const CUME_DIST = 57910 +const DENSE_RANK = 57911 +const FIRST_VALUE = 57912 +const LAG = 57913 +const LAST_VALUE = 57914 +const LEAD = 57915 +const NTH_VALUE = 57916 +const NTILE = 57917 +const ROW_NUMBER = 57918 +const PERCENT_RANK = 57919 +const RANK = 57920 +const DUAL = 57921 +const JSON_TABLE = 57922 +const PATH = 57923 +const AVG_ROW_LENGTH = 57924 +const CHECKSUM = 57925 +const TABLE_CHECKSUM = 57926 +const COMPRESSION = 57927 +const DIRECTORY = 57928 +const DELAY_KEY_WRITE = 57929 +const ENGINE_ATTRIBUTE = 57930 +const INSERT_METHOD = 57931 +const MAX_ROWS = 57932 +const MIN_ROWS = 57933 +const PACK_KEYS = 57934 +const ROW_FORMAT = 57935 +const SECONDARY_ENGINE = 57936 +const SECONDARY_ENGINE_ATTRIBUTE = 57937 +const STATS_AUTO_RECALC = 57938 +const STATS_PERSISTENT = 57939 +const STATS_SAMPLE_PAGES = 57940 +const STORAGE = 57941 +const DISK = 57942 +const MEMORY = 57943 +const DYNAMIC = 57944 +const COMPRESSED = 57945 +const REDUNDANT = 57946 +const COMPACT = 57947 +const LIST = 57948 +const HASH = 57949 +const PARTITIONS = 57950 +const SUBPARTITION = 57951 +const SUBPARTITIONS = 57952 +const PREPARE = 57953 +const DEALLOCATE = 57954 +const MATCH = 57955 +const AGAINST = 57956 +const BOOLEAN = 57957 +const LANGUAGE = 57958 +const WITH = 57959 +const QUERY = 57960 +const EXPANSION = 57961 +const MICROSECOND = 57962 +const SECOND = 57963 +const MINUTE = 57964 +const HOUR = 57965 +const DAY = 57966 +const WEEK = 57967 +const MONTH = 57968 +const QUARTER = 57969 +const YEAR = 57970 +const SECOND_MICROSECOND = 57971 +const MINUTE_MICROSECOND = 57972 +const MINUTE_SECOND = 57973 +const HOUR_MICROSECOND = 57974 +const HOUR_SECOND = 57975 +const HOUR_MINUTE = 57976 +const DAY_MICROSECOND = 57977 +const DAY_SECOND = 57978 +const DAY_MINUTE = 57979 +const DAY_HOUR = 57980 +const YEAR_MONTH = 57981 +const NAME = 57982 +const SYSTEM = 57983 +const ACCESSIBLE = 57984 +const ASENSITIVE = 57985 +const CUBE = 57986 +const DELAYED = 57987 +const DISTINCTROW = 57988 +const EMPTY = 57989 +const FLOAT4 = 57990 +const FLOAT8 = 57991 +const GET = 57992 +const HIGH_PRIORITY = 57993 +const INSENSITIVE = 57994 +const IO_AFTER_GTIDS = 57995 +const IO_BEFORE_GTIDS = 57996 +const LINEAR = 57997 +const MASTER_BIND = 57998 +const MASTER_SSL_VERIFY_SERVER_CERT = 57999 +const MIDDLEINT = 58000 +const PURGE = 58001 +const READ_WRITE = 58002 +const RLIKE = 58003 +const SENSITIVE = 58004 +const SPECIFIC = 58005 +const SQL_BIG_RESULT = 58006 +const SQL_SMALL_RESULT = 58007 +const UNUSED = 58008 +const DESCRIPTION = 58009 +const LATERAL = 58010 +const MEMBER = 58011 +const RECURSIVE = 58012 +const BUCKETS = 58013 +const CLONE = 58014 +const COMPONENT = 58015 +const DEFINITION = 58016 +const ENFORCED = 58017 +const NOT_ENFORCED = 58018 +const EXCLUDE = 58019 +const GEOMCOLLECTION = 58020 +const GET_MASTER_PUBLIC_KEY = 58021 +const HISTOGRAM = 58022 +const HISTORY = 58023 +const INACTIVE = 58024 +const INVISIBLE = 58025 +const MASTER_COMPRESSION_ALGORITHMS = 58026 +const MASTER_PUBLIC_KEY_PATH = 58027 +const MASTER_TLS_CIPHERSUITES = 58028 +const MASTER_ZSTD_COMPRESSION_LEVEL = 58029 +const NESTED = 58030 +const NETWORK_NAMESPACE = 58031 +const NOWAIT = 58032 +const NULLS = 58033 +const OJ = 58034 +const OLD = 58035 +const ORDINALITY = 58036 +const ORGANIZATION = 58037 +const OTHERS = 58038 +const PERSIST = 58039 +const PERSIST_ONLY = 58040 +const PRIVILEGE_CHECKS_USER = 58041 +const PROCESS = 58042 +const REFERENCE = 58043 +const REQUIRE_ROW_FORMAT = 58044 +const RESOURCE = 58045 +const RESPECT = 58046 +const RESTART = 58047 +const RETAIN = 58048 +const SECONDARY = 58049 +const SECONDARY_LOAD = 58050 +const SECONDARY_UNLOAD = 58051 +const THREAD_PRIORITY = 58052 +const TIES = 58053 +const VCPU = 58054 +const VISIBLE = 58055 +const INFILE = 58056 +const ACTIVE = 58057 +const AGGREGATE = 58058 +const ARRAY = 58059 +const ASCII = 58060 +const AT = 58061 +const AUTOEXTEND_SIZE = 58062 +const GENERATED = 58063 +const ALWAYS = 58064 +const STORED = 58065 +const VIRTUAL = 58066 +const NVAR = 58067 +const PASSWORD_LOCK = 58068 var yyToknames = [...]string{ "$end", "error", "$unk", + "STRING_TYPE_PREFIX_NON_KEYWORD", "LEX_ERROR", "FOR_SYSTEM_TIME", "FOR_VERSION", @@ -977,9 +1007,9 @@ var yyToknames = [...]string{ "')'", "'@'", "':'", + "STRING", "ID", "HEX", - "STRING", "INTEGRAL", "FLOAT", "HEXNUM", @@ -1173,6 +1203,21 @@ var yyToknames = [...]string{ "ENDS", "COMPLETION", "PRESERVE", + "CASCADED", + "INSTANT", + "INPLACE", + "COPY", + "DISCARD", + "IMPORT", + "SHARED", + "EXCLUSIVE", + "WITHOUT", + "VALIDATION", + "COALESCE", + "EXCHANGE", + "REBUILD", + "REMOVE", + "PARTITIONING", "CLASS_ORIGIN", "SUBCLASS_ORIGIN", "MESSAGE_TEXT", @@ -1305,16 +1350,20 @@ var yyToknames = [...]string{ "VERSION_TOKEN_ADMIN", "XA_RECOVER_ADMIN", "REPLICA", + "REPLICAS", "SOURCE", "STOP", "RESET", "FILTER", + "LOG", + "MASTER", "SOURCE_HOST", "SOURCE_USER", "SOURCE_PASSWORD", "SOURCE_PORT", "SOURCE_CONNECT_RETRY", "SOURCE_RETRY_COUNT", + "SOURCE_AUTO_POSITION", "REPLICATE_DO_TABLE", "REPLICATE_IGNORE_TABLE", "BEGIN", @@ -1429,6 +1478,7 @@ var yyToknames = [...]string{ "REPLACE", "CONVERT", "CAST", + "POSITION", "SUBSTR", "SUBSTRING", "TRIM", @@ -1569,6 +1619,7 @@ var yyToknames = [...]string{ "COMPONENT", "DEFINITION", "ENFORCED", + "NOT_ENFORCED", "EXCLUDE", "GEOMCOLLECTION", "GET_MASTER_PUBLIC_KEY", @@ -1632,7796 +1683,8477 @@ const yyInitialStackSize = 16 var yyExca = [...]int{ -1, 0, 1, 39, - 724, 39, + 746, 39, -2, 73, -1, 1, 1, -1, -2, 0, -1, 45, - 200, 1654, - 201, 1673, - -2, 320, - -1, 57, - 241, 1054, - 242, 1054, - -2, 1043, - -1, 82, - 270, 320, - -2, 1660, - -1, 86, - 7, 52, + 201, 1747, + 202, 1767, + -2, 325, + -1, 58, + 242, 1131, + 243, 1131, + -2, 1120, + -1, 83, + 271, 325, + -2, 1753, + -1, 87, 8, 52, 9, 52, + 10, 52, -2, 45, - -1, 87, - 7, 55, + -1, 88, 8, 55, + 9, 55, -2, 46, - -1, 502, - 1, 2342, - 5, 2342, - 6, 2342, - 29, 2342, - 188, 2342, - 724, 2342, - -2, 1088, - -1, 515, - 188, 1683, - -2, 1677, - -1, 516, - 188, 1684, - -2, 1678, - -1, 617, + -1, 524, + 1, 2443, + 6, 2443, + 7, 2443, + 30, 2443, + 189, 2443, + 746, 2443, + -2, 1165, + -1, 537, + 189, 1777, + -2, 1771, + -1, 538, + 189, 1778, + -2, 1772, + -1, 639, + 1, 666, + 746, 666, + -2, 664, + -1, 648, + 1, 1265, + 8, 1265, + 9, 1265, + 10, 1265, + 17, 1265, + 18, 1265, + 19, 1265, + 20, 1265, + 22, 1265, + 24, 1265, + 36, 1265, + 37, 1265, + 66, 1265, + 67, 1265, + 68, 1265, + 69, 1265, + 70, 1265, + 72, 1265, + 73, 1265, + 76, 1265, + 77, 1265, + 79, 1265, + 80, 1265, + 98, 1265, + 520, 1265, + 567, 1265, + 636, 1265, + 746, 1265, + -2, 1762, + -1, 653, + 1, 1372, + 8, 1372, + 9, 1372, + 10, 1372, + 17, 1372, + 18, 1372, + 19, 1372, + 20, 1372, + 22, 1372, + 24, 1372, + 36, 1372, + 37, 1372, + 66, 1372, + 67, 1372, + 68, 1372, + 69, 1372, + 70, 1372, + 72, 1372, + 73, 1372, + 76, 1372, + 77, 1372, + 79, 1372, + 80, 1372, + 98, 1372, + 520, 1372, + 567, 1372, + 636, 1372, + 746, 1372, + -2, 1762, + -1, 679, + 189, 2142, + -2, 1386, + -1, 712, + 189, 2250, + -2, 1656, + -1, 713, + 189, 2331, + -2, 1388, + -1, 714, + 189, 2162, + -2, 1389, + -1, 783, + 189, 2113, + -2, 1622, + -1, 786, + 189, 2128, + -2, 1540, + -1, 787, + 189, 2131, + -2, 1540, + -1, 788, + 189, 2341, + -2, 1540, + -1, 790, + 189, 2129, + -2, 1540, + -1, 791, + 189, 2342, + -2, 1540, + -1, 792, + 189, 2343, + -2, 1540, + -1, 850, + 189, 2130, + -2, 1540, + -1, 933, + 189, 2230, + -2, 1540, + -1, 934, + 189, 2231, + -2, 1540, + -1, 1045, + 111, 2456, + 122, 2456, + 189, 2456, + -2, 1730, + -1, 1046, + 111, 2585, + 122, 2585, + 189, 2585, + -2, 1731, + -1, 1051, + 111, 2482, + 122, 2482, + 189, 2482, + -2, 1732, + -1, 1052, + 111, 2533, + 122, 2533, + 189, 2533, + -2, 1733, + -1, 1053, + 111, 2534, + 122, 2534, + 189, 2534, + -2, 1734, + -1, 1054, + 111, 2384, + 122, 2384, + 189, 2384, + -2, 1739, + -1, 1056, + 111, 2510, + 122, 2510, + 189, 2510, + -2, 1741, + -1, 1227, + 449, 1144, + -2, 1148, + -1, 1229, + 449, 1144, + -2, 1148, + -1, 1350, + 1, 666, + 746, 666, + -2, 664, + -1, 1352, 1, 667, - 724, 667, - -2, 665, - -1, 625, - 1, 1188, - 7, 1188, - 8, 1188, - 9, 1188, - 16, 1188, - 17, 1188, - 18, 1188, - 19, 1188, - 21, 1188, - 23, 1188, - 35, 1188, - 36, 1188, - 65, 1188, - 66, 1188, - 67, 1188, - 68, 1188, - 69, 1188, - 71, 1188, - 72, 1188, - 75, 1188, - 76, 1188, - 78, 1188, - 79, 1188, - 97, 1188, - 500, 1188, - 546, 1188, - 724, 1188, - -2, 1244, - -1, 630, - 1, 1294, - 7, 1294, - 8, 1294, - 9, 1294, - 16, 1294, - 17, 1294, - 18, 1294, - 19, 1294, - 21, 1294, - 23, 1294, - 35, 1294, - 36, 1294, - 65, 1294, - 66, 1294, - 67, 1294, - 68, 1294, - 69, 1294, - 71, 1294, - 72, 1294, - 75, 1294, - 76, 1294, - 78, 1294, - 79, 1294, - 97, 1294, - 500, 1294, - 546, 1294, - 724, 1294, - -2, 1244, - -1, 656, - 188, 2046, - -2, 1308, - -1, 686, - 188, 2154, - -2, 1568, - -1, 687, - 188, 2235, - -2, 1310, - -1, 688, - 188, 2066, - -2, 1311, - -1, 755, - 188, 2017, - -2, 1538, - -1, 759, - 188, 2034, - -2, 1465, - -1, 760, - 188, 2247, - -2, 1465, - -1, 761, - 188, 2246, - -2, 1465, - -1, 762, - 188, 2245, - -2, 1465, - -1, 763, - 188, 2134, - -2, 1465, - -1, 764, - 188, 2135, - -2, 1465, - -1, 765, - 188, 2032, - -2, 1465, - -1, 766, - 188, 2033, - -2, 1465, - -1, 767, - 188, 2035, - -2, 1465, - -1, 1016, - 110, 2355, - 121, 2355, - 188, 2355, + 746, 667, + -2, 664, + -1, 1375, + 1, 1266, + 8, 1266, + 9, 1266, + 10, 1266, + 17, 1266, + 18, 1266, + 19, 1266, + 20, 1266, + 22, 1266, + 24, 1266, + 36, 1266, + 37, 1266, + 66, 1266, + 67, 1266, + 68, 1266, + 69, 1266, + 70, 1266, + 72, 1266, + 73, 1266, + 76, 1266, + 77, 1266, + 79, 1266, + 80, 1266, + 98, 1266, + 520, 1266, + 567, 1266, + 636, 1266, + 746, 1266, + -2, 1762, + -1, 1387, + 1, 1372, + 8, 1372, + 9, 1372, + 10, 1372, + 17, 1372, + 18, 1372, + 19, 1372, + 20, 1372, + 22, 1372, + 24, 1372, + 36, 1372, + 37, 1372, + 66, 1372, + 67, 1372, + 68, 1372, + 69, 1372, + 70, 1372, + 72, 1372, + 73, 1372, + 76, 1372, + 77, 1372, + 79, 1372, + 80, 1372, + 98, 1372, + 520, 1372, + 567, 1372, + 636, 1372, + 746, 1372, + -2, 1762, + -1, 1681, + 1, 666, + 746, 666, + -2, 664, + -1, 1683, + 1, 666, + 746, 666, + -2, 664, + -1, 2229, + 189, 1781, + -2, 1634, + -1, 2231, + 189, 2668, + -2, 1636, + -1, 2232, + 189, 2669, -2, 1637, - -1, 1017, - 110, 2477, - 121, 2477, - 188, 2477, - -2, 1638, - -1, 1022, - 110, 2380, - 121, 2380, - 188, 2380, - -2, 1639, - -1, 1023, - 110, 2428, - 121, 2428, - 188, 2428, - -2, 1640, - -1, 1024, - 110, 2429, - 121, 2429, - 188, 2429, - -2, 1641, - -1, 1025, - 110, 2286, - 121, 2286, - 188, 2286, - -2, 1646, - -1, 1027, - 110, 2405, - 121, 2405, - 188, 2405, - -2, 1648, - -1, 1194, - 429, 1067, - -2, 1071, - -1, 1196, - 429, 1067, - -2, 1071, - -1, 1315, - 1, 667, - 724, 667, - -2, 665, - -1, 1317, - 1, 668, - 724, 668, - -2, 665, - -1, 1339, - 1, 1189, - 7, 1189, - 8, 1189, - 9, 1189, - 16, 1189, - 17, 1189, - 18, 1189, - 19, 1189, - 21, 1189, - 23, 1189, - 35, 1189, - 36, 1189, - 65, 1189, - 66, 1189, - 67, 1189, - 68, 1189, - 69, 1189, - 71, 1189, - 72, 1189, - 75, 1189, - 76, 1189, - 78, 1189, - 79, 1189, - 97, 1189, - 500, 1189, - 546, 1189, - 724, 1189, - -2, 1244, - -1, 1351, - 1, 1294, - 7, 1294, - 8, 1294, - 9, 1294, - 16, 1294, - 17, 1294, - 18, 1294, - 19, 1294, - 21, 1294, - 23, 1294, - 35, 1294, - 36, 1294, - 65, 1294, - 66, 1294, - 67, 1294, - 68, 1294, - 69, 1294, - 71, 1294, - 72, 1294, - 75, 1294, - 76, 1294, - 78, 1294, - 79, 1294, - 97, 1294, - 500, 1294, - 546, 1294, - 724, 1294, - -2, 1244, - -1, 1644, - 1, 667, - 724, 667, - -2, 665, - -1, 1646, - 1, 667, - 724, 667, - -2, 665, - -1, 2189, - 188, 1686, - -2, 1682, - -1, 2330, - 76, 91, - 78, 91, - -2, 95, - -1, 2348, - 188, 2158, - -2, 1642, - -1, 2531, - 50, 887, - 207, 890, - 209, 887, - 210, 887, - -2, 946, - -1, 2568, - 7, 53, + -1, 2233, + 189, 1780, + -2, 1776, + -1, 2380, + 77, 92, + 79, 92, + -2, 96, + -1, 2398, + 189, 2254, + -2, 1735, + -1, 2405, + 1, 866, + 746, 866, + -2, 664, + -1, 2586, + 51, 886, + 208, 889, + 210, 886, + 211, 886, + -2, 993, + -1, 2662, 8, 53, 9, 53, - -2, 1343, - -1, 2585, - 1, 1232, - 7, 1232, - 8, 1232, - 9, 1232, - 16, 1232, - 17, 1232, - 18, 1232, - 19, 1232, - 21, 1232, - 23, 1232, - 35, 1232, - 36, 1232, - 65, 1232, - 66, 1232, - 67, 1232, - 68, 1232, - 69, 1232, - 71, 1232, - 72, 1232, - 75, 1232, - 76, 1232, - 78, 1232, - 79, 1232, - 97, 1232, - 500, 1232, - 546, 1232, - 724, 1232, - -2, 1244, - -1, 2943, - 1, 1294, - 7, 1294, - 8, 1294, - 9, 1294, - 16, 1294, - 17, 1294, - 18, 1294, - 19, 1294, - 21, 1294, - 23, 1294, - 35, 1294, - 36, 1294, - 65, 1294, - 66, 1294, - 67, 1294, - 68, 1294, - 69, 1294, - 71, 1294, - 72, 1294, - 75, 1294, - 76, 1294, - 78, 1294, - 79, 1294, - 97, 1294, - 500, 1294, - 546, 1294, - 724, 1294, - -2, 1244, - -1, 3237, - 207, 891, - -2, 889, - -1, 3348, - 78, 1930, - 79, 1930, - 188, 1930, - -2, 1094, - -1, 3581, - 7, 53, + 10, 53, + -2, 1421, + -1, 2679, + 1, 1311, + 8, 1311, + 9, 1311, + 10, 1311, + 17, 1311, + 18, 1311, + 19, 1311, + 20, 1311, + 22, 1311, + 24, 1311, + 36, 1311, + 37, 1311, + 66, 1311, + 67, 1311, + 68, 1311, + 69, 1311, + 70, 1311, + 72, 1311, + 73, 1311, + 76, 1311, + 77, 1311, + 79, 1311, + 80, 1311, + 98, 1311, + 520, 1311, + 567, 1311, + 636, 1311, + 746, 1311, + -2, 1762, + -1, 2848, + 213, 987, + 217, 987, + -2, 766, + -1, 2849, + 213, 1057, + 217, 1057, + -2, 767, + -1, 3101, + 1, 1372, + 8, 1372, + 9, 1372, + 10, 1372, + 17, 1372, + 18, 1372, + 19, 1372, + 20, 1372, + 22, 1372, + 24, 1372, + 36, 1372, + 37, 1372, + 66, 1372, + 67, 1372, + 68, 1372, + 69, 1372, + 70, 1372, + 72, 1372, + 73, 1372, + 76, 1372, + 77, 1372, + 79, 1372, + 80, 1372, + 98, 1372, + 520, 1372, + 567, 1372, + 636, 1372, + 746, 1372, + -2, 1762, + -1, 3203, + 1, 1687, + 76, 1687, + 746, 1687, + -2, 1762, + -1, 3391, + 51, 886, + 208, 889, + 210, 886, + 211, 886, + -2, 993, + -1, 3404, + 208, 890, + 213, 987, + 217, 987, + -2, 888, + -1, 3578, + 79, 2026, + 80, 2026, + 189, 2026, + -2, 1171, + -1, 3579, + 78, 1698, + 252, 1698, + -2, 2075, + -1, 3580, + 78, 1699, + 252, 1699, + -2, 2635, + -1, 3807, 8, 53, 9, 53, - -2, 1601, - -1, 3798, - 47, 1696, + 10, 53, -2, 1694, - -1, 3973, - 7, 53, + -1, 3949, + 48, 1792, + -2, 1790, + -1, 4209, 8, 53, 9, 53, - -2, 1604, - -1, 3996, - 299, 410, - -2, 1750, - -1, 3997, - 299, 411, - -2, 1791, - -1, 3998, - 299, 412, - -2, 1967, - -1, 4218, - 105, 396, - 107, 396, - 109, 396, + 10, 53, + -2, 1695, + -1, 4234, + 315, 416, + -2, 1846, + -1, 4235, + 315, 417, + -2, 1887, + -1, 4236, + 315, 418, + -2, 2063, + -1, 4462, + 106, 402, + 108, 402, + 110, 402, -2, 73, - -1, 4298, - 107, 403, - 108, 403, - 109, 403, + -1, 4543, + 108, 409, + 109, 409, + 110, 409, -2, 73, } const yyPrivate = 57344 -const yyLast = 74181 +const yyLast = 80576 var yyAct = [...]int{ - 698, 92, 4271, 4177, 4222, 4211, 4210, 4179, 1381, 658, - 3160, 1130, 527, 4100, 2771, 4101, 2345, 3860, 3, 3714, - 3863, 7, 3862, 6, 3965, 3990, 2770, 1342, 3855, 1566, - 3861, 5, 3506, 3454, 3894, 27, 3864, 8, 2275, 3989, - 3709, 3196, 614, 3018, 2276, 3826, 3809, 1350, 3109, 3798, - 675, 3547, 3762, 3723, 2561, 3963, 3610, 3341, 1466, 3540, - 3715, 2417, 3361, 697, 3808, 1679, 3681, 644, 3040, 95, - 3046, 3268, 506, 509, 3342, 2932, 662, 2436, 1177, 2217, - 3517, 3175, 3483, 3477, 2371, 554, 554, 599, 3376, 627, - 610, 3209, 1491, 92, 2838, 3460, 2549, 1400, 3110, 3526, - 2754, 3856, 2362, 3377, 2160, 1344, 3047, 3230, 92, 3537, - 642, 3338, 454, 4003, 2093, 1681, 1157, 2760, 3274, 2569, - 641, 2824, 2085, 1347, 1321, 2508, 2530, 2848, 1102, 3095, - 123, 1148, 3098, 2693, 1207, 3194, 1341, 3026, 661, 2985, - 2715, 667, 2468, 649, 2146, 2898, 1349, 1684, 2491, 2148, - 2358, 2086, 2072, 1095, 1182, 1678, 2526, 2402, 2031, 2761, - 2805, 1973, 1654, 2375, 2398, 1382, 1018, 1547, 1208, 2264, - 1543, 2194, 1389, 2552, 625, 1241, 1385, 2036, 1219, 1316, - 1313, 1106, 1021, 1546, 1094, 1014, 2332, 1408, 2153, 1015, - 1327, 634, 4002, 80, 621, 622, 2229, 1129, 1320, 1319, - 1318, 613, 530, 665, 3716, 529, 2004, 1972, 1200, 512, - 2005, 1117, 1647, 118, 1218, 1111, 4298, 4292, 4279, 114, - 4263, 618, 4249, 1099, 4218, 4216, 647, 4192, 4189, 4188, - 4187, 4172, 4170, 4082, 4078, 4073, 94, 3764, 3763, 3125, - 3276, 2029, 2778, 2421, 1121, 1490, 3187, 2783, 3953, 3656, - 2455, 2454, 3158, 3452, 3365, 4242, 4206, 4204, 4287, 4241, - 3112, 4205, 2816, 2788, 2787, 3654, 86, 1657, 89, 4017, - 1370, 4016, 4209, 3190, 40, 40, 3362, 522, 3657, 91, - 3188, 3961, 40, 640, 66, 4155, 3832, 3669, 2784, 3461, - 2452, 2836, 631, 3611, 4108, 43, 619, 2452, 3934, 3463, - 3189, 1091, 3172, 3960, 2790, 3831, 2768, 3730, 3613, 3009, - 612, 111, 464, 4056, 2769, 451, 1422, 1421, 1431, 1432, - 1424, 1425, 1426, 1427, 1428, 1429, 1430, 1423, 1345, 3744, - 1433, 3599, 2147, 1113, 3593, 1119, 1120, 3077, 1123, 3606, - 3607, 93, 93, 3412, 3076, 3952, 3823, 4041, 3237, 93, - 3789, 3719, 2670, 3331, 2795, 2377, 2347, 2772, 2277, 2289, - 2287, 2286, 2285, 2288, 2284, 2283, 2282, 2278, 2279, 2296, - 2280, 2295, 2294, 2281, 2293, 2292, 2291, 2290, 2484, 3969, - 40, 3969, 1110, 40, 2490, 2750, 3058, 3059, 2032, 2289, - 2287, 2286, 2285, 2288, 2284, 2283, 2282, 3964, 620, 2296, - 3057, 2295, 2294, 1143, 2293, 2292, 2291, 2290, 3039, 3397, - 2546, 2722, 2342, 2343, 1294, 3466, 3966, 2341, 3966, 2730, - 2786, 2075, 2076, 2789, 93, 2035, 3043, 1391, 3612, 3043, - 3044, 2781, 4043, 3044, 2707, 93, 1322, 2706, 524, 1548, - 2708, 1549, 1180, 1181, 1632, 3954, 501, 93, 125, 3297, - 93, 2033, 2034, 2053, 1271, 2716, 521, 3464, 3465, 3467, - 3468, 3469, 520, 2792, 88, 88, 2373, 2374, 2727, 2966, - 127, 2593, 88, 103, 101, 102, 608, 2489, 1105, 2782, - 145, 3970, 1194, 3970, 1238, 1189, 494, 2382, 2384, 2379, - 2383, 145, 2392, 1178, 514, 1179, 1180, 1181, 3068, 3317, - 2717, 3562, 92, 2116, 92, 1333, 1334, 1633, 2379, 615, - 3315, 2474, 2379, 1279, 2399, 2473, 145, 2924, 115, 1201, - 2726, 642, 1202, 496, 1204, 2010, 2379, 652, 1197, 519, - 603, 1206, 1203, 1029, 2100, 602, 153, 145, 3089, 4241, - 4205, 4203, 2379, 2073, 2074, 136, 132, 133, 605, 134, - 603, 1161, 1162, 1190, 1191, 1165, 1292, 3437, 145, 1293, - 3443, 3445, 3444, 3441, 3442, 3440, 3439, 3438, 604, 2886, - 88, 145, 4286, 88, 1105, 4242, 4240, 4239, 2731, 3446, - 3447, 3448, 4206, 138, 137, 499, 1167, 2082, 2737, 1163, - 1164, 2081, 601, 609, 2538, 2532, 2533, 2080, 2531, 2534, - 2535, 2079, 2078, 1633, 680, 679, 682, 683, 684, 685, - 3655, 92, 2077, 681, 2225, 1314, 141, 3685, 4104, 117, - 1275, 1276, 1166, 2729, 3707, 2831, 3921, 1340, 1346, 121, - 128, 1254, 153, 1364, 1365, 92, 2548, 92, 92, 2868, - 3208, 92, 1192, 2873, 2503, 642, 3484, 3485, 3486, 3487, - 2540, 2539, 3176, 3177, 3178, 3179, 3180, 1442, 1444, 1268, - 139, 1446, 140, 1329, 1332, 1333, 1334, 1330, 3478, 1331, - 1336, 3182, 2782, 1337, 3923, 125, 3481, 4103, 1286, 3783, - 3793, 1287, 4166, 3275, 1245, 126, 129, 3495, 3479, 3480, - 1458, 3791, 3651, 1461, 1462, 1463, 1464, 1465, 3512, 1469, - 2835, 2741, 4075, 2785, 2485, 4076, 2504, 4077, 2780, 2509, - 2510, 2511, 2512, 2513, 2514, 617, 642, 3673, 3675, 2065, - 4027, 3173, 2833, 2437, 3493, 1154, 2749, 3176, 3177, 3178, - 3179, 3180, 4295, 130, 119, 3185, 120, 2734, 4035, 4015, - 3705, 1254, 1471, 1472, 1473, 1474, 1475, 1476, 1477, 1478, - 1479, 1480, 1481, 1482, 1483, 1484, 3363, 1487, 1488, 1489, - 1492, 1492, 1492, 1498, 1492, 1492, 1498, 1492, 1498, 1507, - 1508, 1509, 1510, 1511, 1512, 1513, 1514, 1515, 1516, 1517, - 1518, 1519, 1520, 1521, 1522, 1523, 1524, 1525, 1526, 1527, - 1528, 1529, 1530, 1531, 1532, 1533, 1534, 1535, 1536, 1356, - 2743, 1339, 3731, 3614, 1310, 3365, 2986, 1278, 523, 500, - 3615, 4265, 3462, 4294, 3067, 151, 4264, 4261, 4074, 152, - 4185, 4070, 154, 155, 3157, 2796, 3399, 3210, 156, 4226, - 631, 631, 3785, 2923, 2497, 3544, 2723, 4068, 4069, 2934, - 3946, 3824, 3967, 510, 3967, 2035, 3830, 131, 3273, 3597, - 2098, 507, 4174, 1494, 1496, 3815, 1500, 1502, 3170, 1505, - 3595, 1443, 3066, 1324, 1298, 93, 3648, 2719, 135, 2386, - 2011, 2033, 2034, 1198, 1160, 4167, 2387, 145, 2782, 643, - 81, 1652, 3670, 3647, 2721, 3598, 2837, 643, 2988, 2401, - 511, 3646, 2537, 2767, 3951, 2801, 2733, 3617, 2099, 2799, - 3645, 1367, 1253, 1367, 1367, 1372, 1372, 1367, 1373, 3644, - 2101, 151, 1412, 2381, 1366, 152, 1371, 1371, 154, 155, - 1378, 3642, 1311, 3652, 156, 2834, 1254, 3616, 3922, 2378, - 3790, 2779, 1118, 1329, 1332, 1333, 1334, 1330, 1335, 1331, - 1336, 1288, 116, 2553, 2554, 4102, 2935, 1246, 145, 1205, - 2934, 1662, 1663, 1661, 3643, 142, 3672, 2720, 2724, 2725, - 2728, 1308, 2732, 2735, 2736, 2738, 2739, 2740, 2742, 2744, - 2745, 2746, 2747, 2748, 3184, 3398, 3400, 3401, 3402, 3784, - 1264, 1196, 125, 2544, 2545, 643, 1642, 4050, 643, 2547, - 3778, 3779, 104, 3858, 2542, 2543, 2942, 3097, 3105, 3107, - 3106, 1405, 1406, 1404, 3099, 2427, 1493, 1495, 1497, 1499, - 1501, 1503, 1504, 1506, 3774, 1405, 1406, 1404, 2431, 2432, - 1407, 3985, 3986, 4183, 3272, 2125, 4178, 1115, 1114, 3269, - 3270, 4142, 125, 2037, 1407, 4095, 2426, 2856, 2857, 615, - 1176, 3437, 4181, 129, 3443, 3445, 3444, 3441, 3442, 3440, - 3439, 3438, 1261, 1118, 3752, 145, 1174, 1175, 1304, 508, - 1116, 508, 1173, 3446, 3447, 3448, 1172, 1171, 505, 3388, - 2039, 615, 3389, 2038, 3390, 3518, 3519, 1965, 3853, 1303, - 1299, 1300, 1301, 1302, 1305, 1306, 1307, 1309, 4275, 2006, - 3264, 1021, 3113, 3265, 2718, 3266, 1021, 1105, 1335, 1105, - 508, 2368, 1105, 2368, 4288, 1101, 127, 1105, 2996, 2997, - 2990, 4301, 2904, 3236, 1259, 2994, 4296, 2989, 2987, 3927, - 1361, 1362, 4280, 2992, 2438, 4252, 2916, 1628, 1629, 1630, - 1631, 1112, 554, 1656, 1132, 620, 3530, 2991, 1250, 1352, - 1354, 3528, 3271, 1540, 1355, 2370, 3206, 1338, 2370, 2867, - 2863, 2841, 554, 1680, 2993, 2995, 2840, 2370, 2498, 2070, - 1667, 1562, 1665, 1260, 1199, 1256, 2420, 1109, 2133, 2132, - 1363, 1361, 1362, 2131, 1637, 1108, 3201, 1323, 1557, 1122, - 112, 1551, 449, 3100, 2933, 1655, 1552, 3533, 1352, 1354, - 1660, 1352, 1354, 1963, 3296, 1355, 3056, 1257, 1258, 1448, - 1449, 1380, 2370, 2865, 2642, 2864, 92, 2712, 1558, 2639, - 1447, 1445, 2610, 2449, 2587, 4190, 2523, 2453, 2448, 1559, - 2428, 1363, 2337, 1201, 2163, 93, 1202, 3944, 1204, 4079, - 1635, 1537, 1538, 508, 1450, 1561, 1203, 3101, 1348, 1352, - 1354, 3788, 4180, 4182, 2347, 2439, 1460, 93, 1565, 1459, - 1413, 1236, 1145, 3225, 1999, 3226, 3025, 2893, 2703, 2894, - 1686, 3813, 554, 1669, 1249, 3235, 128, 4273, 3806, 1433, - 4274, 1353, 4272, 1975, 1221, 1222, 1223, 1224, 1225, 1226, - 1227, 1228, 1229, 1230, 1231, 1232, 1450, 112, 1987, 3424, - 1988, 1989, 1990, 1423, 2026, 2369, 1433, 2063, 2369, 1994, - 1977, 2915, 3810, 1193, 3203, 2912, 107, 2369, 2001, 2002, - 1450, 1967, 1971, 2911, 2904, 3227, 3527, 2046, 2908, 2895, - 1353, 2907, 2910, 1353, 1643, 1650, 627, 627, 627, 627, - 1641, 1991, 1651, 1993, 1638, 1659, 1447, 3576, 1658, 2584, - 2890, 92, 2891, 4051, 4052, 3534, 2694, 1346, 1677, 2127, - 1676, 3425, 2369, 4084, 110, 4048, 4049, 2069, 642, 2904, - 1974, 3835, 3834, 1105, 642, 2931, 2905, 2368, 1335, 2024, - 88, 1353, 3659, 1964, 2126, 2201, 1979, 1980, 1448, 1449, - 2118, 2581, 92, 1448, 1449, 1558, 2578, 2119, 1183, 2156, - 2199, 2200, 2198, 2128, 2463, 109, 1559, 1407, 1159, 2130, - 3849, 2882, 2892, 2008, 2881, 2044, 2007, 2880, 1169, 3660, - 1969, 1969, 1969, 1969, 2012, 2879, 1424, 1425, 1426, 1427, - 1428, 1429, 1430, 1423, 1185, 2041, 1433, 2090, 2017, 2018, - 2878, 2877, 2020, 2106, 4085, 2517, 1405, 1406, 1404, 1544, - 2103, 2516, 1029, 2022, 4282, 92, 2068, 1029, 2023, 1404, - 2634, 1212, 2633, 2045, 2042, 1407, 2265, 1125, 2224, 2226, - 1406, 1404, 642, 1124, 2064, 3011, 1407, 2067, 4278, 4251, - 1469, 627, 1405, 1406, 1404, 4168, 4109, 88, 1407, 4117, - 2195, 1426, 1427, 1428, 1429, 1430, 1423, 642, 3991, 1433, - 4116, 1407, 4115, 1184, 2265, 2094, 2655, 2126, 2129, 2464, - 1158, 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, - 1429, 1430, 1423, 1170, 2083, 1433, 2097, 2095, 2096, 2087, - 2839, 2104, 2105, 1645, 2107, 3494, 1187, 2117, 2189, 631, - 631, 631, 631, 3488, 1405, 1406, 1404, 145, 1195, 627, - 4135, 2169, 1649, 514, 2170, 4284, 3539, 2297, 2298, 2861, - 631, 2154, 3123, 1407, 4111, 3541, 2250, 2253, 4289, 145, - 2154, 2183, 145, 640, 2266, 1649, 514, 1401, 2346, 1683, - 4149, 2161, 2162, 1685, 93, 1310, 621, 2273, 4020, 1405, - 1406, 1404, 2168, 3981, 2635, 2143, 2197, 4119, 3925, 3918, - 145, 145, 145, 145, 145, 2145, 145, 2180, 1407, 2469, - 2268, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, 1430, - 1423, 1995, 1996, 1433, 1405, 1406, 1404, 4290, 2184, 4146, - 2196, 2003, 1021, 2144, 3850, 4232, 1405, 1406, 1404, 4148, - 2354, 3919, 1386, 1407, 4067, 1387, 3745, 516, 1405, 1406, - 1404, 1314, 4255, 4223, 4254, 1407, 2218, 3991, 2219, 4064, - 2221, 4063, 2223, 1405, 1406, 1404, 2300, 1407, 2235, 2236, - 2237, 2238, 2239, 3667, 2232, 2234, 2305, 3666, 2307, 2139, - 1412, 2331, 1407, 2142, 631, 2329, 2189, 1099, 4145, 2141, - 2446, 2262, 3920, 2015, 1405, 1406, 1404, 1405, 1406, 1404, - 150, 3991, 452, 463, 97, 3013, 150, 2176, 2178, 2179, - 3665, 150, 2165, 1407, 3664, 2177, 1407, 2140, 3658, 2353, - 3502, 596, 596, 2408, 2409, 2410, 2411, 490, 2359, 150, - 1405, 1406, 1404, 3451, 2367, 3450, 150, 2166, 2335, 3221, - 2167, 2339, 2444, 2445, 2344, 2338, 99, 3786, 105, 1407, - 615, 3220, 631, 2607, 2608, 2609, 3219, 150, 1104, 2356, - 3162, 145, 1683, 145, 145, 145, 145, 2138, 2395, 2396, - 2397, 2412, 2413, 2414, 4139, 615, 2352, 2430, 150, 596, - 2811, 1104, 3126, 2810, 145, 3403, 3407, 3405, 615, 2222, - 452, 150, 2404, 2405, 2406, 2407, 3404, 2400, 3787, 1405, - 1406, 1404, 2151, 2808, 2793, 1009, 1010, 1011, 3257, 2709, - 3258, 2710, 4138, 2416, 2242, 2243, 2244, 1107, 1407, 3259, - 2248, 2249, 2252, 2255, 1244, 2260, 2261, 3105, 3107, 3106, - 3409, 2419, 2272, 465, 2422, 1243, 2424, 3408, 652, 4105, - 145, 1216, 4086, 1380, 4040, 4026, 4018, 3955, 4004, 3852, - 3851, 1685, 3782, 2299, 3781, 2301, 2302, 3758, 3706, 3674, - 2306, 3641, 2308, 2309, 3605, 1215, 3604, 3572, 2314, 2315, - 2316, 2317, 2318, 2319, 2320, 2321, 2322, 2323, 2324, 2325, - 468, 3105, 3107, 3106, 2151, 3501, 3500, 3499, 3498, 478, - 488, 489, 3491, 1422, 1421, 1431, 1432, 1424, 1425, 1426, - 1427, 1428, 1429, 1430, 1423, 3490, 615, 1433, 145, 2151, - 2151, 2151, 3489, 3449, 3427, 2151, 2151, 2151, 2151, 3406, - 2151, 2151, 3395, 3387, 3385, 1029, 474, 2151, 480, 476, - 3381, 3380, 485, 486, 3379, 3555, 3260, 3224, 3218, 3217, - 2380, 4300, 2385, 2388, 2389, 2390, 2391, 3216, 2151, 2151, - 2151, 2151, 3144, 2965, 2151, 2151, 2151, 2151, 2151, 2964, - 487, 2962, 2896, 2151, 2151, 2151, 2151, 2151, 2151, 2151, - 2151, 2151, 2151, 2151, 2151, 145, 145, 145, 2806, 2711, - 2486, 2458, 1976, 1029, 2019, 4299, 1422, 1421, 1431, 1432, - 1424, 1425, 1426, 1427, 1428, 1429, 1430, 1423, 4283, 1685, - 1433, 4266, 4260, 4194, 4186, 4080, 4061, 4060, 482, 4008, - 4007, 1498, 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, - 1428, 1429, 1430, 1423, 4001, 4000, 1433, 483, 3792, 3847, - 680, 679, 682, 683, 684, 685, 3687, 3525, 1131, 681, - 2225, 3337, 2480, 699, 700, 701, 702, 703, 704, 705, - 706, 707, 708, 709, 710, 711, 712, 713, 714, 715, - 716, 717, 718, 719, 720, 721, 722, 723, 724, 725, - 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, - 736, 737, 738, 739, 740, 2488, 1322, 2956, 3252, 1683, - 3186, 3122, 2851, 2850, 2475, 1340, 145, 150, 475, 2460, - 2459, 2220, 145, 145, 2016, 2009, 1675, 1674, 2150, 145, - 1646, 1644, 452, 1239, 1155, 518, 1668, 2637, 2465, 2586, - 1380, 3820, 1380, 2135, 3279, 4158, 2461, 3279, 1380, 3415, - 4093, 627, 1380, 2137, 1315, 1285, 2567, 2014, 2467, 3940, - 1380, 3686, 2573, 2574, 2575, 3415, 4030, 3634, 466, 1422, - 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, 1430, - 1423, 2136, 3633, 1433, 3415, 3935, 3415, 3771, 150, 2586, - 1380, 3164, 2563, 1134, 1135, 1136, 1137, 1138, 1139, 1140, - 1141, 3279, 3766, 2572, 3147, 481, 469, 470, 3146, 493, - 3279, 3761, 3145, 471, 473, 2611, 467, 492, 491, 2566, - 2495, 1250, 1444, 1444, 1444, 3702, 1380, 4234, 651, 96, - 2479, 2134, 3279, 3678, 2944, 1380, 2487, 2522, 1380, 3279, - 3551, 1965, 3515, 2502, 2953, 2849, 2505, 2849, 2494, 1379, - 680, 679, 682, 683, 684, 685, 2564, 2541, 3339, 681, - 2225, 3353, 484, 1422, 1421, 1431, 1432, 1424, 1425, 1426, - 1427, 1428, 1429, 1430, 1423, 1289, 2471, 1433, 1248, 150, - 1965, 3514, 3415, 3414, 3279, 3278, 3155, 3154, 2586, 2520, - 3151, 3152, 2195, 3151, 3150, 150, 2333, 2605, 2606, 2500, - 2499, 2240, 2482, 2240, 1380, 2571, 2333, 2120, 2189, 3353, - 2557, 150, 2120, 1380, 1417, 2698, 1420, 1965, 631, 452, - 2646, 1564, 1563, 1434, 1435, 1436, 1437, 1438, 1439, 1440, - 2696, 1418, 1419, 1416, 3554, 2435, 3353, 3008, 2950, 1290, - 3579, 2353, 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, - 1428, 1429, 1430, 1423, 631, 2158, 1433, 2334, 1247, 2336, - 2240, 1248, 2597, 627, 2595, 2596, 627, 2334, 3956, 1965, - 3828, 2452, 3279, 2120, 2120, 2619, 3165, 3153, 2963, 2434, - 2897, 2876, 2340, 93, 1380, 1422, 1421, 1431, 1432, 1424, - 1425, 1426, 1427, 1428, 1429, 1430, 1423, 2663, 2184, 1433, - 2615, 2662, 1250, 2586, 2623, 2565, 2515, 2021, 2457, 2451, - 2159, 2157, 1312, 630, 2066, 2030, 1965, 1666, 1664, 1545, - 4058, 2562, 3936, 145, 3804, 2612, 2613, 2614, 3690, 3453, - 3423, 3420, 2196, 2376, 1422, 1421, 1431, 1432, 1424, 1425, - 1426, 1427, 1428, 1429, 1430, 1423, 1021, 2403, 1433, 2379, - 145, 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, - 1429, 1430, 1423, 2654, 2937, 1433, 144, 2885, 2884, 2399, - 2752, 2669, 2671, 2553, 2554, 4270, 1254, 504, 2677, 2678, - 2679, 2680, 1686, 2429, 2394, 2393, 1636, 1235, 145, 2418, - 615, 3503, 2470, 1152, 2697, 1151, 4269, 2763, 2765, 2699, - 4246, 4244, 2700, 4238, 4237, 4212, 4207, 4201, 4199, 4151, - 4150, 3546, 554, 2855, 3542, 3339, 3163, 2846, 2845, 2829, - 1635, 2812, 2556, 1092, 2550, 2040, 1671, 1291, 1251, 526, - 1655, 2560, 1394, 2559, 2115, 1395, 1551, 2701, 2704, 2114, - 2751, 2112, 1394, 2558, 1127, 1395, 2113, 2110, 2843, 2109, - 2713, 2108, 2111, 4046, 2759, 495, 2762, 1144, 3959, 2967, - 3043, 2594, 4010, 3115, 3044, 1397, 631, 4033, 2602, 631, - 1399, 1398, 2601, 1396, 3736, 1397, 1392, 615, 145, 3524, - 1399, 1398, 3418, 1396, 3246, 2807, 3245, 3143, 615, 3142, - 3141, 2766, 2758, 3929, 3932, 4025, 2809, 4024, 2624, 2625, - 2626, 2627, 2628, 3799, 598, 3797, 4011, 3777, 3776, 2951, - 3677, 517, 2954, 2478, 2853, 2957, 2477, 497, 498, 2013, - 2922, 1685, 3661, 3662, 1383, 2652, 2921, 2832, 3371, 3255, - 3128, 3069, 2524, 1560, 2939, 627, 4227, 1384, 1233, 1217, - 1214, 1213, 1156, 3700, 3699, 2946, 2947, 2948, 2941, 2847, - 1322, 2852, 2161, 2162, 3191, 3577, 1210, 1211, 3496, 2423, - 1670, 1338, 3957, 2958, 3924, 2090, 3682, 3497, 3422, 3161, - 2814, 2230, 2084, 2866, 2231, 1296, 2015, 2862, 2014, 150, - 1209, 2600, 1376, 1374, 2869, 1377, 1375, 2151, 1104, 2599, - 4123, 4122, 2875, 2151, 2151, 2151, 2151, 2151, 2883, 1368, - 4121, 3019, 1369, 3638, 2887, 2519, 1188, 645, 2906, 4088, - 2917, 2918, 2901, 4087, 2920, 2902, 4022, 3933, 3841, 3794, - 2151, 2899, 2909, 2914, 3041, 3045, 3735, 3560, 3061, 627, - 646, 96, 2189, 3559, 3300, 2849, 2818, 2819, 2820, 4248, - 4247, 642, 4081, 3213, 2998, 2874, 2872, 3000, 1969, 2945, - 2871, 3042, 3010, 2664, 2643, 2640, 2604, 2087, 2888, 2506, - 1992, 2969, 1402, 1150, 2794, 2961, 2959, 2797, 2798, 2800, - 2802, 2971, 2803, 2804, 1149, 1390, 1104, 150, 4247, 2972, - 4248, 3837, 3140, 1414, 2155, 145, 2975, 596, 596, 2976, - 145, 635, 596, 145, 2702, 1685, 4140, 1029, 98, 150, - 639, 638, 150, 3048, 63, 2999, 4009, 596, 596, 3124, - 3877, 60, 1, 150, 3137, 3879, 22, 452, 452, 452, - 452, 3950, 2184, 3129, 3878, 21, 629, 1467, 3880, 23, - 150, 150, 150, 150, 150, 46, 150, 2496, 631, 3050, - 3020, 3021, 3022, 3023, 3024, 2974, 3881, 24, 3875, 17, - 2048, 150, 150, 3874, 16, 3052, 596, 3054, 3055, 3873, - 15, 150, 553, 1147, 3476, 3053, 3876, 18, 3872, 14, - 3866, 10, 3901, 38, 3475, 554, 3181, 3482, 145, 3899, - 36, 3898, 35, 3096, 1486, 3166, 3114, 3060, 3116, 3117, - 3118, 3119, 3171, 3120, 3104, 3897, 31, 3896, 30, 3895, - 29, 3892, 26, 3174, 1104, 3891, 25, 3871, 13, 145, - 3553, 2830, 2412, 3945, 2414, 2413, 3814, 596, 596, 596, - 3868, 12, 1104, 3867, 11, 3865, 9, 3492, 1653, 3650, - 1128, 2433, 631, 1240, 1242, 4023, 3928, 3193, 3930, 3796, - 3679, 3459, 3458, 3183, 2823, 2822, 1234, 2974, 2483, 2121, - 2122, 2123, 3132, 596, 2028, 3131, 2900, 2903, 596, 596, - 3263, 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, - 1429, 1430, 1423, 2567, 2447, 1433, 2536, 2518, 2071, 2507, - 150, 1297, 1104, 2360, 4055, 3743, 3592, 3364, 3360, 2714, - 3396, 150, 2355, 150, 150, 150, 150, 1093, 106, 2462, - 1168, 472, 2357, 2776, 3931, 150, 1237, 2775, 2791, 3277, - 2372, 1317, 3197, 2774, 150, 2773, 3926, 3199, 150, 2777, - 1570, 1568, 1569, 1567, 3200, 1572, 1571, 477, 1553, 3995, - 3233, 3295, 3215, 3336, 1403, 691, 3280, 124, 2913, 606, - 3329, 607, 113, 122, 2151, 1685, 3222, 3223, 479, 3202, - 1441, 2598, 2541, 3207, 3228, 3251, 145, 3211, 3212, 2705, - 3214, 3234, 145, 652, 1635, 1019, 1020, 1012, 2589, 2151, - 150, 3344, 92, 3833, 2241, 3718, 3825, 452, 3984, 1388, - 3720, 3558, 2245, 3299, 2653, 1485, 2263, 664, 2124, 642, - 3261, 3262, 3575, 3722, 2175, 678, 2271, 3281, 677, 3345, - 3301, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, - 1430, 1423, 676, 1104, 1433, 1104, 673, 674, 1104, 3968, - 2164, 3038, 2303, 2304, 1415, 1104, 3156, 1104, 1104, 2310, - 2311, 2312, 2313, 1295, 3343, 653, 150, 1360, 150, 3413, - 3340, 1359, 1356, 1358, 1357, 1351, 3048, 624, 2326, 2860, - 1328, 1326, 3358, 1325, 1029, 1672, 145, 1541, 2555, 2551, - 1343, 623, 628, 42, 3429, 3431, 3433, 3434, 2603, 1186, - 3426, 1393, 3330, 3729, 100, 3369, 637, 636, 3313, 648, - 3310, 3311, 3050, 3312, 2090, 3148, 3314, 3149, 3316, 3232, - 3121, 28, 20, 19, 3347, 3351, 1146, 3239, 3241, 3243, - 2529, 1126, 3455, 3248, 3352, 150, 150, 150, 3232, 44, - 49, 3359, 47, 48, 3386, 2817, 2425, 3104, 3994, 4176, - 1220, 3436, 3366, 3367, 3368, 3104, 4193, 3471, 3472, 3473, - 4221, 37, 1104, 3374, 3375, 3354, 3355, 3356, 3357, 145, - 34, 3384, 33, 3391, 3392, 3393, 32, 3893, 3887, 3394, - 3886, 3889, 3888, 3885, 3411, 3890, 3410, 3507, 3884, 3883, - 3882, 3900, 3870, 3419, 3869, 4160, 4159, 3504, 4, 90, - 145, 87, 39, 108, 1090, 2, 2087, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3456, 1978, 0, - 0, 3520, 3521, 0, 0, 655, 0, 0, 145, 0, - 0, 0, 0, 0, 0, 3416, 3417, 0, 0, 0, - 0, 0, 0, 0, 1997, 3548, 3550, 3470, 0, 3474, - 0, 0, 0, 0, 3509, 3522, 150, 0, 3557, 3511, - 0, 0, 150, 150, 596, 596, 596, 0, 0, 150, - 0, 0, 145, 145, 0, 0, 3505, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 3549, 0, 0, 2525, - 0, 0, 3531, 0, 1467, 0, 3536, 3516, 3507, 0, - 3114, 145, 0, 0, 3561, 3334, 0, 0, 3529, 0, - 0, 627, 3523, 0, 0, 0, 0, 0, 0, 0, - 3532, 0, 3510, 3594, 3596, 0, 2412, 3538, 0, 3513, - 0, 3545, 0, 0, 0, 0, 0, 0, 3104, 3428, - 3430, 3432, 0, 0, 0, 0, 615, 3543, 0, 0, - 0, 0, 0, 0, 0, 1542, 1422, 1421, 1431, 1432, - 1424, 1425, 1426, 1427, 1428, 1429, 1430, 1423, 0, 0, - 1433, 0, 0, 0, 0, 3582, 0, 0, 0, 0, - 0, 0, 3585, 3625, 0, 0, 3591, 0, 0, 0, - 3048, 0, 0, 0, 0, 0, 0, 0, 1492, 1492, - 1492, 1498, 1492, 1492, 1498, 1492, 1498, 1507, 1508, 1509, - 3600, 0, 3578, 3603, 0, 92, 621, 0, 0, 0, - 3586, 3602, 3623, 0, 0, 3626, 3050, 1029, 0, 0, - 0, 0, 642, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 3636, 0, 0, 0, 0, 3104, 0, 3637, - 3232, 0, 0, 1640, 0, 0, 0, 0, 0, 651, - 0, 2974, 3635, 2172, 2173, 2174, 0, 0, 0, 0, - 0, 0, 0, 3232, 3618, 1542, 3609, 3538, 1673, 3621, - 3622, 3619, 3620, 3608, 0, 0, 0, 0, 3104, 0, - 0, 1494, 1496, 0, 1500, 1502, 0, 1505, 0, 0, - 3704, 0, 0, 0, 0, 0, 1981, 1982, 1983, 1984, - 1985, 0, 1986, 0, 631, 3640, 3639, 0, 0, 0, - 3653, 0, 0, 0, 0, 3663, 0, 0, 1467, 0, - 3668, 3649, 3671, 0, 2246, 2247, 0, 0, 3684, 2472, - 3344, 0, 0, 3344, 3741, 3680, 0, 0, 0, 0, - 0, 145, 0, 0, 0, 3710, 3747, 3676, 3749, 3750, - 3751, 642, 3683, 150, 0, 3688, 3689, 0, 0, 0, - 0, 3740, 0, 3698, 0, 3701, 0, 0, 0, 0, - 0, 3708, 0, 0, 3691, 3692, 0, 0, 0, 145, - 150, 0, 0, 0, 0, 0, 0, 0, 92, 0, - 3738, 0, 0, 3343, 0, 3734, 3343, 3772, 0, 0, - 0, 0, 3739, 3742, 3737, 642, 2351, 0, 0, 0, - 1104, 0, 0, 2521, 0, 3773, 3755, 0, 150, 0, - 150, 0, 0, 3775, 1104, 0, 0, 0, 0, 1104, - 0, 3753, 0, 0, 1493, 1495, 1497, 1499, 1501, 1503, - 1504, 1506, 0, 0, 0, 0, 0, 0, 3746, 1683, - 3748, 0, 1104, 0, 2568, 1104, 0, 2102, 0, 3104, - 0, 3104, 0, 0, 0, 3756, 3811, 0, 0, 0, - 0, 3780, 0, 0, 2585, 0, 3104, 0, 0, 0, - 0, 0, 0, 0, 0, 2415, 0, 0, 0, 3802, - 3344, 0, 92, 0, 3840, 0, 3821, 0, 3800, 0, - 3801, 0, 0, 3803, 0, 0, 0, 150, 150, 642, - 3846, 0, 3627, 0, 3628, 1104, 3629, 3631, 150, 3839, - 0, 0, 0, 0, 0, 0, 92, 615, 145, 0, - 3812, 1029, 0, 0, 3857, 0, 2171, 3694, 0, 3843, - 3696, 3845, 1104, 3848, 3836, 0, 0, 3838, 2621, 0, - 2622, 0, 0, 3343, 0, 0, 3807, 0, 0, 0, - 0, 0, 92, 0, 0, 0, 0, 3104, 0, 0, - 2630, 2631, 2632, 0, 0, 3548, 2636, 2638, 0, 0, - 2641, 0, 0, 2644, 2645, 0, 0, 0, 2650, 2651, - 3917, 0, 0, 0, 2657, 2658, 2659, 0, 0, 0, - 2660, 0, 2661, 3937, 0, 0, 0, 2151, 0, 2151, - 0, 2151, 2151, 0, 0, 0, 3549, 3947, 0, 0, - 3987, 0, 3943, 0, 0, 0, 0, 2665, 2666, 2667, - 2668, 3949, 3958, 2672, 2673, 2674, 2675, 2676, 0, 3859, - 0, 3971, 2681, 2682, 2683, 2684, 2685, 2686, 2687, 2688, - 2689, 2690, 2691, 2692, 3975, 3974, 0, 3983, 3972, 92, - 0, 92, 0, 3755, 3048, 0, 0, 92, 0, 0, - 0, 2328, 0, 2330, 0, 3942, 0, 0, 0, 0, - 0, 0, 1451, 1452, 1453, 1454, 1455, 1456, 1457, 3027, - 3028, 3029, 3030, 3031, 3032, 3033, 3034, 3035, 3036, 3037, - 3050, 0, 0, 4034, 4036, 4042, 3548, 0, 3019, 0, - 0, 0, 0, 0, 4028, 150, 0, 0, 0, 0, - 150, 0, 0, 150, 150, 150, 0, 0, 4021, 0, - 4053, 4019, 4057, 0, 0, 4029, 0, 4032, 4038, 4047, - 0, 0, 0, 0, 0, 4059, 4039, 3549, 4037, 2757, - 0, 4045, 4044, 0, 2757, 2757, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 4065, 0, 0, 4031, 0, - 0, 0, 0, 0, 0, 4071, 4083, 0, 4062, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 554, - 4092, 0, 2440, 0, 4107, 0, 4096, 0, 2442, 2443, - 0, 0, 0, 0, 0, 2450, 1104, 0, 150, 4094, - 0, 0, 4106, 0, 0, 92, 1104, 1104, 92, 0, - 0, 0, 596, 0, 92, 92, 92, 92, 4098, 92, - 92, 4097, 4099, 92, 92, 0, 0, 0, 4065, 150, - 596, 1104, 4110, 4114, 0, 452, 0, 92, 3507, 4112, - 4113, 0, 0, 4005, 4124, 0, 0, 0, 596, 4014, - 3999, 0, 0, 0, 4152, 4147, 4144, 92, 0, 0, - 92, 0, 4141, 92, 0, 0, 0, 4154, 0, 4173, - 0, 0, 1104, 0, 4156, 4165, 596, 4164, 1104, 2346, - 642, 4184, 0, 4197, 596, 4163, 0, 2943, 4195, 4162, - 4175, 4161, 554, 4196, 4198, 0, 4200, 0, 0, 4202, - 1104, 1104, 0, 0, 0, 0, 0, 92, 0, 0, - 4213, 92, 0, 92, 0, 0, 4215, 92, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 4127, 92, 92, - 92, 92, 4127, 92, 0, 0, 4127, 4137, 0, 0, - 1104, 2979, 2980, 2981, 2982, 2983, 2984, 0, 0, 0, - 4143, 1104, 1104, 1104, 0, 0, 4243, 92, 4245, 92, - 0, 92, 0, 0, 0, 0, 4256, 0, 0, 4258, - 0, 0, 0, 0, 0, 0, 150, 3304, 3305, 3306, - 3307, 3308, 150, 0, 0, 0, 0, 0, 1104, 0, - 92, 4276, 0, 0, 0, 0, 92, 4118, 1390, 0, - 4120, 0, 0, 0, 92, 1029, 0, 4129, 4130, 4131, - 0, 0, 4134, 0, 0, 0, 0, 4125, 0, 1252, - 92, 145, 0, 92, 4127, 0, 4127, 0, 0, 0, - 4224, 0, 0, 92, 0, 0, 0, 2750, 0, 92, - 0, 4127, 4127, 4127, 0, 0, 4127, 0, 1104, 4169, - 0, 0, 4171, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 2722, 0, 0, 0, 0, 0, 3324, - 4127, 2730, 4127, 0, 0, 0, 150, 0, 0, 2629, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2456, - 1104, 0, 0, 0, 0, 0, 0, 0, 0, 4214, - 0, 0, 0, 4127, 2656, 0, 0, 0, 0, 3333, - 0, 0, 0, 0, 0, 0, 2466, 4127, 0, 0, - 2727, 0, 0, 4231, 0, 0, 0, 3103, 0, 0, - 452, 0, 0, 4127, 0, 0, 2757, 2757, 2757, 0, - 2757, 0, 0, 0, 0, 0, 4127, 0, 0, 0, - 0, 0, 4127, 4253, 1242, 0, 0, 0, 0, 150, - 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, - 1430, 1423, 2726, 0, 1433, 1422, 1421, 1431, 1432, 1424, - 1425, 1426, 1427, 1428, 1429, 1430, 1423, 0, 4281, 1433, - 150, 0, 0, 1998, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1104, 1104, 1104, 615, 0, 0, - 0, 596, 0, 0, 689, 4293, 0, 0, 150, 596, - 0, 0, 0, 1104, 1104, 0, 0, 0, 0, 0, - 2731, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2737, 596, 0, 1104, 0, 596, 0, 0, 0, 596, - 596, 0, 596, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 150, 150, 3283, 3284, 3285, 0, 0, 0, - 0, 0, 0, 0, 0, 2729, 452, 2757, 0, 0, - 0, 513, 0, 0, 452, 452, 452, 1104, 0, 0, - 452, 150, 1104, 3302, 0, 452, 0, 0, 1104, 0, - 0, 0, 0, 3309, 0, 0, 0, 0, 0, 1104, - 0, 0, 0, 0, 0, 1104, 3318, 3319, 3320, 0, - 1028, 0, 1104, 3325, 0, 1096, 0, 0, 0, 0, - 0, 0, 0, 0, 3335, 615, 150, 0, 0, 0, - 0, 1104, 0, 0, 0, 0, 0, 0, 1133, 0, - 0, 0, 0, 2741, 0, 0, 0, 0, 663, 3346, - 0, 0, 0, 0, 3323, 0, 0, 0, 0, 0, - 0, 2152, 0, 0, 0, 0, 0, 0, 2749, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2734, - 0, 0, 2936, 0, 0, 2938, 0, 3322, 0, 0, - 0, 0, 0, 0, 0, 0, 1467, 0, 0, 0, - 0, 146, 0, 455, 3321, 0, 0, 0, 0, 1104, - 0, 2190, 146, 1104, 2202, 2203, 2204, 2205, 2206, 2207, - 2208, 2209, 2210, 2211, 2212, 2213, 2214, 2215, 2216, 0, - 616, 0, 0, 0, 651, 0, 0, 146, 0, 0, - 3103, 2695, 2743, 0, 0, 0, 0, 0, 3103, 0, - 0, 0, 0, 0, 1030, 0, 0, 0, 146, 1097, - 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, - 1430, 1423, 0, 0, 1433, 0, 0, 2256, 2723, 146, - 0, 0, 0, 0, 3012, 0, 0, 0, 2274, 0, - 0, 455, 146, 1422, 1421, 1431, 1432, 1424, 1425, 1426, - 1427, 1428, 1429, 1430, 1423, 0, 0, 1433, 0, 2719, - 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, - 1430, 1423, 0, 0, 1433, 0, 2721, 0, 0, 0, - 0, 150, 0, 1104, 2815, 0, 0, 0, 2733, 0, - 0, 0, 1255, 1262, 1263, 1265, 1266, 1267, 0, 1269, - 1270, 3007, 1272, 1273, 1274, 2977, 1277, 0, 1280, 1281, - 1282, 1283, 1284, 1104, 0, 2842, 3006, 0, 0, 150, - 0, 0, 0, 0, 596, 0, 0, 0, 0, 0, - 0, 596, 0, 0, 1422, 1421, 1431, 1432, 1424, 1425, - 1426, 1427, 1428, 1429, 1430, 1423, 0, 452, 1433, 2720, - 2724, 2725, 2728, 0, 2732, 2735, 2736, 2738, 2739, 2740, - 2742, 2744, 2745, 2746, 2747, 2748, 0, 0, 0, 0, - 452, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 3103, 0, 0, 3567, 3568, 3569, 0, 3571, 0, - 0, 0, 0, 0, 2588, 0, 0, 1104, 0, 0, - 0, 0, 3580, 3581, 0, 3583, 0, 0, 0, 3584, - 0, 0, 0, 0, 1104, 1422, 1421, 1431, 1432, 1424, - 1425, 1426, 1427, 1428, 1429, 1430, 1423, 0, 3198, 1433, - 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, - 1430, 1423, 0, 0, 1433, 1422, 1421, 1431, 1432, 1424, - 1425, 1426, 1427, 1428, 1429, 1430, 1423, 0, 0, 1433, - 0, 0, 2968, 0, 0, 0, 0, 150, 150, 0, - 2955, 0, 0, 0, 0, 0, 0, 0, 0, 3624, - 0, 0, 0, 0, 0, 2952, 2718, 0, 0, 0, - 3103, 0, 3630, 3632, 0, 0, 0, 0, 3253, 1422, - 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, 1430, - 1423, 0, 0, 1433, 1422, 1421, 1431, 1432, 1424, 1425, - 1426, 1427, 1428, 1429, 1430, 1423, 0, 0, 1433, 0, - 0, 3103, 0, 452, 0, 0, 2757, 2757, 1104, 0, - 0, 1104, 0, 2949, 0, 0, 0, 0, 146, 0, - 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, 1428, 1429, - 1430, 1423, 0, 455, 1433, 0, 0, 2620, 0, 0, - 0, 452, 1422, 1421, 1431, 1432, 1424, 1425, 1426, 1427, - 1428, 1429, 1430, 1423, 0, 0, 1433, 0, 0, 0, - 0, 0, 3332, 0, 0, 3703, 1422, 1421, 1431, 1432, - 1424, 1425, 1426, 1427, 1428, 1429, 1430, 1423, 0, 0, - 1433, 0, 0, 0, 0, 0, 0, 0, 0, 146, - 0, 3725, 3726, 3727, 3728, 0, 0, 0, 0, 0, - 0, 3732, 3733, 0, 0, 0, 0, 0, 0, 0, - 0, 2757, 2757, 0, 452, 3127, 0, 452, 1104, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 3754, 0, 0, 0, - 0, 0, 0, 0, 0, 1104, 3159, 0, 0, 0, - 0, 0, 0, 0, 0, 3767, 3768, 3769, 0, 3770, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 3192, 0, 0, 0, 0, 0, - 616, 0, 3103, 0, 3103, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 146, 0, 0, 3103, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 616, 0, 0, 0, 0, 0, 1542, 1542, - 455, 0, 0, 0, 0, 0, 0, 0, 0, 2476, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 3816, - 3817, 3818, 3819, 0, 0, 0, 0, 3249, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3829, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 596, 0, 0, 0, 3842, 0, 3844, 0, 452, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 3103, 0, 0, 3854, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1104, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1104, 3939, 1104, 0, 1104, - 0, 0, 0, 0, 0, 0, 0, 3948, 0, 0, - 2576, 2577, 0, 0, 2579, 2580, 0, 0, 2582, 2583, - 0, 3962, 0, 0, 0, 0, 0, 3973, 0, 0, - 0, 3976, 0, 3977, 3978, 3979, 3980, 0, 0, 0, - 2527, 2528, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 452, 1467, 0, 0, 0, 0, 1104, 0, - 0, 0, 0, 3587, 3588, 3589, 3590, 0, 1104, 0, - 0, 0, 0, 0, 0, 2616, 2617, 2618, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1028, - 0, 150, 0, 0, 1028, 1554, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 2647, 2648, 2649, 0, 0, 0, 0, - 0, 0, 0, 2047, 0, 0, 2050, 2051, 2052, 0, - 2054, 2055, 0, 1104, 2056, 0, 0, 3457, 2057, 0, - 0, 2058, 4054, 0, 0, 2059, 2060, 0, 2061, 2062, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 452, 0, 0, 0, 0, 0, - 0, 0, 0, 1639, 0, 3508, 0, 0, 0, 1648, - 513, 0, 0, 0, 1104, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1648, 513, 0, 0, 1682, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 146, 0, 0, 1030, 0, 0, 0, 0, 1030, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 3721, 3724, - 0, 0, 0, 0, 0, 596, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 150, 0, 0, - 1104, 0, 0, 0, 4153, 0, 0, 0, 0, 0, - 4157, 0, 0, 0, 0, 1104, 1104, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1104, 2027, 0, 0, 0, 0, 0, 0, 0, 0, - 1634, 0, 0, 0, 0, 0, 0, 0, 146, 2049, - 0, 0, 4208, 0, 0, 2854, 0, 0, 0, 0, - 0, 0, 0, 2858, 2859, 1104, 0, 0, 0, 0, - 146, 0, 0, 146, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 455, 455, - 455, 455, 0, 0, 0, 0, 0, 0, 596, 0, - 0, 146, 146, 146, 146, 146, 0, 146, 0, 2092, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1682, - 0, 0, 0, 0, 0, 150, 0, 0, 0, 0, - 0, 0, 0, 4267, 4268, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1467, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2889, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2919, 0, 0, - 0, 0, 2925, 2926, 2927, 2928, 2929, 2930, 0, 0, - 0, 0, 0, 0, 0, 0, 2978, 0, 2092, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3001, 3002, 0, 3003, 3004, - 0, 0, 3005, 0, 0, 0, 0, 0, 0, 0, - 2092, 0, 2092, 0, 0, 2227, 0, 3724, 3014, 3015, - 3016, 616, 2228, 2088, 2092, 2092, 0, 0, 0, 0, - 0, 0, 146, 0, 146, 146, 146, 146, 0, 0, - 0, 0, 0, 0, 0, 0, 616, 0, 0, 0, - 0, 0, 1028, 0, 0, 146, 0, 0, 0, 616, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 3988, 3992, 0, 0, 0, 0, 0, 0, 0, - 4006, 0, 0, 0, 0, 0, 40, 0, 0, 0, - 1028, 146, 0, 0, 0, 0, 0, 0, 455, 0, - 66, 0, 2186, 0, 0, 0, 2092, 0, 85, 1096, - 0, 43, 0, 0, 0, 0, 0, 0, 3062, 3063, - 3064, 3065, 0, 0, 3070, 3071, 3072, 3073, 3074, 3075, - 0, 0, 3078, 3079, 3080, 3081, 3082, 3083, 3084, 3085, - 3086, 3087, 3088, 0, 3090, 3091, 3092, 3093, 3094, 0, - 3108, 0, 0, 93, 0, 0, 0, 616, 3909, 146, - 4066, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 2267, 0, 0, 0, - 3902, 0, 0, 4220, 4223, 4219, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 1682, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 146, 146, 146, 0, - 0, 0, 0, 0, 1030, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 4132, 0, 0, 0, - 2186, 0, 0, 1097, 546, 0, 540, 551, 533, 0, - 0, 0, 0, 0, 0, 0, 0, 45, 82, 51, - 50, 53, 0, 0, 0, 0, 88, 0, 0, 0, - 541, 0, 3903, 0, 0, 3286, 3287, 3288, 3289, 3290, - 3291, 3292, 3293, 3294, 0, 0, 0, 0, 0, 57, - 84, 83, 4191, 0, 0, 0, 52, 3982, 0, 0, - 0, 0, 0, 3303, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 3256, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 690, 0, 3326, 3327, 3328, 0, 0, 146, 0, 0, - 0, 0, 0, 146, 146, 0, 0, 0, 0, 0, - 146, 0, 0, 0, 0, 0, 64, 65, 0, 3905, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 3914, - 3906, 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, - 0, 0, 4257, 147, 73, 453, 74, 0, 0, 4262, - 0, 0, 0, 2501, 147, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 79, - 0, 0, 0, 0, 0, 0, 0, 0, 55, 147, - 0, 0, 0, 0, 0, 532, 531, 534, 0, 0, - 0, 0, 0, 0, 0, 539, 0, 0, 0, 0, - 147, 1098, 0, 0, 0, 0, 0, 0, 0, 0, - 3421, 0, 543, 0, 0, 0, 3370, 547, 3372, 3373, - 0, 147, 0, 3435, 0, 0, 3382, 3383, 0, 0, - 0, 0, 550, 453, 147, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 3916, 3904, - 0, 61, 62, 68, 0, 69, 0, 0, 0, 0, - 0, 0, 40, 41, 535, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 66, 0, 0, 0, - 0, 0, 0, 0, 85, 0, 0, 43, 70, 71, - 0, 0, 0, 0, 0, 67, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 538, 0, 0, 0, 0, 2481, 0, 0, - 0, 0, 0, 0, 0, 58, 0, 0, 0, 93, - 0, 2493, 0, 0, 0, 0, 2493, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 536, 537, 544, 2043, - 548, 549, 552, 0, 0, 0, 0, 0, 0, 2493, - 0, 0, 2493, 0, 555, 556, 557, 558, 559, 560, - 561, 562, 563, 564, 565, 566, 567, 568, 569, 570, - 571, 572, 573, 574, 575, 576, 577, 578, 579, 580, - 581, 582, 583, 584, 585, 586, 587, 588, 589, 590, - 591, 592, 593, 0, 146, 3535, 0, 3563, 3564, 3565, - 3566, 0, 0, 0, 0, 3570, 0, 0, 0, 3573, - 3574, 0, 2570, 0, 0, 0, 0, 0, 0, 0, - 0, 146, 0, 0, 0, 54, 56, 0, 0, 0, - 0, 81, 0, 45, 82, 51, 50, 53, 0, 2592, - 75, 0, 88, 0, 0, 0, 0, 0, 2092, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 146, - 0, 616, 0, 0, 0, 57, 84, 83, 0, 0, - 0, 0, 52, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 72, 0, 0, + 725, 93, 4516, 4485, 4466, 4417, 4454, 4453, 1160, 549, + 1417, 4094, 3, 1378, 2864, 2395, 3320, 4097, 7, 4201, + 681, 4419, 3943, 4096, 6, 4337, 4095, 5, 2863, 4128, + 27, 4098, 8, 4240, 3524, 4336, 3657, 3983, 4087, 4228, + 3356, 3945, 2323, 4089, 4227, 4061, 1601, 3938, 3180, 1386, + 3840, 2324, 698, 636, 3770, 2655, 3260, 4199, 3727, 3994, + 685, 1672, 3211, 3598, 3949, 3956, 3944, 3763, 3493, 3576, + 1716, 474, 2601, 1506, 3762, 3728, 3947, 2135, 3905, 2466, + 667, 3719, 3584, 576, 576, 621, 2846, 528, 531, 2261, + 650, 3369, 3335, 632, 93, 3090, 3781, 2485, 3680, 3686, + 1437, 2931, 2643, 3663, 2204, 665, 96, 664, 3261, 93, + 4088, 2421, 3761, 724, 3212, 1718, 3037, 471, 2875, 4241, + 3499, 3568, 1380, 3396, 2852, 1189, 2917, 789, 2127, 1535, + 2941, 3076, 1534, 3475, 2853, 3466, 3000, 2579, 2452, 124, + 1383, 1132, 2789, 2847, 1356, 2584, 1715, 2557, 2585, 1240, + 1178, 3354, 1348, 690, 684, 3143, 2427, 2812, 2412, 2190, + 672, 2583, 2517, 1721, 3585, 2128, 2192, 1050, 2112, 3187, + 1241, 1385, 1377, 2540, 2071, 1214, 2012, 1691, 2898, 1047, + 2448, 2313, 1583, 1128, 1418, 1426, 2425, 2238, 1421, 2646, + 648, 688, 1579, 1274, 2570, 1252, 1608, 2663, 1351, 1582, + 1043, 1044, 3004, 1159, 1123, 1173, 2382, 3079, 1445, 2076, + 2197, 81, 644, 657, 1363, 645, 1355, 1354, 2277, 1136, + 1353, 552, 1233, 3188, 635, 2044, 1141, 551, 2045, 2011, + 1124, 1684, 1251, 1147, 119, 534, 670, 115, 640, 4543, + 4537, 4524, 4508, 4494, 4462, 4460, 4432, 2871, 4429, 4428, + 4427, 4412, 2878, 4410, 4321, 4317, 4312, 95, 3996, 3995, + 2844, 3275, 3738, 2069, 2470, 1151, 3501, 4183, 2883, 2882, + 2504, 3347, 2503, 3881, 3733, 3734, 3731, 3732, 3317, 3318, + 3601, 654, 87, 4484, 3599, 4447, 1357, 4445, 4532, 3879, + 4483, 4446, 3737, 2879, 2824, 90, 2909, 3841, 3350, 1694, + 92, 1406, 3882, 4255, 4254, 3348, 663, 40, 4450, 2885, + 4197, 2861, 3843, 4394, 2613, 4067, 3894, 67, 642, 2862, + 1120, 2194, 544, 2501, 2929, 2004, 3349, 112, 43, 1161, + 2813, 3664, 3202, 2501, 4346, 4090, 4162, 3756, 3332, 4196, + 2191, 3666, 4066, 2821, 634, 1143, 3171, 1149, 1150, 484, + 40, 4486, 40, 3208, 3978, 3824, 4291, 3209, 3635, 40, + 1153, 2397, 2865, 3828, 3836, 3837, 3759, 3760, 3491, 3239, + 40, 3238, 3059, 3058, 94, 2814, 2325, 2337, 2335, 2334, + 2333, 2336, 2332, 2331, 2330, 2326, 2327, 2344, 2328, 2343, + 2342, 2329, 2341, 2340, 2339, 2338, 2337, 2335, 2334, 2333, + 2336, 2332, 2331, 2330, 4182, 1381, 2344, 4273, 2343, 2342, + 2889, 2341, 2340, 2339, 2338, 4017, 3208, 94, 3952, 94, + 3209, 4052, 674, 2765, 3561, 2881, 94, 1140, 2884, 3963, + 1135, 2539, 3842, 1131, 3476, 3222, 2874, 94, 1459, 1458, + 1468, 1469, 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, + 4205, 2981, 1470, 2825, 104, 102, 103, 3669, 2803, 3223, + 3224, 2802, 2075, 2831, 2804, 1164, 1165, 1166, 1167, 1168, + 1169, 1170, 1171, 1331, 1327, 3298, 1037, 2072, 2392, 2393, + 2533, 3299, 3300, 546, 1584, 128, 1585, 4202, 2073, 2074, + 2391, 4205, 523, 643, 2115, 2116, 3232, 89, 2823, 3667, + 3668, 3670, 3671, 3672, 2142, 1221, 137, 133, 134, 4200, + 135, 3789, 1365, 1368, 1369, 1370, 1366, 2876, 1367, 1372, + 3787, 94, 2647, 2648, 93, 2844, 93, 4275, 4202, 1343, + 1212, 1213, 4184, 116, 3522, 1234, 1227, 665, 2093, 1239, + 89, 1235, 89, 126, 139, 138, 1184, 1237, 1304, 89, + 1236, 1357, 4206, 1210, 543, 1211, 1212, 1213, 542, 2824, + 89, 2159, 1312, 1369, 1370, 2877, 2887, 2423, 2424, 3124, + 1341, 2687, 4483, 2538, 4446, 1271, 4444, 142, 1365, 1368, + 1369, 1370, 1366, 2438, 1367, 1372, 1222, 1223, 3782, 2437, + 3423, 2835, 630, 4206, 3023, 2428, 2431, 2430, 2442, 2432, + 3542, 3546, 3544, 1193, 1194, 2428, 4218, 1197, 2821, 2449, + 2523, 2522, 518, 541, 625, 1199, 2843, 641, 705, 3251, + 706, 708, 709, 710, 711, 627, 521, 2828, 707, 2273, + 2050, 2113, 2114, 93, 118, 1230, 140, 1349, 141, 1285, + 3880, 1195, 1196, 626, 122, 129, 624, 2980, 4531, 1325, + 1376, 1382, 1326, 4484, 4482, 4481, 1400, 1401, 93, 1185, + 93, 93, 665, 2612, 93, 625, 3144, 4447, 2122, 2121, + 623, 2924, 4219, 2120, 1198, 2119, 4340, 2118, 1308, 1309, + 1479, 1481, 1337, 1224, 1483, 2117, 3936, 3754, 3746, 1278, + 126, 3744, 3029, 2961, 2837, 3027, 2876, 4155, 1373, 3102, + 127, 130, 4353, 1336, 1332, 1333, 1334, 1335, 1338, 1339, + 1340, 1342, 4314, 631, 4352, 4315, 1498, 4316, 2825, 3102, + 1501, 1502, 1503, 1504, 1505, 4011, 1509, 2880, 2831, 1424, + 3500, 4294, 2873, 3102, 4406, 4339, 1449, 665, 1287, 3687, + 3688, 3689, 3690, 3909, 2877, 3368, 2966, 2552, 3147, 2558, + 2559, 2560, 2561, 2562, 2563, 2564, 3336, 3337, 3338, 3339, + 3340, 2816, 2270, 2823, 120, 1319, 121, 1301, 1320, 1511, + 1512, 1513, 1514, 1515, 1516, 1517, 1518, 1519, 1520, 1521, + 1522, 1523, 1524, 1525, 3600, 1528, 1529, 1531, 1531, 1531, + 2827, 1536, 1536, 1536, 1539, 1540, 1541, 1542, 1543, 1544, + 1545, 1546, 1547, 1548, 1549, 1550, 1551, 1552, 1553, 1554, + 1555, 1556, 1557, 1558, 1559, 1560, 1561, 1562, 1563, 1564, + 1565, 1566, 1567, 1568, 1392, 2534, 3342, 3844, 3030, 639, + 3028, 3231, 4313, 3601, 3845, 3714, 4157, 538, 4021, 2140, + 1375, 654, 654, 3698, 1345, 4019, 3898, 1344, 136, 2553, + 3345, 1536, 2817, 2819, 2820, 2822, 2835, 2826, 2829, 2830, + 2832, 2833, 2834, 2836, 2838, 2839, 2840, 2841, 2842, 522, + 3478, 2928, 1480, 545, 3665, 1311, 2105, 4259, 4013, 3230, + 3370, 2843, 2571, 1287, 1287, 2926, 3900, 2141, 3681, 3876, + 2546, 152, 2828, 472, 483, 2486, 3684, 152, 4220, 2143, + 3696, 2890, 152, 4065, 4267, 3428, 2876, 4253, 3682, 3683, + 131, 3934, 618, 618, 4540, 2876, 1530, 1532, 1533, 2860, + 152, 4510, 3847, 4539, 1537, 1538, 4509, 152, 4407, 3022, + 4290, 3895, 666, 4203, 1536, 1536, 143, 3827, 4053, 2930, + 1403, 4506, 1403, 1403, 3964, 1192, 1403, 4425, 152, 1134, + 1187, 4470, 3846, 2075, 2877, 1408, 1408, 2872, 1402, 2837, + 1407, 1407, 1409, 2877, 1414, 3826, 1371, 1279, 4309, 152, + 618, 1359, 1134, 4181, 4203, 666, 117, 82, 1346, 2073, + 2074, 472, 152, 1569, 666, 3753, 3151, 3150, 3152, 3149, + 2815, 1427, 105, 2051, 3156, 666, 3148, 3145, 1231, 1451, + 3146, 2892, 3154, 2451, 2434, 3745, 1186, 4414, 2271, 2272, + 1294, 2435, 4307, 4308, 4156, 1371, 3153, 1238, 4338, 3743, + 3477, 3479, 3480, 3481, 1286, 705, 2816, 706, 708, 709, + 710, 711, 1371, 3155, 3157, 707, 2273, 529, 1572, 132, + 4012, 3049, 3333, 1321, 4265, 532, 3040, 1507, 3336, 3337, + 3338, 3339, 3340, 3416, 3498, 2827, 3767, 1229, 1442, 1443, + 1441, 3093, 3092, 4176, 4044, 3092, 1570, 1571, 3330, 3029, + 1360, 3027, 1292, 3873, 3984, 3298, 1037, 1444, 3289, 3290, + 3292, 3299, 3300, 3291, 3293, 3294, 3078, 1689, 1209, 3086, + 3088, 3087, 4423, 533, 4418, 3080, 3872, 3871, 3295, 3296, + 3297, 4018, 3897, 3870, 1050, 1527, 3344, 3869, 1679, 1050, + 4421, 2927, 1699, 1700, 1698, 3867, 1148, 2817, 2819, 2820, + 2822, 3868, 2826, 2829, 2830, 2832, 2833, 2834, 2836, 2838, + 2839, 2840, 2841, 2842, 126, 3877, 1293, 1297, 1289, 1442, + 1443, 1441, 1254, 1255, 1256, 1257, 1258, 1259, 1260, 1261, + 1262, 1263, 1264, 1265, 126, 3430, 3431, 4002, 1444, 576, + 1693, 4006, 4007, 2480, 2481, 130, 4223, 4224, 3158, 2270, + 1290, 1291, 2476, 1664, 1665, 1666, 1667, 1668, 4285, 576, + 1717, 4092, 2169, 1145, 1144, 3494, 3495, 4166, 1593, 1206, + 1207, 1576, 2949, 2950, 1288, 1295, 1296, 1298, 1299, 1300, + 2077, 1302, 1303, 2475, 1305, 1306, 1307, 3429, 1310, 1148, + 1313, 1314, 1315, 1316, 1317, 2014, 1146, 1674, 1225, 1208, + 1692, 1205, 1204, 1587, 1203, 1697, 4263, 1598, 1588, 530, + 3497, 3467, 527, 4085, 3468, 2004, 3469, 2079, 2046, 93, + 2078, 2008, 2008, 2008, 2008, 3720, 3721, 1725, 4533, 4520, + 1234, 4296, 3019, 1723, 1135, 2815, 1235, 4295, 2418, 3007, + 1135, 530, 1237, 3017, 3007, 1236, 3016, 3265, 3402, 1397, + 1398, 2487, 4546, 1670, 3081, 1669, 128, 1573, 1574, 1388, + 1390, 4541, 4525, 4497, 1142, 1397, 1398, 4430, 1162, 4161, + 3039, 2039, 576, 1391, 643, 4035, 1283, 3928, 3417, 3418, + 3419, 1374, 3752, 3749, 3496, 3366, 3024, 152, 2960, 1391, + 2956, 2934, 1706, 2933, 2015, 2547, 530, 530, 2110, 1399, + 1704, 1702, 472, 1232, 2469, 4420, 4422, 2103, 1139, 2027, + 2177, 2028, 2029, 2030, 2176, 1399, 2175, 1388, 1390, 2420, + 2034, 1138, 2066, 3082, 2017, 1388, 1390, 113, 3931, 3361, + 2042, 1358, 1152, 1388, 1390, 2086, 2006, 2010, 469, 3091, + 3735, 1594, 650, 650, 650, 650, 1416, 2002, 4318, 3521, + 2420, 2498, 1595, 1688, 1675, 1680, 2497, 93, 1678, 1695, + 152, 1687, 3221, 1382, 2031, 2171, 2033, 1696, 665, 1485, + 1486, 2129, 2488, 2958, 665, 2109, 2170, 2957, 2809, 1713, + 1484, 2420, 4174, 1384, 1714, 94, 4016, 113, 1482, 2704, + 2681, 1389, 2013, 2576, 94, 2271, 2272, 2064, 93, 2019, + 2020, 2132, 1282, 2502, 3264, 2162, 108, 2161, 4518, 2084, + 2145, 4519, 2737, 4517, 2734, 3401, 129, 2174, 2477, 1487, + 2172, 2387, 1459, 1458, 1468, 1469, 1461, 1462, 1463, 1464, + 1465, 1466, 1467, 1460, 2207, 2048, 1470, 2047, 1487, 1597, + 2397, 2052, 1500, 2420, 1499, 3038, 1450, 1269, 1226, 1389, + 2108, 152, 1175, 3015, 111, 1487, 2146, 1389, 1460, 2057, + 2058, 1470, 93, 2060, 2993, 1389, 2149, 3647, 152, 2419, + 2081, 3279, 2228, 665, 2123, 2124, 2420, 2799, 4034, 2063, + 4033, 1470, 3363, 2041, 152, 2085, 2269, 2274, 1449, 2082, + 1509, 650, 472, 2018, 4042, 110, 1484, 3729, 3736, 3803, + 2419, 665, 1725, 2170, 2266, 3030, 2268, 3007, 2233, 2104, + 3028, 1135, 2107, 3015, 3008, 2418, 3006, 89, 2790, 2037, + 2518, 2280, 2282, 2263, 2262, 2678, 2168, 2003, 3648, 2136, + 3048, 2419, 3280, 654, 654, 654, 654, 3013, 3007, 2173, + 3388, 3387, 3010, 4323, 3039, 3009, 3014, 2239, 3006, 2139, + 2137, 3047, 2125, 2138, 654, 650, 3046, 2147, 2148, 3884, + 2150, 2299, 2302, 2345, 2346, 3045, 2420, 2160, 3044, 2315, + 1507, 3043, 2989, 2988, 4286, 4287, 3042, 89, 2214, 2996, + 2317, 2607, 2995, 3041, 2396, 2264, 1485, 1486, 1485, 1486, + 2675, 2986, 2985, 2419, 2227, 2996, 3885, 2607, 2995, 3013, + 3007, 663, 3389, 2672, 3010, 4283, 4284, 3009, 3014, 1345, + 2806, 2805, 1594, 644, 2610, 2608, 2603, 4070, 4069, 2402, + 2605, 2212, 1050, 1595, 4324, 2240, 2419, 1191, 2200, 1215, + 2610, 2608, 2603, 3007, 2990, 2224, 2605, 1135, 1217, 1444, + 3008, 2418, 1463, 1464, 1465, 1466, 1467, 1460, 4081, 1725, + 1470, 2976, 1128, 2987, 2975, 2233, 2512, 2974, 1349, 2404, + 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 2997, 2998, + 1470, 2245, 2807, 1201, 2604, 2606, 2609, 2611, 3173, 1442, + 1443, 1441, 654, 2348, 2997, 2998, 2243, 2244, 2242, 2973, + 2604, 2606, 2609, 2611, 2495, 2353, 1441, 2355, 1444, 2409, + 2283, 2284, 2285, 2286, 2287, 2972, 2381, 2205, 2206, 2728, + 4229, 2727, 4356, 1444, 4355, 2417, 2419, 1443, 1441, 3038, + 4500, 4467, 4499, 3033, 2311, 2971, 2970, 2379, 2314, 1190, + 3036, 1442, 1443, 1441, 1216, 1444, 2567, 2566, 2062, 674, + 1219, 2403, 1245, 2216, 2217, 2218, 654, 2433, 2436, 1155, + 1444, 2439, 2440, 2441, 2493, 2494, 2458, 2459, 2460, 2461, + 2462, 2513, 2389, 2388, 2385, 1154, 2394, 4523, 4496, 1442, + 1443, 1441, 4408, 4357, 1442, 1443, 1441, 4527, 1202, 2454, + 2455, 2456, 2457, 2408, 2479, 2406, 2429, 2314, 1444, 2750, + 2932, 2463, 1682, 1444, 1442, 1443, 1441, 2445, 2446, 2447, + 4347, 1442, 1443, 1441, 2267, 4529, 1442, 1443, 1441, 3697, + 2468, 1507, 4476, 1444, 4359, 3691, 1228, 2294, 2295, 2450, + 1444, 4375, 4229, 2954, 4303, 1444, 4302, 1442, 1443, 1441, + 3102, 2198, 2290, 2291, 2292, 4306, 2904, 2183, 2296, 2465, + 2298, 2301, 2304, 3273, 2309, 2310, 1444, 2185, 4534, 3755, + 2320, 2055, 1442, 1443, 1441, 1442, 1443, 1441, 152, 4229, + 2471, 3764, 2473, 2347, 4388, 2349, 2350, 1134, 4385, 1438, + 2354, 1444, 2356, 2357, 1444, 2184, 4514, 4258, 2362, 2363, + 2364, 2365, 2366, 2367, 2368, 2369, 2370, 2371, 2372, 2373, + 2729, 4215, 4159, 2213, 4153, 2401, 1468, 1469, 1461, 1462, + 1463, 1464, 1465, 1466, 1467, 1460, 2087, 4535, 1470, 2090, + 2091, 2092, 2198, 2094, 2095, 4545, 2179, 2096, 2701, 2702, + 2703, 2097, 4152, 4387, 2098, 2182, 2181, 4384, 2099, 2100, + 2054, 2101, 2102, 1459, 1458, 1468, 1469, 1461, 1462, 1463, + 1464, 1465, 1466, 1467, 1460, 4154, 4345, 1470, 4082, 472, + 1442, 1443, 1441, 2187, 2180, 2209, 1134, 152, 3175, 1442, + 1443, 1441, 94, 2189, 3979, 3628, 3626, 618, 618, 1444, + 3484, 3482, 618, 4544, 2241, 2464, 3627, 4528, 1444, 152, + 2210, 3483, 152, 2211, 2220, 2222, 2223, 618, 618, 4014, + 3892, 2188, 2221, 152, 3086, 3088, 3087, 472, 472, 472, + 472, 1416, 3891, 3890, 2178, 1416, 3889, 2375, 3114, 3632, + 3170, 2322, 152, 152, 152, 152, 152, 3883, 152, 3705, + 4511, 1531, 1458, 1468, 1469, 1461, 1462, 1463, 1464, 1465, + 1466, 1467, 1460, 152, 152, 1470, 3655, 3654, 618, 3441, + 4015, 2186, 3382, 3381, 152, 1459, 1458, 1468, 1469, 1461, + 1462, 1463, 1464, 1465, 1466, 1467, 1460, 3380, 3379, 1470, + 3086, 3088, 3087, 2529, 1459, 1458, 1468, 1469, 1461, 1462, + 1463, 1464, 1465, 1466, 1467, 1460, 3322, 3276, 1470, 2903, + 1454, 2901, 1457, 2888, 1277, 1276, 4505, 1134, 4434, 1471, + 1472, 1473, 1474, 1475, 1476, 1477, 1357, 1455, 1456, 1453, + 618, 618, 618, 4426, 4319, 1134, 2537, 1376, 1459, 1458, + 1468, 1469, 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, + 3111, 3630, 1470, 4300, 1459, 1458, 1468, 1469, 1461, 1462, + 1463, 1464, 1465, 1466, 1467, 1460, 618, 2514, 1470, 3108, + 4299, 618, 618, 4246, 650, 1350, 98, 4245, 4239, 2661, + 2520, 2510, 4238, 4020, 3488, 3911, 2667, 2668, 2669, 3486, + 2741, 152, 152, 2516, 3567, 152, 3420, 1134, 3346, 2944, + 4242, 2943, 3086, 3088, 3087, 2524, 152, 618, 2509, 152, + 152, 152, 152, 2508, 2265, 2056, 2049, 1712, 100, 1711, + 106, 152, 1683, 1681, 1272, 540, 2657, 1249, 4344, 4341, + 152, 4276, 1705, 4272, 152, 3086, 3088, 3087, 2666, 2705, + 3086, 3088, 3087, 4256, 4191, 4185, 1481, 1481, 1481, 1248, + 4084, 4083, 4010, 2642, 1416, 4009, 3990, 1318, 3935, 2228, + 3899, 3866, 3835, 3834, 3799, 2544, 3758, 2528, 3757, 3704, + 3703, 3702, 1424, 1424, 2536, 3701, 3694, 3693, 1038, 1039, + 1040, 3692, 3653, 3650, 3629, 3624, 3618, 152, 2551, 1725, + 1137, 2554, 2660, 3616, 472, 2233, 2658, 3612, 3611, 2591, + 2543, 3610, 3485, 3474, 1459, 1458, 1468, 1469, 1461, 1462, + 1463, 1464, 1465, 1466, 1467, 1460, 3465, 3463, 1470, 1416, + 3459, 3458, 1416, 3457, 2699, 2700, 3385, 2573, 654, 2572, + 1134, 3378, 1134, 3377, 3376, 1134, 3305, 3123, 3122, 3120, + 2991, 2899, 1134, 2808, 1497, 1496, 1495, 1134, 1134, 2651, + 2535, 3778, 2507, 2059, 2665, 3910, 152, 2731, 152, 2680, + 1416, 4049, 1416, 3504, 4398, 654, 2239, 3638, 4329, 1459, + 1458, 1468, 1469, 1461, 1462, 1463, 1464, 1465, 1466, 1467, + 1460, 2403, 3859, 1470, 3504, 1416, 3918, 1416, 3638, 4262, + 3638, 4163, 3858, 650, 3638, 3999, 650, 3504, 3998, 2691, + 2689, 2690, 1459, 1458, 1468, 1469, 1461, 1462, 1463, 1464, + 1465, 1466, 1467, 1460, 3504, 3993, 1470, 3932, 1416, 2713, + 3324, 152, 152, 152, 3308, 3777, 3504, 3903, 3102, 1416, + 2575, 1416, 3504, 3774, 2004, 3717, 3307, 2706, 2707, 2708, + 2709, 3776, 2004, 3716, 2240, 3638, 3637, 2717, 1134, 3504, + 3503, 3315, 3314, 3311, 3312, 3311, 3310, 2680, 1416, 3306, + 1050, 2549, 2548, 1283, 3564, 2288, 2531, 2383, 2794, 1725, + 2004, 2383, 2288, 1416, 2942, 1723, 1459, 1458, 1468, 1469, + 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 2163, 1416, + 1470, 2321, 1459, 1458, 1468, 1469, 1461, 1462, 1463, 1464, + 1465, 1466, 1467, 1460, 2749, 2942, 1470, 1600, 1599, 3569, + 97, 2792, 3588, 2855, 2858, 1459, 1458, 1468, 1469, 1461, + 1462, 1463, 1464, 1465, 1466, 1467, 1460, 3208, 2384, 1470, + 2386, 3209, 2384, 2793, 2004, 1427, 2163, 2484, 576, 2948, + 1323, 1322, 2202, 152, 1281, 4478, 3588, 2288, 94, 152, + 152, 618, 618, 618, 2163, 1280, 152, 3563, 1281, 2851, + 2818, 2854, 4192, 1670, 1692, 2795, 4063, 3588, 2796, 2680, + 2501, 3812, 3102, 3504, 2163, 3325, 3313, 3121, 2008, 1587, + 2969, 2483, 2936, 2800, 654, 2764, 2766, 654, 2390, 2797, + 2758, 2757, 2772, 2773, 2774, 2775, 2891, 2893, 2201, 2810, + 2680, 2894, 2895, 1283, 2896, 2897, 2659, 2565, 1459, 1458, + 1468, 1469, 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, + 2723, 2061, 1470, 2506, 2500, 2203, 1347, 2129, 2983, 2106, + 2070, 2004, 1703, 2900, 2718, 2719, 2720, 2721, 2722, 1701, + 1581, 94, 2902, 4293, 2656, 4164, 2751, 4029, 3914, 3656, + 3646, 3643, 2946, 2426, 2453, 2428, 3095, 2132, 2979, 2978, + 2449, 2845, 2747, 2647, 2648, 548, 1287, 2478, 2444, 2443, + 1673, 2925, 3554, 1268, 2467, 3706, 2519, 1182, 1181, 4513, + 4512, 4491, 4489, 3109, 4480, 4479, 3112, 4455, 4448, 3115, + 4442, 4440, 4390, 2940, 4389, 3769, 3765, 3569, 3323, 2939, + 2938, 2945, 2922, 2905, 2962, 2650, 2644, 3097, 2080, 650, + 3553, 1708, 2968, 1324, 1284, 3005, 2158, 2654, 3104, 3105, + 3106, 2157, 2955, 3099, 2653, 3077, 1431, 2959, 3085, 1432, + 2652, 3001, 3012, 2228, 3011, 3018, 2152, 3021, 2151, 3116, + 517, 620, 2999, 2550, 2977, 3034, 3032, 2155, 2153, 4248, + 4281, 2982, 2156, 2154, 2994, 4195, 3132, 3125, 1431, 1434, + 1429, 1432, 4031, 1725, 1436, 1435, 2688, 1433, 2696, 2233, + 2695, 3969, 3750, 3726, 3641, 3410, 3181, 3409, 1459, 1458, + 1468, 1469, 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, + 3304, 1434, 1470, 4249, 3303, 3302, 1436, 1435, 2859, 1433, + 3205, 3210, 2850, 519, 520, 650, 4055, 4058, 4190, 4189, + 3950, 665, 3948, 3204, 4005, 4004, 1459, 1458, 1468, 1469, + 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 3159, 3902, + 1470, 3161, 539, 2527, 3100, 2526, 2053, 3026, 3127, 3886, + 3887, 1419, 3025, 3386, 3742, 3606, 3421, 3278, 3103, 2577, + 1596, 1266, 152, 4471, 1420, 3119, 1250, 3117, 1247, 1246, + 1188, 3132, 3921, 3213, 3172, 3920, 1357, 2205, 2206, 3206, + 3130, 3804, 1243, 1244, 3215, 3133, 3699, 3351, 2472, 1707, + 152, 3129, 3274, 3134, 1374, 3700, 4193, 4158, 3906, 3286, + 3658, 3645, 2907, 2126, 2278, 3160, 1242, 2279, 1329, 2055, + 654, 2054, 1412, 1410, 1404, 1413, 1411, 1405, 2694, 3281, + 1134, 4363, 4362, 4361, 3863, 2569, 2693, 3263, 152, 1349, + 152, 1220, 668, 4278, 1134, 4277, 4187, 4076, 3258, 1134, + 4059, 3085, 4022, 3169, 3217, 3968, 3219, 3220, 3527, 3785, + 3226, 3285, 669, 97, 3784, 576, 3341, 3267, 3268, 3269, + 2942, 3270, 1134, 4493, 4492, 1134, 4320, 3189, 3190, 3191, + 3192, 3193, 3194, 3195, 3196, 3197, 3198, 3199, 2818, 3168, + 2911, 2912, 2913, 4493, 3373, 3326, 2967, 3218, 2965, 3094, + 2964, 3225, 3096, 2759, 2738, 3257, 2735, 2698, 2555, 2032, + 1439, 1180, 1179, 1507, 4492, 4072, 654, 3301, 2199, 2463, + 658, 3182, 3183, 3184, 3185, 3186, 662, 661, 4378, 3207, + 152, 152, 99, 3272, 64, 3353, 3266, 3403, 4247, 1134, + 4111, 61, 152, 4113, 22, 4112, 21, 4114, 23, 4115, + 24, 674, 4109, 17, 4108, 16, 3343, 4107, 15, 4110, + 18, 1, 3283, 3284, 4106, 14, 1134, 1459, 1458, 1468, + 1469, 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 3309, + 4180, 1470, 4100, 10, 4135, 38, 4133, 36, 4132, 35, + 652, 3321, 3398, 4131, 31, 4130, 30, 4129, 29, 4126, + 26, 46, 3174, 1459, 1458, 1468, 1469, 1461, 1462, 1463, + 1464, 1465, 1466, 1467, 1460, 4125, 25, 1470, 3399, 2545, + 3492, 3357, 4105, 13, 3398, 3359, 3360, 4102, 12, 4101, + 11, 2661, 2088, 3362, 4099, 9, 575, 3367, 3679, 3678, + 3685, 3371, 3372, 3331, 3374, 3334, 2923, 3375, 4175, 4043, + 3695, 1690, 3875, 1158, 2482, 1273, 4188, 4054, 4056, 3383, + 3384, 3662, 3661, 2916, 2915, 1267, 3502, 3464, 2591, 3390, + 3085, 2532, 3400, 2999, 2068, 3002, 1415, 3003, 2496, 2992, + 1670, 4074, 3525, 3405, 3406, 3407, 3432, 2568, 2111, 2556, + 3412, 3413, 1330, 3415, 2405, 2410, 3823, 3597, 3977, 3596, + 3520, 3595, 3559, 2811, 1122, 107, 2511, 3433, 1200, 492, + 3438, 2407, 3452, 2869, 3454, 4057, 1270, 2868, 2886, 2422, + 1352, 3831, 2867, 2866, 4160, 2870, 1605, 3470, 3471, 3472, + 1603, 1604, 1602, 1607, 1606, 497, 3577, 3490, 1589, 4233, + 3566, 1440, 717, 3411, 3505, 152, 125, 665, 3035, 3573, + 152, 628, 629, 152, 152, 152, 3424, 114, 3426, 123, + 499, 3528, 1478, 2692, 2801, 1048, 1049, 1041, 2683, 3439, + 4068, 3442, 3506, 3444, 3446, 3448, 3450, 2129, 3951, 2849, + 4060, 4222, 1425, 3572, 2857, 2857, 3953, 3783, 3526, 2748, + 3636, 3455, 3456, 3213, 3358, 3571, 1526, 2312, 3462, 687, + 2167, 3583, 1392, 3802, 3215, 3955, 3473, 2132, 2219, 701, + 700, 3487, 3489, 699, 696, 697, 4204, 2208, 3541, 3201, + 1531, 1531, 1531, 1536, 1536, 1536, 1539, 1540, 1541, 1536, + 1536, 1536, 3200, 3649, 3203, 1134, 1452, 152, 3531, 3532, + 3533, 3534, 3535, 3316, 1328, 1134, 1134, 3617, 676, 1396, + 3085, 618, 1395, 3570, 3593, 1394, 1393, 1387, 647, 2376, + 2953, 3537, 3538, 3539, 3575, 3540, 1364, 1362, 152, 618, + 1134, 3543, 3587, 3545, 472, 1361, 1709, 1577, 2649, 3594, + 2645, 3589, 3590, 3591, 3592, 1379, 646, 618, 651, 3602, + 3603, 3604, 42, 2697, 1218, 1430, 3560, 3962, 101, 660, + 659, 671, 3271, 3453, 3674, 3675, 3676, 3620, 3621, 3622, + 3619, 1134, 28, 20, 3625, 618, 19, 1134, 3634, 3525, + 3642, 1176, 2582, 618, 2602, 3709, 3707, 1156, 44, 50, + 49, 47, 48, 2910, 2474, 4232, 4416, 1253, 3586, 4433, + 4465, 37, 34, 1134, 1134, 33, 32, 4127, 4121, 1530, + 1532, 1533, 4120, 4123, 3659, 4122, 1537, 1538, 4119, 3652, + 4124, 1569, 1570, 1571, 4118, 4117, 4116, 3135, 4134, 4104, + 4103, 3608, 3609, 4400, 3722, 3723, 4399, 4, 3615, 3639, + 3640, 3677, 3673, 91, 3711, 88, 3623, 3398, 39, 3713, + 109, 1119, 3631, 3633, 2, 0, 1459, 1458, 1468, 1469, + 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 3084, 3724, + 1470, 0, 3398, 0, 0, 3708, 0, 0, 0, 0, + 0, 0, 0, 0, 1134, 0, 0, 3562, 0, 0, + 0, 0, 0, 0, 0, 1134, 1134, 1134, 3552, 0, + 3005, 0, 3741, 3712, 3747, 0, 0, 0, 0, 3718, + 3715, 3771, 3773, 3780, 0, 3725, 3001, 3012, 0, 3011, + 152, 0, 0, 0, 0, 0, 152, 0, 0, 0, + 0, 0, 1134, 0, 3739, 0, 0, 0, 0, 0, + 3748, 0, 0, 3772, 3730, 0, 0, 0, 0, 0, + 0, 0, 0, 3132, 0, 0, 0, 3525, 3525, 0, + 3085, 0, 0, 3786, 3788, 3809, 0, 0, 3577, 0, + 0, 3751, 0, 650, 0, 0, 3814, 0, 0, 665, + 0, 664, 0, 0, 0, 0, 0, 0, 3825, 0, + 0, 0, 3768, 1134, 0, 0, 0, 0, 0, 0, + 0, 0, 3766, 0, 1459, 1458, 1468, 1469, 1461, 1462, + 1463, 1464, 1465, 1466, 1467, 1460, 3806, 0, 1470, 0, + 0, 0, 152, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 3808, 0, 3855, 1134, 0, 3213, + 0, 0, 0, 0, 0, 0, 0, 0, 93, 0, + 3215, 0, 0, 0, 0, 0, 0, 0, 0, 665, + 0, 3861, 0, 0, 3822, 3862, 0, 0, 0, 0, + 0, 3084, 3832, 472, 3853, 3085, 0, 3856, 2857, 2857, + 2857, 0, 2857, 3805, 3816, 3829, 0, 472, 0, 3813, + 3263, 0, 0, 3817, 0, 644, 0, 0, 0, 0, + 0, 0, 152, 3860, 3085, 0, 0, 0, 3263, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3851, 3852, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 152, 3849, 3850, 0, 3848, 3839, 3838, + 0, 0, 0, 0, 0, 0, 3930, 1134, 1134, 1134, + 0, 0, 3864, 0, 618, 0, 3865, 0, 0, 0, + 0, 152, 618, 0, 654, 0, 1134, 1134, 3878, 0, + 3874, 0, 0, 0, 3893, 3888, 0, 0, 0, 0, + 0, 0, 3908, 0, 618, 3896, 1134, 0, 618, 0, + 0, 0, 618, 618, 3907, 618, 3904, 3901, 0, 0, + 3809, 3973, 3915, 3916, 0, 3551, 152, 152, 0, 0, + 0, 3922, 665, 0, 3972, 3939, 0, 3981, 3982, 0, + 3923, 0, 3924, 0, 3912, 3913, 0, 0, 472, 2857, + 0, 0, 0, 0, 0, 0, 472, 472, 472, 472, + 1134, 0, 0, 1134, 472, 472, 1134, 472, 0, 2164, + 2165, 2166, 3970, 0, 3937, 0, 1134, 0, 1134, 0, + 472, 472, 1134, 152, 472, 0, 0, 0, 4000, 1134, + 3971, 1134, 1134, 1134, 1134, 1134, 1134, 0, 0, 0, + 3987, 0, 3925, 0, 3927, 3974, 3929, 3976, 0, 4001, + 3084, 4003, 0, 0, 0, 0, 0, 1428, 0, 3967, + 0, 3818, 3819, 3820, 3821, 0, 3988, 0, 0, 3085, + 3985, 1459, 1458, 1468, 1469, 1461, 1462, 1463, 1464, 1465, + 1466, 1467, 1460, 1134, 0, 1470, 0, 0, 0, 0, + 1134, 0, 0, 4008, 0, 0, 0, 0, 0, 0, + 0, 4040, 0, 0, 152, 0, 0, 0, 0, 1134, + 0, 146, 0, 0, 0, 0, 0, 516, 0, 0, + 0, 4027, 146, 0, 3577, 536, 3263, 4025, 4075, 0, + 0, 4024, 0, 0, 4080, 665, 4026, 4073, 2289, 4037, + 637, 0, 4050, 0, 4030, 4028, 2293, 146, 0, 0, + 0, 0, 93, 0, 93, 0, 4041, 4039, 675, 0, + 3085, 0, 0, 665, 1058, 4091, 0, 0, 146, 0, + 0, 0, 4078, 0, 0, 0, 0, 0, 2351, 2352, + 0, 0, 0, 0, 0, 2358, 2359, 2360, 2361, 146, + 0, 93, 4071, 1134, 0, 0, 0, 0, 1134, 0, + 0, 0, 146, 0, 2374, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 3771, 0, 0, 0, 0, + 0, 0, 4036, 0, 0, 0, 4151, 0, 0, 0, + 3084, 0, 0, 0, 0, 0, 4165, 0, 0, 0, + 0, 3263, 0, 0, 0, 0, 0, 3772, 0, 4177, + 0, 0, 0, 0, 0, 0, 3954, 3957, 4221, 4173, + 4225, 4171, 0, 0, 0, 0, 4179, 0, 0, 4186, + 0, 4214, 0, 4093, 4168, 0, 0, 0, 4207, 4194, + 0, 0, 0, 3213, 4210, 4208, 1507, 3113, 0, 3987, + 4211, 0, 0, 93, 3215, 93, 4217, 0, 0, 0, + 0, 93, 0, 0, 0, 0, 0, 0, 0, 0, + 4172, 152, 0, 1134, 0, 0, 1459, 1458, 1468, 1469, + 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 4243, 4169, + 1470, 4237, 0, 0, 4252, 4274, 0, 0, 0, 4266, + 0, 0, 0, 1134, 3181, 4268, 0, 3771, 0, 152, + 0, 0, 4260, 0, 618, 0, 678, 0, 0, 0, + 0, 618, 0, 0, 0, 0, 4257, 0, 0, 0, + 4282, 4261, 0, 0, 0, 4270, 3263, 4288, 4271, 3772, + 0, 4269, 0, 472, 0, 0, 0, 0, 4279, 4298, + 0, 0, 4280, 0, 0, 0, 0, 0, 472, 0, + 0, 0, 0, 0, 0, 0, 0, 4264, 472, 0, + 0, 0, 0, 0, 4331, 4297, 0, 4304, 576, 4328, + 4322, 4301, 0, 0, 0, 472, 4343, 0, 0, 0, + 4310, 0, 0, 0, 4332, 0, 0, 0, 0, 0, + 1507, 4349, 0, 0, 0, 0, 0, 4342, 0, 0, + 0, 4330, 0, 0, 93, 0, 0, 93, 0, 0, + 0, 0, 0, 93, 93, 93, 93, 4334, 93, 93, + 4333, 0, 93, 93, 0, 4335, 0, 0, 0, 4350, + 3084, 4348, 0, 93, 4351, 4354, 0, 4358, 0, 3525, + 4360, 4304, 1134, 0, 0, 4364, 0, 4369, 4370, 4371, + 0, 4397, 4374, 4365, 0, 0, 0, 93, 0, 1134, + 93, 4391, 4383, 93, 0, 0, 4393, 4395, 4379, 0, + 0, 0, 4405, 4386, 665, 0, 4415, 146, 4404, 2396, + 4424, 4403, 0, 4413, 4402, 3957, 4401, 576, 4436, 0, + 4409, 0, 0, 4411, 4435, 0, 0, 0, 0, 4439, + 0, 0, 0, 0, 0, 0, 4441, 93, 0, 4443, + 152, 93, 0, 93, 0, 0, 4456, 93, 4459, 152, + 152, 0, 0, 0, 0, 0, 0, 0, 93, 93, + 93, 93, 4367, 93, 0, 0, 0, 4367, 0, 0, + 4457, 4367, 4377, 0, 0, 3084, 0, 0, 0, 0, + 146, 0, 4382, 0, 0, 0, 0, 0, 4226, 4230, + 4488, 93, 4490, 93, 4475, 93, 0, 4244, 0, 0, + 4501, 0, 0, 0, 3084, 4503, 472, 0, 0, 2857, + 2857, 1134, 0, 0, 1134, 0, 0, 0, 0, 0, + 0, 4515, 0, 0, 472, 93, 4521, 0, 4498, 0, + 0, 93, 0, 0, 0, 0, 0, 0, 0, 93, + 1459, 1458, 1468, 1469, 1461, 1462, 1463, 1464, 1465, 1466, + 1467, 1460, 0, 2521, 1470, 93, 0, 512, 93, 0, + 4367, 0, 4367, 0, 4526, 0, 4468, 718, 93, 0, + 0, 637, 0, 0, 93, 0, 0, 4367, 4367, 4367, + 0, 4305, 4367, 0, 0, 0, 0, 0, 146, 0, + 0, 4538, 0, 2857, 2857, 0, 0, 1134, 0, 0, + 0, 0, 0, 0, 637, 0, 1058, 0, 0, 0, + 4367, 0, 4367, 0, 0, 0, 472, 1134, 472, 0, + 472, 149, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 149, 0, 0, 0, 0, 0, 0, 2574, + 0, 0, 0, 0, 4367, 0, 0, 0, 1134, 0, + 0, 0, 0, 0, 0, 0, 0, 149, 4367, 0, + 0, 0, 0, 485, 0, 0, 0, 0, 4372, 0, + 0, 0, 0, 0, 4367, 0, 0, 0, 149, 1130, + 0, 0, 2662, 0, 0, 0, 0, 4367, 0, 0, + 0, 0, 0, 4367, 0, 0, 0, 3110, 0, 149, + 0, 0, 2679, 0, 0, 0, 0, 0, 0, 3084, + 488, 0, 149, 0, 3107, 0, 0, 0, 0, 498, + 510, 511, 0, 0, 0, 4431, 1459, 1458, 1468, 1469, + 1461, 1462, 1463, 1464, 1465, 1466, 1467, 1460, 0, 0, + 1470, 0, 0, 1459, 1458, 1468, 1469, 1461, 1462, 1463, + 1464, 1465, 1466, 1467, 1460, 0, 494, 1470, 500, 496, + 0, 0, 505, 506, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 618, 0, 0, 2715, 0, 2716, + 0, 0, 472, 0, 0, 0, 0, 0, 0, 0, + 507, 0, 0, 653, 0, 0, 472, 0, 0, 152, + 3084, 0, 2724, 2725, 2726, 0, 0, 0, 2730, 0, + 2733, 0, 0, 2736, 0, 0, 2739, 2740, 0, 4502, + 1134, 2745, 2746, 0, 0, 0, 4507, 2752, 2753, 2754, + 0, 0, 2755, 0, 2756, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 145, 0, 1134, + 0, 0, 0, 502, 0, 0, 0, 0, 526, 2760, + 2761, 2762, 2763, 0, 0, 2767, 2768, 2769, 2770, 2771, + 0, 0, 503, 0, 2776, 2777, 2778, 2779, 2780, 2781, + 2782, 2783, 2784, 2785, 2786, 2787, 0, 2788, 0, 0, + 0, 0, 0, 0, 0, 0, 2732, 472, 0, 0, + 0, 0, 0, 472, 1121, 1459, 1458, 1468, 1469, 1461, + 1462, 1463, 1464, 1465, 1466, 1467, 1460, 1134, 0, 1470, + 0, 0, 0, 0, 0, 1157, 1488, 1489, 1490, 1491, + 1492, 1493, 1494, 2714, 0, 0, 0, 0, 1174, 0, + 0, 0, 0, 495, 508, 0, 0, 0, 1134, 0, + 509, 0, 0, 152, 0, 0, 0, 0, 0, 0, + 0, 0, 1459, 1458, 1468, 1469, 1461, 1462, 1463, 1464, + 1465, 1466, 1467, 1460, 0, 0, 1470, 0, 1580, 0, + 0, 1058, 0, 0, 2641, 0, 1058, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 486, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1134, 0, 0, + 1357, 0, 2598, 0, 0, 0, 0, 0, 2622, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 472, 0, 501, 489, 490, 149, 515, 0, + 0, 0, 491, 493, 0, 487, 514, 513, 0, 0, + 2597, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1134, 0, 0, 2682, 0, 0, 0, 2619, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 146, 0, 0, + 0, 0, 1686, 536, 0, 0, 0, 0, 0, 0, + 0, 0, 504, 0, 0, 0, 0, 0, 0, 146, + 0, 0, 146, 0, 0, 1686, 536, 0, 0, 1720, + 149, 0, 0, 1722, 1459, 1458, 1468, 1469, 1461, 1462, + 1463, 1464, 1465, 1466, 1467, 1460, 0, 618, 1470, 0, + 0, 0, 146, 146, 146, 146, 146, 0, 146, 152, + 0, 0, 1134, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 2035, 2036, 0, 0, 0, 0, 0, + 0, 1134, 0, 0, 2043, 0, 0, 0, 2588, 2587, + 2600, 2607, 2586, 2599, 2590, 3101, 0, 2623, 0, 1134, + 0, 0, 0, 0, 0, 0, 0, 2629, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 2610, 2608, 2603, 0, 0, 0, + 2605, 1134, 0, 0, 0, 0, 0, 0, 149, 0, + 0, 0, 2621, 0, 2594, 2593, 0, 0, 0, 3137, + 3138, 3139, 3140, 3141, 3142, 0, 0, 0, 0, 0, + 0, 0, 2589, 0, 0, 0, 618, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2595, 2596, + 0, 0, 2613, 1177, 2604, 2606, 2609, 2611, 0, 0, + 0, 0, 0, 0, 0, 152, 0, 0, 0, 0, + 0, 146, 146, 0, 0, 637, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 146, 0, 1720, 146, + 146, 146, 146, 0, 0, 0, 0, 0, 0, 0, + 0, 637, 0, 0, 0, 2633, 0, 0, 0, 0, + 146, 0, 0, 0, 637, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1275, 0, 2195, 0, + 2640, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 2626, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 675, 0, 146, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1722, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 2195, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 637, 0, 146, 2195, + 2195, 2195, 0, 0, 0, 2195, 2038, 2195, 2195, 2195, + 0, 2195, 2195, 0, 0, 0, 1058, 2195, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2195, 2195, 2195, 2195, 0, 2615, 2195, 2195, 2195, 2195, + 2195, 0, 0, 0, 0, 2195, 2195, 2195, 2195, 2195, + 2195, 2195, 2195, 2195, 2195, 2195, 2195, 0, 0, 0, + 0, 146, 146, 146, 2625, 0, 0, 0, 0, 1058, + 0, 0, 0, 0, 0, 0, 0, 2592, 0, 715, + 0, 0, 0, 0, 0, 1722, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2616, 2617, 2618, 2620, + 0, 2624, 2627, 2628, 2630, 2631, 2632, 2634, 2635, 2636, + 2637, 2638, 2639, 0, 0, 0, 0, 535, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 149, 0, + 0, 2612, 0, 0, 0, 0, 3508, 3509, 3510, 0, + 0, 0, 0, 0, 0, 0, 1720, 0, 0, 0, + 0, 0, 0, 146, 0, 0, 1057, 0, 2196, 146, + 146, 1125, 0, 0, 0, 3529, 146, 0, 0, 0, + 0, 0, 0, 0, 568, 3536, 562, 573, 555, 0, + 0, 0, 0, 0, 1163, 0, 0, 0, 0, 0, + 0, 3547, 3548, 3549, 3550, 0, 0, 0, 0, 3555, + 563, 0, 0, 0, 0, 0, 0, 0, 0, 2234, + 3565, 0, 2246, 2247, 2248, 2249, 2250, 2251, 2252, 2253, + 2254, 2255, 2256, 2257, 2258, 2259, 2260, 149, 0, 0, + 0, 0, 0, 0, 2614, 0, 0, 3574, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 149, + 0, 0, 149, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 686, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2297, 0, 0, 0, 2305, + 0, 0, 149, 149, 149, 149, 149, 0, 149, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 147, 0, 475, 0, + 0, 0, 0, 0, 0, 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 40, 0, 0, 0, 0, 0, 0, - 0, 3601, 0, 0, 0, 0, 0, 66, 0, 0, - 0, 0, 0, 0, 0, 85, 0, 0, 43, 0, - 147, 0, 64, 65, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 453, 0, 0, 616, 146, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 616, - 73, 0, 74, 0, 0, 0, 0, 0, 0, 0, - 93, 0, 0, 0, 0, 3909, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 79, 0, 0, 0, 0, - 0, 0, 2186, 0, 55, 0, 0, 3902, 0, 0, - 0, 147, 4297, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1028, 0, 0, 0, 0, 3711, - 3712, 3713, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 77, 78, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 59, 76, 0, 61, 62, 68, - 0, 69, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 542, 0, 0, 45, 82, 51, 50, 53, 0, - 0, 0, 0, 88, 0, 0, 0, 0, 0, 3903, - 0, 3765, 0, 2813, 0, 0, 0, 0, 147, 0, - 0, 0, 0, 2821, 2825, 0, 57, 84, 83, 0, - 0, 0, 0, 52, 0, 0, 0, 0, 0, 0, - 0, 0, 453, 0, 0, 0, 0, 0, 2844, 0, - 0, 0, 0, 0, 0, 40, 0, 0, 0, 0, - 0, 0, 3757, 3795, 3759, 3760, 146, 0, 0, 66, - 0, 146, 0, 0, 146, 0, 0, 85, 1030, 0, - 43, 0, 0, 0, 0, 3805, 0, 0, 0, 2493, - 0, 0, 0, 64, 65, 2870, 3905, 0, 0, 0, - 2755, 0, 0, 0, 0, 0, 3914, 3906, 3907, 3908, - 3912, 3913, 3910, 0, 3911, 0, 3915, 2092, 2092, 0, - 0, 73, 93, 74, 0, 0, 0, 3909, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 79, 0, 0, 3902, - 0, 0, 0, 0, 4291, 55, 0, 2940, 0, 146, - 0, 54, 56, 0, 0, 0, 0, 81, 2940, 2940, - 2940, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2092, 0, 0, 0, 0, 0, 0, 0, - 146, 0, 0, 0, 0, 0, 455, 0, 0, 0, - 0, 0, 0, 0, 0, 2092, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3916, 3904, 0, 61, 62, - 68, 0, 69, 0, 0, 0, 45, 82, 51, 50, - 53, 0, 0, 0, 0, 88, 0, 0, 0, 0, - 0, 3903, 0, 0, 0, 0, 3938, 0, 0, 0, - 0, 2088, 0, 0, 0, 3017, 0, 0, 57, 84, - 83, 0, 0, 0, 0, 52, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1028, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 4012, 0, 0, 0, 0, 0, 2092, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 2186, 0, 0, 0, - 0, 0, 0, 0, 0, 64, 65, 146, 3905, 0, - 0, 0, 0, 146, 0, 0, 0, 0, 3914, 3906, - 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, 0, - 0, 0, 0, 73, 0, 74, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 79, 0, - 0, 0, 0, 0, 0, 0, 0, 55, 0, 0, - 0, 0, 147, 0, 0, 0, 0, 0, 0, 1592, - 0, 0, 54, 56, 0, 0, 0, 0, 81, 0, - 0, 3167, 3168, 3169, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3049, 0, 146, 0, 0, - 2940, 2940, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 4072, 0, 0, 0, 0, 0, 0, 0, - 3205, 0, 0, 0, 0, 0, 0, 3916, 3904, 0, - 61, 62, 68, 0, 69, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 455, 0, 0, 0, 0, 0, 0, 0, 0, - 147, 0, 0, 0, 3244, 0, 0, 0, 0, 3250, - 0, 0, 0, 0, 0, 3254, 0, 0, 1579, 0, - 146, 0, 147, 0, 0, 147, 3267, 0, 0, 0, - 0, 0, 2940, 0, 0, 0, 0, 0, 0, 3282, - 453, 453, 453, 453, 0, 0, 0, 0, 0, 0, - 0, 146, 0, 147, 147, 147, 147, 147, 3298, 147, + 0, 0, 0, 0, 0, 638, 0, 0, 0, 0, + 0, 0, 147, 0, 1578, 554, 553, 556, 0, 0, + 0, 0, 0, 0, 0, 561, 0, 0, 0, 1059, + 0, 0, 0, 147, 1126, 0, 0, 0, 0, 0, + 0, 0, 565, 0, 0, 0, 0, 569, 0, 0, + 0, 0, 0, 0, 147, 0, 0, 0, 0, 0, + 0, 0, 572, 0, 0, 0, 475, 147, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 149, 149, 0, 557, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 149, 0, 0, 149, + 149, 149, 149, 1677, 0, 0, 0, 0, 0, 0, + 0, 0, 146, 0, 0, 0, 0, 0, 0, 0, + 149, 0, 0, 0, 0, 1578, 0, 0, 1710, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 146, 0, 0, 0, 0, 0, 0, 560, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2021, 2022, + 2023, 2024, 2025, 0, 2026, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 149, 146, 0, + 637, 558, 559, 566, 2083, 570, 571, 574, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 577, + 578, 579, 580, 581, 582, 583, 584, 585, 586, 587, + 588, 589, 590, 591, 592, 593, 594, 595, 596, 597, + 598, 599, 600, 601, 602, 603, 604, 605, 606, 607, + 608, 609, 610, 611, 612, 613, 614, 615, 3794, 3795, + 3796, 0, 3798, 0, 0, 0, 0, 0, 149, 0, + 0, 0, 0, 0, 0, 3807, 0, 3810, 3811, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3815, 0, + 637, 146, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 637, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1578, 1578, 1058, + 1058, 149, 149, 149, 0, 1722, 0, 0, 0, 0, + 0, 0, 2144, 0, 0, 0, 3854, 0, 0, 0, + 0, 0, 0, 3857, 0, 0, 0, 0, 1130, 0, + 0, 0, 0, 0, 0, 40, 41, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 67, + 0, 0, 0, 0, 0, 0, 0, 86, 1057, 0, + 43, 71, 72, 0, 0, 0, 0, 0, 68, 0, + 0, 0, 147, 0, 0, 2195, 0, 0, 0, 0, + 0, 2195, 2195, 2195, 2195, 2195, 0, 475, 0, 0, + 0, 0, 0, 2215, 0, 0, 0, 0, 59, 3917, + 0, 0, 94, 0, 0, 0, 0, 0, 0, 2195, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 149, 0, 0, 0, 0, 0, 149, + 149, 0, 0, 3933, 0, 0, 149, 0, 0, 0, + 0, 0, 0, 0, 0, 147, 0, 0, 0, 0, + 2525, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3958, 3959, 3960, 3961, 0, 0, 0, 0, + 0, 0, 3965, 3966, 0, 146, 0, 0, 0, 0, + 146, 0, 0, 146, 2798, 1722, 3975, 1058, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 3986, 0, 0, 0, 0, 0, 45, 83, 52, 51, + 54, 2578, 564, 76, 0, 89, 0, 2378, 0, 2380, + 0, 0, 0, 0, 0, 0, 638, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 58, 85, + 84, 0, 0, 147, 0, 53, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 146, 0, 638, + 73, 1059, 0, 0, 0, 2670, 2671, 475, 0, 2673, + 2674, 0, 0, 2676, 2677, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 146, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4045, 4046, 4047, 4048, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 65, 66, 0, 0, 4064, 0, 0, 0, 0, 0, + 2710, 2711, 2712, 0, 0, 0, 0, 0, 0, 2489, + 0, 0, 4077, 0, 0, 2491, 2492, 0, 74, 0, + 75, 0, 2499, 0, 0, 0, 0, 0, 0, 4086, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 80, 0, 0, 0, 0, 0, 0, + 0, 0, 56, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 2742, 2743, 2744, 0, 0, 0, 4170, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 4178, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 149, 1057, 0, 0, 0, 0, 1057, 1590, + 4198, 0, 0, 0, 0, 4209, 0, 0, 0, 0, + 4212, 4213, 78, 79, 0, 0, 0, 0, 0, 0, + 149, 0, 0, 0, 0, 0, 60, 77, 0, 62, + 63, 69, 0, 70, 0, 0, 0, 0, 2195, 1722, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 146, 0, 0, 0, 0, 0, 146, 675, 149, 0, + 0, 0, 0, 2195, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1676, 0, + 0, 0, 0, 0, 1685, 535, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1685, 535, 0, + 0, 1719, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4289, 0, 0, 0, 4292, 0, 0, 0, + 1058, 149, 146, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2947, 0, 0, 0, 0, + 0, 0, 0, 2951, 2952, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 147, 0, 0, 1059, 0, 0, 0, + 0, 1059, 0, 0, 55, 57, 0, 0, 2505, 2067, + 82, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 146, 0, 0, 0, 0, 2089, 0, 0, + 0, 0, 0, 0, 0, 0, 2515, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 146, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 4392, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1275, 0, 0, 0, 0, 0, + 0, 146, 0, 0, 475, 0, 0, 0, 0, 2134, + 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, + 1719, 0, 4437, 4438, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 147, 4449, 0, 147, 4451, 0, + 0, 0, 0, 0, 0, 0, 146, 146, 0, 0, + 0, 0, 475, 475, 475, 475, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 147, 147, 147, + 147, 147, 0, 147, 0, 149, 0, 0, 0, 0, + 149, 3136, 0, 149, 0, 0, 0, 0, 0, 2641, + 0, 0, 0, 0, 4487, 0, 0, 0, 0, 3162, + 0, 3163, 3164, 146, 3165, 3166, 0, 0, 3167, 0, + 2134, 0, 0, 0, 0, 1357, 0, 2598, 0, 0, + 0, 0, 0, 2622, 3176, 3177, 3178, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2134, 0, 2134, 0, 0, 2275, 0, 0, + 0, 0, 0, 0, 2276, 2597, 0, 0, 0, 2134, + 2134, 0, 0, 0, 0, 0, 0, 149, 0, 0, + 0, 0, 2619, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 637, 0, 0, 0, 1057, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 149, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 147, 147, 0, 0, + 638, 0, 2130, 0, 0, 0, 0, 0, 0, 0, + 0, 147, 0, 0, 147, 147, 147, 147, 0, 0, + 0, 1057, 0, 0, 0, 0, 638, 0, 0, 0, + 0, 0, 0, 0, 0, 147, 0, 2134, 0, 638, + 1125, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1058, 0, 0, 2588, 3392, 2600, 0, 3391, 2599, 2590, + 0, 0, 2623, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2629, 0, 0, 0, 0, 0, 0, 0, + 0, 2791, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 147, 0, 0, 0, 0, 0, 0, 475, + 0, 0, 0, 2230, 0, 0, 0, 2621, 0, 2594, + 2593, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 2589, 1719, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 3393, 3394, 0, 0, 2613, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 638, 0, 147, 0, 0, 0, 0, 0, 0, + 149, 146, 0, 2908, 0, 0, 149, 0, 0, 0, + 0, 2316, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2633, 0, 0, 0, 2935, 0, 0, 0, 0, 146, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2640, 147, 147, 147, 0, + 0, 0, 0, 0, 1059, 0, 2626, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2230, 0, 0, 1126, 3511, 3512, 3513, 3514, 3515, 3516, + 3517, 3518, 3519, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 149, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3530, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 3556, 3557, 3558, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1720, 0, 0, 0, 147, 0, + 0, 0, 149, 0, 147, 147, 0, 0, 0, 0, + 0, 147, 0, 0, 0, 0, 0, 0, 0, 0, + 2615, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 149, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 3126, 0, 0, 2625, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 149, 2592, 0, 0, 0, 0, 0, 0, 0, + 637, 3644, 0, 0, 0, 0, 0, 0, 716, 637, + 146, 0, 0, 3651, 0, 0, 1058, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 149, 149, 0, 0, + 0, 2616, 2617, 2618, 2620, 0, 2624, 2627, 2628, 2630, + 2631, 2632, 2634, 2635, 2636, 2637, 2638, 2639, 0, 0, + 0, 0, 148, 0, 473, 0, 0, 0, 0, 0, + 0, 0, 0, 148, 0, 0, 2612, 0, 0, 0, + 0, 0, 2530, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 149, 0, 0, 2542, 0, 148, 0, + 0, 2542, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 148, + 1127, 0, 0, 0, 2542, 0, 0, 2542, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 148, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 473, 148, 0, 0, 0, 0, 3277, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2614, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 3319, + 0, 2664, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 3352, 2686, 0, + 0, 1057, 1057, 0, 0, 0, 0, 2134, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 146, - 0, 0, 0, 4235, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1593, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 4259, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 146, 146, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1028, 0, 2092, 455, 0, 0, - 2570, 0, 0, 0, 2755, 455, 455, 455, 0, 0, - 0, 455, 146, 0, 54, 56, 455, 0, 0, 0, - 81, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1578, 1578, 0, 147, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3790, 3791, + 3792, 3793, 0, 0, 0, 0, 3797, 0, 0, 0, + 3800, 3801, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 147, 0, 638, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 3435, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1628, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 616, 0, 0, - 0, 0, 0, 0, 0, 2089, 0, 0, 0, 0, - 0, 0, 0, 0, 147, 0, 147, 147, 147, 147, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 146, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 4311, + 0, 149, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 638, 147, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 638, 0, 1057, + 0, 0, 0, 0, 0, 0, 4051, 0, 0, 149, + 0, 0, 0, 0, 0, 0, 0, 0, 1628, 0, + 0, 0, 0, 0, 1059, 1059, 0, 0, 0, 0, + 2230, 0, 0, 0, 0, 1615, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 148, 0, + 0, 0, 0, 0, 0, 0, 0, 2906, 0, 0, + 0, 0, 0, 473, 0, 0, 0, 2914, 2918, 0, + 1058, 0, 0, 3940, 3941, 3942, 0, 0, 0, 0, + 0, 0, 0, 146, 0, 0, 0, 0, 0, 0, + 0, 0, 2937, 0, 0, 0, 0, 1629, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1615, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 148, 3980, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 2542, 0, 0, 0, 0, 0, 2963, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3997, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2134, 2134, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 3660, 0, 0, + 147, 0, 0, 0, 0, 147, 0, 0, 147, 1629, + 0, 0, 1059, 0, 0, 0, 0, 0, 0, 4023, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 149, 0, 0, 0, 475, 3710, 0, 4032, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 148, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 3098, 0, 0, 0, + 0, 0, 0, 473, 0, 0, 0, 3098, 3098, 3098, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 637, + 0, 2134, 147, 0, 0, 0, 0, 0, 0, 4079, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 2134, 0, 0, 0, 0, 0, + 0, 0, 0, 147, 0, 0, 0, 0, 0, 475, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1642, 1645, 1646, 1647, 1648, 1649, 1650, 0, 1651, + 1652, 1653, 1654, 1655, 1656, 1657, 1658, 1659, 1660, 1661, + 1662, 1663, 0, 1630, 1631, 1632, 1612, 1611, 1643, 1613, + 1616, 1610, 1614, 1609, 0, 3179, 1617, 1618, 1619, 1620, + 1621, 1622, 1623, 1624, 1625, 1626, 1627, 1634, 1635, 1636, + 1637, 1638, 1639, 1640, 1641, 0, 0, 0, 2130, 0, + 0, 0, 1057, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2134, + 0, 0, 0, 0, 0, 637, 0, 0, 0, 0, + 0, 0, 0, 1642, 1645, 1646, 1647, 1648, 1649, 1650, + 0, 1651, 1652, 1653, 1654, 1655, 1656, 1657, 1658, 1659, + 1660, 1661, 1662, 1663, 1628, 1630, 1631, 1632, 1612, 1611, + 1643, 1613, 1616, 1610, 1614, 1609, 4250, 0, 1617, 1618, + 1619, 1620, 1621, 1622, 1623, 1624, 1625, 1626, 1627, 1634, + 1635, 1636, 1637, 1638, 1639, 1640, 1641, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 2230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 147, 0, 0, 0, 0, + 0, 147, 0, 0, 1644, 0, 0, 0, 0, 3327, + 3328, 3329, 0, 0, 0, 0, 0, 1633, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3098, 3098, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1615, 0, 0, 0, 0, 3365, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 149, + 0, 0, 0, 0, 2580, 2581, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 3214, 1644, 147, 0, 0, + 0, 0, 3408, 0, 0, 2664, 0, 0, 3414, 1633, + 0, 0, 0, 0, 0, 0, 0, 0, 2664, 148, + 2664, 0, 0, 0, 3434, 1629, 0, 0, 4380, 0, + 0, 2664, 0, 2664, 3443, 2664, 2664, 2664, 2664, 0, + 0, 0, 0, 0, 0, 0, 4396, 0, 475, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 475, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 147, 0, 0, + 0, 0, 0, 0, 0, 3098, 0, 0, 0, 0, + 0, 0, 3507, 0, 4452, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 147, 0, + 473, 3523, 0, 149, 0, 0, 0, 0, 148, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 147, 0, 0, 0, + 148, 0, 0, 148, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1724, 0, 0, 0, 473, 473, + 473, 473, 0, 0, 0, 0, 0, 0, 4504, 0, + 0, 0, 0, 148, 148, 148, 148, 148, 0, 148, + 0, 147, 147, 0, 0, 4038, 0, 0, 0, 0, + 0, 0, 1057, 0, 0, 2134, 0, 0, 0, 0, + 2664, 0, 0, 475, 0, 0, 0, 0, 0, 0, + 0, 475, 475, 475, 475, 0, 0, 0, 0, 475, + 475, 0, 475, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 475, 475, 0, 147, 475, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1642, + 1645, 1646, 1647, 1648, 1649, 1650, 0, 1651, 1652, 1653, + 1654, 1655, 1656, 1657, 1658, 1659, 1660, 1661, 1662, 1663, + 0, 1630, 1631, 1632, 1612, 1611, 1643, 1613, 1616, 1610, + 1614, 1609, 0, 0, 1617, 1618, 1619, 1620, 1621, 1622, + 1623, 1624, 1625, 1626, 1627, 1634, 1635, 1636, 1637, 1638, + 1639, 1640, 1641, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2918, 0, 0, 0, 638, + 0, 0, 148, 148, 0, 0, 0, 0, 2131, 0, + 0, 0, 0, 0, 0, 0, 0, 148, 0, 4216, + 148, 148, 148, 148, 0, 3098, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 148, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2984, + 0, 0, 0, 0, 0, 3214, 0, 0, 2130, 0, + 0, 3020, 0, 0, 0, 0, 0, 0, 148, 0, + 3031, 0, 0, 0, 0, 473, 0, 0, 0, 2229, + 0, 0, 1644, 0, 0, 0, 3050, 3051, 3052, 3053, + 3054, 3055, 3056, 3057, 0, 1633, 3060, 3061, 3062, 3063, + 3064, 3065, 3066, 3067, 3068, 3069, 3070, 3071, 3072, 3073, + 3074, 3075, 0, 3089, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1719, 0, 0, 148, + 0, 0, 0, 0, 3775, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 2134, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 147, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 148, 148, 148, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 147, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2229, 0, 1057, 1127, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 475, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 475, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 475, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 3098, 0, 0, 3098, 3227, 3228, 3229, + 475, 3233, 3234, 3235, 3236, 3237, 0, 0, 3240, 3241, + 3242, 3243, 3244, 3245, 3246, 3247, 3248, 3249, 3250, 0, + 3252, 3253, 3254, 3255, 3256, 0, 3259, 0, 0, 0, + 0, 0, 0, 0, 148, 0, 0, 0, 0, 0, + 148, 148, 0, 0, 0, 0, 0, 148, 0, 40, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 67, 0, 0, 0, 0, 0, 0, + 0, 86, 0, 0, 43, 0, 0, 0, 0, 3919, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2016, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 3926, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 94, 0, 0, 0, + 0, 0, 4143, 0, 0, 0, 0, 0, 0, 0, + 2134, 0, 0, 0, 0, 638, 0, 0, 0, 0, + 0, 0, 0, 4136, 638, 147, 4464, 4467, 4463, 0, + 0, 3214, 726, 727, 728, 729, 730, 731, 732, 733, + 734, 735, 736, 737, 738, 739, 740, 741, 742, 743, + 744, 745, 746, 747, 748, 749, 750, 751, 752, 753, + 754, 755, 756, 757, 758, 759, 760, 761, 762, 763, + 764, 765, 766, 767, 0, 0, 0, 0, 0, 0, + 0, 475, 0, 0, 0, 3422, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 475, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 45, 83, 52, 51, 54, 0, 0, 0, 0, 89, + 3460, 3461, 0, 0, 0, 4137, 0, 0, 0, 0, + 0, 0, 40, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 58, 85, 84, 0, 67, 0, 0, 53, + 0, 0, 0, 0, 86, 0, 0, 43, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4062, 0, 0, 0, 0, 0, 0, 0, + 0, 475, 0, 475, 0, 475, 0, 0, 0, 94, + 0, 0, 0, 0, 0, 4143, 0, 0, 0, 0, + 0, 3098, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 148, 65, 66, 4136, 4139, 0, 0, + 0, 4542, 0, 0, 0, 0, 0, 4148, 4140, 4141, + 4142, 4146, 4147, 4144, 0, 4145, 0, 4149, 0, 0, + 0, 148, 74, 0, 75, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 80, 0, 2134, + 0, 0, 0, 0, 0, 0, 56, 0, 0, 148, + 0, 0, 3605, 0, 3607, 0, 0, 0, 0, 0, + 3613, 3614, 1057, 0, 0, 0, 0, 0, 0, 0, + 3098, 0, 0, 45, 83, 52, 51, 54, 0, 0, + 0, 0, 89, 0, 0, 0, 0, 0, 4137, 0, + 0, 0, 0, 0, 0, 0, 0, 40, 0, 0, + 0, 0, 0, 0, 0, 58, 85, 84, 0, 0, + 0, 67, 53, 0, 0, 0, 0, 475, 0, 86, + 4150, 4138, 43, 62, 63, 69, 0, 70, 0, 2134, + 0, 475, 0, 0, 147, 0, 0, 0, 0, 0, + 0, 0, 148, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 3822, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2825, 0, 1592, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 3049, 0, - 2088, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2940, 0, 0, 147, 0, 0, 0, 0, 0, 0, - 453, 0, 0, 0, 2185, 1606, 1609, 1610, 1611, 1612, - 1613, 1614, 0, 1615, 1616, 1617, 1618, 1619, 1620, 1621, - 1622, 1623, 1624, 1625, 1626, 1627, 0, 1594, 1595, 1596, - 1573, 1577, 1607, 1574, 1580, 1576, 1578, 1575, 0, 0, - 1581, 1582, 1583, 1584, 1585, 1586, 1587, 1588, 1589, 1590, - 1591, 1598, 1599, 1600, 1601, 1602, 1603, 1604, 1605, 0, - 0, 147, 0, 0, 0, 0, 1682, 0, 0, 0, - 0, 1579, 0, 0, 3552, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1592, 0, 0, 0, 0, 0, - 0, 2092, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 146, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 94, 0, 0, 0, 0, 0, + 4143, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4062, 0, 0, 0, 2229, 65, 66, 0, + 4139, 4136, 0, 0, 0, 0, 4536, 0, 0, 0, + 4148, 4140, 4141, 4142, 4146, 4147, 4144, 0, 4145, 0, + 4149, 0, 0, 0, 0, 74, 0, 75, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 147, 147, - 147, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 146, 0, 0, 0, 0, 0, 0, 0, 1028, 0, - 0, 0, 2185, 1593, 0, 1098, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 455, 0, + 0, 0, 475, 0, 0, 0, 0, 0, 475, 0, + 80, 0, 0, 3740, 0, 0, 0, 0, 40, 56, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1608, 0, 0, - 0, 455, 0, 1579, 0, 0, 0, 0, 0, 0, - 1597, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2940, 0, 0, 2940, 0, + 0, 0, 67, 0, 2134, 0, 0, 0, 0, 0, + 86, 0, 0, 43, 0, 3214, 0, 0, 45, 83, + 52, 51, 54, 3098, 0, 0, 0, 89, 147, 0, + 0, 0, 0, 4137, 0, 0, 0, 0, 0, 0, + 0, 2134, 0, 0, 0, 0, 0, 0, 55, 57, + 58, 85, 84, 0, 82, 94, 0, 53, 0, 0, + 0, 4143, 0, 4150, 4138, 0, 62, 63, 69, 0, + 70, 0, 0, 2134, 0, 0, 0, 0, 0, 0, + 0, 0, 4136, 0, 0, 0, 0, 4530, 0, 0, + 0, 0, 0, 0, 0, 0, 148, 0, 0, 0, + 0, 148, 0, 0, 148, 0, 1724, 475, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 147, - 0, 0, 0, 0, 0, 147, 147, 0, 0, 0, - 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1593, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 616, 146, - 0, 0, 3049, 0, 0, 0, 0, 0, 0, 0, + 473, 0, 65, 66, 0, 4139, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 4148, 4140, 4141, 4142, 4146, + 4147, 4144, 0, 4145, 0, 4149, 0, 0, 0, 0, + 74, 0, 75, 0, 0, 0, 0, 0, 3830, 45, + 83, 52, 51, 54, 0, 0, 0, 0, 89, 0, + 0, 0, 0, 0, 4137, 80, 0, 0, 148, 0, + 0, 0, 0, 0, 56, 0, 0, 0, 0, 0, + 0, 58, 85, 84, 0, 0, 0, 0, 53, 0, + 0, 0, 0, 0, 638, 0, 0, 0, 0, 148, + 0, 0, 0, 0, 0, 473, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3697, 0, 0, 0, 0, + 0, 55, 57, 0, 0, 0, 0, 82, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 4150, 4138, + 0, 62, 63, 69, 0, 70, 0, 0, 0, 0, + 0, 0, 0, 65, 66, 0, 4139, 0, 0, 0, + 0, 0, 0, 0, 2131, 0, 4148, 4140, 4141, 4142, + 4146, 4147, 4144, 0, 4145, 0, 4149, 0, 0, 0, + 0, 74, 0, 75, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 40, 80, 0, 0, 0, + 0, 0, 0, 0, 0, 56, 0, 0, 0, 67, + 638, 0, 0, 0, 0, 0, 0, 86, 0, 0, + 43, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2092, 0, 455, 0, 0, 0, 1606, 1609, - 1610, 1611, 1612, 1613, 1614, 0, 1615, 1616, 1617, 1618, - 1619, 1620, 1621, 1622, 1623, 1624, 1625, 1626, 1627, 0, - 1594, 1595, 1596, 1573, 1577, 1607, 1574, 1580, 1576, 1578, - 1575, 0, 455, 1581, 1582, 1583, 1584, 1585, 1586, 1587, - 1588, 1589, 1590, 1591, 1598, 1599, 1600, 1601, 1602, 1603, - 1604, 1605, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2229, 0, 94, 0, 3989, 0, 3991, 3992, 4143, 0, + 0, 148, 0, 0, 0, 0, 0, 148, 0, 4150, + 4138, 0, 62, 63, 69, 0, 70, 0, 0, 4136, + 0, 0, 0, 0, 4522, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 55, 57, 0, 0, + 0, 0, 82, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 455, 0, 0, 455, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1606, 1609, 1610, 1611, 1612, 1613, 1614, 0, 1615, 1616, - 1617, 1618, 1619, 1620, 1621, 1622, 1623, 1624, 1625, 1626, - 1627, 0, 1594, 1595, 1596, 1573, 1577, 1607, 1574, 1580, - 1576, 1578, 1575, 0, 3827, 1581, 1582, 1583, 1584, 1585, - 1586, 1587, 1588, 1589, 1590, 1591, 1598, 1599, 1600, 1601, - 1602, 1603, 1604, 1605, 0, 0, 0, 0, 0, 0, - 1608, 0, 2940, 0, 2940, 0, 2940, 0, 0, 0, - 0, 0, 0, 1597, 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 40, 0, 0, 0, 0, - 0, 0, 0, 147, 0, 0, 0, 0, 0, 66, - 0, 0, 0, 0, 0, 0, 0, 85, 0, 0, - 43, 0, 0, 0, 0, 3941, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2092, 0, 0, 0, 0, - 0, 147, 0, 0, 0, 0, 0, 0, 0, 455, - 0, 0, 1028, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 0, 0, 0, 0, 3909, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1608, 0, 0, 0, 0, 0, 0, 3902, - 0, 0, 0, 0, 4285, 1597, 0, 0, 0, 0, + 0, 0, 0, 148, 0, 0, 45, 83, 52, 51, + 54, 0, 0, 0, 0, 89, 0, 0, 0, 0, + 0, 4137, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 58, 85, + 84, 0, 0, 0, 0, 53, 0, 0, 0, 0, + 0, 0, 0, 0, 473, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 473, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 148, 0, 4167, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 55, 57, 0, + 0, 0, 0, 82, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 148, 0, 0, 0, 0, 0, + 65, 66, 0, 4139, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 4148, 4140, 4141, 4142, 4146, 4147, 4144, + 0, 4145, 148, 4149, 0, 0, 0, 0, 74, 0, + 75, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 80, 0, 0, 0, 0, 0, 0, + 0, 0, 56, 0, 0, 0, 0, 148, 148, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 473, + 0, 0, 0, 0, 0, 0, 0, 473, 473, 473, + 473, 0, 0, 0, 0, 473, 473, 0, 473, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 473, 473, 0, 148, 473, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 4150, 4138, 0, 62, + 63, 69, 0, 70, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 2131, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 55, 57, 0, 0, 0, 0, + 82, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 40, 430, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 342, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 0, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 161, 459, 178, 1381, 299, 0, 0, 457, 408, + 324, 0, 148, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 94, 0, 0, 0, 0, + 0, 655, 0, 0, 0, 0, 0, 0, 0, 160, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 148, 0, 0, 0, 0, 0, 0, 250, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, + 0, 0, 0, 0, 473, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 473, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 473, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 473, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 325, 0, 0, 89, 0, + 288, 179, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 0, 0, 166, 186, + 298, 0, 0, 0, 232, 0, 377, 0, 449, 0, + 265, 0, 376, 300, 442, 0, 0, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 155, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 148, 0, 452, 0, 244, 0, 454, 168, 391, + 390, 0, 279, 0, 169, 159, 370, 170, 289, 192, + 0, 467, 208, 294, 432, 150, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 164, 171, 0, + 367, 393, 437, 210, 411, 162, 165, 173, 383, 174, + 175, 0, 307, 253, 257, 273, 284, 473, 374, 412, + 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 473, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2092, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 147, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 0, 0, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 473, 0, 473, + 0, 473, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 167, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 180, 181, 0, 0, 182, 0, 0, 0, 0, 0, + 176, 177, 163, 0, 0, 0, 229, 153, 0, 0, + 0, 154, 0, 0, 156, 157, 0, 0, 0, 0, + 158, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 656, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 666, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 473, 0, 0, 331, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 473, 0, 0, + 148, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 649, 0, 0, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 172, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 0, 184, 0, 190, 0, 191, 193, 0, 189, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 473, 0, + 0, 0, 874, 1016, 473, 0, 430, 776, 1020, 861, + 884, 1029, 890, 892, 957, 836, 932, 342, 881, 837, + 2235, 2236, 2237, 0, 828, 1077, 829, 862, 246, 1075, + 990, 935, 1018, 918, 950, 960, 245, 231, 925, 924, + 1007, 873, 872, 955, 1003, 1017, 0, 0, 161, 459, + 178, 784, 299, 0, 148, 457, 408, 324, 0, 0, + 916, 0, 768, 769, 901, 959, 848, 946, 1022, 882, + 951, 1023, 94, 0, 0, 0, 0, 705, 537, 706, + 708, 709, 710, 711, 0, 0, 160, 707, 712, 713, + 714, 0, 911, 956, 1034, 827, 1094, 694, 832, 783, + 0, 1008, 869, 870, 250, 0, 0, 0, 0, 0, + 0, 0, 914, 931, 975, 898, 0, 450, 962, 971, + 985, 891, 361, 270, 0, 0, 0, 0, 691, 692, + 0, 0, 0, 473, 798, 0, 693, 0, 842, 689, + 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, + 736, 737, 738, 739, 740, 741, 742, 743, 744, 745, + 746, 747, 748, 749, 750, 751, 752, 753, 754, 755, + 756, 757, 758, 759, 760, 761, 762, 763, 764, 765, + 766, 767, 695, 0, 0, 0, 847, 825, 867, 977, + 826, 824, 325, 839, 771, 1006, 899, 288, 179, 1012, + 897, 796, 965, 843, 994, 885, 296, 841, 183, 838, + 844, 883, 338, 974, 980, 781, 186, 298, 991, 863, + 876, 702, 0, 377, 952, 449, 683, 265, 938, 376, + 300, 442, 966, 1014, 448, 886, 424, 458, 463, 258, + 919, 222, 405, 248, 241, 868, 984, 831, 271, 360, + 236, 292, 902, 958, 864, 228, 969, 945, 996, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 992, 979, 998, 859, 845, 851, 846, 875, 1015, 280, + 272, 999, 997, 877, 346, 212, 929, 922, 915, 785, + 452, 1030, 244, 981, 454, 168, 391, 390, 889, 279, + 982, 169, 159, 370, 170, 289, 192, 1002, 467, 208, + 294, 432, 682, 264, 337, 954, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 978, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 1021, 307, + 253, 257, 273, 284, 953, 374, 412, 455, 947, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 976, 204, 198, 1010, 993, 940, 904, + 910, 833, 0, 197, 905, 906, 907, 908, 909, 972, + 866, 878, 858, 948, 857, 268, 964, 703, 704, 233, + 774, 1025, 199, 840, 1024, 334, 341, 333, 1027, 1026, + 441, 1011, 941, 928, 926, 834, 1009, 939, 927, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 930, 410, 305, 0, 194, 0, 409, 1019, 1036, 421, + 214, 852, 986, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 968, 1033, 345, 378, + 221, 451, 406, 249, 850, 1037, 797, 786, 787, 790, + 933, 934, 788, 791, 792, 799, 772, 773, 775, 777, + 778, 779, 921, 1013, 835, 782, 989, 793, 794, 795, + 961, 1031, 770, 229, 719, 811, 812, 813, 720, 814, + 815, 721, 722, 816, 817, 818, 819, 723, 820, 821, + 822, 800, 801, 802, 803, 804, 805, 806, 807, 810, + 808, 809, 0, 917, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 780, 187, 200, 297, + 1032, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 987, 944, 0, 894, 896, 895, 854, 856, + 855, 853, 1035, 331, 1005, 823, 830, 849, 860, 865, + 871, 879, 880, 888, 893, 903, 912, 913, 923, 936, + 937, 943, 967, 970, 983, 988, 995, 1000, 1001, 453, + 239, 920, 942, 973, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 900, 184, 0, + 190, 0, 191, 193, 887, 189, 1004, 1028, 949, 963, + 874, 1016, 0, 0, 430, 776, 1020, 861, 884, 1029, + 890, 892, 957, 836, 932, 342, 881, 837, 0, 0, + 0, 0, 828, 680, 829, 862, 246, 679, 990, 935, + 1018, 918, 950, 960, 245, 231, 925, 924, 1007, 873, + 872, 955, 1003, 1017, 0, 0, 161, 459, 178, 784, + 299, 0, 0, 457, 408, 324, 0, 0, 916, 0, + 768, 769, 901, 959, 848, 946, 1022, 882, 951, 1023, + 94, 0, 0, 0, 0, 705, 537, 706, 708, 709, + 710, 711, 0, 0, 160, 707, 712, 713, 714, 0, + 911, 956, 1034, 827, 677, 694, 832, 783, 4229, 1008, + 869, 870, 250, 0, 0, 0, 0, 0, 0, 0, + 914, 931, 975, 898, 0, 450, 962, 971, 985, 891, + 361, 270, 0, 0, 0, 0, 691, 692, 0, 0, + 0, 0, 798, 0, 693, 0, 842, 689, 726, 727, + 728, 729, 730, 731, 732, 733, 734, 735, 736, 737, + 738, 739, 740, 741, 742, 743, 744, 745, 746, 747, + 748, 749, 750, 751, 752, 753, 754, 755, 756, 757, + 758, 759, 760, 761, 762, 763, 764, 765, 766, 767, + 695, 0, 0, 0, 847, 825, 867, 977, 826, 824, + 325, 839, 771, 1006, 899, 288, 179, 1012, 897, 796, + 965, 843, 994, 885, 296, 841, 183, 838, 844, 883, + 338, 974, 980, 781, 186, 298, 991, 863, 876, 702, + 0, 377, 952, 449, 683, 265, 938, 376, 300, 442, + 966, 1014, 448, 886, 424, 458, 463, 258, 919, 222, + 405, 248, 241, 868, 984, 831, 271, 360, 236, 292, + 902, 958, 864, 228, 969, 945, 996, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 992, 979, + 998, 859, 845, 851, 846, 875, 1015, 280, 272, 999, + 997, 877, 346, 212, 929, 922, 915, 785, 452, 1030, + 244, 981, 454, 168, 391, 390, 889, 279, 982, 169, + 159, 370, 170, 289, 192, 1002, 467, 208, 294, 432, + 682, 264, 337, 954, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 978, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 1021, 307, 253, 257, + 273, 284, 953, 374, 412, 455, 947, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 976, 204, 198, 1010, 993, 940, 904, 910, 833, + 0, 197, 905, 906, 907, 908, 909, 972, 866, 878, + 858, 948, 857, 268, 964, 703, 704, 233, 774, 1025, + 199, 840, 1024, 334, 341, 333, 1027, 1026, 441, 1011, + 941, 928, 926, 834, 1009, 939, 927, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 930, 410, + 305, 0, 194, 0, 409, 1019, 1036, 421, 214, 852, + 986, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 968, 1033, 345, 378, 221, 451, + 406, 249, 850, 1037, 797, 786, 787, 790, 933, 934, + 788, 791, 792, 799, 772, 773, 775, 777, 778, 779, + 921, 1013, 835, 782, 989, 793, 794, 795, 961, 1031, + 770, 229, 719, 811, 812, 813, 720, 814, 815, 721, + 722, 816, 817, 818, 819, 723, 820, 821, 822, 800, + 801, 802, 803, 804, 805, 806, 807, 810, 808, 809, + 0, 917, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 780, 187, 200, 297, 1032, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 987, 944, 0, 894, 896, 895, 854, 856, 855, 853, + 1035, 331, 1005, 823, 830, 849, 860, 865, 871, 879, + 880, 888, 893, 903, 912, 913, 923, 936, 937, 943, + 967, 970, 983, 988, 995, 1000, 1001, 453, 239, 920, + 942, 973, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 900, 184, 0, 190, 0, + 191, 193, 887, 189, 1004, 1028, 949, 963, 874, 1016, + 0, 0, 430, 776, 1020, 861, 884, 1029, 890, 892, + 957, 836, 932, 342, 881, 837, 0, 0, 0, 0, + 828, 680, 829, 862, 246, 679, 990, 935, 1018, 918, + 950, 960, 245, 231, 925, 924, 1007, 873, 872, 955, + 1003, 1017, 0, 0, 161, 459, 178, 784, 299, 0, + 0, 457, 408, 324, 0, 0, 916, 0, 768, 769, + 901, 959, 848, 946, 1022, 882, 951, 1023, 94, 0, + 1416, 0, 0, 705, 537, 706, 708, 709, 710, 711, + 0, 0, 160, 707, 712, 713, 714, 0, 911, 956, + 1034, 827, 677, 694, 832, 783, 0, 1008, 869, 870, + 250, 0, 0, 0, 0, 0, 0, 0, 914, 931, + 975, 898, 0, 450, 962, 971, 985, 891, 361, 270, + 0, 0, 0, 0, 691, 692, 0, 0, 0, 0, + 798, 0, 693, 0, 842, 689, 726, 727, 728, 729, + 730, 731, 732, 733, 734, 735, 736, 737, 738, 739, + 740, 741, 742, 743, 744, 745, 746, 747, 748, 749, + 750, 751, 752, 753, 754, 755, 756, 757, 758, 759, + 760, 761, 762, 763, 764, 765, 766, 767, 695, 0, + 0, 0, 847, 825, 867, 977, 826, 824, 325, 839, + 771, 1006, 899, 288, 179, 1012, 897, 796, 965, 843, + 994, 885, 296, 841, 183, 838, 844, 883, 338, 974, + 980, 781, 186, 298, 991, 863, 876, 702, 0, 377, + 952, 449, 683, 265, 938, 376, 300, 442, 966, 1014, + 448, 886, 424, 458, 463, 258, 919, 222, 405, 248, + 241, 868, 984, 831, 271, 360, 236, 292, 902, 958, + 864, 228, 969, 945, 996, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 992, 979, 998, 859, + 845, 851, 846, 875, 1015, 280, 272, 999, 997, 877, + 346, 212, 929, 922, 915, 785, 452, 1030, 244, 981, + 454, 168, 391, 390, 889, 279, 982, 169, 159, 370, + 170, 289, 192, 1002, 467, 208, 294, 432, 682, 264, + 337, 954, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 978, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 1021, 307, 253, 257, 273, 284, + 953, 374, 412, 455, 947, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 976, + 204, 198, 1010, 993, 940, 904, 910, 833, 0, 197, + 905, 906, 907, 908, 909, 972, 866, 878, 858, 948, + 857, 268, 964, 703, 704, 233, 774, 1025, 199, 840, + 1024, 334, 341, 333, 1027, 1026, 441, 1011, 941, 928, + 926, 834, 1009, 939, 927, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 930, 410, 305, 0, + 194, 0, 409, 1019, 1036, 421, 214, 852, 986, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 968, 1033, 345, 378, 221, 451, 406, 249, + 850, 1037, 797, 786, 787, 790, 933, 934, 788, 791, + 792, 799, 772, 773, 775, 777, 778, 779, 921, 1013, + 835, 782, 989, 793, 794, 795, 961, 1031, 770, 229, + 719, 811, 812, 813, 720, 814, 815, 721, 722, 816, + 817, 818, 819, 723, 820, 821, 822, 800, 801, 802, + 803, 804, 805, 806, 807, 810, 808, 809, 0, 917, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 780, 187, 200, 297, 1032, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 987, 944, + 0, 894, 896, 895, 854, 856, 855, 853, 1035, 331, + 1005, 823, 830, 849, 860, 865, 871, 879, 880, 888, + 893, 903, 912, 913, 923, 936, 937, 943, 967, 970, + 983, 988, 995, 1000, 1001, 453, 239, 920, 942, 973, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 900, 184, 0, 190, 0, 191, 193, + 887, 189, 1004, 1028, 949, 963, 874, 1016, 0, 0, + 430, 776, 1020, 861, 884, 1029, 890, 892, 957, 836, + 932, 342, 881, 837, 0, 0, 0, 0, 828, 680, + 829, 862, 246, 679, 990, 935, 1018, 918, 950, 960, + 245, 231, 925, 924, 1007, 873, 872, 955, 1003, 1017, + 0, 0, 161, 459, 178, 784, 299, 0, 0, 457, + 408, 324, 0, 0, 916, 0, 768, 769, 901, 959, + 848, 946, 1022, 882, 951, 1023, 94, 0, 0, 0, + 0, 705, 537, 706, 708, 709, 710, 711, 0, 0, + 160, 707, 712, 713, 714, 0, 911, 956, 1034, 827, + 677, 694, 832, 783, 0, 1008, 869, 870, 250, 0, + 0, 0, 0, 0, 0, 0, 914, 931, 975, 898, + 0, 450, 962, 971, 985, 891, 361, 270, 0, 0, + 0, 0, 691, 692, 2193, 0, 0, 0, 798, 0, + 693, 0, 842, 689, 726, 727, 728, 729, 730, 731, + 732, 733, 734, 735, 736, 737, 738, 739, 740, 741, + 742, 743, 744, 745, 746, 747, 748, 749, 750, 751, + 752, 753, 754, 755, 756, 757, 758, 759, 760, 761, + 762, 763, 764, 765, 766, 767, 695, 0, 0, 0, + 847, 825, 867, 977, 826, 824, 325, 839, 771, 1006, + 899, 288, 179, 1012, 897, 796, 965, 843, 994, 885, + 296, 841, 183, 838, 844, 883, 338, 974, 980, 781, + 186, 298, 991, 863, 876, 702, 0, 377, 952, 449, + 683, 265, 938, 376, 300, 442, 966, 1014, 448, 886, + 424, 458, 463, 258, 919, 222, 405, 248, 241, 868, + 984, 831, 271, 360, 236, 292, 902, 958, 864, 228, + 969, 945, 996, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 992, 979, 998, 859, 845, 851, + 846, 875, 1015, 280, 272, 999, 997, 877, 346, 212, + 929, 922, 915, 785, 452, 1030, 244, 981, 454, 168, + 391, 390, 889, 279, 982, 169, 159, 370, 170, 289, + 192, 1002, 467, 208, 294, 432, 682, 264, 337, 954, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 978, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 1021, 307, 253, 257, 273, 284, 953, 374, + 412, 455, 947, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 976, 204, 198, + 1010, 993, 940, 904, 910, 833, 0, 197, 905, 906, + 907, 908, 909, 972, 866, 878, 858, 948, 857, 268, + 964, 703, 704, 233, 774, 1025, 199, 840, 1024, 334, + 341, 333, 1027, 1026, 441, 1011, 941, 928, 926, 834, + 1009, 939, 927, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 930, 410, 305, 0, 194, 0, + 409, 1019, 1036, 421, 214, 852, 986, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 968, 1033, 345, 378, 221, 451, 406, 249, 850, 1037, + 797, 786, 787, 790, 933, 934, 788, 791, 792, 799, + 772, 773, 775, 777, 778, 779, 921, 1013, 835, 782, + 989, 793, 794, 795, 961, 1031, 770, 229, 719, 811, + 812, 813, 720, 814, 815, 721, 722, 816, 817, 818, + 819, 723, 820, 821, 822, 800, 801, 802, 803, 804, + 805, 806, 807, 810, 808, 809, 0, 917, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 780, 187, 200, 297, 1032, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 987, 944, 0, 894, + 896, 895, 854, 856, 855, 853, 1035, 331, 1005, 823, + 830, 849, 860, 865, 871, 879, 880, 888, 893, 903, + 912, 913, 923, 936, 937, 943, 967, 970, 983, 988, + 995, 1000, 1001, 453, 239, 920, 942, 973, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 900, 184, 0, 190, 0, 191, 193, 887, 189, + 1004, 1028, 949, 963, 874, 1016, 0, 0, 430, 776, + 1020, 861, 884, 1029, 890, 892, 957, 836, 932, 342, + 881, 837, 0, 0, 0, 0, 828, 680, 829, 862, + 246, 679, 990, 935, 1018, 918, 950, 960, 245, 231, + 925, 924, 1007, 873, 872, 955, 1003, 1017, 0, 0, + 161, 459, 178, 784, 299, 0, 0, 457, 408, 324, + 0, 0, 916, 0, 768, 769, 901, 959, 848, 946, + 1022, 882, 951, 1023, 94, 0, 0, 0, 0, 705, + 537, 706, 708, 709, 710, 711, 0, 0, 160, 707, + 712, 713, 714, 0, 911, 956, 1034, 827, 677, 694, + 832, 783, 0, 1008, 869, 870, 250, 0, 0, 0, + 0, 0, 0, 0, 914, 931, 975, 898, 0, 450, + 962, 971, 985, 891, 361, 270, 0, 0, 0, 0, + 691, 692, 673, 0, 0, 0, 798, 0, 693, 0, + 842, 689, 726, 727, 728, 729, 730, 731, 732, 733, + 734, 735, 736, 737, 738, 739, 740, 741, 742, 743, + 744, 745, 746, 747, 748, 749, 750, 751, 752, 753, + 754, 755, 756, 757, 758, 759, 760, 761, 762, 763, + 764, 765, 766, 767, 695, 0, 0, 0, 847, 825, + 867, 977, 826, 824, 325, 839, 771, 1006, 899, 288, + 179, 1012, 897, 796, 965, 843, 994, 885, 296, 841, + 183, 838, 844, 883, 338, 974, 980, 781, 186, 298, + 991, 863, 876, 702, 0, 377, 952, 449, 683, 265, + 938, 376, 300, 442, 966, 1014, 448, 886, 424, 458, + 463, 258, 919, 222, 405, 248, 241, 868, 984, 831, + 271, 360, 236, 292, 902, 958, 864, 228, 969, 945, + 996, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 992, 979, 998, 859, 845, 851, 846, 875, + 1015, 280, 272, 999, 997, 877, 346, 212, 929, 922, + 915, 785, 452, 1030, 244, 981, 454, 168, 391, 390, + 889, 279, 982, 169, 159, 370, 170, 289, 192, 1002, + 467, 208, 294, 432, 682, 264, 337, 954, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 978, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 1021, 307, 253, 257, 273, 284, 953, 374, 412, 455, + 947, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 976, 204, 198, 1010, 993, + 940, 904, 910, 833, 0, 197, 905, 906, 907, 908, + 909, 972, 866, 878, 858, 948, 857, 268, 964, 703, + 704, 233, 774, 1025, 199, 840, 1024, 334, 341, 333, + 1027, 1026, 441, 1011, 941, 928, 926, 834, 1009, 939, + 927, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 930, 410, 305, 0, 194, 0, 409, 1019, + 1036, 421, 214, 852, 986, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 968, 1033, + 345, 378, 221, 451, 406, 249, 850, 1037, 797, 786, + 787, 790, 933, 934, 788, 791, 792, 799, 772, 773, + 775, 777, 778, 779, 921, 1013, 835, 782, 989, 793, + 794, 795, 961, 1031, 770, 229, 719, 811, 812, 813, + 720, 814, 815, 721, 722, 816, 817, 818, 819, 723, + 820, 821, 822, 800, 801, 802, 803, 804, 805, 806, + 807, 810, 808, 809, 0, 917, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 780, 187, + 200, 297, 1032, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 987, 944, 0, 894, 896, 895, + 854, 856, 855, 853, 1035, 331, 1005, 823, 830, 849, + 860, 865, 871, 879, 880, 888, 893, 903, 912, 913, + 923, 936, 937, 943, 967, 970, 983, 988, 995, 1000, + 1001, 453, 239, 920, 942, 973, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 900, + 184, 0, 190, 0, 191, 193, 887, 189, 1004, 1028, + 949, 963, 874, 1016, 0, 0, 430, 776, 1020, 861, + 884, 1029, 890, 892, 957, 836, 932, 342, 881, 837, + 0, 0, 0, 0, 828, 680, 829, 862, 246, 679, + 990, 935, 1018, 918, 950, 960, 245, 231, 925, 924, + 1007, 873, 872, 955, 1003, 1017, 0, 0, 161, 459, + 178, 784, 299, 0, 0, 457, 408, 324, 0, 0, + 916, 0, 768, 769, 901, 959, 848, 946, 1022, 882, + 2398, 1023, 94, 0, 0, 0, 0, 2400, 537, 706, + 708, 709, 710, 711, 0, 0, 160, 707, 712, 713, + 714, 2399, 911, 956, 1034, 827, 677, 694, 832, 783, + 0, 1008, 869, 870, 250, 0, 0, 0, 0, 0, + 0, 0, 914, 931, 975, 898, 0, 450, 962, 971, + 985, 891, 361, 270, 0, 0, 0, 0, 691, 692, + 0, 0, 0, 0, 798, 0, 693, 0, 842, 689, + 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, + 736, 737, 738, 739, 740, 741, 742, 743, 744, 745, + 746, 747, 748, 749, 750, 751, 752, 753, 754, 755, + 756, 757, 758, 759, 760, 761, 762, 763, 764, 765, + 766, 767, 695, 0, 0, 0, 847, 825, 867, 977, + 826, 824, 325, 839, 771, 1006, 899, 288, 179, 1012, + 897, 796, 965, 843, 994, 885, 296, 841, 183, 838, + 844, 883, 338, 974, 980, 781, 186, 298, 991, 863, + 876, 702, 0, 377, 952, 449, 683, 265, 938, 376, + 300, 442, 966, 1014, 448, 886, 424, 458, 463, 258, + 919, 222, 405, 248, 241, 868, 984, 831, 271, 360, + 236, 292, 902, 958, 864, 228, 969, 945, 996, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 992, 979, 998, 859, 845, 851, 846, 875, 1015, 280, + 272, 999, 997, 877, 346, 212, 929, 922, 915, 785, + 452, 1030, 244, 981, 454, 168, 391, 390, 889, 279, + 982, 169, 159, 370, 170, 289, 192, 1002, 467, 208, + 294, 432, 682, 264, 337, 954, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 978, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 1021, 307, + 253, 257, 273, 284, 953, 374, 412, 455, 947, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 976, 204, 198, 1010, 993, 940, 904, + 910, 833, 0, 197, 905, 906, 907, 908, 909, 972, + 866, 878, 858, 948, 857, 268, 964, 703, 704, 233, + 774, 1025, 199, 840, 1024, 334, 341, 333, 1027, 1026, + 441, 1011, 941, 928, 926, 834, 1009, 939, 927, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 930, 410, 305, 0, 194, 0, 409, 1019, 1036, 421, + 214, 852, 986, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 968, 1033, 345, 378, + 221, 451, 406, 249, 850, 1037, 797, 786, 787, 790, + 933, 934, 788, 791, 792, 799, 772, 773, 775, 777, + 778, 779, 921, 1013, 835, 782, 989, 793, 794, 795, + 961, 1031, 770, 229, 719, 811, 812, 813, 720, 814, + 815, 721, 722, 816, 817, 818, 819, 723, 820, 821, + 822, 800, 801, 802, 803, 804, 805, 806, 807, 810, + 808, 809, 0, 917, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 780, 187, 200, 297, + 1032, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 987, 944, 0, 894, 896, 895, 854, 856, + 855, 853, 1035, 331, 1005, 823, 830, 849, 860, 865, + 871, 879, 880, 888, 893, 903, 912, 913, 923, 936, + 937, 943, 967, 970, 983, 988, 995, 1000, 1001, 453, + 239, 920, 942, 973, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 900, 184, 0, + 190, 0, 191, 193, 887, 189, 1004, 1028, 949, 963, + 874, 1016, 0, 0, 430, 776, 1020, 861, 884, 1029, + 890, 892, 957, 836, 932, 342, 881, 837, 0, 0, + 0, 0, 828, 680, 829, 862, 246, 679, 990, 935, + 1018, 918, 950, 960, 245, 231, 925, 924, 1007, 873, + 872, 955, 1003, 1017, 0, 0, 161, 459, 178, 784, + 299, 0, 0, 457, 408, 324, 0, 0, 916, 0, + 768, 769, 901, 959, 848, 946, 1022, 882, 951, 1023, + 94, 0, 0, 0, 0, 2303, 537, 706, 708, 709, + 710, 711, 0, 0, 160, 707, 712, 713, 714, 0, + 911, 956, 1034, 827, 677, 694, 832, 783, 0, 1008, + 869, 870, 250, 0, 0, 0, 0, 0, 0, 0, + 914, 931, 975, 898, 0, 450, 962, 971, 985, 891, + 361, 270, 0, 0, 0, 0, 691, 692, 2193, 0, + 0, 0, 798, 0, 693, 0, 842, 689, 726, 727, + 728, 729, 730, 731, 732, 733, 734, 735, 736, 737, + 738, 739, 740, 741, 742, 743, 744, 745, 746, 747, + 748, 749, 750, 751, 752, 753, 754, 755, 756, 757, + 758, 759, 760, 761, 762, 763, 764, 765, 766, 767, + 695, 0, 0, 0, 847, 825, 867, 977, 826, 824, + 325, 839, 771, 1006, 899, 288, 179, 1012, 897, 796, + 965, 843, 994, 885, 296, 841, 183, 838, 844, 883, + 338, 974, 980, 781, 186, 298, 991, 863, 876, 702, + 0, 377, 952, 449, 683, 265, 938, 376, 300, 442, + 966, 1014, 448, 886, 424, 458, 463, 258, 919, 222, + 405, 248, 241, 868, 984, 831, 271, 360, 236, 292, + 902, 958, 864, 228, 969, 945, 996, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 992, 979, + 998, 859, 845, 851, 846, 875, 1015, 280, 272, 999, + 997, 877, 346, 212, 929, 922, 915, 785, 452, 1030, + 244, 981, 454, 168, 391, 390, 889, 279, 982, 169, + 159, 370, 170, 289, 192, 1002, 467, 208, 294, 432, + 682, 264, 337, 954, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 978, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 1021, 307, 253, 257, + 273, 284, 953, 374, 412, 455, 947, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 976, 204, 198, 1010, 993, 940, 904, 910, 833, + 0, 197, 905, 906, 907, 908, 909, 972, 866, 878, + 858, 948, 857, 268, 964, 703, 704, 233, 774, 1025, + 199, 840, 1024, 334, 341, 333, 1027, 1026, 441, 1011, + 941, 928, 926, 834, 1009, 939, 927, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 930, 410, + 305, 0, 194, 0, 409, 1019, 1036, 421, 214, 852, + 986, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 968, 1033, 345, 378, 221, 451, + 406, 249, 850, 1037, 797, 786, 787, 790, 933, 934, + 788, 791, 792, 799, 772, 773, 775, 777, 778, 779, + 921, 1013, 835, 782, 989, 793, 794, 795, 961, 1031, + 770, 229, 719, 811, 812, 813, 720, 814, 815, 721, + 722, 816, 817, 818, 819, 723, 820, 821, 822, 800, + 801, 802, 803, 804, 805, 806, 807, 810, 808, 809, + 0, 917, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 780, 187, 200, 297, 1032, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 987, 944, 0, 894, 896, 895, 854, 856, 855, 853, + 1035, 331, 1005, 823, 830, 849, 860, 865, 871, 879, + 880, 888, 893, 903, 912, 913, 923, 936, 937, 943, + 967, 970, 983, 988, 995, 1000, 1001, 453, 239, 920, + 942, 973, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 900, 184, 0, 190, 0, + 191, 193, 887, 189, 1004, 1028, 949, 963, 874, 1016, + 0, 0, 430, 776, 1020, 861, 884, 1029, 890, 892, + 957, 836, 932, 342, 881, 837, 0, 0, 0, 0, + 828, 680, 829, 862, 246, 679, 990, 935, 1018, 918, + 950, 960, 245, 231, 925, 924, 1007, 873, 872, 955, + 1003, 1017, 0, 0, 161, 459, 178, 784, 299, 0, + 0, 457, 408, 324, 0, 0, 916, 0, 768, 769, + 901, 959, 848, 946, 1022, 882, 951, 1023, 94, 0, + 0, 0, 0, 2300, 537, 706, 708, 709, 710, 711, + 0, 0, 160, 707, 712, 713, 714, 0, 911, 956, + 1034, 827, 677, 694, 832, 783, 0, 1008, 869, 870, + 250, 0, 0, 0, 0, 0, 0, 0, 914, 931, + 975, 898, 0, 450, 962, 971, 985, 891, 361, 270, + 0, 0, 0, 0, 691, 692, 2193, 0, 0, 0, + 798, 0, 693, 0, 842, 689, 726, 727, 728, 729, + 730, 731, 732, 733, 734, 735, 736, 737, 738, 739, + 740, 741, 742, 743, 744, 745, 746, 747, 748, 749, + 750, 751, 752, 753, 754, 755, 756, 757, 758, 759, + 760, 761, 762, 763, 764, 765, 766, 767, 695, 0, + 0, 0, 847, 825, 867, 977, 826, 824, 325, 839, + 771, 1006, 899, 288, 179, 1012, 897, 796, 965, 843, + 994, 885, 296, 841, 183, 838, 844, 883, 338, 974, + 980, 781, 186, 298, 991, 863, 876, 702, 0, 377, + 952, 449, 683, 265, 938, 376, 300, 442, 966, 1014, + 448, 886, 424, 458, 463, 258, 919, 222, 405, 248, + 241, 868, 984, 831, 271, 360, 236, 292, 902, 958, + 864, 228, 969, 945, 996, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 992, 979, 998, 859, + 845, 851, 846, 875, 1015, 280, 272, 999, 997, 877, + 346, 212, 929, 922, 915, 785, 452, 1030, 244, 981, + 454, 168, 391, 390, 889, 279, 982, 169, 159, 370, + 170, 289, 192, 1002, 467, 208, 294, 432, 682, 264, + 337, 954, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 978, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 1021, 307, 253, 257, 273, 284, + 953, 374, 412, 455, 947, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 976, + 204, 198, 1010, 993, 940, 904, 910, 833, 0, 197, + 905, 906, 907, 908, 909, 972, 866, 878, 858, 948, + 857, 268, 964, 703, 704, 233, 774, 1025, 199, 840, + 1024, 334, 341, 333, 1027, 1026, 441, 1011, 941, 928, + 926, 834, 1009, 939, 927, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 930, 410, 305, 0, + 194, 0, 409, 1019, 1036, 421, 214, 852, 986, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 968, 1033, 345, 378, 221, 451, 406, 249, + 850, 1037, 797, 786, 787, 790, 933, 934, 788, 791, + 792, 799, 772, 773, 775, 777, 778, 779, 921, 1013, + 835, 782, 989, 793, 794, 795, 961, 1031, 770, 229, + 719, 811, 812, 813, 720, 814, 815, 721, 722, 816, + 817, 818, 819, 723, 820, 821, 822, 800, 801, 802, + 803, 804, 805, 806, 807, 810, 808, 809, 0, 917, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 780, 187, 200, 297, 1032, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 987, 944, + 0, 894, 896, 895, 854, 856, 855, 853, 1035, 331, + 1005, 823, 830, 849, 860, 865, 871, 879, 880, 888, + 893, 903, 912, 913, 923, 936, 937, 943, 967, 970, + 983, 988, 995, 1000, 1001, 453, 239, 920, 942, 973, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 900, 184, 0, 190, 0, 191, 193, + 887, 189, 1004, 1028, 949, 963, 874, 1016, 0, 40, + 430, 776, 1020, 861, 884, 1029, 890, 892, 957, 836, + 932, 342, 881, 837, 0, 0, 0, 0, 828, 680, + 829, 862, 246, 679, 990, 935, 1018, 918, 950, 960, + 245, 231, 925, 924, 1007, 873, 872, 955, 1003, 1017, + 0, 0, 161, 459, 178, 784, 299, 0, 0, 457, + 408, 324, 0, 0, 916, 0, 768, 769, 901, 959, + 848, 946, 1022, 882, 951, 1023, 94, 0, 0, 0, + 0, 705, 537, 706, 708, 709, 710, 711, 0, 0, + 160, 707, 712, 713, 714, 0, 911, 956, 1034, 827, + 677, 694, 832, 783, 0, 1008, 869, 870, 250, 0, + 0, 0, 0, 0, 0, 0, 914, 931, 975, 898, + 0, 450, 962, 971, 985, 891, 361, 270, 0, 0, + 0, 0, 691, 692, 0, 0, 0, 0, 798, 0, + 693, 0, 842, 689, 726, 727, 728, 729, 730, 731, + 732, 733, 734, 735, 736, 737, 738, 739, 740, 741, + 742, 743, 744, 745, 746, 747, 748, 749, 750, 751, + 752, 753, 754, 755, 756, 757, 758, 759, 760, 761, + 762, 763, 764, 765, 766, 767, 695, 0, 0, 0, + 847, 825, 867, 977, 826, 824, 325, 839, 771, 1510, + 899, 288, 179, 1012, 897, 796, 965, 843, 994, 885, + 296, 841, 183, 838, 844, 883, 338, 974, 980, 781, + 186, 298, 991, 863, 876, 702, 0, 377, 952, 449, + 683, 265, 938, 376, 300, 442, 966, 1014, 448, 886, + 424, 458, 463, 258, 919, 222, 405, 248, 241, 868, + 984, 831, 271, 360, 236, 292, 902, 958, 864, 228, + 969, 945, 996, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 992, 979, 998, 859, 845, 851, + 846, 875, 1015, 280, 272, 999, 997, 877, 346, 212, + 929, 922, 915, 785, 452, 1030, 244, 981, 454, 168, + 391, 390, 889, 279, 982, 169, 159, 370, 170, 289, + 192, 1002, 467, 208, 294, 432, 682, 264, 337, 954, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 978, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 1021, 307, 253, 257, 273, 284, 953, 374, + 412, 455, 947, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 976, 204, 198, + 1010, 993, 940, 904, 910, 833, 0, 197, 905, 906, + 907, 908, 909, 972, 866, 878, 858, 948, 857, 268, + 964, 703, 704, 233, 774, 1025, 199, 840, 1024, 334, + 341, 333, 1027, 1026, 441, 1011, 941, 928, 926, 834, + 1009, 939, 927, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 930, 410, 305, 0, 194, 0, + 409, 1019, 1036, 421, 214, 852, 986, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 968, 1033, 345, 378, 221, 451, 406, 249, 850, 1037, + 797, 786, 787, 790, 933, 934, 788, 791, 792, 799, + 772, 773, 775, 777, 778, 779, 921, 1013, 835, 782, + 989, 793, 794, 795, 961, 1031, 770, 229, 719, 811, + 812, 813, 720, 814, 815, 721, 722, 816, 817, 818, + 819, 723, 820, 821, 822, 800, 801, 802, 803, 804, + 805, 806, 807, 810, 808, 809, 0, 917, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 780, 187, 200, 297, 1508, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 987, 944, 0, 894, + 896, 895, 854, 856, 855, 853, 1035, 331, 1005, 823, + 830, 849, 860, 865, 871, 879, 880, 888, 893, 903, + 912, 913, 923, 936, 937, 943, 967, 970, 983, 988, + 995, 1000, 1001, 453, 239, 920, 942, 973, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 900, 184, 0, 190, 0, 191, 193, 887, 189, + 1004, 1028, 949, 963, 874, 1016, 0, 0, 430, 776, + 1020, 861, 884, 1029, 890, 892, 957, 836, 932, 342, + 881, 837, 0, 0, 0, 0, 828, 680, 829, 862, + 246, 679, 990, 935, 1018, 918, 950, 960, 245, 231, + 925, 924, 1007, 873, 872, 955, 1003, 1017, 0, 0, + 161, 459, 178, 784, 299, 0, 0, 457, 408, 324, + 0, 0, 916, 0, 768, 769, 901, 959, 848, 946, + 1022, 882, 951, 1023, 94, 0, 2065, 0, 0, 705, + 537, 706, 708, 709, 710, 711, 0, 0, 160, 707, + 712, 713, 714, 0, 911, 956, 1034, 827, 677, 694, + 832, 783, 0, 1008, 869, 870, 250, 0, 0, 0, + 0, 0, 0, 0, 914, 931, 975, 898, 0, 450, + 962, 971, 985, 891, 361, 270, 0, 0, 0, 0, + 691, 692, 0, 0, 0, 0, 798, 0, 693, 0, + 842, 689, 726, 727, 728, 729, 730, 731, 732, 733, + 734, 735, 736, 737, 738, 739, 740, 741, 742, 743, + 744, 745, 746, 747, 748, 749, 750, 751, 752, 753, + 754, 755, 756, 757, 758, 759, 760, 761, 762, 763, + 764, 765, 766, 767, 695, 0, 0, 0, 847, 825, + 867, 977, 826, 824, 325, 839, 771, 1006, 899, 288, + 179, 1012, 897, 796, 965, 843, 994, 885, 296, 841, + 183, 838, 844, 883, 338, 974, 980, 781, 186, 298, + 991, 863, 876, 702, 0, 377, 952, 449, 683, 265, + 938, 376, 300, 442, 966, 1014, 448, 886, 424, 458, + 463, 258, 919, 222, 405, 248, 241, 868, 984, 831, + 271, 360, 236, 292, 902, 958, 864, 228, 969, 945, + 996, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 992, 979, 998, 859, 845, 851, 846, 875, + 1015, 280, 272, 999, 997, 877, 346, 212, 929, 922, + 915, 785, 452, 1030, 244, 981, 454, 168, 391, 390, + 889, 279, 982, 169, 159, 370, 170, 289, 192, 1002, + 467, 208, 294, 432, 682, 264, 337, 954, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 978, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 1021, 307, 253, 257, 273, 284, 953, 374, 412, 455, + 947, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 976, 204, 198, 1010, 993, + 940, 904, 910, 833, 0, 197, 905, 906, 907, 908, + 909, 972, 866, 878, 858, 948, 857, 268, 964, 703, + 704, 233, 774, 1025, 199, 840, 1024, 334, 341, 333, + 1027, 1026, 441, 1011, 941, 928, 926, 834, 1009, 939, + 927, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 930, 410, 305, 0, 194, 0, 409, 1019, + 1036, 421, 214, 852, 986, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 968, 1033, + 345, 378, 221, 451, 406, 249, 850, 1037, 797, 786, + 787, 790, 933, 934, 788, 791, 792, 799, 772, 773, + 775, 777, 778, 779, 921, 1013, 835, 782, 989, 793, + 794, 795, 961, 1031, 770, 229, 719, 811, 812, 813, + 720, 814, 815, 721, 722, 816, 817, 818, 819, 723, + 820, 821, 822, 800, 801, 802, 803, 804, 805, 806, + 807, 810, 808, 809, 0, 917, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 780, 187, + 200, 297, 1032, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 987, 944, 0, 894, 896, 895, + 854, 856, 855, 853, 1035, 331, 1005, 823, 830, 849, + 860, 865, 871, 879, 880, 888, 893, 903, 912, 913, + 923, 936, 937, 943, 967, 970, 983, 988, 995, 1000, + 1001, 453, 239, 920, 942, 973, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 900, + 184, 0, 190, 0, 191, 193, 887, 189, 1004, 1028, + 949, 963, 874, 1016, 0, 0, 430, 776, 1020, 861, + 884, 1029, 890, 892, 957, 836, 932, 342, 881, 837, + 0, 0, 0, 0, 828, 680, 829, 862, 246, 679, + 990, 935, 1018, 918, 950, 960, 245, 231, 925, 924, + 1007, 873, 872, 955, 1003, 1017, 0, 0, 161, 459, + 178, 784, 299, 0, 0, 457, 408, 324, 0, 0, + 916, 0, 768, 769, 901, 959, 848, 946, 1022, 882, + 951, 1023, 94, 0, 0, 0, 0, 705, 537, 706, + 708, 709, 710, 711, 0, 0, 160, 707, 712, 713, + 714, 0, 911, 956, 1034, 827, 677, 694, 832, 783, + 0, 1008, 869, 870, 250, 0, 0, 0, 0, 0, + 0, 0, 914, 931, 975, 898, 0, 450, 962, 971, + 985, 891, 361, 270, 0, 0, 0, 0, 691, 692, + 0, 0, 0, 0, 798, 0, 693, 0, 842, 689, + 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, + 736, 737, 738, 739, 740, 741, 742, 743, 744, 745, + 746, 747, 748, 749, 750, 751, 752, 753, 754, 755, + 756, 757, 758, 759, 760, 761, 762, 763, 764, 765, + 766, 767, 695, 0, 0, 0, 847, 825, 867, 977, + 826, 824, 325, 839, 771, 1006, 899, 288, 179, 1012, + 897, 796, 965, 843, 994, 885, 296, 841, 183, 838, + 844, 883, 338, 974, 980, 781, 186, 298, 991, 863, + 876, 702, 0, 377, 952, 449, 683, 265, 938, 376, + 300, 442, 966, 1014, 448, 886, 424, 458, 463, 258, + 919, 222, 405, 248, 241, 868, 984, 831, 271, 360, + 236, 292, 902, 958, 864, 228, 969, 945, 996, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 992, 979, 998, 859, 845, 851, 846, 875, 1015, 280, + 272, 999, 997, 877, 346, 212, 929, 922, 915, 785, + 452, 1030, 244, 981, 454, 168, 391, 390, 889, 279, + 982, 169, 159, 370, 170, 289, 192, 1002, 467, 208, + 294, 432, 682, 264, 337, 954, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 978, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 1021, 307, + 253, 257, 273, 284, 953, 374, 412, 455, 947, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 976, 204, 198, 1010, 993, 940, 904, + 910, 833, 0, 197, 905, 906, 907, 908, 909, 972, + 866, 878, 858, 948, 857, 268, 964, 703, 704, 233, + 774, 1025, 199, 840, 1024, 334, 341, 333, 1027, 1026, + 441, 1011, 941, 928, 926, 834, 1009, 939, 927, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 930, 410, 305, 0, 194, 0, 409, 1019, 1036, 421, + 214, 852, 986, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 968, 1033, 345, 378, + 221, 451, 406, 249, 850, 1037, 797, 786, 787, 790, + 933, 934, 788, 791, 792, 799, 772, 773, 775, 777, + 778, 779, 921, 1013, 835, 782, 989, 793, 794, 795, + 961, 1031, 770, 229, 719, 811, 812, 813, 720, 814, + 815, 721, 722, 816, 817, 818, 819, 723, 820, 821, + 822, 800, 801, 802, 803, 804, 805, 806, 807, 810, + 808, 809, 0, 917, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 780, 187, 200, 297, + 1032, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 987, 944, 0, 894, 896, 895, 854, 856, + 855, 853, 1035, 331, 1005, 823, 830, 849, 860, 865, + 871, 879, 880, 888, 893, 903, 912, 913, 923, 936, + 937, 943, 967, 970, 983, 988, 995, 1000, 1001, 453, + 239, 920, 942, 973, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 900, 184, 0, + 190, 0, 191, 193, 887, 189, 1004, 1028, 949, 963, + 874, 1016, 0, 0, 430, 776, 1020, 861, 884, 1029, + 890, 892, 957, 836, 932, 342, 881, 837, 0, 0, + 0, 0, 828, 1077, 829, 862, 246, 1075, 990, 935, + 1018, 918, 950, 960, 245, 231, 925, 924, 1007, 873, + 872, 955, 1003, 1017, 0, 0, 161, 459, 178, 784, + 299, 0, 0, 457, 408, 324, 0, 0, 916, 0, + 768, 769, 901, 959, 848, 946, 1022, 882, 951, 1023, + 94, 0, 0, 0, 0, 705, 537, 706, 708, 709, + 710, 711, 0, 0, 160, 707, 712, 713, 714, 0, + 911, 956, 1034, 827, 1094, 694, 832, 783, 0, 1008, + 869, 870, 250, 0, 0, 0, 0, 0, 0, 0, + 914, 931, 975, 898, 0, 450, 962, 971, 985, 891, + 361, 270, 0, 0, 0, 0, 691, 692, 0, 0, + 0, 0, 798, 0, 693, 0, 842, 689, 726, 727, + 728, 729, 730, 731, 732, 733, 734, 735, 736, 737, + 738, 739, 740, 741, 742, 743, 744, 745, 746, 747, + 748, 749, 750, 751, 752, 753, 754, 755, 756, 757, + 758, 759, 760, 761, 762, 763, 764, 765, 766, 767, + 695, 0, 0, 0, 847, 825, 867, 977, 826, 824, + 325, 839, 771, 1006, 899, 288, 179, 1012, 897, 796, + 965, 843, 994, 885, 296, 841, 183, 838, 844, 883, + 338, 974, 980, 781, 186, 298, 991, 863, 876, 702, + 0, 377, 952, 449, 683, 265, 938, 376, 300, 442, + 966, 1014, 448, 886, 424, 458, 463, 258, 919, 222, + 405, 248, 241, 868, 984, 831, 271, 360, 236, 292, + 902, 958, 864, 228, 969, 945, 996, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 992, 979, + 998, 859, 845, 851, 846, 875, 1015, 280, 272, 999, + 997, 877, 346, 212, 929, 922, 915, 785, 452, 1030, + 244, 981, 454, 168, 391, 390, 889, 279, 982, 169, + 159, 370, 170, 289, 192, 1002, 467, 208, 294, 432, + 682, 264, 337, 954, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 978, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 1021, 307, 253, 257, + 273, 284, 953, 374, 412, 455, 947, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 976, 204, 198, 1010, 993, 940, 904, 910, 833, + 0, 197, 905, 906, 907, 908, 909, 972, 866, 878, + 858, 948, 857, 268, 964, 703, 704, 233, 774, 1025, + 199, 840, 1024, 334, 341, 333, 1027, 1026, 441, 1011, + 941, 928, 926, 834, 1009, 939, 927, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 930, 410, + 305, 0, 194, 0, 409, 1019, 1036, 421, 214, 852, + 986, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 968, 1033, 345, 378, 221, 451, + 406, 249, 850, 1037, 797, 786, 787, 790, 933, 934, + 788, 791, 792, 799, 772, 773, 775, 777, 778, 779, + 921, 1013, 835, 782, 989, 793, 794, 795, 961, 1031, + 770, 229, 719, 811, 812, 813, 720, 814, 815, 721, + 722, 816, 817, 818, 819, 723, 820, 821, 822, 800, + 801, 802, 803, 804, 805, 806, 807, 810, 808, 809, + 0, 917, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 780, 187, 200, 297, 1032, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 987, 944, 0, 894, 896, 895, 854, 856, 855, 853, + 1035, 331, 1005, 823, 830, 849, 860, 865, 871, 879, + 880, 888, 893, 903, 912, 913, 923, 936, 937, 943, + 967, 970, 983, 988, 995, 1000, 1001, 453, 239, 920, + 942, 973, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 900, 184, 0, 190, 0, + 191, 193, 887, 189, 1004, 1028, 949, 963, 874, 1016, + 0, 0, 430, 776, 1020, 861, 884, 1029, 890, 892, + 957, 836, 932, 342, 881, 837, 0, 0, 0, 0, + 828, 1077, 829, 862, 246, 1075, 990, 935, 1018, 918, + 950, 960, 245, 231, 925, 924, 1007, 873, 872, 955, + 1003, 1017, 0, 0, 161, 459, 178, 784, 299, 0, + 0, 457, 408, 324, 0, 0, 916, 0, 768, 769, + 901, 959, 848, 946, 1022, 882, 951, 1023, 94, 0, + 0, 0, 0, 705, 537, 706, 708, 709, 710, 711, + 0, 0, 160, 707, 712, 713, 714, 0, 911, 956, + 1034, 827, 1094, 694, 832, 783, 0, 1008, 869, 870, + 250, 0, 0, 0, 0, 0, 0, 0, 914, 931, + 975, 898, 0, 450, 962, 971, 985, 891, 361, 270, + 0, 0, 0, 0, 691, 692, 0, 0, 0, 0, + 798, 0, 693, 0, 842, 689, 726, 727, 728, 729, + 730, 731, 732, 733, 734, 735, 736, 737, 738, 739, + 740, 741, 742, 743, 744, 745, 746, 747, 748, 749, + 750, 751, 752, 753, 754, 755, 756, 757, 758, 759, + 760, 761, 762, 763, 764, 765, 766, 767, 695, 0, + 0, 0, 847, 825, 867, 977, 826, 824, 325, 839, + 771, 1006, 899, 288, 179, 1012, 897, 796, 965, 843, + 994, 885, 296, 841, 183, 838, 844, 883, 338, 974, + 980, 781, 186, 298, 991, 863, 876, 702, 0, 377, + 952, 449, 683, 265, 4381, 376, 300, 442, 966, 1014, + 448, 886, 424, 458, 463, 258, 919, 222, 405, 248, + 241, 868, 984, 831, 271, 360, 236, 292, 902, 958, + 864, 228, 969, 945, 996, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 992, 979, 998, 859, + 845, 851, 846, 875, 1015, 280, 272, 999, 997, 877, + 346, 212, 929, 922, 915, 785, 452, 1030, 244, 981, + 454, 168, 391, 390, 889, 279, 982, 169, 159, 370, + 170, 289, 192, 1002, 467, 208, 294, 432, 682, 264, + 337, 954, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 978, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 1021, 307, 253, 257, 273, 284, + 953, 374, 412, 455, 947, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 976, + 204, 198, 1010, 993, 940, 904, 910, 833, 0, 197, + 905, 906, 907, 908, 909, 972, 866, 878, 858, 948, + 857, 268, 964, 703, 704, 233, 774, 1025, 199, 840, + 1024, 334, 341, 333, 1027, 1026, 441, 1011, 941, 928, + 926, 834, 1009, 939, 927, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 930, 410, 305, 0, + 194, 0, 409, 1019, 1036, 421, 214, 852, 986, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 968, 1033, 345, 378, 221, 451, 406, 249, + 850, 1037, 797, 786, 787, 790, 933, 934, 788, 791, + 792, 799, 772, 773, 775, 777, 778, 779, 921, 1013, + 835, 782, 989, 793, 794, 795, 961, 1031, 770, 229, + 719, 811, 812, 813, 720, 814, 815, 721, 722, 816, + 817, 818, 819, 723, 820, 821, 822, 800, 801, 802, + 803, 804, 805, 806, 807, 810, 808, 809, 0, 917, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 780, 187, 200, 297, 1032, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 987, 944, + 0, 894, 896, 895, 854, 856, 855, 853, 1035, 331, + 1005, 823, 830, 849, 860, 865, 871, 879, 880, 888, + 893, 903, 912, 913, 923, 936, 937, 943, 967, 970, + 983, 988, 995, 1000, 1001, 453, 239, 920, 942, 973, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 900, 184, 0, 190, 0, 191, 193, + 887, 189, 1004, 1028, 949, 963, 874, 1016, 0, 0, + 430, 776, 1020, 861, 884, 1029, 890, 892, 957, 836, + 932, 342, 881, 837, 0, 0, 0, 0, 828, 1077, + 829, 862, 246, 1075, 990, 935, 1018, 918, 950, 960, + 245, 231, 925, 924, 1007, 873, 872, 955, 1003, 1017, + 0, 0, 161, 459, 178, 784, 299, 0, 0, 457, + 408, 324, 0, 0, 916, 0, 768, 769, 901, 959, + 848, 946, 1022, 882, 951, 1023, 94, 0, 0, 0, + 0, 705, 537, 706, 708, 709, 710, 711, 0, 0, + 160, 707, 712, 713, 714, 0, 911, 956, 1034, 827, + 1094, 694, 832, 783, 0, 1008, 869, 870, 250, 0, + 0, 0, 0, 0, 0, 0, 914, 931, 975, 898, + 0, 450, 962, 971, 985, 891, 361, 270, 0, 0, + 0, 0, 691, 692, 0, 0, 0, 0, 798, 0, + 693, 0, 842, 689, 726, 727, 728, 729, 730, 731, + 732, 733, 734, 735, 736, 737, 738, 739, 740, 741, + 742, 743, 744, 745, 746, 747, 748, 749, 750, 751, + 752, 753, 754, 755, 756, 757, 758, 759, 760, 761, + 762, 763, 764, 765, 766, 767, 695, 0, 0, 0, + 847, 825, 867, 977, 826, 824, 325, 839, 771, 1006, + 899, 288, 179, 1012, 897, 796, 965, 843, 994, 885, + 296, 841, 183, 838, 844, 883, 338, 974, 980, 781, + 186, 298, 991, 863, 876, 702, 0, 377, 952, 449, + 683, 265, 938, 376, 300, 442, 966, 1014, 448, 886, + 424, 458, 463, 258, 919, 222, 405, 248, 241, 868, + 984, 831, 271, 360, 236, 292, 902, 958, 864, 228, + 969, 945, 996, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 992, 979, 998, 859, 845, 851, + 846, 875, 1015, 280, 272, 999, 997, 877, 346, 212, + 929, 922, 915, 785, 452, 1030, 244, 981, 454, 168, + 391, 390, 889, 279, 982, 169, 159, 370, 170, 289, + 192, 1002, 467, 208, 294, 432, 682, 264, 337, 954, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 978, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 1021, 307, 253, 257, 273, 284, 953, 374, + 412, 455, 947, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 976, 204, 198, + 1010, 993, 940, 904, 910, 833, 0, 197, 905, 906, + 907, 908, 909, 972, 866, 878, 858, 948, 857, 268, + 964, 703, 704, 233, 774, 1025, 199, 840, 1024, 334, + 341, 333, 1027, 1026, 441, 1011, 941, 928, 926, 834, + 1009, 939, 927, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 930, 410, 305, 0, 194, 0, + 409, 1019, 1036, 421, 214, 852, 986, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 968, 1033, 345, 378, 221, 451, 406, 249, 850, 1037, + 797, 786, 787, 790, 933, 934, 788, 791, 792, 799, + 772, 773, 775, 777, 778, 779, 2306, 2307, 2308, 782, + 989, 793, 794, 795, 961, 1031, 770, 229, 719, 811, + 812, 813, 720, 814, 815, 721, 722, 816, 817, 818, + 819, 723, 820, 821, 822, 800, 801, 802, 803, 804, + 805, 806, 807, 810, 808, 809, 0, 917, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 780, 187, 200, 297, 1032, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 987, 944, 0, 894, + 896, 895, 854, 856, 855, 853, 1035, 331, 1005, 823, + 830, 849, 860, 865, 871, 879, 880, 888, 893, 903, + 912, 913, 923, 936, 937, 943, 967, 970, 983, 988, + 995, 1000, 1001, 453, 239, 920, 942, 973, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 900, 184, 0, 190, 0, 191, 193, 887, 189, + 1004, 1028, 949, 963, 1794, 1973, 0, 3578, 430, 1828, + 1977, 1777, 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, + 1804, 1744, 0, 0, 0, 1782, 1731, 1795, 1732, 1779, + 246, 1775, 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, + 1858, 1857, 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, + 161, 459, 178, 3579, 299, 1949, 478, 3580, 408, 324, + 481, 480, 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, + 1979, 1805, 1891, 1980, 94, 0, 1416, 0, 0, 0, + 1133, 0, 0, 0, 0, 0, 0, 0, 160, 0, + 1887, 1971, 1798, 479, 1838, 1896, 1999, 1730, 1883, 0, + 1735, 1746, 1993, 1964, 1789, 1790, 250, 0, 0, 0, + 0, 0, 0, 0, 1841, 1865, 1917, 1823, 0, 450, + 1902, 1912, 1930, 1815, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 1784, 0, 1880, 0, 0, 0, + 1751, 1737, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1837, 0, 0, 0, 1758, 1728, + 1786, 1919, 1729, 1727, 325, 1747, 1932, 3582, 1824, 288, + 179, 1968, 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, + 183, 1745, 1753, 1806, 338, 1916, 1924, 166, 186, 298, + 1939, 1780, 1797, 232, 2133, 377, 1892, 449, 477, 265, + 1873, 376, 300, 442, 1907, 1970, 448, 1809, 424, 458, + 463, 258, 1849, 222, 405, 248, 241, 1788, 1929, 1734, + 271, 360, 236, 292, 1827, 1898, 1781, 228, 1910, 1881, + 1944, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 1940, 1923, 1946, 1774, 1754, 1765, 1755, 1796, + 1972, 280, 272, 1947, 1945, 1799, 346, 212, 1862, 1855, + 1842, 1920, 452, 1995, 244, 1925, 454, 168, 391, 390, + 1812, 279, 1926, 169, 159, 370, 170, 289, 192, 1951, + 467, 208, 294, 432, 476, 264, 337, 1894, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 1922, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 1978, 307, 253, 257, 273, 284, 1893, 374, 412, 455, + 1884, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 1918, 204, 198, 1966, 1941, + 1875, 1830, 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, + 1835, 1914, 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, + 446, 233, 1748, 1986, 199, 1749, 1985, 334, 341, 333, + 1989, 1987, 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, + 1860, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 1863, 410, 305, 0, 194, 0, 409, 1976, + 2001, 421, 214, 1767, 1933, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 1909, 1998, + 345, 378, 221, 451, 406, 249, 1763, 0, 1766, 1761, + 1764, 1762, 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, + 0, 1959, 1960, 0, 1854, 1969, 1742, 0, 1937, 176, + 177, 163, 1901, 1996, 1814, 229, 153, 1738, 1739, 1740, + 154, 1844, 1845, 156, 157, 1955, 1954, 1953, 1956, 158, + 1990, 1988, 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, + 1886, 1931, 1904, 1913, 1787, 1846, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 1872, 187, + 200, 297, 3581, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 1934, 1879, 0, 1818, 1820, 1819, + 1769, 1771, 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, + 1776, 1783, 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, + 1856, 1870, 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, + 1950, 453, 239, 1852, 1877, 1915, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 1825, + 184, 0, 190, 0, 191, 193, 1810, 189, 1957, 1992, + 1889, 1903, 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, + 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, + 0, 0, 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, + 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, + 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, 161, 459, + 178, 1984, 299, 1949, 478, 457, 408, 324, 481, 480, + 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, + 1891, 1980, 0, 0, 0, 0, 0, 0, 537, 0, + 0, 0, 0, 0, 0, 0, 160, 0, 1887, 1971, + 1798, 479, 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, + 1993, 1964, 1789, 1790, 250, 0, 0, 0, 0, 0, + 0, 0, 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, + 1930, 1815, 361, 270, 0, 0, 0, 0, 0, 0, + 3118, 0, 1784, 0, 1880, 0, 0, 0, 1751, 1737, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1837, 0, 0, 0, 1758, 1728, 1786, 1919, + 1729, 1727, 325, 1747, 1932, 1962, 1824, 288, 179, 1968, + 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, + 1753, 1806, 338, 1916, 1924, 166, 186, 298, 1939, 1780, + 1797, 232, 0, 377, 1892, 449, 2232, 265, 1873, 376, + 300, 442, 1907, 1970, 448, 1809, 424, 458, 463, 258, + 1849, 222, 405, 248, 241, 1788, 1929, 1734, 271, 360, + 236, 292, 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 1940, 1923, 1946, 1774, 1754, 1765, 1755, 1796, 1972, 280, + 272, 1947, 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, + 452, 1995, 244, 1925, 454, 168, 391, 390, 1812, 279, + 1926, 169, 159, 370, 170, 289, 192, 1951, 467, 208, + 294, 432, 2231, 264, 337, 1894, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 1922, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 1978, 307, + 253, 257, 273, 284, 1893, 374, 412, 455, 1884, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 1918, 204, 198, 1966, 1941, 1875, 1830, + 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, + 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, 446, 233, + 1748, 1986, 199, 1749, 1985, 334, 341, 333, 1989, 1987, + 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 1863, 410, 305, 0, 194, 0, 409, 1976, 2001, 421, + 214, 1767, 1933, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 1909, 1998, 345, 378, + 221, 451, 406, 249, 1763, 0, 1766, 1761, 1764, 1762, + 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, + 1960, 0, 1854, 1969, 1742, 0, 1937, 176, 177, 163, + 1901, 1996, 1814, 229, 153, 1738, 1739, 1740, 154, 1844, + 1845, 156, 157, 1955, 1954, 1953, 1956, 158, 1990, 1988, + 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, + 1904, 1913, 1787, 1846, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 1872, 187, 200, 297, + 1997, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, + 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, + 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, + 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, + 239, 1852, 1877, 1915, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 1825, 184, 0, + 190, 0, 191, 193, 1810, 189, 1957, 1992, 1889, 1903, + 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, 1807, 1994, + 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, 0, 0, + 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, 1938, 1869, + 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, 1963, 1793, + 1792, 1895, 1952, 1974, 1847, 0, 161, 459, 178, 1984, + 299, 1949, 478, 457, 408, 324, 481, 480, 1843, 1958, + 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, 1891, 1980, + 0, 0, 0, 0, 0, 0, 1133, 0, 0, 0, + 0, 0, 0, 0, 160, 0, 1887, 1971, 1798, 479, + 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, 1993, 1964, + 1789, 1790, 250, 0, 0, 0, 0, 0, 0, 0, + 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, 1930, 1815, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 1784, 0, 1880, 0, 0, 0, 1751, 1737, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1837, 0, 0, 0, 1758, 1728, 1786, 1919, 1729, 1727, + 325, 1747, 1932, 1962, 1824, 288, 179, 1968, 1822, 1821, + 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, 1753, 1806, + 338, 1916, 1924, 166, 186, 298, 1939, 1780, 1797, 232, + 2133, 377, 1892, 449, 477, 265, 1873, 376, 300, 442, + 1907, 1970, 448, 1809, 424, 458, 463, 258, 1849, 222, + 405, 248, 241, 1788, 1929, 1734, 271, 360, 236, 292, + 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 1940, 1923, + 1946, 1774, 1754, 1765, 1755, 1796, 1972, 280, 272, 1947, + 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, 452, 1995, + 244, 1925, 454, 168, 391, 390, 1812, 279, 1926, 169, + 159, 370, 170, 289, 192, 1951, 467, 208, 294, 432, + 476, 264, 337, 1894, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 1922, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 1978, 307, 253, 257, + 273, 284, 1893, 374, 412, 455, 1884, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 1918, 204, 198, 1966, 1941, 1875, 1830, 1836, 1736, + 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, 1785, 1801, + 1773, 1888, 1772, 268, 1905, 445, 446, 233, 1748, 1986, + 199, 1749, 1985, 334, 341, 333, 1989, 1987, 441, 1967, + 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 1863, 410, + 305, 0, 194, 0, 409, 1976, 2001, 421, 214, 1767, + 1933, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 1909, 1998, 345, 378, 221, 451, + 406, 249, 1763, 0, 1766, 1761, 1764, 1762, 1867, 1868, + 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, 1960, 0, + 1854, 1969, 1742, 0, 1937, 176, 177, 163, 1901, 1996, + 1814, 229, 153, 1738, 1739, 1740, 154, 1844, 1845, 156, + 157, 1955, 1954, 1953, 1956, 158, 1990, 1988, 1991, 1757, + 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, 1904, 1913, + 1787, 1846, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 1872, 187, 200, 297, 1997, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, 1770, 1768, + 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, 1791, 1802, + 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, 1871, 1878, + 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, 239, 1852, + 1877, 1915, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 1825, 184, 0, 190, 0, + 191, 193, 1810, 189, 1957, 1992, 1889, 1903, 1794, 1973, + 0, 1935, 430, 1828, 1977, 1777, 1807, 1994, 1813, 1816, + 1897, 1743, 1866, 342, 1804, 1744, 0, 0, 0, 1782, + 1731, 1795, 1732, 1779, 246, 1775, 1938, 1869, 1975, 1848, + 1890, 1900, 245, 231, 1858, 1857, 1963, 1793, 1792, 1895, + 1952, 1974, 1847, 0, 161, 459, 178, 1984, 299, 1949, + 478, 457, 408, 324, 481, 480, 1843, 1958, 1864, 1927, + 1826, 1899, 1759, 1882, 1979, 1805, 1891, 1980, 0, 0, + 0, 0, 0, 0, 537, 0, 0, 0, 0, 0, + 0, 0, 160, 0, 1887, 1971, 1798, 479, 1838, 1896, + 1999, 1730, 1883, 0, 1735, 1746, 1993, 1964, 1789, 1790, + 250, 0, 0, 0, 0, 0, 0, 0, 1841, 1865, + 1917, 1823, 0, 450, 1902, 1912, 1930, 1815, 361, 270, + 0, 0, 0, 0, 0, 0, 2226, 0, 1784, 0, + 1880, 0, 0, 0, 1751, 1737, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1837, 0, + 0, 0, 1758, 1728, 1786, 1919, 1729, 1727, 325, 1747, + 1932, 1962, 1824, 288, 179, 1968, 1822, 1821, 1906, 1752, + 1942, 1808, 296, 1750, 183, 1745, 1753, 1806, 338, 1916, + 1924, 166, 186, 298, 1939, 1780, 1797, 232, 0, 377, + 1892, 449, 2232, 265, 1873, 376, 300, 442, 1907, 1970, + 448, 1809, 424, 458, 463, 258, 1849, 222, 405, 248, + 241, 1788, 1929, 1734, 271, 360, 236, 292, 1827, 1898, + 1781, 228, 1910, 1881, 1944, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 1940, 1923, 1946, 1774, + 1754, 1765, 1755, 1796, 1972, 280, 272, 1947, 1945, 1799, + 346, 212, 1862, 1855, 1842, 1920, 452, 1995, 244, 1925, + 454, 168, 391, 390, 1812, 279, 1926, 169, 159, 370, + 170, 289, 192, 1951, 467, 208, 294, 432, 2231, 264, + 337, 1894, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 1922, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 1978, 307, 253, 257, 273, 284, + 1893, 374, 412, 455, 1884, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 1918, + 204, 198, 1966, 1941, 1875, 1830, 1836, 1736, 0, 197, + 1831, 1832, 1833, 1834, 1835, 1914, 1785, 1801, 1773, 1888, + 1772, 268, 1905, 445, 446, 233, 1748, 1986, 199, 1749, + 1985, 334, 341, 333, 1989, 1987, 441, 1967, 1876, 1861, + 1859, 1741, 1965, 1874, 1860, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 1863, 410, 305, 0, + 194, 0, 409, 1976, 2001, 421, 214, 1767, 1933, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 1909, 1998, 345, 378, 221, 451, 406, 249, + 1763, 0, 1766, 1761, 1764, 1762, 1867, 1868, 1981, 1982, + 1983, 1921, 1756, 0, 0, 1959, 1960, 0, 1854, 1969, + 1742, 0, 1937, 176, 177, 163, 1901, 1996, 1814, 229, + 153, 1738, 1739, 1740, 154, 1844, 1845, 156, 157, 1955, + 1954, 1953, 1956, 158, 1990, 1988, 1991, 1757, 1778, 1800, + 1850, 1851, 1853, 1885, 1886, 1931, 1904, 1913, 1787, 1846, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 1872, 187, 200, 297, 1997, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 1934, 1879, + 0, 1818, 1820, 1819, 1769, 1771, 1770, 1768, 2000, 331, + 1961, 1726, 1733, 1760, 1776, 1783, 1791, 1802, 1803, 1811, + 1817, 1829, 1839, 1840, 1856, 1870, 1871, 1878, 1908, 1911, + 1928, 1936, 1943, 1948, 1950, 453, 239, 1852, 1877, 1915, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 1825, 184, 0, 190, 0, 191, 193, + 1810, 189, 1957, 1992, 1889, 1903, 1794, 1973, 0, 1935, + 430, 1828, 1977, 1777, 1807, 1994, 1813, 1816, 1897, 1743, + 1866, 342, 1804, 1744, 0, 0, 0, 1782, 1731, 1795, + 1732, 1779, 246, 1775, 1938, 1869, 1975, 1848, 1890, 1900, + 245, 231, 1858, 1857, 1963, 1793, 1792, 1895, 1952, 1974, + 1847, 0, 161, 459, 178, 1984, 299, 1949, 478, 457, + 408, 324, 481, 480, 1843, 1958, 1864, 1927, 1826, 1899, + 1759, 1882, 1979, 1805, 1891, 1980, 0, 0, 0, 0, + 0, 0, 537, 0, 0, 0, 0, 0, 0, 0, + 160, 0, 1887, 1971, 1798, 479, 1838, 1896, 1999, 1730, + 1883, 0, 1735, 1746, 1993, 1964, 1789, 1790, 250, 0, + 0, 0, 0, 0, 0, 0, 1841, 1865, 1917, 1823, + 0, 450, 1902, 1912, 1930, 1815, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 1784, 0, 1880, 0, + 0, 0, 1751, 1737, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1837, 0, 0, 0, + 1758, 1728, 1786, 1919, 1729, 1727, 325, 1747, 1932, 1962, + 1824, 288, 179, 1968, 1822, 1821, 1906, 1752, 1942, 1808, + 296, 1750, 183, 1745, 1753, 1806, 338, 1916, 1924, 166, + 186, 298, 1939, 1780, 1797, 232, 0, 377, 1892, 449, + 2232, 265, 1873, 376, 300, 442, 1907, 1970, 448, 1809, + 424, 458, 463, 258, 1849, 222, 405, 248, 241, 1788, + 1929, 1734, 271, 360, 236, 292, 1827, 1898, 1781, 228, + 1910, 1881, 1944, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 1940, 1923, 1946, 1774, 1754, 1765, + 1755, 1796, 1972, 280, 272, 1947, 1945, 1799, 346, 212, + 1862, 1855, 1842, 1920, 452, 1995, 244, 1925, 454, 168, + 391, 390, 1812, 279, 1926, 169, 159, 370, 170, 289, + 192, 1951, 467, 208, 294, 432, 2231, 264, 337, 1894, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 1922, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 1978, 307, 253, 257, 273, 284, 1893, 374, + 412, 455, 1884, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 1918, 204, 198, + 1966, 1941, 1875, 1830, 1836, 1736, 0, 197, 1831, 1832, + 1833, 1834, 1835, 1914, 1785, 1801, 1773, 1888, 1772, 268, + 1905, 445, 446, 233, 1748, 1986, 199, 1749, 1985, 334, + 341, 333, 1989, 1987, 441, 1967, 1876, 1861, 1859, 1741, + 1965, 1874, 1860, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 1863, 410, 305, 0, 194, 0, + 409, 1976, 2001, 421, 214, 1767, 1933, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 1909, 1998, 345, 378, 221, 451, 406, 249, 1763, 0, + 1766, 1761, 1764, 1762, 1867, 1868, 1981, 1982, 1983, 1921, + 1756, 0, 0, 1959, 1960, 0, 1854, 1969, 1742, 0, + 1937, 176, 177, 163, 1901, 1996, 1814, 229, 153, 1738, + 1739, 1740, 154, 1844, 1845, 156, 157, 1955, 1954, 1953, + 1956, 158, 1990, 1988, 1991, 1757, 1778, 1800, 1850, 1851, + 1853, 1885, 1886, 1931, 1904, 1913, 1787, 1846, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 1872, 187, 200, 297, 1997, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 1934, 1879, 0, 1818, + 1820, 1819, 1769, 1771, 1770, 1768, 2000, 331, 1961, 1726, + 1733, 1760, 1776, 1783, 1791, 1802, 1803, 1811, 1817, 1829, + 1839, 1840, 1856, 1870, 1871, 1878, 1908, 1911, 1928, 1936, + 1943, 1948, 1950, 453, 239, 1852, 1877, 1915, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 1825, 184, 0, 190, 0, 191, 193, 1810, 189, + 1957, 1992, 1889, 1903, 874, 1016, 0, 0, 430, 1082, + 1020, 861, 884, 1029, 890, 892, 957, 836, 932, 342, + 881, 837, 0, 0, 0, 0, 828, 1077, 829, 862, + 246, 1075, 990, 935, 1018, 918, 950, 960, 245, 231, + 925, 924, 1007, 873, 872, 955, 1003, 1017, 0, 0, + 161, 459, 178, 1115, 299, 0, 478, 457, 408, 324, + 481, 480, 916, 0, 1089, 1102, 901, 959, 848, 946, + 1022, 882, 951, 1023, 0, 0, 0, 0, 0, 0, + 537, 0, 0, 0, 0, 0, 0, 0, 160, 0, + 1097, 1111, 1078, 479, 911, 956, 1034, 827, 1094, 0, + 832, 1066, 0, 1008, 869, 870, 250, 0, 0, 0, + 0, 0, 0, 0, 914, 931, 975, 898, 0, 450, + 962, 971, 985, 891, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1093, 0, 0, 0, + 842, 1062, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1083, 0, 0, 0, 847, 825, + 867, 977, 826, 824, 325, 839, 1104, 1006, 899, 288, + 179, 1012, 897, 1081, 965, 843, 994, 885, 296, 841, + 183, 838, 844, 883, 338, 974, 980, 166, 186, 298, + 991, 863, 876, 232, 3216, 377, 952, 449, 2319, 265, + 938, 376, 300, 442, 966, 1014, 448, 886, 424, 458, + 463, 258, 919, 222, 405, 248, 241, 868, 984, 831, + 271, 360, 236, 292, 902, 958, 864, 228, 969, 945, + 996, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 992, 979, 998, 859, 845, 851, 846, 875, + 1015, 280, 272, 999, 997, 877, 346, 212, 929, 922, + 915, 1100, 452, 1030, 244, 981, 454, 168, 391, 390, + 889, 279, 982, 169, 159, 370, 170, 289, 192, 1002, + 467, 208, 294, 432, 2318, 264, 337, 954, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 978, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 1021, 307, 253, 257, 273, 284, 953, 374, 412, 455, + 947, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 976, 204, 198, 1010, 993, + 940, 904, 910, 833, 0, 197, 905, 906, 907, 908, + 909, 972, 866, 878, 858, 948, 857, 268, 964, 445, + 446, 233, 1067, 1025, 199, 840, 1024, 334, 341, 333, + 1027, 1026, 441, 1011, 941, 928, 926, 834, 1009, 939, + 927, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 930, 410, 305, 0, 194, 0, 409, 1019, + 1036, 421, 214, 852, 986, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 968, 1033, + 345, 378, 221, 451, 406, 249, 1072, 0, 1074, 1070, + 1073, 1071, 1090, 1091, 1112, 1113, 1114, 1101, 1068, 180, + 181, 1109, 1110, 182, 921, 1013, 835, 0, 989, 176, + 177, 163, 961, 1031, 1080, 229, 153, 1063, 1064, 1065, + 154, 1084, 1085, 156, 157, 1107, 1106, 1105, 1108, 158, + 1117, 1116, 1118, 1069, 1076, 1079, 1086, 1087, 1088, 1095, + 1096, 1103, 1098, 1099, 0, 917, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 1092, 187, + 200, 297, 1032, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 987, 944, 0, 894, 896, 895, + 854, 856, 855, 853, 1035, 331, 1005, 823, 830, 849, + 860, 865, 871, 879, 880, 888, 893, 903, 912, 913, + 923, 936, 937, 943, 967, 970, 983, 988, 995, 1000, + 1001, 453, 239, 920, 942, 973, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 900, + 184, 0, 190, 0, 191, 193, 887, 189, 1004, 1028, + 949, 963, 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, + 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, + 0, 0, 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, + 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, + 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, 161, 459, + 178, 1984, 299, 1949, 478, 457, 408, 324, 481, 480, + 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, + 1891, 1980, 0, 0, 0, 0, 0, 0, 151, 0, + 0, 0, 0, 0, 0, 0, 160, 0, 1887, 1971, + 1798, 479, 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, + 1993, 1964, 1789, 1790, 250, 0, 0, 0, 0, 0, + 0, 0, 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, + 1930, 1815, 361, 270, 0, 0, 0, 0, 0, 0, + 2799, 0, 1784, 0, 1880, 0, 0, 0, 1751, 1737, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1837, 0, 0, 0, 1758, 1728, 1786, 1919, + 1729, 1727, 325, 1747, 1932, 1962, 1824, 288, 179, 1968, + 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, + 1753, 1806, 338, 1916, 1924, 166, 186, 298, 1939, 1780, + 1797, 232, 0, 377, 1892, 449, 477, 265, 1873, 376, + 300, 442, 1907, 1970, 448, 1809, 424, 458, 463, 258, + 1849, 222, 405, 248, 241, 1788, 1929, 1734, 271, 360, + 236, 292, 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, + 439, 188, 319, 440, 462, 0, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 1940, 1923, 1946, 1774, 1754, 1765, 1755, 1796, 1972, 280, + 272, 1947, 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, + 452, 1995, 244, 1925, 454, 168, 391, 390, 1812, 279, + 1926, 169, 159, 370, 170, 289, 192, 1951, 467, 208, + 294, 432, 476, 264, 337, 1894, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 1922, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 1978, 307, + 253, 257, 273, 284, 1893, 374, 412, 455, 1884, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 1918, 204, 198, 1966, 1941, 1875, 1830, + 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, + 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, 446, 233, + 1748, 1986, 199, 1749, 1985, 334, 341, 333, 1989, 1987, + 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 1863, 410, 305, 0, 194, 0, 409, 1976, 2001, 421, + 214, 1767, 1933, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 1909, 1998, 345, 378, + 221, 451, 406, 249, 1763, 0, 1766, 1761, 1764, 1762, + 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, + 1960, 0, 1854, 1969, 1742, 0, 1937, 176, 177, 163, + 1901, 1996, 1814, 229, 0, 1738, 1739, 1740, 0, 1844, + 1845, 0, 0, 1955, 1954, 1953, 1956, 0, 1990, 1988, + 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, + 1904, 1913, 1787, 1846, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 1872, 187, 200, 297, + 1997, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, + 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, + 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, + 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, + 239, 1852, 1877, 1915, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 1825, 184, 0, + 190, 0, 191, 193, 1810, 189, 1957, 1992, 1889, 1903, + 874, 1016, 0, 0, 430, 1082, 1020, 861, 884, 1029, + 890, 892, 957, 836, 932, 342, 881, 837, 0, 0, + 0, 0, 828, 1077, 829, 862, 246, 1075, 990, 935, + 1018, 918, 950, 960, 245, 231, 925, 924, 1007, 873, + 872, 955, 1003, 1017, 0, 0, 161, 459, 178, 1115, + 299, 0, 478, 457, 408, 324, 481, 480, 916, 0, + 1089, 1102, 901, 959, 848, 946, 1022, 882, 951, 1023, + 0, 0, 0, 0, 0, 0, 537, 0, 0, 0, + 0, 0, 0, 0, 160, 0, 1097, 1111, 1078, 479, + 911, 956, 1034, 827, 1094, 0, 832, 1066, 0, 1008, + 869, 870, 250, 0, 0, 0, 0, 0, 0, 0, + 914, 931, 975, 898, 0, 450, 962, 971, 985, 891, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1093, 0, 0, 0, 842, 1062, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1083, 0, 0, 0, 847, 825, 867, 977, 826, 824, + 325, 839, 1104, 1006, 899, 288, 179, 1012, 897, 1081, + 965, 843, 994, 885, 296, 841, 183, 838, 844, 883, + 338, 974, 980, 166, 186, 298, 991, 863, 876, 232, + 0, 377, 952, 449, 2319, 265, 938, 376, 300, 442, + 966, 1014, 448, 886, 424, 458, 463, 258, 919, 222, + 405, 248, 241, 868, 984, 831, 271, 360, 236, 292, + 902, 958, 864, 228, 969, 945, 996, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 992, 979, + 998, 859, 845, 851, 846, 875, 1015, 280, 272, 999, + 997, 877, 346, 212, 929, 922, 915, 1100, 452, 1030, + 244, 981, 454, 168, 391, 390, 889, 279, 982, 169, + 159, 370, 170, 289, 192, 1002, 467, 208, 294, 432, + 2318, 264, 337, 954, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 978, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 1021, 307, 253, 257, + 273, 284, 953, 374, 412, 455, 947, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 976, 204, 198, 1010, 993, 940, 904, 910, 833, + 0, 197, 905, 906, 907, 908, 909, 972, 866, 878, + 858, 948, 857, 268, 964, 445, 446, 233, 1067, 1025, + 199, 840, 1024, 334, 341, 333, 1027, 1026, 441, 1011, + 941, 928, 926, 834, 1009, 939, 927, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 930, 410, + 305, 0, 194, 0, 409, 1019, 1036, 421, 214, 852, + 986, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 968, 1033, 345, 378, 221, 451, + 406, 249, 1072, 0, 1074, 1070, 1073, 1071, 1090, 1091, + 1112, 1113, 1114, 1101, 1068, 180, 181, 1109, 1110, 182, + 921, 1013, 835, 0, 989, 176, 177, 163, 961, 1031, + 1080, 229, 153, 1063, 1064, 1065, 154, 1084, 1085, 156, + 157, 1107, 1106, 1105, 1108, 158, 1117, 1116, 1118, 1069, + 1076, 1079, 1086, 1087, 1088, 1095, 1096, 1103, 1098, 1099, + 0, 917, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 1092, 187, 200, 297, 1032, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 987, 944, 0, 894, 896, 895, 854, 856, 855, 853, + 1035, 331, 1005, 823, 830, 849, 860, 865, 871, 879, + 880, 888, 893, 903, 912, 913, 923, 936, 937, 943, + 967, 970, 983, 988, 995, 1000, 1001, 453, 239, 920, + 942, 973, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 900, 184, 0, 190, 0, + 191, 193, 887, 189, 1004, 1028, 949, 963, 1794, 1973, + 0, 1935, 430, 1828, 1977, 1777, 1807, 1994, 1813, 1816, + 1897, 1743, 1866, 342, 1804, 1744, 0, 0, 0, 1782, + 1731, 1795, 1732, 1779, 246, 1775, 1938, 1869, 1975, 1848, + 1890, 1900, 245, 231, 1858, 1857, 1963, 1793, 1792, 1895, + 1952, 1974, 1847, 0, 161, 459, 178, 1984, 299, 1949, + 478, 457, 408, 324, 481, 480, 1843, 1958, 1864, 1927, + 1826, 1899, 1759, 1882, 1979, 1805, 1891, 1980, 0, 0, + 0, 0, 0, 0, 151, 0, 0, 0, 0, 0, + 0, 0, 160, 0, 1887, 1971, 1798, 479, 1838, 1896, + 1999, 1730, 1883, 0, 1735, 1746, 1993, 1964, 1789, 1790, + 250, 0, 0, 0, 0, 0, 0, 0, 1841, 1865, + 1917, 1823, 0, 450, 1902, 1912, 1930, 1815, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 1784, 0, + 1880, 0, 0, 0, 1751, 1737, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1837, 0, + 0, 0, 1758, 1728, 1786, 1919, 1729, 1727, 325, 1747, + 1932, 1962, 1824, 288, 179, 1968, 1822, 1821, 1906, 1752, + 1942, 1808, 296, 1750, 183, 1745, 1753, 1806, 338, 1916, + 1924, 166, 186, 298, 1939, 1780, 1797, 232, 0, 377, + 1892, 449, 477, 265, 1873, 376, 300, 442, 1907, 1970, + 448, 1809, 424, 458, 463, 258, 1849, 222, 405, 248, + 241, 1788, 1929, 1734, 271, 360, 236, 292, 1827, 1898, + 1781, 228, 1910, 1881, 1944, 404, 439, 188, 319, 440, + 462, 0, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 1940, 1923, 1946, 1774, + 1754, 1765, 1755, 1796, 1972, 280, 272, 1947, 1945, 1799, + 346, 212, 1862, 1855, 1842, 1920, 452, 1995, 244, 1925, + 454, 168, 391, 390, 1812, 279, 1926, 169, 159, 370, + 170, 289, 192, 1951, 467, 208, 294, 432, 476, 264, + 337, 1894, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 1922, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 1978, 307, 253, 257, 273, 284, + 1893, 374, 412, 455, 1884, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 1918, + 204, 198, 1966, 1941, 1875, 1830, 1836, 1736, 0, 197, + 1831, 1832, 1833, 1834, 1835, 1914, 1785, 1801, 1773, 1888, + 1772, 268, 1905, 445, 446, 233, 1748, 1986, 199, 1749, + 1985, 334, 341, 333, 1989, 1987, 441, 1967, 1876, 1861, + 1859, 1741, 1965, 1874, 1860, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 1863, 410, 305, 0, + 194, 0, 409, 1976, 2001, 421, 214, 1767, 1933, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 1909, 1998, 345, 378, 221, 451, 406, 249, + 1763, 0, 1766, 1761, 1764, 1762, 1867, 1868, 1981, 1982, + 1983, 1921, 1756, 0, 0, 1959, 1960, 0, 1854, 1969, + 1742, 0, 1937, 176, 177, 163, 1901, 1996, 1814, 229, + 0, 1738, 1739, 1740, 0, 1844, 1845, 0, 0, 1955, + 1954, 1953, 1956, 0, 1990, 1988, 1991, 1757, 1778, 1800, + 1850, 1851, 1853, 1885, 1886, 1931, 1904, 1913, 1787, 1846, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 1872, 187, 200, 297, 1997, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 1934, 1879, + 0, 1818, 1820, 1819, 1769, 1771, 1770, 1768, 2000, 331, + 1961, 1726, 1733, 1760, 1776, 1783, 1791, 1802, 1803, 1811, + 1817, 1829, 1839, 1840, 1856, 1870, 1871, 1878, 1908, 1911, + 1928, 1936, 1943, 1948, 1950, 453, 239, 1852, 1877, 1915, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 1825, 184, 0, 190, 0, 191, 193, + 1810, 189, 1957, 1992, 1889, 1903, 874, 1016, 0, 0, + 430, 1082, 1020, 861, 884, 1029, 890, 892, 957, 836, + 932, 342, 881, 837, 0, 0, 0, 0, 828, 1077, + 829, 862, 246, 1075, 990, 935, 1018, 918, 950, 960, + 245, 231, 925, 924, 1007, 873, 872, 955, 1003, 1017, + 0, 0, 161, 459, 178, 1115, 299, 0, 0, 457, + 408, 324, 0, 0, 916, 0, 1089, 1102, 901, 959, + 848, 946, 1022, 882, 951, 1023, 0, 0, 0, 0, + 0, 0, 537, 0, 1422, 0, 0, 1423, 0, 0, + 160, 0, 1097, 1111, 1078, 0, 911, 956, 1034, 827, + 1094, 0, 832, 1066, 0, 1008, 869, 870, 250, 0, + 0, 0, 0, 0, 0, 0, 914, 931, 975, 898, + 0, 450, 962, 971, 985, 891, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1093, 0, + 0, 0, 842, 1062, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1083, 0, 0, 0, + 847, 825, 867, 977, 826, 824, 325, 839, 1104, 1006, + 899, 288, 179, 1012, 897, 1081, 965, 843, 994, 885, + 296, 841, 183, 838, 844, 883, 338, 974, 980, 166, + 186, 298, 991, 863, 876, 232, 0, 377, 952, 449, + 1061, 265, 938, 376, 300, 442, 966, 1014, 448, 886, + 424, 458, 463, 258, 919, 222, 405, 248, 241, 868, + 984, 831, 271, 360, 236, 292, 902, 958, 864, 228, + 969, 945, 996, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 992, 979, 998, 859, 845, 851, + 846, 875, 1015, 280, 272, 999, 997, 877, 346, 212, + 929, 922, 915, 1100, 452, 1030, 244, 981, 454, 168, + 391, 390, 889, 279, 982, 169, 159, 370, 170, 289, + 192, 1002, 467, 208, 294, 432, 1060, 264, 337, 954, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 978, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 1021, 307, 253, 257, 273, 284, 953, 374, + 412, 455, 947, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 976, 204, 198, + 1010, 993, 940, 904, 910, 833, 0, 197, 905, 906, + 907, 908, 909, 972, 866, 878, 858, 948, 857, 268, + 964, 445, 446, 233, 1067, 1025, 199, 840, 1024, 334, + 341, 333, 1027, 1026, 441, 1011, 941, 928, 926, 834, + 1009, 939, 927, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 930, 410, 305, 0, 194, 0, + 409, 1019, 1036, 421, 214, 852, 986, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 968, 1033, 345, 378, 221, 451, 406, 249, 1072, 0, + 1074, 1070, 1073, 1071, 1090, 1091, 1112, 1113, 1114, 1101, + 1068, 180, 181, 1109, 1110, 182, 921, 1013, 835, 0, + 989, 176, 177, 163, 961, 1031, 1080, 229, 153, 1063, + 1064, 1065, 154, 1084, 1085, 156, 157, 1107, 1106, 1105, + 1108, 158, 1117, 1116, 1118, 1069, 1076, 1079, 1086, 1087, + 1088, 1095, 1096, 1103, 1098, 1099, 0, 917, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 1092, 187, 200, 297, 1032, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 987, 944, 0, 894, + 896, 895, 854, 856, 855, 853, 1035, 331, 1005, 823, + 830, 849, 860, 865, 871, 879, 880, 888, 893, 903, + 912, 913, 923, 936, 937, 943, 967, 970, 983, 988, + 995, 1000, 1001, 453, 239, 920, 942, 973, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 900, 184, 0, 190, 0, 191, 193, 887, 189, + 1004, 1028, 949, 963, 874, 1016, 0, 0, 430, 1082, + 1020, 861, 884, 1029, 890, 892, 957, 836, 932, 342, + 881, 837, 0, 0, 0, 0, 828, 1077, 829, 862, + 246, 1075, 990, 935, 1018, 918, 950, 960, 245, 231, + 925, 924, 1007, 873, 872, 955, 1003, 1017, 0, 0, + 161, 459, 178, 1115, 299, 0, 0, 457, 408, 324, + 0, 0, 916, 0, 1089, 1102, 901, 959, 848, 946, + 1022, 882, 951, 1023, 0, 0, 0, 0, 0, 0, + 537, 0, 0, 0, 0, 0, 0, 0, 160, 0, + 1097, 1111, 1078, 0, 911, 956, 1034, 827, 1094, 0, + 832, 1066, 0, 1008, 869, 870, 250, 0, 0, 0, + 0, 0, 0, 0, 914, 931, 975, 898, 0, 450, + 962, 971, 985, 891, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1093, 0, 0, 0, + 842, 1062, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1083, 0, 0, 0, 847, 825, + 867, 977, 826, 824, 325, 839, 1104, 1006, 899, 288, + 179, 1012, 897, 1081, 965, 843, 994, 885, 296, 841, + 183, 838, 844, 883, 338, 974, 980, 166, 186, 298, + 991, 863, 876, 232, 0, 377, 952, 449, 1061, 265, + 938, 376, 300, 442, 966, 1014, 448, 886, 424, 458, + 463, 258, 919, 222, 405, 248, 241, 868, 984, 831, + 271, 360, 236, 292, 902, 958, 864, 228, 969, 945, + 996, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 992, 979, 998, 859, 845, 851, 846, 875, + 1015, 280, 272, 999, 997, 877, 346, 212, 929, 922, + 915, 1100, 452, 1030, 244, 981, 454, 168, 391, 390, + 889, 279, 982, 169, 159, 370, 170, 289, 192, 1002, + 467, 208, 294, 432, 1060, 264, 337, 954, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 978, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 1021, 307, 253, 257, 273, 284, 953, 374, 412, 455, + 947, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 976, 204, 198, 1010, 993, + 940, 904, 910, 833, 0, 197, 905, 906, 907, 908, + 909, 972, 866, 878, 858, 948, 857, 268, 964, 445, + 446, 233, 1067, 1025, 199, 840, 1024, 334, 341, 333, + 1027, 1026, 441, 1011, 941, 928, 926, 834, 1009, 939, + 927, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 930, 410, 305, 0, 194, 0, 409, 1019, + 1036, 421, 214, 852, 986, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 968, 1033, + 345, 378, 221, 451, 406, 249, 1072, 0, 1074, 1070, + 1073, 1071, 1090, 1091, 1112, 1113, 1114, 1101, 1068, 180, + 181, 1109, 1110, 182, 921, 1013, 835, 0, 989, 176, + 177, 163, 961, 1031, 1080, 229, 153, 1063, 1064, 1065, + 154, 1084, 1085, 156, 157, 1107, 1106, 1105, 1108, 158, + 1117, 1116, 1118, 1069, 1076, 1079, 1086, 1087, 1088, 1095, + 1096, 1103, 1098, 1099, 0, 917, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 1092, 187, + 200, 297, 1032, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 987, 944, 0, 894, 896, 895, + 854, 856, 855, 853, 1035, 331, 1005, 823, 830, 849, + 860, 865, 871, 879, 880, 888, 893, 903, 912, 913, + 923, 936, 937, 943, 967, 970, 983, 988, 995, 1000, + 1001, 453, 239, 920, 942, 973, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 900, + 184, 0, 190, 0, 191, 193, 887, 189, 1004, 1028, + 949, 963, 874, 1016, 0, 0, 430, 1082, 1020, 861, + 884, 1029, 890, 892, 957, 836, 932, 342, 881, 837, + 0, 0, 0, 0, 828, 1077, 829, 862, 246, 1075, + 990, 935, 1018, 918, 950, 960, 245, 231, 925, 924, + 1007, 873, 872, 955, 1003, 1017, 0, 0, 161, 459, + 178, 1115, 299, 0, 0, 457, 408, 324, 0, 0, + 916, 0, 1089, 1102, 901, 959, 848, 946, 1022, 882, + 951, 1023, 0, 0, 0, 0, 0, 0, 537, 0, + 0, 0, 0, 0, 0, 0, 160, 0, 1097, 1111, + 1078, 0, 911, 956, 1034, 827, 1094, 0, 832, 1066, + 0, 1008, 869, 870, 250, 0, 0, 0, 0, 0, + 0, 0, 914, 931, 975, 898, 0, 450, 962, 971, + 985, 891, 361, 270, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1093, 0, 0, 0, 842, 1062, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1083, 0, 0, 0, 847, 825, 867, 977, + 826, 824, 325, 839, 1104, 1006, 899, 288, 179, 1012, + 897, 1081, 965, 843, 994, 885, 296, 841, 183, 838, + 844, 883, 338, 974, 980, 166, 186, 298, 991, 863, + 876, 232, 0, 377, 952, 449, 1061, 265, 938, 376, + 300, 442, 966, 1014, 448, 886, 424, 458, 463, 258, + 919, 222, 405, 248, 241, 868, 984, 831, 271, 360, + 236, 292, 902, 958, 864, 228, 969, 945, 996, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 992, 979, 998, 859, 845, 851, 846, 875, 1015, 280, + 272, 999, 997, 877, 346, 212, 929, 922, 915, 1100, + 452, 1030, 244, 981, 454, 168, 391, 390, 889, 279, + 982, 169, 159, 370, 170, 289, 192, 1002, 467, 208, + 294, 432, 1060, 264, 337, 954, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 978, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 1021, 307, + 253, 257, 273, 284, 953, 374, 412, 455, 947, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 976, 204, 198, 1010, 993, 940, 904, + 910, 833, 0, 197, 905, 906, 907, 908, 909, 972, + 866, 878, 858, 948, 857, 268, 964, 445, 446, 233, + 1067, 1025, 199, 1055, 1024, 334, 341, 333, 1027, 1026, + 441, 1011, 941, 928, 926, 834, 1009, 939, 927, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 1051, + 930, 410, 305, 0, 194, 0, 409, 1019, 1036, 421, + 214, 852, 986, 436, 167, 366, 215, 266, 254, 357, + 1056, 1054, 1045, 1046, 293, 301, 968, 1033, 345, 378, + 221, 451, 406, 249, 1072, 0, 1074, 1070, 1073, 1071, + 1090, 1091, 1112, 1113, 1114, 1101, 1068, 180, 181, 1109, + 1110, 182, 921, 1013, 835, 0, 989, 176, 177, 163, + 961, 1031, 1080, 229, 153, 1063, 1064, 1065, 154, 1084, + 1085, 156, 157, 1107, 1106, 1105, 1108, 158, 1117, 1116, + 1118, 1069, 1076, 1079, 1086, 1087, 1088, 1095, 1096, 1103, + 1098, 1099, 0, 917, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 1092, 187, 200, 297, + 1032, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 987, 944, 0, 894, 896, 895, 854, 856, + 855, 853, 1035, 331, 1005, 823, 830, 849, 860, 865, + 871, 879, 880, 888, 893, 903, 912, 913, 923, 936, + 937, 943, 967, 970, 983, 988, 995, 1000, 1001, 453, + 239, 920, 942, 973, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 1052, 1053, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 900, 184, 0, + 190, 0, 191, 193, 887, 189, 1004, 1028, 949, 963, + 874, 1016, 0, 0, 430, 1082, 1020, 861, 884, 1029, + 890, 892, 957, 836, 932, 342, 881, 837, 0, 0, + 0, 0, 828, 1077, 829, 862, 246, 1075, 990, 935, + 1018, 918, 950, 960, 245, 231, 925, 924, 1007, 873, + 872, 955, 1003, 1017, 0, 0, 161, 459, 178, 1115, + 299, 0, 0, 457, 408, 324, 0, 0, 916, 0, + 1089, 1102, 901, 959, 848, 946, 1022, 882, 951, 1023, + 0, 0, 0, 0, 0, 0, 537, 0, 0, 0, + 0, 0, 0, 0, 160, 0, 1097, 1111, 1078, 0, + 911, 956, 1034, 827, 1094, 0, 832, 1066, 0, 1008, + 869, 870, 250, 0, 0, 0, 0, 0, 0, 0, + 914, 931, 975, 898, 0, 450, 962, 971, 985, 891, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1093, 0, 0, 0, 842, 1062, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1083, 0, 0, 0, 847, 825, 867, 977, 826, 824, + 325, 839, 1104, 1006, 899, 288, 179, 1012, 897, 1081, + 965, 843, 994, 885, 296, 841, 183, 838, 844, 883, + 338, 974, 980, 166, 186, 298, 991, 863, 876, 232, + 0, 377, 952, 449, 1061, 265, 938, 376, 300, 442, + 966, 1014, 448, 886, 424, 458, 463, 258, 919, 222, + 405, 248, 241, 868, 984, 831, 271, 360, 236, 292, + 902, 958, 864, 228, 969, 945, 996, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 992, 979, + 998, 859, 845, 851, 846, 875, 1015, 280, 272, 999, + 997, 877, 346, 212, 929, 922, 915, 1100, 452, 1030, + 244, 981, 454, 168, 391, 390, 889, 279, 982, 169, + 159, 370, 170, 289, 192, 1002, 467, 208, 294, 432, + 1060, 264, 337, 954, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 978, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 1021, 307, 253, 257, + 273, 284, 953, 374, 412, 455, 947, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 1586, 217, 392, 395, + 466, 976, 204, 198, 1010, 993, 940, 904, 910, 833, + 0, 197, 905, 906, 907, 908, 909, 972, 866, 878, + 858, 948, 857, 268, 964, 445, 446, 233, 1067, 1025, + 199, 840, 1024, 334, 341, 333, 1027, 1026, 441, 1011, + 941, 928, 926, 834, 1009, 939, 927, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 930, 410, + 305, 0, 194, 0, 409, 1019, 1036, 421, 214, 852, + 986, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 968, 1033, 345, 378, 221, 451, + 406, 249, 1072, 0, 1074, 1070, 1073, 1071, 1090, 1091, + 1112, 1113, 1114, 1101, 1068, 180, 181, 1109, 1110, 182, + 921, 1013, 835, 0, 989, 176, 177, 163, 961, 1031, + 1080, 229, 153, 1063, 1064, 1065, 154, 1084, 1085, 156, + 157, 1107, 1106, 1105, 1108, 158, 1117, 1116, 1118, 1069, + 1076, 1079, 1086, 1087, 1088, 1095, 1096, 1103, 1098, 1099, + 0, 917, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 1092, 187, 200, 297, 1032, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 987, 944, 0, 894, 896, 895, 854, 856, 855, 853, + 1035, 331, 1005, 823, 830, 849, 860, 865, 871, 879, + 880, 888, 893, 903, 912, 913, 923, 936, 937, 943, + 967, 970, 983, 988, 995, 1000, 1001, 453, 239, 920, + 942, 973, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 900, 184, 0, 190, 0, + 191, 193, 887, 189, 1004, 1028, 949, 963, 874, 1016, + 0, 0, 430, 1082, 1020, 861, 884, 1029, 890, 892, + 957, 836, 932, 342, 881, 837, 0, 0, 0, 0, + 828, 1077, 829, 862, 246, 1075, 990, 935, 1018, 918, + 950, 960, 245, 231, 925, 924, 1007, 873, 872, 955, + 1003, 1017, 0, 0, 161, 459, 178, 1115, 299, 0, + 0, 457, 408, 324, 0, 0, 916, 0, 1089, 1102, + 901, 959, 848, 946, 1022, 882, 951, 1023, 0, 0, + 0, 0, 0, 0, 537, 0, 0, 0, 0, 0, + 0, 0, 160, 0, 1097, 1111, 1078, 0, 911, 956, + 1034, 827, 1094, 0, 832, 1066, 0, 1008, 869, 870, + 250, 0, 0, 0, 0, 0, 0, 0, 914, 931, + 975, 898, 0, 450, 962, 971, 985, 891, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1093, 0, 0, 0, 842, 1062, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1083, 0, + 0, 0, 847, 825, 867, 977, 826, 824, 325, 839, + 1104, 1006, 899, 288, 179, 1012, 897, 1081, 965, 843, + 994, 885, 296, 841, 183, 838, 844, 883, 338, 974, + 980, 166, 186, 298, 991, 863, 876, 232, 0, 377, + 952, 449, 1061, 265, 938, 376, 300, 442, 966, 1014, + 448, 886, 424, 458, 463, 258, 919, 222, 405, 248, + 241, 868, 984, 831, 271, 360, 236, 292, 902, 958, + 864, 228, 969, 945, 996, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 992, 979, 998, 859, + 845, 851, 846, 875, 1015, 280, 272, 999, 997, 877, + 346, 212, 929, 922, 915, 1100, 452, 1030, 244, 981, + 454, 168, 391, 390, 889, 279, 982, 169, 159, 370, + 170, 289, 192, 1002, 467, 208, 294, 432, 1060, 264, + 337, 954, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 978, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 1021, 307, 253, 257, 273, 284, + 953, 374, 412, 455, 947, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 1042, 217, 392, 395, 466, 976, + 204, 198, 1010, 993, 940, 904, 910, 833, 0, 197, + 905, 906, 907, 908, 909, 972, 866, 878, 858, 948, + 857, 268, 964, 445, 446, 233, 1067, 1025, 199, 1055, + 1024, 334, 341, 333, 1027, 1026, 441, 1011, 941, 928, + 926, 834, 1009, 939, 927, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 1051, 930, 410, 305, 0, + 194, 0, 409, 1019, 1036, 421, 214, 852, 986, 436, + 167, 366, 215, 266, 254, 357, 1056, 1054, 1045, 1046, + 293, 301, 968, 1033, 345, 378, 221, 451, 406, 249, + 1072, 0, 1074, 1070, 1073, 1071, 1090, 1091, 1112, 1113, + 1114, 1101, 1068, 180, 181, 1109, 1110, 182, 921, 1013, + 835, 0, 989, 176, 177, 163, 961, 1031, 1080, 229, + 153, 1063, 1064, 1065, 154, 1084, 1085, 156, 157, 1107, + 1106, 1105, 1108, 158, 1117, 1116, 1118, 1069, 1076, 1079, + 1086, 1087, 1088, 1095, 1096, 1103, 1098, 1099, 0, 917, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 1092, 187, 200, 297, 1032, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 987, 944, + 0, 894, 896, 895, 854, 856, 855, 853, 1035, 331, + 1005, 823, 830, 849, 860, 865, 871, 879, 880, 888, + 893, 903, 912, 913, 923, 936, 937, 943, 967, 970, + 983, 988, 995, 1000, 1001, 453, 239, 920, 942, 973, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 1052, 1053, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 900, 184, 0, 190, 0, 191, 193, + 887, 189, 1004, 1028, 949, 963, 1794, 1973, 0, 1935, + 430, 1828, 1977, 1777, 1807, 1994, 1813, 1816, 1897, 1743, + 1866, 342, 1804, 1744, 0, 0, 0, 1782, 1731, 1795, + 1732, 1779, 246, 1775, 1938, 1869, 1975, 1848, 1890, 1900, + 245, 231, 1858, 1857, 1963, 1793, 1792, 1895, 1952, 1974, + 1847, 0, 0, 459, 0, 1984, 299, 1949, 0, 457, + 408, 324, 0, 0, 1843, 1958, 1864, 1927, 1826, 1899, + 1759, 1882, 1979, 1805, 1891, 1980, 0, 0, 0, 0, + 0, 3078, 3083, 0, 3086, 3088, 3087, 0, 0, 0, + 3080, 0, 1887, 1971, 1798, 0, 1838, 1896, 1999, 1730, + 1883, 0, 1735, 1746, 1993, 1964, 1789, 1790, 250, 0, + 0, 0, 0, 0, 0, 0, 1841, 1865, 1917, 1823, + 0, 450, 1902, 1912, 1930, 1815, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 1784, 0, 1880, 0, + 0, 0, 1751, 1737, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1837, 0, 0, 0, + 1758, 1728, 1786, 1919, 1729, 1727, 325, 1747, 1932, 1962, + 1824, 288, 0, 1968, 1822, 1821, 1906, 1752, 1942, 1808, + 296, 1750, 183, 1745, 1753, 1806, 338, 1916, 1924, 0, + 186, 298, 1939, 1780, 1797, 232, 0, 377, 1892, 449, + 0, 265, 1873, 376, 300, 442, 1907, 1970, 448, 1809, + 424, 458, 463, 258, 1849, 222, 405, 248, 241, 1788, + 1929, 1734, 271, 360, 236, 292, 1827, 1898, 1781, 228, + 1910, 1881, 1944, 404, 439, 188, 319, 440, 462, 3081, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 1940, 1923, 1946, 1774, 1754, 1765, + 1755, 1796, 1972, 280, 272, 1947, 1945, 1799, 346, 212, + 1862, 1855, 1842, 1920, 452, 1995, 244, 1925, 454, 0, + 391, 390, 1812, 279, 1926, 0, 0, 370, 3082, 289, + 192, 1951, 467, 208, 294, 432, 0, 264, 337, 1894, + 347, 185, 365, 314, 316, 313, 317, 269, 0, 0, + 1922, 367, 393, 437, 210, 411, 0, 0, 0, 383, + 0, 0, 1978, 307, 253, 257, 273, 284, 1893, 374, + 412, 455, 1884, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 1918, 204, 198, + 1966, 1941, 1875, 1830, 1836, 1736, 0, 197, 1831, 1832, + 1833, 1834, 1835, 1914, 1785, 1801, 1773, 1888, 1772, 268, + 1905, 445, 446, 233, 1748, 1986, 199, 1749, 1985, 334, + 341, 333, 1989, 1987, 441, 1967, 1876, 1861, 1859, 1741, + 1965, 1874, 1860, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 1863, 410, 305, 0, 194, 0, + 409, 1976, 2001, 421, 214, 1767, 1933, 436, 0, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 1909, 1998, 345, 378, 221, 451, 406, 249, 1763, 0, + 1766, 1761, 1764, 1762, 1867, 1868, 1981, 1982, 1983, 1921, + 1756, 0, 0, 1959, 1960, 0, 1854, 1969, 1742, 0, + 1937, 0, 0, 0, 1901, 1996, 1814, 229, 0, 1738, + 1739, 1740, 0, 1844, 1845, 0, 0, 1955, 1954, 1953, + 1956, 0, 1990, 1988, 1991, 1757, 1778, 1800, 1850, 1851, + 1853, 1885, 1886, 1931, 1904, 1913, 1787, 1846, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 1872, 187, 200, 297, 1997, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 1934, 1879, 0, 1818, + 1820, 1819, 1769, 1771, 1770, 1768, 2000, 331, 1961, 1726, + 1733, 1760, 1776, 1783, 1791, 1802, 1803, 1811, 1817, 1829, + 1839, 1840, 1856, 1870, 1871, 1878, 1908, 1911, 1928, 1936, + 1943, 1948, 1950, 453, 239, 1852, 1877, 1915, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 0, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 1825, 184, 0, 190, 0, 191, 193, 1810, 189, + 1957, 1992, 1889, 1903, 1794, 1973, 0, 1935, 430, 1828, + 1977, 1777, 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, + 1804, 1744, 0, 0, 0, 1782, 1731, 1795, 1732, 1779, + 246, 1775, 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, + 1858, 1857, 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, + 0, 459, 0, 1984, 299, 1949, 0, 457, 408, 324, + 0, 0, 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, + 1979, 1805, 1891, 1980, 0, 0, 0, 0, 0, 3833, + 3083, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1887, 1971, 1798, 0, 1838, 1896, 1999, 1730, 1883, 0, + 1735, 1746, 1993, 1964, 1789, 1790, 250, 0, 0, 0, + 0, 0, 0, 0, 1841, 1865, 1917, 1823, 0, 450, + 1902, 1912, 1930, 1815, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 1784, 0, 1880, 0, 0, 0, + 1751, 1737, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1837, 0, 0, 0, 1758, 1728, + 1786, 1919, 1729, 1727, 325, 1747, 1932, 1962, 1824, 288, + 0, 1968, 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, + 183, 1745, 1753, 1806, 338, 1916, 1924, 0, 186, 298, + 1939, 1780, 1797, 232, 0, 377, 1892, 449, 0, 265, + 1873, 376, 300, 442, 1907, 1970, 448, 1809, 424, 458, + 463, 258, 1849, 222, 405, 248, 241, 1788, 1929, 1734, + 271, 360, 236, 292, 1827, 1898, 1781, 228, 1910, 1881, + 1944, 404, 439, 188, 319, 440, 462, 0, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 1940, 1923, 1946, 1774, 1754, 1765, 1755, 1796, + 1972, 280, 272, 1947, 1945, 1799, 346, 212, 1862, 1855, + 1842, 1920, 452, 1995, 244, 1925, 454, 0, 391, 390, + 1812, 279, 1926, 0, 0, 370, 0, 289, 192, 1951, + 467, 208, 294, 432, 0, 264, 337, 1894, 347, 185, + 365, 314, 316, 313, 317, 269, 0, 0, 1922, 367, + 393, 437, 210, 411, 0, 0, 0, 383, 0, 0, + 1978, 307, 253, 257, 273, 284, 1893, 374, 412, 455, + 1884, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 1918, 204, 198, 1966, 1941, + 1875, 1830, 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, + 1835, 1914, 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, + 446, 233, 1748, 1986, 199, 1749, 1985, 334, 341, 333, + 1989, 1987, 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, + 1860, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 1863, 410, 305, 0, 194, 0, 409, 1976, + 2001, 421, 214, 1767, 1933, 436, 0, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 1909, 1998, + 345, 378, 221, 451, 406, 249, 1763, 0, 1766, 1761, + 1764, 1762, 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, + 0, 1959, 1960, 0, 1854, 1969, 1742, 0, 1937, 0, + 0, 0, 1901, 1996, 1814, 229, 0, 1738, 1739, 1740, + 0, 1844, 1845, 0, 0, 1955, 1954, 1953, 1956, 0, + 1990, 1988, 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, + 1886, 1931, 1904, 1913, 1787, 1846, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 1872, 187, + 200, 297, 1997, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 1934, 1879, 0, 1818, 1820, 1819, + 1769, 1771, 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, + 1776, 1783, 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, + 1856, 1870, 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, + 1950, 453, 239, 1852, 1877, 1915, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 0, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 1825, + 184, 0, 190, 0, 191, 193, 1810, 189, 1957, 1992, + 1889, 1903, 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, + 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, + 0, 0, 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, + 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, + 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, 0, 459, + 0, 1984, 299, 1949, 0, 457, 408, 324, 0, 0, + 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, + 1891, 1980, 0, 0, 0, 0, 0, 0, 1133, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1887, 1971, + 1798, 0, 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, + 1993, 1964, 1789, 1790, 250, 0, 0, 0, 0, 0, + 0, 0, 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, + 1930, 1815, 361, 270, 0, 0, 0, 0, 0, 0, + 3779, 0, 1784, 0, 1880, 0, 0, 0, 1751, 1737, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1837, 0, 0, 0, 1758, 1728, 1786, 1919, + 1729, 1727, 325, 1747, 1932, 1962, 1824, 288, 0, 1968, + 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, + 1753, 1806, 338, 1916, 1924, 0, 186, 298, 1939, 1780, + 1797, 232, 0, 377, 1892, 449, 0, 265, 1873, 376, + 300, 442, 1907, 1970, 448, 1809, 424, 458, 463, 258, + 1849, 222, 405, 248, 241, 1788, 1929, 1734, 271, 360, + 236, 292, 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, + 439, 188, 319, 440, 462, 0, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 1940, 1923, 1946, 1774, 1754, 1765, 1755, 1796, 1972, 280, + 272, 1947, 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, + 452, 1995, 244, 1925, 454, 0, 391, 390, 1812, 279, + 1926, 0, 0, 370, 0, 289, 192, 1951, 467, 208, + 294, 432, 0, 264, 337, 1894, 347, 185, 365, 314, + 316, 313, 317, 269, 0, 0, 1922, 367, 393, 437, + 210, 411, 0, 0, 0, 383, 0, 0, 1978, 307, + 253, 257, 273, 284, 1893, 374, 412, 455, 1884, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 1918, 204, 198, 1966, 1941, 1875, 1830, + 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, + 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, 446, 233, + 1748, 1986, 199, 1749, 1985, 334, 341, 333, 1989, 1987, + 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 1863, 410, 305, 0, 194, 0, 409, 1976, 2001, 421, + 214, 1767, 1933, 436, 0, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 1909, 1998, 345, 378, + 221, 451, 406, 249, 1763, 0, 1766, 1761, 1764, 1762, + 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, + 1960, 0, 1854, 1969, 1742, 0, 1937, 0, 0, 0, + 1901, 1996, 1814, 229, 0, 1738, 1739, 1740, 0, 1844, + 1845, 0, 0, 1955, 1954, 1953, 1956, 0, 1990, 1988, + 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, + 1904, 1913, 1787, 1846, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 1872, 187, 200, 297, + 1997, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, + 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, + 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, + 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, + 239, 1852, 1877, 1915, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 0, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 1825, 184, 0, + 190, 0, 191, 193, 1810, 189, 1957, 1992, 1889, 1903, + 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, 1807, 1994, + 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, 0, 0, + 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, 1938, 1869, + 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, 1963, 1793, + 1792, 1895, 1952, 1974, 1847, 0, 0, 459, 0, 1984, + 299, 1949, 0, 457, 408, 324, 0, 0, 1843, 1958, + 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, 1891, 1980, + 0, 0, 0, 0, 0, 0, 1133, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1887, 1971, 1798, 0, + 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, 1993, 1964, + 1789, 1790, 250, 0, 0, 0, 0, 0, 0, 0, + 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, 1930, 1815, + 361, 270, 0, 0, 0, 0, 0, 0, 3131, 0, + 1784, 0, 1880, 0, 0, 0, 1751, 1737, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1837, 0, 0, 0, 1758, 1728, 1786, 1919, 1729, 1727, + 325, 1747, 1932, 1962, 1824, 288, 0, 1968, 1822, 1821, + 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, 1753, 1806, + 338, 1916, 1924, 0, 186, 298, 1939, 1780, 1797, 232, + 0, 377, 1892, 449, 0, 265, 1873, 376, 300, 442, + 1907, 1970, 448, 1809, 424, 458, 463, 258, 1849, 222, + 405, 248, 241, 1788, 1929, 1734, 271, 360, 236, 292, + 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, 439, 188, + 319, 440, 462, 0, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 1940, 1923, + 1946, 1774, 1754, 1765, 1755, 1796, 1972, 280, 272, 1947, + 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, 452, 1995, + 244, 1925, 454, 0, 391, 390, 1812, 279, 1926, 0, + 0, 370, 0, 289, 192, 1951, 467, 208, 294, 432, + 0, 264, 337, 1894, 347, 185, 365, 314, 316, 313, + 317, 269, 0, 0, 1922, 367, 393, 437, 210, 411, + 0, 0, 0, 383, 0, 0, 1978, 307, 253, 257, + 273, 284, 1893, 374, 412, 455, 1884, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 1918, 204, 198, 1966, 1941, 1875, 1830, 1836, 1736, + 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, 1785, 1801, + 1773, 1888, 1772, 268, 1905, 445, 446, 233, 1748, 1986, + 199, 1749, 1985, 334, 341, 333, 1989, 1987, 441, 1967, + 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 1863, 410, + 305, 0, 194, 0, 409, 1976, 2001, 421, 214, 1767, + 1933, 436, 0, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 1909, 1998, 345, 378, 221, 451, + 406, 249, 1763, 0, 1766, 1761, 1764, 1762, 1867, 1868, + 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, 1960, 0, + 1854, 1969, 1742, 0, 1937, 0, 0, 0, 1901, 1996, + 1814, 229, 0, 1738, 1739, 1740, 0, 1844, 1845, 0, + 0, 1955, 1954, 1953, 1956, 0, 1990, 1988, 1991, 1757, + 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, 1904, 1913, + 1787, 1846, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 1872, 187, 200, 297, 1997, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, 1770, 1768, + 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, 1791, 1802, + 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, 1871, 1878, + 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, 239, 1852, + 1877, 1915, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 0, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 1825, 184, 0, 190, 0, + 191, 193, 1810, 189, 1957, 1992, 1889, 1903, 1794, 1973, + 0, 1935, 430, 1828, 1977, 1777, 1807, 1994, 1813, 1816, + 1897, 1743, 1866, 342, 1804, 1744, 0, 0, 0, 1782, + 1731, 1795, 1732, 1779, 246, 1775, 1938, 1869, 1975, 1848, + 1890, 1900, 245, 231, 1858, 1857, 1963, 1793, 1792, 1895, + 1952, 1974, 1847, 0, 0, 459, 0, 1984, 299, 1949, + 0, 457, 408, 324, 0, 0, 1843, 1958, 1864, 1927, + 1826, 1899, 1759, 1882, 1979, 1805, 1891, 1980, 0, 0, + 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1887, 1971, 1798, 0, 1838, 1896, + 1999, 1730, 1883, 0, 1735, 1746, 1993, 1964, 1789, 1790, + 250, 0, 0, 0, 0, 0, 0, 0, 1841, 1865, + 1917, 1823, 0, 450, 1902, 1912, 1930, 1815, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 1784, 0, + 1880, 0, 0, 0, 1751, 1737, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1837, 0, + 0, 0, 1758, 1728, 1786, 1919, 1729, 1727, 325, 1747, + 1932, 1962, 1824, 288, 0, 1968, 1822, 1821, 1906, 1752, + 1942, 1808, 296, 1750, 183, 1745, 1753, 1806, 338, 1916, + 1924, 0, 186, 298, 1939, 1780, 1797, 232, 0, 377, + 1892, 449, 0, 265, 1873, 376, 300, 442, 1907, 1970, + 448, 1809, 424, 458, 463, 258, 1849, 222, 405, 248, + 241, 1788, 1929, 1734, 271, 360, 236, 292, 1827, 1898, + 1781, 228, 1910, 1881, 1944, 404, 439, 188, 319, 440, + 462, 0, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 1940, 1923, 1946, 1774, + 1754, 1765, 1755, 1796, 1972, 280, 272, 1947, 1945, 1799, + 346, 212, 1862, 1855, 1842, 1920, 452, 1995, 244, 1925, + 454, 0, 391, 390, 1812, 279, 1926, 0, 0, 370, + 0, 289, 192, 1951, 467, 208, 294, 432, 0, 264, + 337, 1894, 347, 185, 365, 314, 316, 313, 317, 269, + 0, 0, 1922, 367, 393, 437, 210, 411, 0, 0, + 0, 383, 0, 0, 1978, 307, 253, 257, 273, 284, + 1893, 374, 412, 455, 1884, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 1918, + 204, 198, 1966, 1941, 1875, 1830, 1836, 1736, 0, 197, + 1831, 1832, 1833, 1834, 1835, 1914, 1785, 1801, 1773, 1888, + 1772, 268, 1905, 445, 446, 233, 1748, 1986, 199, 1749, + 1985, 334, 341, 333, 1989, 1987, 441, 1967, 1876, 1861, + 1859, 1741, 1965, 1874, 1860, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 1863, 410, 305, 0, + 194, 0, 409, 1976, 2001, 421, 214, 1767, 1933, 436, + 2281, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 1909, 1998, 345, 378, 221, 451, 406, 249, + 1763, 0, 1766, 1761, 1764, 1762, 1867, 1868, 1981, 1982, + 1983, 1921, 1756, 0, 0, 1959, 1960, 0, 1854, 1969, + 1742, 0, 1937, 0, 0, 0, 1901, 1996, 1814, 229, + 0, 1738, 1739, 1740, 0, 1844, 1845, 0, 0, 1955, + 1954, 1953, 1956, 0, 1990, 1988, 1991, 1757, 1778, 1800, + 1850, 1851, 1853, 1885, 1886, 1931, 1904, 1913, 1787, 1846, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 1872, 187, 200, 297, 1997, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 1934, 1879, + 0, 1818, 1820, 1819, 1769, 1771, 1770, 1768, 2000, 331, + 1961, 1726, 1733, 1760, 1776, 1783, 1791, 1802, 1803, 1811, + 1817, 1829, 1839, 1840, 1856, 1870, 1871, 1878, 1908, 1911, + 1928, 1936, 1943, 1948, 1950, 453, 239, 1852, 1877, 1915, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 0, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 1825, 184, 0, 190, 0, 191, 193, + 1810, 189, 1957, 1992, 1889, 1903, 1794, 1973, 0, 1935, + 430, 1828, 1977, 1777, 1807, 1994, 1813, 1816, 1897, 1743, + 1866, 342, 1804, 1744, 0, 0, 0, 1782, 1731, 1795, + 1732, 1779, 246, 1775, 1938, 1869, 1975, 1848, 1890, 1900, + 245, 231, 1858, 1857, 1963, 1793, 1792, 1895, 1952, 1974, + 1847, 0, 0, 459, 0, 1984, 299, 1949, 0, 457, + 408, 324, 0, 0, 1843, 1958, 1864, 1927, 1826, 1899, + 1759, 1882, 1979, 1805, 1891, 1980, 0, 0, 0, 0, + 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1887, 1971, 1798, 0, 1838, 1896, 1999, 1730, + 1883, 0, 1735, 1746, 1993, 1964, 1789, 1790, 250, 0, + 0, 0, 0, 0, 0, 0, 1841, 1865, 1917, 1823, + 0, 450, 1902, 1912, 1930, 1815, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 1784, 0, 1880, 0, + 0, 0, 1751, 1737, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1837, 0, 0, 0, + 1758, 1728, 1786, 1919, 1729, 1727, 325, 1747, 1932, 1962, + 1824, 288, 0, 1968, 1822, 1821, 1906, 1752, 1942, 1808, + 296, 1750, 183, 1745, 1753, 1806, 338, 1916, 1924, 0, + 186, 298, 1939, 1780, 1797, 232, 0, 377, 1892, 449, + 0, 265, 1873, 376, 300, 442, 1907, 1970, 448, 1809, + 424, 458, 463, 258, 1849, 222, 405, 248, 241, 1788, + 1929, 1734, 271, 360, 236, 292, 1827, 1898, 1781, 228, + 1910, 1881, 1944, 404, 439, 188, 319, 440, 462, 0, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 1940, 1923, 1946, 1774, 1754, 1765, + 1755, 1796, 1972, 280, 272, 1947, 1945, 1799, 346, 212, + 1862, 1855, 1842, 1920, 452, 1995, 244, 1925, 454, 0, + 391, 390, 1812, 279, 1926, 0, 0, 370, 0, 289, + 192, 1951, 467, 208, 294, 432, 0, 264, 337, 1894, + 347, 185, 365, 314, 316, 313, 317, 269, 0, 0, + 1922, 367, 393, 437, 210, 411, 0, 0, 0, 383, + 0, 0, 1978, 307, 253, 257, 273, 284, 1893, 374, + 412, 455, 1884, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 1918, 204, 198, + 1966, 1941, 1875, 1830, 1836, 1736, 0, 197, 1831, 1832, + 1833, 1834, 1835, 1914, 1785, 1801, 1773, 1888, 1772, 268, + 1905, 445, 446, 233, 1748, 1986, 199, 1749, 1985, 334, + 341, 333, 1989, 1987, 441, 1967, 1876, 1861, 1859, 1741, + 1965, 1874, 1860, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 1863, 410, 305, 0, 194, 0, + 409, 1976, 2001, 421, 214, 1767, 1933, 436, 0, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 1909, 1998, 345, 378, 221, 451, 406, 249, 1763, 0, + 1766, 1761, 1764, 1762, 1867, 1868, 1981, 1982, 1983, 1921, + 1756, 0, 0, 1959, 1960, 0, 1854, 1969, 1742, 0, + 1937, 0, 0, 0, 1901, 1996, 1814, 229, 0, 1738, + 1739, 1740, 0, 1844, 1845, 0, 0, 1955, 1954, 1953, + 1956, 0, 1990, 1988, 1991, 1757, 1778, 1800, 1850, 1851, + 1853, 1885, 1886, 1931, 1904, 1913, 1787, 1846, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 1872, 187, 200, 297, 1997, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 1934, 1879, 0, 1818, + 1820, 1819, 1769, 1771, 1770, 1768, 2000, 331, 1961, 1726, + 1733, 1760, 1776, 1783, 1791, 1802, 1803, 1811, 1817, 1829, + 1839, 1840, 1856, 1870, 1871, 1878, 1908, 1911, 1928, 1936, + 1943, 1948, 1950, 453, 239, 1852, 1877, 1915, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 3946, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 0, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 1825, 184, 0, 190, 0, 191, 193, 1810, 189, + 1957, 1992, 1889, 1903, 1794, 1973, 0, 1935, 430, 1828, + 1977, 1777, 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, + 1804, 1744, 0, 0, 0, 1782, 1731, 1795, 1732, 1779, + 246, 1775, 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, + 1858, 1857, 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, + 0, 459, 0, 1984, 299, 1949, 0, 457, 408, 324, + 0, 0, 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, + 1979, 1805, 1891, 1980, 0, 0, 0, 0, 0, 0, + 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1887, 1971, 1798, 0, 1838, 1896, 1999, 1730, 1883, 0, + 1735, 1746, 1993, 1964, 1789, 1790, 250, 0, 0, 0, + 0, 0, 0, 0, 1841, 1865, 1917, 1823, 0, 450, + 1902, 1912, 1930, 1815, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 1784, 0, 1880, 0, 0, 0, + 1751, 1737, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1837, 0, 0, 0, 1758, 1728, + 1786, 1919, 1729, 1727, 325, 1747, 1932, 1962, 1824, 288, + 0, 1968, 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, + 183, 1745, 1753, 1806, 338, 1916, 1924, 0, 186, 298, + 1939, 1780, 1797, 232, 0, 377, 1892, 449, 0, 265, + 1873, 376, 300, 442, 1907, 1970, 448, 1809, 424, 458, + 463, 258, 1849, 222, 405, 248, 241, 1788, 1929, 1734, + 271, 360, 236, 292, 1827, 1898, 1781, 228, 1910, 1881, + 1944, 404, 439, 188, 319, 440, 462, 0, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 1940, 1923, 1946, 1774, 1754, 1765, 1755, 1796, + 1972, 280, 272, 1947, 1945, 1799, 346, 212, 1862, 1855, + 1842, 1920, 452, 1995, 244, 1925, 454, 0, 391, 390, + 1812, 279, 1926, 0, 0, 370, 0, 289, 192, 1951, + 467, 208, 294, 432, 0, 264, 337, 1894, 347, 185, + 365, 314, 316, 313, 317, 269, 0, 0, 1922, 367, + 393, 437, 210, 411, 0, 0, 0, 383, 0, 0, + 1978, 307, 253, 257, 273, 284, 1893, 374, 412, 455, + 1884, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 1918, 204, 198, 1966, 1941, + 1875, 1830, 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, + 1835, 1914, 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, + 446, 233, 1748, 1986, 199, 1749, 1985, 334, 341, 333, + 1989, 1987, 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, + 1860, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 1863, 410, 305, 0, 194, 0, 409, 1976, + 2001, 421, 214, 1767, 1933, 436, 0, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 1909, 1998, + 345, 378, 221, 451, 406, 249, 1763, 0, 1766, 1761, + 1764, 1762, 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, + 0, 1959, 1960, 0, 1854, 1969, 1742, 0, 1937, 0, + 0, 0, 1901, 1996, 1814, 229, 0, 1738, 1739, 1740, + 0, 1844, 1845, 0, 0, 1955, 1954, 1953, 1956, 0, + 1990, 1988, 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, + 1886, 1931, 1904, 1913, 1787, 1846, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 1872, 187, + 200, 297, 1997, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 1934, 1879, 0, 1818, 1820, 1819, + 1769, 1771, 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, + 1776, 1783, 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, + 1856, 1870, 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, + 1950, 453, 239, 1852, 1877, 1915, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 0, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 1825, + 184, 0, 190, 0, 191, 193, 1810, 189, 1957, 1992, + 1889, 1903, 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, + 1807, 1994, 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, + 0, 0, 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, + 1938, 1869, 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, + 1963, 1793, 1792, 1895, 1952, 1974, 1847, 0, 0, 459, + 0, 1984, 299, 1949, 0, 457, 408, 324, 0, 0, + 1843, 1958, 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, + 1891, 1980, 0, 0, 0, 0, 0, 0, 4231, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1887, 1971, + 1798, 0, 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, + 1993, 1964, 1789, 1790, 250, 0, 0, 0, 0, 0, + 0, 0, 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, + 1930, 1815, 361, 270, 0, 0, 0, 0, 0, 0, + 0, 0, 1784, 0, 1880, 0, 0, 0, 1751, 1737, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1837, 0, 0, 0, 1758, 1728, 1786, 1919, + 1729, 1727, 325, 1747, 1932, 1962, 1824, 288, 0, 1968, + 1822, 1821, 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, + 1753, 1806, 338, 1916, 1924, 0, 186, 298, 1939, 1780, + 1797, 232, 0, 377, 1892, 449, 0, 265, 1873, 376, + 300, 442, 1907, 1970, 448, 1809, 424, 458, 463, 258, + 1849, 222, 405, 248, 241, 1788, 1929, 1734, 271, 360, + 236, 292, 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, + 439, 188, 319, 440, 462, 0, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 1940, 1923, 1946, 1774, 1754, 1765, 4234, 4235, 4236, 280, + 272, 1947, 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, + 452, 1995, 244, 1925, 454, 0, 391, 390, 1812, 279, + 1926, 0, 0, 370, 0, 289, 192, 1951, 467, 208, + 294, 432, 0, 264, 337, 1894, 347, 185, 365, 314, + 316, 313, 317, 269, 0, 0, 1922, 367, 393, 437, + 210, 411, 0, 0, 0, 383, 0, 0, 1978, 307, + 253, 257, 273, 284, 1893, 374, 412, 455, 1884, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 1918, 204, 198, 1966, 1941, 1875, 1830, + 1836, 1736, 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, + 1785, 1801, 1773, 1888, 1772, 268, 1905, 445, 446, 233, + 1748, 1986, 199, 1749, 1985, 334, 341, 333, 1989, 1987, + 441, 1967, 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 1863, 410, 305, 0, 194, 0, 409, 1976, 2001, 421, + 214, 1767, 1933, 436, 0, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 1909, 1998, 345, 378, + 221, 451, 406, 249, 1763, 0, 1766, 1761, 1764, 1762, + 1867, 1868, 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, + 1960, 0, 1854, 1969, 1742, 0, 1937, 0, 0, 0, + 1901, 1996, 1814, 229, 0, 1738, 1739, 1740, 0, 1844, + 1845, 0, 0, 1955, 1954, 1953, 1956, 0, 1990, 1988, + 1991, 1757, 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, + 1904, 1913, 1787, 1846, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 1872, 187, 200, 297, + 1997, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, + 1770, 1768, 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, + 1791, 1802, 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, + 1871, 1878, 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, + 239, 1852, 1877, 1915, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 0, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 1825, 184, 0, + 190, 0, 191, 193, 1810, 189, 1957, 1992, 1889, 1903, + 1794, 1973, 0, 1935, 430, 1828, 1977, 1777, 1807, 1994, + 1813, 1816, 1897, 1743, 1866, 342, 1804, 1744, 0, 0, + 0, 1782, 1731, 1795, 1732, 1779, 246, 1775, 1938, 1869, + 1975, 1848, 1890, 1900, 245, 231, 1858, 1857, 1963, 1793, + 1792, 1895, 1952, 1974, 1847, 0, 0, 459, 0, 1984, + 299, 1949, 0, 457, 408, 324, 0, 0, 1843, 1958, + 1864, 1927, 1826, 1899, 1759, 1882, 1979, 1805, 1891, 1980, + 0, 0, 0, 0, 0, 0, 3083, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1887, 1971, 1798, 0, + 1838, 1896, 1999, 1730, 1883, 0, 1735, 1746, 1993, 1964, + 1789, 1790, 250, 0, 0, 0, 0, 0, 0, 0, + 1841, 1865, 1917, 1823, 0, 450, 1902, 1912, 1930, 1815, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 1784, 0, 1880, 0, 0, 0, 1751, 1737, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1837, 0, 0, 0, 1758, 1728, 1786, 1919, 1729, 1727, + 325, 1747, 1932, 1962, 1824, 288, 0, 1968, 1822, 1821, + 1906, 1752, 1942, 1808, 296, 1750, 183, 1745, 1753, 1806, + 338, 1916, 1924, 0, 186, 298, 1939, 1780, 1797, 232, + 0, 377, 1892, 449, 0, 265, 1873, 376, 300, 442, + 1907, 1970, 448, 1809, 424, 458, 463, 258, 1849, 222, + 405, 248, 241, 1788, 1929, 1734, 271, 360, 236, 292, + 1827, 1898, 1781, 228, 1910, 1881, 1944, 404, 439, 188, + 319, 440, 462, 0, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 1940, 1923, + 1946, 1774, 1754, 1765, 1755, 1796, 1972, 280, 272, 1947, + 1945, 1799, 346, 212, 1862, 1855, 1842, 1920, 452, 1995, + 244, 1925, 454, 0, 391, 390, 1812, 279, 1926, 0, + 0, 370, 0, 289, 192, 1951, 467, 208, 294, 432, + 0, 264, 337, 1894, 347, 185, 365, 314, 316, 313, + 317, 269, 0, 0, 1922, 367, 393, 437, 210, 411, + 0, 0, 0, 383, 0, 0, 1978, 307, 253, 257, + 273, 284, 1893, 374, 412, 455, 1884, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 1918, 204, 198, 1966, 1941, 1875, 1830, 1836, 1736, + 0, 197, 1831, 1832, 1833, 1834, 1835, 1914, 1785, 1801, + 1773, 1888, 1772, 268, 1905, 445, 446, 233, 1748, 1986, + 199, 1749, 1985, 334, 341, 333, 1989, 1987, 441, 1967, + 1876, 1861, 1859, 1741, 1965, 1874, 1860, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 1863, 410, + 305, 0, 194, 0, 409, 1976, 2001, 421, 214, 1767, + 1933, 436, 0, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 1909, 1998, 345, 378, 221, 451, + 406, 249, 1763, 0, 1766, 1761, 1764, 1762, 1867, 1868, + 1981, 1982, 1983, 1921, 1756, 0, 0, 1959, 1960, 0, + 1854, 1969, 1742, 0, 1937, 0, 0, 0, 1901, 1996, + 1814, 229, 0, 1738, 1739, 1740, 0, 1844, 1845, 0, + 0, 1955, 1954, 1953, 1956, 0, 1990, 1988, 1991, 1757, + 1778, 1800, 1850, 1851, 1853, 1885, 1886, 1931, 1904, 1913, + 1787, 1846, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 1872, 187, 200, 297, 1997, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 1934, 1879, 0, 1818, 1820, 1819, 1769, 1771, 1770, 1768, + 2000, 331, 1961, 1726, 1733, 1760, 1776, 1783, 1791, 1802, + 1803, 1811, 1817, 1829, 1839, 1840, 1856, 1870, 1871, 1878, + 1908, 1911, 1928, 1936, 1943, 1948, 1950, 453, 239, 1852, + 1877, 1915, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 0, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 1825, 184, 0, 190, 0, + 191, 193, 1810, 189, 1957, 1992, 1889, 1903, 568, 430, + 562, 573, 555, 0, 0, 0, 0, 0, 0, 0, + 342, 0, 0, 619, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 563, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 459, 0, 0, 299, 0, 0, 457, 408, + 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 94, 0, + 616, 617, 0, 705, 0, 706, 708, 709, 710, 711, + 0, 0, 0, 707, 2273, 3287, 3288, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, + 0, 0, 0, 0, 0, 3282, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 726, 727, 728, 729, + 730, 731, 732, 733, 734, 735, 736, 737, 738, 739, + 740, 741, 742, 743, 744, 745, 746, 747, 748, 749, + 750, 751, 752, 753, 754, 755, 756, 757, 758, 759, + 760, 761, 762, 763, 764, 765, 766, 767, 0, 554, + 553, 556, 0, 0, 0, 325, 0, 0, 0, 561, + 288, 0, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 565, 0, 0, 186, + 298, 569, 0, 0, 232, 0, 377, 2270, 449, 0, + 265, 0, 376, 300, 442, 0, 572, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 557, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 0, 0, 452, 0, 244, 0, 454, 0, 391, + 390, 560, 279, 0, 0, 0, 370, 0, 289, 192, + 0, 467, 208, 294, 432, 0, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 0, 0, 0, + 622, 393, 437, 210, 411, 558, 559, 566, 567, 570, + 571, 574, 307, 253, 257, 273, 284, 0, 374, 412, + 455, 0, 205, 577, 578, 579, 580, 581, 582, 583, + 584, 585, 586, 587, 588, 589, 590, 591, 592, 593, + 594, 595, 596, 597, 598, 599, 600, 601, 602, 603, + 604, 605, 606, 607, 608, 609, 610, 611, 612, 613, + 614, 615, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 2271, 2272, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 0, 0, 0, + 0, 0, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 0, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 3298, 1037, 0, 3289, 3290, 3292, 3299, 3300, 3291, 3293, + 3294, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 3295, 3296, 3297, 229, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 0, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 0, 0, 0, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 564, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 0, 184, 0, 190, 0, 191, 193, 0, 189, 568, + 430, 562, 573, 555, 0, 0, 0, 0, 0, 0, + 0, 342, 0, 0, 547, 0, 0, 0, 0, 0, + 0, 0, 246, 0, 0, 563, 0, 0, 0, 0, + 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 459, 0, 0, 299, 0, 0, 457, + 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 616, 617, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 554, 553, 556, 0, 0, 0, 325, 0, 0, 0, + 561, 288, 0, 0, 0, 0, 0, 0, 0, 0, + 296, 0, 183, 0, 0, 0, 338, 565, 0, 0, + 186, 298, 569, 0, 0, 232, 0, 377, 0, 449, + 0, 265, 0, 376, 300, 442, 0, 572, 448, 0, + 424, 458, 463, 258, 0, 222, 405, 248, 241, 0, + 0, 0, 271, 360, 236, 292, 0, 0, 0, 228, + 0, 0, 0, 404, 439, 188, 319, 440, 462, 557, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 272, 0, 0, 0, 346, 212, + 0, 0, 0, 0, 452, 0, 244, 0, 454, 0, + 391, 390, 560, 279, 0, 0, 0, 370, 0, 289, + 192, 0, 467, 208, 294, 432, 0, 264, 337, 0, + 347, 185, 365, 314, 316, 313, 317, 269, 0, 0, + 0, 550, 393, 437, 210, 411, 558, 559, 566, 567, + 570, 571, 574, 307, 253, 257, 273, 284, 0, 374, + 412, 455, 0, 205, 577, 578, 579, 580, 581, 582, + 583, 584, 585, 586, 587, 588, 589, 590, 591, 592, + 593, 594, 595, 596, 597, 598, 599, 600, 601, 602, + 603, 604, 605, 606, 607, 608, 609, 610, 611, 612, + 613, 614, 615, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 0, 204, 198, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 268, + 0, 445, 446, 233, 0, 0, 199, 0, 0, 334, + 341, 333, 0, 0, 441, 0, 0, 0, 0, 0, + 0, 0, 0, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 0, 410, 305, 0, 194, 0, + 409, 0, 0, 421, 214, 0, 0, 436, 0, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 229, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 0, 187, 200, 297, 0, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 453, 239, 0, 0, 0, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 564, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 430, 184, 0, 190, 0, 191, 193, 0, 189, + 0, 0, 342, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 246, 0, 0, 0, 0, 0, 0, + 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, + 2416, 2420, 0, 161, 459, 178, 0, 299, 0, 478, + 457, 408, 324, 481, 480, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, + 0, 160, 0, 0, 0, 0, 479, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 250, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, + 0, 2419, 288, 179, 0, 0, 0, 2413, 0, 2414, + 2415, 296, 1135, 183, 0, 2411, 2418, 338, 0, 0, + 166, 186, 298, 0, 0, 0, 232, 1129, 377, 0, + 449, 477, 265, 0, 376, 300, 442, 0, 0, 448, + 0, 424, 458, 463, 258, 0, 222, 405, 248, 241, + 0, 0, 0, 271, 360, 236, 292, 0, 0, 0, + 228, 0, 0, 0, 404, 439, 188, 319, 440, 462, + 155, 259, 396, 260, 423, 251, 223, 363, 202, 0, + 0, 0, 242, 286, 0, 0, 465, 456, 213, 261, + 371, 375, 352, 209, 431, 320, 330, 225, 227, 226, + 203, 397, 438, 216, 230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 272, 0, 0, 0, 346, + 212, 0, 0, 0, 0, 452, 0, 244, 0, 454, + 168, 391, 390, 0, 279, 0, 169, 159, 370, 170, + 289, 192, 0, 467, 208, 294, 432, 476, 264, 337, + 0, 347, 185, 365, 314, 316, 313, 317, 269, 164, + 171, 0, 367, 393, 437, 210, 411, 162, 165, 173, + 383, 174, 175, 0, 307, 253, 257, 273, 284, 0, + 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 379, 380, 413, 428, 385, 267, + 306, 308, 415, 420, 416, 417, 414, 419, 418, 381, + 382, 196, 422, 447, 217, 392, 395, 466, 0, 204, + 198, 0, 0, 0, 0, 0, 0, 0, 197, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 268, 0, 445, 446, 233, 0, 0, 199, 0, 0, + 334, 341, 333, 0, 0, 441, 0, 0, 0, 0, + 0, 0, 0, 0, 295, 256, 275, 358, 302, 359, + 276, 328, 327, 329, 304, 0, 410, 305, 0, 194, + 0, 409, 0, 0, 421, 214, 0, 0, 436, 167, + 366, 215, 266, 254, 357, 332, 206, 278, 407, 293, + 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 180, 181, 0, 0, 182, 0, 0, 0, + 0, 0, 176, 177, 163, 0, 0, 0, 229, 153, + 0, 0, 0, 154, 0, 0, 156, 157, 0, 0, + 0, 0, 158, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 354, + 195, 207, 435, 220, 240, 238, 255, 290, 315, 322, + 351, 394, 400, 401, 425, 426, 427, 429, 243, 318, + 247, 219, 372, 218, 303, 281, 353, 433, 434, 362, + 235, 0, 187, 200, 297, 0, 369, 263, 321, 398, + 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 453, 239, 0, 0, 0, 201, + 211, 224, 237, 252, 0, 262, 274, 277, 282, 283, + 287, 291, 309, 310, 311, 312, 335, 336, 339, 340, + 343, 344, 348, 349, 350, 355, 356, 364, 172, 373, + 384, 386, 387, 388, 389, 399, 402, 403, 443, 444, + 460, 461, 430, 184, 0, 190, 0, 191, 193, 0, + 189, 0, 0, 342, 0, 0, 0, 0, 0, 0, + 1446, 0, 0, 0, 246, 0, 0, 0, 0, 0, + 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 161, 459, 178, 0, 299, 0, + 478, 457, 408, 324, 481, 480, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1448, 1447, 0, 0, 0, 0, 0, + 0, 0, 160, 0, 0, 0, 0, 479, 0, 1442, + 1443, 1441, 0, 0, 0, 0, 0, 0, 0, 0, + 250, 0, 0, 0, 0, 0, 0, 0, 1444, 0, + 0, 0, 0, 450, 0, 0, 0, 0, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, + 0, 0, 0, 288, 179, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 183, 0, 0, 0, 338, 0, + 0, 166, 186, 298, 0, 0, 0, 232, 0, 377, + 0, 449, 477, 265, 0, 376, 300, 442, 0, 0, + 448, 0, 424, 458, 463, 258, 0, 222, 405, 248, + 241, 0, 0, 0, 271, 360, 236, 292, 0, 0, + 0, 228, 0, 0, 0, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 272, 0, 0, 0, + 346, 212, 0, 0, 0, 0, 452, 0, 244, 0, + 454, 168, 391, 390, 0, 279, 0, 169, 159, 370, + 170, 289, 192, 0, 467, 208, 294, 432, 476, 264, + 337, 0, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 0, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 0, 307, 253, 257, 273, 284, + 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 0, + 204, 198, 0, 0, 0, 0, 0, 0, 0, 197, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 268, 0, 445, 446, 233, 0, 0, 199, 0, + 0, 334, 341, 333, 0, 0, 441, 0, 0, 0, + 0, 0, 0, 0, 0, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 0, 410, 305, 0, + 194, 0, 409, 0, 0, 421, 214, 0, 0, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 0, 0, 345, 378, 221, 451, 406, 249, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 176, 177, 163, 0, 0, 0, 229, + 153, 0, 0, 0, 154, 0, 0, 156, 157, 0, + 0, 0, 0, 158, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 0, 187, 200, 297, 0, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 331, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 453, 239, 0, 0, 0, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 430, 184, 0, 190, 0, 191, 193, + 0, 189, 0, 0, 342, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, + 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 161, 459, 178, 0, 299, + 0, 478, 457, 408, 324, 481, 480, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1133, 0, 0, 0, 0, + 0, 0, 0, 160, 0, 0, 0, 0, 479, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 450, 0, 0, 0, 0, 361, + 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, + 0, 0, 0, 0, 288, 179, 0, 0, 0, 0, + 0, 0, 0, 296, 1135, 183, 0, 1131, 0, 338, + 0, 0, 166, 186, 298, 0, 0, 0, 232, 1129, + 377, 0, 449, 477, 265, 0, 376, 300, 442, 0, + 0, 448, 0, 424, 458, 463, 258, 0, 222, 405, + 248, 241, 0, 0, 0, 271, 360, 236, 292, 0, + 0, 0, 228, 0, 0, 0, 404, 439, 188, 319, + 440, 462, 155, 259, 396, 260, 423, 251, 223, 363, + 202, 0, 0, 0, 242, 286, 0, 0, 465, 456, + 213, 261, 371, 375, 352, 209, 431, 320, 330, 225, + 227, 226, 203, 397, 438, 216, 230, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 272, 0, 0, + 0, 346, 212, 0, 0, 0, 0, 452, 0, 244, + 0, 454, 168, 391, 390, 0, 279, 0, 169, 159, + 370, 170, 289, 192, 0, 467, 208, 294, 432, 476, + 264, 337, 0, 347, 185, 365, 314, 316, 313, 317, + 269, 164, 171, 0, 367, 393, 437, 210, 411, 162, + 165, 173, 383, 174, 175, 0, 307, 253, 257, 273, + 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 379, 380, 413, 428, + 385, 267, 306, 308, 415, 420, 416, 417, 414, 419, + 418, 381, 382, 196, 422, 447, 217, 392, 395, 466, + 0, 204, 198, 0, 0, 0, 0, 0, 0, 0, + 197, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 268, 0, 445, 446, 233, 0, 0, 199, + 0, 0, 334, 341, 333, 0, 0, 441, 0, 0, + 0, 0, 0, 0, 0, 0, 295, 256, 275, 358, + 302, 359, 276, 328, 327, 329, 304, 0, 410, 305, + 0, 194, 0, 409, 0, 0, 421, 214, 0, 0, + 436, 167, 366, 215, 266, 254, 357, 332, 206, 278, + 407, 293, 301, 0, 0, 345, 378, 221, 451, 406, + 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 180, 181, 0, 0, 182, 0, + 0, 0, 0, 0, 176, 177, 163, 0, 0, 0, + 229, 153, 0, 0, 0, 154, 0, 0, 156, 157, + 0, 0, 0, 0, 158, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 354, 195, 207, 435, 220, 240, 238, 255, 290, + 315, 322, 351, 394, 400, 401, 425, 426, 427, 429, + 243, 318, 247, 219, 372, 218, 303, 281, 353, 433, + 434, 362, 235, 0, 187, 200, 297, 0, 369, 263, + 321, 398, 323, 285, 234, 464, 326, 368, 468, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 453, 239, 0, 0, + 0, 201, 211, 224, 237, 252, 0, 262, 274, 277, + 282, 283, 287, 291, 309, 310, 311, 312, 335, 336, + 339, 340, 343, 344, 348, 349, 350, 355, 356, 364, + 172, 373, 384, 386, 387, 388, 389, 399, 402, 403, + 443, 444, 460, 461, 430, 184, 0, 190, 0, 191, + 193, 0, 189, 0, 0, 342, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 246, 0, 0, 0, + 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 161, 459, 178, 0, + 299, 0, 478, 457, 408, 324, 481, 480, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1671, 0, 0, 0, + 0, 0, 0, 0, 160, 0, 0, 0, 0, 479, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 450, 0, 0, 0, 0, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 325, 0, 0, 0, 0, 288, 179, 0, 0, 0, + 0, 0, 0, 0, 296, 3437, 183, 0, 0, 3436, + 338, 0, 0, 166, 186, 298, 0, 0, 0, 232, + 0, 377, 0, 449, 477, 265, 0, 376, 300, 442, + 0, 0, 448, 0, 424, 458, 463, 258, 0, 222, + 405, 248, 241, 0, 0, 0, 271, 360, 236, 292, + 0, 0, 0, 228, 0, 0, 0, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 272, 0, + 0, 0, 346, 212, 0, 0, 0, 0, 452, 0, + 244, 0, 454, 168, 391, 390, 0, 279, 0, 169, + 159, 370, 170, 289, 192, 0, 467, 208, 294, 432, + 476, 264, 337, 0, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 0, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 0, 307, 253, 257, + 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 0, 204, 198, 0, 0, 0, 0, 0, 0, + 0, 197, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 268, 0, 445, 446, 233, 0, 0, + 199, 0, 0, 334, 341, 333, 0, 0, 441, 0, + 0, 0, 0, 0, 0, 0, 0, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 0, 410, + 305, 0, 194, 0, 409, 0, 0, 421, 214, 0, + 0, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 0, 0, 345, 378, 221, 451, + 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 176, 177, 163, 0, 0, + 0, 229, 153, 0, 0, 0, 154, 0, 0, 156, + 157, 0, 0, 0, 0, 158, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 0, 187, 200, 297, 0, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 453, 239, 0, + 0, 0, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 430, 184, 0, 190, 0, + 191, 193, 0, 189, 0, 0, 342, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 246, 0, 0, + 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 161, 459, 178, + 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 94, 0, 0, 0, 0, 0, 655, 0, 0, + 0, 0, 0, 0, 0, 160, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 450, 0, 0, 0, + 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 325, 0, 0, 0, 0, 288, 179, 0, 0, + 0, 0, 0, 0, 0, 296, 0, 183, 0, 0, + 0, 338, 0, 0, 166, 186, 298, 0, 0, 0, + 232, 0, 377, 0, 449, 0, 265, 0, 376, 300, + 442, 0, 0, 448, 0, 424, 458, 463, 258, 0, + 222, 405, 248, 241, 0, 0, 0, 271, 360, 236, + 292, 0, 0, 0, 228, 0, 0, 0, 404, 439, + 188, 319, 440, 462, 155, 259, 396, 260, 423, 251, + 223, 363, 202, 0, 0, 0, 242, 286, 0, 0, + 465, 456, 213, 261, 371, 375, 352, 209, 431, 320, + 330, 225, 227, 226, 203, 397, 438, 216, 230, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 272, + 0, 0, 0, 346, 212, 0, 0, 0, 0, 452, + 0, 244, 0, 454, 168, 391, 390, 0, 279, 0, + 169, 159, 370, 170, 289, 192, 0, 467, 208, 294, + 432, 150, 264, 337, 0, 347, 185, 365, 314, 316, + 313, 317, 269, 164, 171, 0, 367, 393, 437, 210, + 411, 162, 165, 173, 383, 174, 175, 0, 307, 253, + 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 379, 380, + 413, 428, 385, 267, 306, 308, 415, 420, 416, 417, + 414, 419, 418, 381, 382, 196, 422, 447, 217, 392, + 395, 466, 0, 204, 198, 0, 0, 0, 0, 0, + 0, 0, 197, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 268, 0, 445, 446, 233, 0, + 0, 199, 0, 0, 334, 341, 333, 0, 0, 441, + 0, 0, 0, 0, 0, 0, 0, 0, 295, 256, + 275, 358, 302, 359, 276, 328, 327, 329, 304, 0, + 410, 305, 0, 194, 0, 409, 0, 0, 421, 214, + 0, 0, 436, 167, 366, 215, 266, 254, 357, 332, + 206, 278, 407, 293, 301, 0, 0, 345, 378, 221, + 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 180, 181, 0, 0, + 182, 0, 0, 0, 0, 0, 176, 177, 163, 0, + 0, 0, 229, 153, 0, 0, 0, 154, 0, 0, + 156, 157, 0, 0, 0, 0, 158, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 3128, 656, 354, 195, 207, 435, 220, 240, 238, + 255, 290, 315, 322, 351, 394, 400, 401, 425, 426, + 427, 429, 243, 318, 247, 219, 372, 218, 303, 281, + 353, 433, 434, 362, 235, 0, 187, 200, 297, 0, + 369, 263, 321, 398, 323, 285, 234, 464, 326, 368, + 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 453, 239, + 649, 0, 0, 201, 211, 224, 237, 252, 0, 262, + 274, 277, 282, 283, 287, 291, 309, 310, 311, 312, + 335, 336, 339, 340, 343, 344, 348, 349, 350, 355, + 356, 364, 172, 373, 384, 386, 387, 388, 389, 399, + 402, 403, 443, 444, 460, 461, 430, 184, 0, 190, + 0, 191, 193, 0, 189, 0, 0, 342, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 246, 0, + 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 161, 459, + 178, 0, 299, 0, 478, 457, 408, 324, 481, 480, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1448, 1447, 0, + 0, 0, 0, 0, 0, 0, 160, 0, 0, 0, + 0, 479, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 450, 0, 0, + 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 325, 0, 0, 0, 0, 288, 179, 0, + 0, 0, 0, 0, 0, 0, 296, 0, 183, 0, + 0, 0, 338, 0, 0, 166, 186, 298, 0, 0, + 0, 232, 2225, 377, 0, 449, 477, 265, 0, 376, + 300, 442, 0, 0, 448, 0, 424, 458, 463, 258, + 0, 222, 405, 248, 241, 0, 0, 0, 271, 360, + 236, 292, 0, 0, 0, 228, 0, 0, 0, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 272, 0, 0, 0, 346, 212, 0, 0, 0, 0, + 452, 0, 244, 0, 454, 168, 391, 390, 0, 279, + 0, 169, 159, 370, 170, 289, 192, 0, 467, 208, + 294, 432, 476, 264, 337, 0, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 0, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 0, 307, + 253, 257, 273, 284, 0, 374, 412, 455, 0, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 0, 204, 198, 0, 0, 0, 0, + 0, 0, 0, 197, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 268, 0, 445, 446, 233, + 0, 0, 199, 0, 0, 334, 341, 333, 0, 0, + 441, 0, 0, 0, 0, 0, 0, 0, 0, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 0, 410, 305, 0, 194, 0, 409, 0, 0, 421, + 214, 0, 0, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 0, 0, 345, 378, + 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 176, 177, 163, + 0, 0, 0, 229, 153, 0, 0, 0, 154, 0, + 0, 156, 157, 0, 0, 0, 0, 158, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 0, 187, 200, 297, + 0, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 453, + 239, 0, 0, 0, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 430, 184, 0, + 190, 0, 191, 193, 0, 189, 0, 0, 342, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 246, + 0, 0, 0, 0, 0, 0, 0, 245, 231, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 161, + 459, 178, 0, 299, 0, 0, 457, 408, 324, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 94, 0, 0, 0, 0, 0, 655, + 0, 0, 0, 0, 0, 0, 0, 160, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 450, 0, + 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 325, 0, 0, 0, 0, 288, 179, + 0, 0, 0, 0, 0, 0, 0, 296, 0, 183, + 0, 0, 0, 338, 0, 0, 166, 186, 298, 0, + 0, 0, 232, 0, 377, 0, 449, 0, 265, 0, + 376, 300, 442, 0, 0, 448, 0, 424, 458, 463, + 258, 0, 222, 405, 248, 241, 0, 0, 0, 271, + 360, 236, 292, 0, 0, 0, 228, 0, 0, 0, + 404, 439, 188, 319, 440, 462, 155, 259, 396, 260, + 423, 251, 223, 363, 202, 0, 0, 0, 242, 286, + 0, 0, 465, 456, 213, 261, 371, 375, 352, 209, + 431, 320, 330, 225, 227, 226, 203, 397, 438, 216, + 230, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 272, 0, 0, 0, 346, 212, 0, 0, 0, + 0, 452, 0, 244, 0, 454, 168, 391, 390, 0, + 279, 0, 169, 159, 370, 170, 289, 192, 0, 467, + 208, 294, 432, 150, 264, 337, 0, 347, 185, 365, + 314, 316, 313, 317, 269, 164, 171, 0, 367, 393, + 437, 210, 411, 162, 165, 173, 383, 174, 175, 0, + 307, 253, 257, 273, 284, 0, 374, 412, 455, 0, + 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 379, 380, 413, 428, 385, 267, 306, 308, 415, 420, + 416, 417, 414, 419, 418, 381, 382, 196, 422, 447, + 217, 392, 395, 466, 0, 204, 198, 0, 0, 0, + 0, 0, 0, 0, 197, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 268, 0, 445, 446, + 233, 0, 0, 199, 0, 0, 334, 341, 333, 0, + 0, 441, 0, 0, 0, 0, 0, 0, 0, 0, + 295, 256, 275, 358, 302, 359, 276, 328, 327, 329, + 304, 0, 410, 305, 0, 194, 0, 409, 0, 0, + 421, 214, 0, 0, 436, 167, 366, 215, 266, 254, + 357, 332, 206, 278, 407, 293, 301, 0, 0, 345, + 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 180, 181, + 0, 0, 182, 0, 0, 0, 0, 0, 176, 177, + 163, 0, 0, 0, 229, 153, 0, 0, 0, 154, + 0, 0, 156, 157, 0, 0, 0, 0, 158, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 656, 354, 195, 207, 435, 220, + 240, 238, 255, 290, 315, 322, 351, 394, 400, 401, + 425, 426, 427, 429, 243, 318, 247, 219, 372, 218, + 303, 281, 353, 433, 434, 362, 235, 0, 187, 200, + 297, 0, 369, 263, 321, 398, 323, 285, 234, 464, + 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 453, 239, 649, 0, 0, 201, 211, 224, 237, 252, + 0, 262, 274, 277, 282, 283, 287, 291, 309, 310, + 311, 312, 335, 336, 339, 340, 343, 344, 348, 349, + 350, 355, 356, 364, 172, 373, 384, 386, 387, 388, + 389, 399, 402, 403, 443, 444, 460, 461, 430, 184, + 0, 190, 0, 191, 193, 0, 189, 0, 0, 342, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 246, 0, 0, 0, 0, 0, 0, 0, 245, 231, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 161, 459, 178, 0, 299, 0, 478, 457, 408, 324, + 481, 480, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 3404, 0, 0, 0, 0, 0, 0, 0, 160, 0, + 0, 0, 0, 479, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 450, + 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 325, 0, 0, 0, 0, 288, + 179, 0, 0, 0, 0, 0, 0, 0, 296, 1135, + 183, 0, 0, 0, 338, 0, 0, 166, 186, 298, + 0, 0, 0, 232, 0, 377, 0, 449, 477, 265, + 0, 376, 300, 442, 0, 0, 448, 0, 424, 458, + 463, 258, 0, 222, 405, 248, 241, 0, 0, 0, + 271, 360, 236, 292, 0, 0, 0, 228, 0, 0, + 0, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 272, 0, 0, 0, 346, 212, 0, 0, + 0, 0, 452, 0, 244, 0, 454, 168, 391, 390, + 0, 279, 0, 169, 159, 370, 170, 289, 192, 0, + 467, 208, 294, 432, 476, 264, 337, 0, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 0, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 0, 307, 253, 257, 273, 284, 0, 374, 412, 455, + 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 0, 204, 198, 0, 0, + 0, 0, 0, 0, 0, 197, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 268, 0, 445, + 446, 233, 0, 0, 199, 0, 0, 334, 341, 333, + 0, 0, 441, 0, 0, 0, 0, 0, 0, 0, + 0, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 0, 410, 305, 0, 194, 0, 409, 0, + 0, 421, 214, 0, 0, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 0, 0, + 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 176, + 177, 163, 0, 0, 0, 229, 153, 0, 0, 0, + 154, 0, 0, 156, 157, 0, 0, 0, 0, 158, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 0, 187, + 200, 297, 0, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 453, 239, 0, 0, 0, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 430, + 184, 0, 190, 0, 191, 193, 0, 189, 0, 0, + 342, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 0, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 161, 459, 178, 0, 299, 0, 478, 457, 408, + 324, 481, 480, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 3395, 0, 0, 0, 0, + 0, 3397, 0, 0, 0, 0, 0, 0, 0, 160, + 0, 0, 0, 0, 479, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, + 288, 179, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 0, 0, 166, 186, + 298, 0, 0, 0, 232, 0, 377, 0, 449, 477, + 265, 0, 376, 300, 442, 0, 0, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 155, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 0, 0, 452, 0, 244, 0, 454, 168, 391, + 390, 0, 279, 0, 169, 159, 370, 170, 289, 192, + 0, 467, 208, 294, 432, 476, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 164, 171, 0, + 367, 393, 437, 210, 411, 162, 165, 173, 383, 174, + 175, 0, 307, 253, 257, 273, 284, 0, 374, 412, + 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 0, 0, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 0, 0, 0, + 0, 0, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 167, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 176, 177, 163, 0, 0, 0, 229, 153, 0, 0, + 0, 154, 0, 0, 156, 157, 0, 0, 0, 0, + 158, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 0, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 0, 0, 0, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 172, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 430, 184, 0, 190, 0, 191, 193, 0, 189, 0, + 0, 342, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, + 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 161, 459, 178, 0, 299, 0, 478, 457, + 408, 324, 481, 480, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2848, 0, 0, 0, 0, 0, 0, 0, + 160, 0, 0, 0, 0, 479, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, + 0, 288, 179, 0, 0, 0, 0, 0, 0, 0, + 296, 1135, 183, 0, 0, 0, 338, 0, 0, 166, + 186, 298, 0, 0, 0, 232, 0, 377, 0, 449, + 477, 265, 0, 376, 300, 442, 0, 0, 448, 0, + 424, 458, 463, 258, 0, 222, 405, 248, 241, 0, + 0, 0, 271, 360, 236, 292, 0, 0, 0, 228, + 0, 0, 0, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 272, 0, 0, 0, 346, 212, + 0, 0, 0, 0, 452, 0, 244, 0, 454, 168, + 391, 390, 0, 279, 0, 169, 159, 370, 170, 289, + 192, 0, 467, 208, 294, 432, 476, 264, 337, 0, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 0, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 0, 307, 253, 257, 273, 284, 0, 374, + 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 0, 204, 198, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 268, + 0, 445, 446, 233, 0, 0, 199, 0, 0, 334, + 341, 333, 0, 0, 441, 0, 0, 0, 0, 0, + 0, 0, 0, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 0, 410, 305, 0, 194, 0, + 409, 0, 0, 421, 214, 0, 0, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 176, 177, 163, 0, 0, 0, 229, 153, 0, + 0, 0, 154, 0, 0, 156, 157, 0, 0, 0, + 0, 158, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 0, 187, 200, 297, 0, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 453, 239, 0, 0, 0, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 430, 184, 0, 190, 0, 191, 193, 0, 189, + 0, 0, 342, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 246, 0, 0, 0, 0, 0, 0, + 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 161, 459, 178, 0, 299, 0, 478, + 457, 408, 324, 481, 480, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2009, 2007, 0, 0, 0, 0, 0, 0, + 0, 160, 0, 0, 0, 0, 479, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 250, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, + 0, 0, 288, 179, 0, 0, 0, 0, 0, 0, + 0, 296, 0, 183, 0, 0, 0, 338, 0, 0, + 166, 186, 298, 0, 0, 0, 232, 0, 377, 0, + 449, 477, 265, 0, 376, 300, 442, 0, 0, 448, + 0, 424, 458, 463, 258, 0, 222, 405, 248, 241, + 0, 0, 0, 271, 360, 236, 292, 0, 0, 0, + 228, 0, 0, 0, 404, 439, 188, 319, 440, 462, + 155, 259, 396, 260, 423, 251, 223, 363, 202, 0, + 0, 0, 242, 286, 0, 0, 465, 456, 213, 261, + 371, 375, 352, 209, 431, 320, 330, 225, 227, 226, + 203, 397, 438, 216, 230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 272, 0, 0, 0, 346, + 212, 0, 0, 0, 0, 452, 0, 244, 0, 454, + 168, 391, 390, 0, 279, 0, 169, 159, 370, 170, + 289, 192, 0, 467, 208, 294, 432, 476, 264, 337, + 0, 347, 185, 365, 314, 316, 313, 317, 269, 164, + 171, 0, 367, 393, 437, 210, 411, 162, 165, 173, + 383, 174, 175, 0, 307, 253, 257, 273, 284, 0, + 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 379, 380, 413, 428, 385, 267, + 306, 308, 415, 420, 416, 417, 414, 419, 418, 381, + 382, 196, 422, 447, 217, 392, 395, 466, 0, 204, + 198, 0, 0, 0, 0, 0, 0, 0, 197, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 268, 0, 445, 446, 233, 0, 0, 199, 0, 0, + 334, 341, 333, 0, 0, 441, 0, 0, 0, 0, + 0, 0, 0, 0, 295, 256, 275, 358, 302, 359, + 276, 328, 327, 329, 304, 0, 410, 305, 0, 194, + 0, 409, 0, 0, 421, 214, 0, 0, 436, 167, + 366, 215, 266, 254, 357, 332, 206, 278, 407, 293, + 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 176, 177, 163, 0, 0, 0, 229, 153, + 0, 0, 0, 154, 0, 0, 156, 157, 0, 0, + 0, 0, 158, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 354, + 195, 207, 435, 220, 240, 238, 255, 290, 315, 322, + 351, 394, 400, 401, 425, 426, 427, 429, 243, 318, + 247, 219, 372, 218, 303, 281, 353, 433, 434, 362, + 235, 0, 187, 200, 297, 0, 369, 263, 321, 398, + 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 453, 239, 0, 0, 0, 201, + 211, 224, 237, 252, 0, 262, 274, 277, 282, 283, + 287, 291, 309, 310, 311, 312, 335, 336, 339, 340, + 343, 344, 348, 349, 350, 355, 356, 364, 172, 373, + 384, 386, 387, 388, 389, 399, 402, 403, 443, 444, + 460, 461, 430, 184, 0, 190, 0, 191, 193, 0, + 189, 0, 0, 342, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 246, 0, 0, 0, 0, 0, + 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 161, 459, 178, 0, 299, 0, + 478, 457, 408, 324, 481, 480, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 2005, 2007, 0, 0, 0, 0, 0, + 0, 0, 160, 0, 0, 0, 0, 479, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 450, 0, 0, 0, 0, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, + 0, 0, 0, 288, 179, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 183, 0, 0, 0, 338, 0, + 0, 166, 186, 298, 0, 0, 0, 232, 0, 377, + 0, 449, 477, 265, 0, 376, 300, 442, 0, 0, + 448, 0, 424, 458, 463, 258, 0, 222, 405, 248, + 241, 0, 0, 0, 271, 360, 236, 292, 0, 0, + 0, 228, 0, 0, 0, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 272, 0, 0, 0, + 346, 212, 0, 0, 0, 0, 452, 0, 244, 0, + 454, 168, 391, 390, 0, 279, 0, 169, 159, 370, + 170, 289, 192, 0, 467, 208, 294, 432, 476, 264, + 337, 0, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 0, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 0, 307, 253, 257, 273, 284, + 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 0, + 204, 198, 0, 0, 0, 0, 0, 0, 0, 197, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 268, 0, 445, 446, 233, 0, 0, 199, 0, + 0, 334, 341, 333, 0, 0, 441, 0, 0, 0, + 0, 0, 0, 0, 0, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 0, 410, 305, 0, + 194, 0, 409, 0, 0, 421, 214, 0, 0, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 0, 0, 345, 378, 221, 451, 406, 249, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 176, 177, 163, 0, 0, 0, 229, + 153, 0, 0, 0, 154, 0, 0, 156, 157, 0, + 0, 0, 0, 158, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 0, 187, 200, 297, 0, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 331, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 453, 239, 0, 0, 0, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 430, 184, 0, 190, 0, 191, 193, + 0, 189, 0, 0, 342, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, + 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 161, 459, 178, 0, 299, + 0, 478, 457, 408, 324, 481, 480, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1671, 0, 0, 0, 0, + 0, 0, 0, 160, 0, 0, 0, 0, 479, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 450, 0, 0, 0, 0, 361, + 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, + 0, 0, 0, 0, 288, 179, 0, 0, 0, 0, + 0, 0, 0, 296, 1135, 183, 0, 0, 0, 338, + 0, 0, 166, 186, 298, 0, 0, 0, 232, 0, + 377, 0, 449, 477, 265, 0, 376, 300, 442, 0, + 0, 448, 0, 424, 458, 463, 258, 0, 222, 405, + 248, 241, 0, 0, 0, 271, 360, 236, 292, 0, + 0, 0, 228, 0, 0, 0, 404, 439, 188, 319, + 440, 462, 155, 259, 396, 260, 423, 251, 223, 363, + 202, 0, 0, 0, 242, 286, 0, 0, 465, 456, + 213, 261, 371, 375, 352, 209, 431, 320, 330, 225, + 227, 226, 203, 397, 438, 216, 230, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 272, 0, 0, + 0, 346, 212, 0, 0, 0, 0, 452, 0, 244, + 0, 454, 168, 391, 390, 0, 279, 0, 169, 159, + 370, 170, 289, 192, 0, 467, 208, 294, 432, 476, + 264, 337, 0, 347, 185, 365, 314, 316, 313, 317, + 269, 164, 171, 0, 367, 393, 437, 210, 411, 162, + 165, 173, 383, 174, 175, 0, 307, 253, 257, 273, + 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 379, 380, 413, 428, + 385, 267, 306, 308, 415, 420, 416, 417, 414, 419, + 418, 381, 382, 196, 422, 447, 217, 392, 395, 466, + 0, 204, 198, 0, 0, 0, 0, 0, 0, 0, + 197, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 268, 0, 445, 446, 233, 0, 0, 199, + 0, 0, 334, 341, 333, 0, 0, 441, 0, 0, + 0, 0, 0, 0, 0, 0, 295, 256, 275, 358, + 302, 359, 276, 328, 327, 329, 304, 0, 410, 305, + 0, 194, 0, 409, 0, 0, 421, 214, 0, 0, + 436, 167, 366, 215, 266, 254, 357, 332, 206, 278, + 407, 293, 301, 0, 0, 345, 378, 221, 451, 406, + 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 176, 177, 163, 0, 0, 0, + 229, 153, 0, 0, 0, 154, 0, 0, 156, 157, + 0, 0, 0, 0, 158, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 354, 195, 207, 435, 220, 240, 238, 255, 290, + 315, 322, 351, 394, 400, 401, 425, 426, 427, 429, + 243, 318, 247, 219, 372, 218, 303, 281, 353, 433, + 434, 362, 235, 0, 187, 200, 297, 0, 369, 263, + 321, 398, 323, 285, 234, 464, 326, 368, 468, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 453, 239, 0, 0, + 0, 201, 211, 224, 237, 252, 0, 262, 274, 277, + 282, 283, 287, 291, 309, 310, 311, 312, 335, 336, + 339, 340, 343, 344, 348, 349, 350, 355, 356, 364, + 172, 373, 384, 386, 387, 388, 389, 399, 402, 403, + 443, 444, 460, 461, 430, 184, 0, 190, 0, 191, + 193, 0, 189, 0, 0, 342, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 246, 0, 0, 0, + 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 161, 459, 178, 0, + 299, 0, 478, 457, 408, 324, 481, 480, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 3262, 0, 0, 0, + 0, 0, 0, 0, 160, 0, 0, 0, 0, 479, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 450, 0, 0, 0, 0, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 325, 0, 0, 0, 0, 288, 179, 0, 0, 0, + 0, 0, 0, 0, 296, 0, 183, 0, 0, 0, + 338, 0, 0, 166, 186, 298, 0, 0, 0, 232, + 0, 377, 0, 449, 477, 265, 0, 376, 300, 442, + 0, 0, 448, 0, 424, 458, 463, 258, 0, 222, + 405, 248, 241, 0, 0, 0, 271, 360, 236, 292, + 0, 0, 0, 228, 0, 0, 0, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 272, 0, + 0, 0, 346, 212, 0, 0, 0, 0, 452, 0, + 244, 0, 454, 168, 391, 390, 0, 279, 0, 169, + 159, 370, 170, 289, 192, 0, 467, 208, 294, 432, + 476, 264, 337, 0, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 0, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 0, 307, 253, 257, + 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 0, 204, 198, 0, 0, 0, 0, 0, 0, + 0, 197, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 268, 0, 445, 446, 233, 0, 0, + 199, 0, 0, 334, 341, 333, 0, 0, 441, 0, + 0, 0, 0, 0, 0, 0, 0, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 0, 410, + 305, 0, 194, 0, 409, 0, 0, 421, 214, 0, + 0, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 0, 0, 345, 378, 221, 451, + 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 176, 177, 163, 0, 0, + 0, 229, 153, 0, 0, 0, 154, 0, 0, 156, + 157, 0, 0, 0, 0, 158, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 0, 187, 200, 297, 0, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 453, 239, 0, + 0, 0, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 430, 184, 0, 190, 0, + 191, 193, 0, 189, 0, 0, 342, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 246, 0, 0, + 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 161, 459, 178, + 0, 299, 0, 478, 457, 408, 324, 481, 480, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1671, 0, 0, + 0, 0, 0, 0, 0, 160, 0, 0, 0, 0, + 479, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 450, 0, 0, 0, + 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 325, 0, 0, 0, 0, 288, 179, 0, 0, + 0, 0, 0, 0, 0, 296, 0, 183, 0, 0, + 0, 338, 0, 0, 166, 186, 298, 0, 0, 0, + 232, 0, 377, 0, 449, 477, 265, 0, 376, 300, + 442, 0, 0, 448, 0, 424, 458, 463, 258, 0, + 222, 405, 248, 241, 0, 0, 0, 271, 360, 236, + 292, 0, 0, 0, 228, 0, 0, 0, 404, 439, + 188, 319, 440, 462, 155, 259, 396, 260, 423, 251, + 223, 363, 202, 0, 0, 0, 242, 286, 0, 0, + 465, 456, 213, 261, 371, 375, 352, 209, 431, 320, + 330, 225, 227, 226, 203, 397, 438, 216, 230, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 272, + 0, 0, 0, 346, 212, 0, 0, 0, 0, 452, + 0, 244, 0, 454, 168, 391, 390, 0, 279, 0, + 169, 159, 370, 170, 289, 192, 0, 467, 208, 294, + 432, 476, 264, 337, 0, 347, 185, 365, 314, 316, + 313, 317, 269, 164, 171, 0, 367, 393, 437, 210, + 411, 162, 165, 173, 383, 174, 175, 0, 307, 253, + 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 379, 380, + 413, 428, 385, 267, 306, 308, 415, 420, 416, 417, + 414, 419, 418, 381, 382, 196, 422, 447, 217, 392, + 395, 466, 0, 204, 198, 0, 0, 0, 0, 0, + 0, 0, 197, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 268, 0, 445, 446, 233, 0, + 0, 199, 0, 0, 334, 341, 333, 0, 0, 441, + 0, 0, 0, 0, 0, 0, 0, 0, 295, 256, + 275, 358, 302, 359, 276, 328, 327, 329, 304, 0, + 410, 305, 0, 194, 0, 409, 0, 0, 421, 214, + 0, 0, 436, 167, 366, 215, 266, 254, 357, 332, + 206, 278, 407, 293, 301, 0, 0, 345, 378, 221, + 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 176, 177, 163, 0, + 0, 0, 229, 153, 0, 0, 0, 154, 0, 0, + 156, 157, 0, 0, 0, 0, 158, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 354, 195, 207, 435, 220, 240, 238, + 255, 290, 315, 322, 351, 394, 400, 401, 425, 426, + 427, 429, 243, 318, 247, 219, 372, 218, 303, 281, + 353, 433, 434, 362, 235, 0, 187, 200, 297, 0, + 369, 263, 321, 398, 323, 285, 234, 464, 326, 368, + 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 453, 239, + 0, 0, 0, 201, 211, 224, 237, 252, 0, 262, + 274, 277, 282, 283, 287, 291, 309, 310, 311, 312, + 335, 336, 339, 340, 343, 344, 348, 349, 350, 355, + 356, 364, 172, 373, 384, 386, 387, 388, 389, 399, + 402, 403, 443, 444, 460, 461, 430, 184, 0, 190, + 0, 191, 193, 0, 189, 0, 0, 342, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 246, 0, + 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 161, 459, + 178, 0, 299, 0, 478, 457, 408, 324, 481, 480, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3397, 0, + 0, 0, 0, 0, 0, 0, 160, 0, 0, 0, + 0, 479, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 450, 0, 0, + 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 325, 0, 0, 0, 0, 288, 179, 0, + 0, 0, 0, 0, 0, 0, 296, 0, 183, 0, + 0, 0, 338, 0, 0, 166, 186, 298, 0, 0, + 0, 232, 0, 377, 0, 449, 477, 265, 0, 376, + 300, 442, 0, 0, 448, 0, 424, 458, 463, 258, + 0, 222, 405, 248, 241, 0, 0, 0, 271, 360, + 236, 292, 0, 0, 0, 228, 0, 0, 0, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 272, 0, 0, 0, 346, 212, 0, 0, 0, 0, + 452, 0, 244, 0, 454, 168, 391, 390, 0, 279, + 0, 169, 159, 370, 170, 289, 192, 0, 467, 208, + 294, 432, 476, 264, 337, 0, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 0, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 0, 307, + 253, 257, 273, 284, 0, 374, 412, 455, 0, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 0, 204, 198, 0, 0, 0, 0, + 0, 0, 0, 197, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 268, 0, 445, 446, 233, + 0, 0, 199, 0, 0, 334, 341, 333, 0, 0, + 441, 0, 0, 0, 0, 0, 0, 0, 0, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 0, 410, 305, 0, 194, 0, 409, 0, 0, 421, + 214, 0, 0, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 0, 0, 345, 378, + 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 176, 177, 163, + 0, 0, 0, 229, 153, 0, 0, 0, 154, 0, + 0, 156, 157, 0, 0, 0, 0, 158, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 0, 187, 200, 297, + 0, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 455, 0, 0, 0, 0, 0, 0, - 0, 3827, 0, 0, 2185, 0, 45, 82, 51, 50, - 53, 0, 0, 0, 0, 88, 0, 0, 0, 0, - 0, 3903, 0, 0, 0, 0, 3049, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 40, 57, 84, - 83, 0, 146, 0, 0, 52, 0, 0, 0, 0, - 0, 66, 0, 0, 0, 0, 0, 0, 0, 85, - 0, 0, 43, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2092, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2940, 2940, 93, 64, 65, 0, 3905, 3909, - 0, 0, 0, 0, 0, 0, 0, 2092, 3914, 3906, - 3907, 3908, 3912, 3913, 3910, 455, 3911, 0, 3915, 0, - 0, 3902, 0, 73, 0, 74, 4277, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2092, 0, 0, 0, 0, 0, 79, 0, - 0, 0, 0, 0, 0, 0, 0, 55, 147, 0, - 0, 0, 0, 147, 0, 0, 147, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 40, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 66, 0, 0, 0, 0, - 0, 0, 0, 85, 0, 0, 43, 0, 45, 82, - 51, 50, 53, 0, 0, 0, 0, 88, 616, 0, - 0, 0, 0, 3903, 0, 0, 0, 3916, 3904, 0, - 61, 62, 68, 0, 69, 0, 0, 0, 0, 0, - 57, 84, 83, 0, 0, 0, 0, 52, 93, 0, - 0, 147, 0, 3909, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3902, 0, 0, 0, 0, - 4250, 0, 147, 0, 0, 0, 0, 0, 453, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 64, 65, 0, - 3905, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 3914, 3906, 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, - 3915, 0, 0, 0, 0, 73, 0, 74, 0, 0, - 0, 0, 0, 0, 0, 0, 616, 0, 0, 0, - 0, 0, 0, 2089, 40, 0, 0, 0, 0, 0, - 79, 0, 45, 82, 51, 50, 53, 0, 66, 55, - 0, 88, 0, 0, 0, 0, 85, 3903, 0, 43, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 57, 84, 83, 0, 0, 0, - 0, 52, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 54, 56, 0, 0, 2185, 0, - 81, 93, 0, 0, 0, 0, 3909, 0, 0, 147, - 0, 0, 0, 0, 0, 147, 0, 0, 0, 3916, - 3904, 0, 61, 62, 68, 0, 69, 0, 3902, 0, - 0, 0, 0, 4233, 0, 0, 0, 0, 0, 0, - 0, 64, 65, 0, 3905, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 3914, 3906, 3907, 3908, 3912, 3913, - 3910, 0, 3911, 0, 3915, 0, 0, 0, 0, 73, - 0, 74, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 79, 0, 0, 0, 0, 0, - 0, 0, 0, 55, 0, 0, 0, 0, 0, 147, - 0, 0, 0, 0, 0, 45, 82, 51, 50, 53, - 0, 0, 0, 0, 88, 0, 0, 0, 0, 0, - 3903, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 57, 84, 83, - 0, 0, 0, 0, 52, 0, 0, 0, 0, 0, - 0, 0, 0, 453, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 3916, 3904, 0, 61, 62, 68, 0, - 69, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 54, 56, 0, 0, - 0, 0, 81, 0, 64, 65, 0, 3905, 0, 0, - 0, 0, 0, 147, 0, 0, 0, 3914, 3906, 3907, - 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, 0, 0, - 0, 0, 73, 0, 74, 0, 0, 0, 0, 0, - 0, 147, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 79, 0, 0, - 0, 0, 0, 0, 0, 0, 55, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 453, + 239, 0, 0, 0, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 430, 184, 0, + 190, 0, 191, 193, 0, 189, 0, 0, 342, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 246, + 0, 0, 0, 0, 0, 0, 0, 245, 231, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 161, + 459, 178, 0, 299, 0, 478, 457, 408, 324, 481, + 480, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2007, + 0, 0, 0, 0, 0, 0, 0, 160, 0, 0, + 0, 0, 479, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 450, 0, + 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 325, 0, 0, 0, 0, 288, 179, + 0, 0, 0, 0, 0, 0, 0, 296, 0, 183, + 0, 0, 0, 338, 0, 0, 166, 186, 298, 0, + 0, 0, 232, 0, 377, 0, 449, 477, 265, 0, + 376, 300, 442, 0, 0, 448, 0, 424, 458, 463, + 258, 0, 222, 405, 248, 241, 0, 0, 0, 271, + 360, 236, 292, 0, 0, 0, 228, 0, 0, 0, + 404, 439, 188, 319, 440, 462, 155, 259, 396, 260, + 423, 251, 223, 363, 202, 0, 0, 0, 242, 286, + 0, 0, 465, 456, 213, 261, 371, 375, 352, 209, + 431, 320, 330, 225, 227, 226, 203, 397, 438, 216, + 230, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 272, 0, 0, 0, 346, 212, 0, 0, 0, + 0, 452, 0, 244, 0, 454, 168, 391, 390, 0, + 279, 0, 169, 159, 370, 170, 289, 192, 0, 467, + 208, 294, 432, 476, 264, 337, 0, 347, 185, 365, + 314, 316, 313, 317, 269, 164, 171, 0, 367, 393, + 437, 210, 411, 162, 165, 173, 383, 174, 175, 0, + 307, 253, 257, 273, 284, 0, 374, 412, 455, 0, + 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 379, 380, 413, 428, 385, 267, 306, 308, 415, 420, + 416, 417, 414, 419, 418, 381, 382, 196, 422, 447, + 217, 392, 395, 466, 0, 204, 198, 0, 0, 0, + 0, 0, 0, 0, 197, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 268, 0, 445, 446, + 233, 0, 0, 199, 0, 0, 334, 341, 333, 0, + 0, 441, 0, 0, 0, 0, 0, 0, 0, 0, + 295, 256, 275, 358, 302, 359, 276, 328, 327, 329, + 304, 0, 410, 305, 0, 194, 0, 409, 0, 0, + 421, 214, 0, 0, 436, 167, 366, 215, 266, 254, + 357, 332, 206, 278, 407, 293, 301, 0, 0, 345, + 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 176, 177, + 163, 0, 0, 0, 229, 153, 0, 0, 0, 154, + 0, 0, 156, 157, 0, 0, 0, 0, 158, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 354, 195, 207, 435, 220, + 240, 238, 255, 290, 315, 322, 351, 394, 400, 401, + 425, 426, 427, 429, 243, 318, 247, 219, 372, 218, + 303, 281, 353, 433, 434, 362, 235, 0, 187, 200, + 297, 0, 369, 263, 321, 398, 323, 285, 234, 464, + 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 453, 239, 0, 0, 0, 201, 211, 224, 237, 252, + 0, 262, 274, 277, 282, 283, 287, 291, 309, 310, + 311, 312, 335, 336, 339, 340, 343, 344, 348, 349, + 350, 355, 356, 364, 172, 373, 384, 386, 387, 388, + 389, 399, 402, 403, 443, 444, 460, 461, 430, 184, + 0, 190, 0, 191, 193, 0, 189, 0, 0, 342, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 246, 0, 0, 0, 0, 0, 0, 0, 245, 231, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 161, 459, 178, 0, 299, 0, 478, 457, 408, 324, + 481, 480, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1183, 0, 0, 0, 0, 0, 0, 0, 160, 0, + 0, 0, 0, 479, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 450, + 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 325, 0, 0, 0, 0, 288, + 179, 0, 0, 0, 0, 0, 0, 0, 296, 0, + 183, 0, 0, 0, 338, 0, 0, 166, 186, 298, + 0, 0, 0, 232, 0, 377, 0, 449, 477, 265, + 0, 376, 300, 442, 0, 0, 448, 0, 424, 458, + 463, 258, 0, 222, 405, 248, 241, 0, 0, 0, + 271, 360, 236, 292, 0, 0, 0, 228, 0, 0, + 0, 404, 439, 188, 319, 440, 462, 155, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 272, 0, 0, 0, 346, 212, 0, 0, + 0, 0, 452, 0, 244, 0, 454, 168, 391, 390, + 0, 279, 0, 169, 159, 370, 170, 289, 192, 0, + 467, 208, 294, 432, 476, 264, 337, 0, 347, 185, + 365, 314, 316, 313, 317, 269, 164, 171, 0, 367, + 393, 437, 210, 411, 162, 165, 173, 383, 174, 175, + 0, 307, 253, 257, 273, 284, 0, 374, 412, 455, + 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 0, 204, 198, 0, 0, + 0, 0, 0, 0, 0, 197, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 268, 0, 445, + 446, 233, 0, 0, 199, 0, 0, 334, 341, 333, + 0, 0, 441, 0, 0, 0, 0, 0, 0, 0, + 0, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 0, 410, 305, 0, 194, 0, 409, 0, + 0, 421, 214, 0, 0, 436, 167, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 0, 0, + 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 176, + 177, 163, 0, 0, 0, 229, 153, 0, 0, 0, + 154, 0, 0, 156, 157, 0, 0, 0, 0, 158, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 0, 187, + 200, 297, 0, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 453, 239, 0, 0, 0, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 172, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 430, + 184, 0, 190, 0, 191, 193, 0, 189, 0, 0, + 342, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 0, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 161, 459, 178, 0, 299, 0, 478, 457, 408, + 324, 481, 480, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1172, 0, 0, 0, 0, 0, 0, 0, 160, + 0, 0, 0, 0, 479, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, + 288, 179, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 0, 0, 166, 186, + 298, 0, 0, 0, 232, 0, 377, 0, 449, 477, + 265, 0, 376, 300, 442, 0, 0, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 155, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 0, 0, 452, 0, 244, 0, 454, 168, 391, + 390, 0, 279, 0, 169, 159, 370, 170, 289, 192, + 0, 467, 208, 294, 432, 476, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 164, 171, 0, + 367, 393, 437, 210, 411, 162, 165, 173, 383, 174, + 175, 0, 307, 253, 257, 273, 284, 0, 374, 412, + 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 0, 0, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 0, 0, 0, + 0, 0, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 167, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 176, 177, 163, 0, 0, 0, 229, 153, 0, 0, + 0, 154, 0, 0, 156, 157, 0, 0, 0, 0, + 158, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 0, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 0, 0, 0, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 172, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 430, 184, 0, 190, 0, 191, 193, 0, 189, 0, + 0, 342, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, + 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 161, 459, 178, 0, 299, 0, 0, 457, + 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 151, 0, 0, 0, 0, 0, 0, 0, + 160, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 525, 0, 325, 0, 0, 0, + 0, 288, 179, 0, 0, 0, 0, 0, 0, 0, + 296, 0, 183, 0, 0, 0, 338, 0, 0, 166, + 186, 298, 0, 0, 0, 232, 0, 377, 0, 449, + 527, 524, 0, 376, 300, 442, 0, 0, 448, 0, + 424, 458, 463, 258, 0, 222, 405, 248, 241, 0, + 0, 0, 271, 360, 236, 292, 0, 0, 0, 228, + 0, 0, 0, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 272, 0, 0, 0, 346, 212, + 0, 0, 0, 0, 452, 0, 244, 0, 454, 168, + 391, 390, 0, 279, 0, 169, 159, 370, 170, 289, + 192, 0, 467, 208, 294, 432, 150, 264, 337, 0, + 347, 185, 365, 314, 316, 313, 317, 269, 164, 171, + 0, 367, 393, 437, 210, 411, 162, 165, 173, 383, + 174, 175, 0, 307, 253, 257, 273, 284, 0, 374, + 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 0, 204, 198, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 268, + 0, 445, 446, 233, 0, 0, 199, 0, 0, 334, + 341, 333, 0, 0, 441, 0, 0, 0, 0, 0, + 0, 0, 0, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 0, 410, 305, 0, 194, 0, + 409, 0, 0, 421, 214, 0, 0, 436, 167, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 180, 181, 0, 0, 182, 0, 0, 0, 0, + 0, 176, 177, 163, 0, 0, 0, 229, 153, 0, + 0, 0, 154, 0, 0, 156, 157, 0, 0, 0, + 0, 158, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 0, 187, 200, 297, 0, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 453, 239, 0, 0, 0, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 172, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 430, 184, 0, 190, 0, 191, 193, 0, 189, + 0, 0, 342, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 246, 0, 0, 0, 0, 0, 0, + 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 161, 459, 178, 0, 299, 0, 478, + 457, 408, 324, 481, 480, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 470, 0, 0, 0, 0, 0, 0, + 0, 160, 0, 0, 0, 0, 479, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 250, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, + 0, 0, 288, 179, 0, 0, 0, 0, 0, 0, + 0, 296, 0, 183, 0, 0, 0, 338, 0, 0, + 166, 186, 298, 0, 0, 0, 232, 0, 377, 0, + 449, 477, 265, 0, 376, 300, 442, 0, 0, 448, + 0, 424, 458, 463, 258, 0, 222, 405, 248, 241, + 0, 0, 0, 271, 360, 236, 292, 0, 0, 0, + 228, 0, 0, 0, 404, 439, 188, 319, 440, 462, + 155, 259, 396, 260, 423, 251, 223, 363, 202, 0, + 0, 0, 242, 286, 0, 0, 465, 456, 213, 261, + 371, 375, 352, 209, 431, 320, 330, 225, 227, 226, + 203, 397, 438, 216, 230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 272, 0, 0, 0, 346, + 212, 0, 0, 0, 0, 452, 0, 244, 0, 454, + 168, 391, 390, 0, 279, 0, 169, 159, 370, 170, + 289, 192, 0, 467, 208, 294, 432, 476, 264, 337, + 0, 347, 185, 365, 314, 316, 313, 317, 269, 164, + 171, 0, 367, 393, 437, 210, 411, 162, 165, 173, + 383, 174, 175, 0, 307, 253, 257, 273, 284, 0, + 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 379, 380, 413, 428, 385, 267, + 306, 308, 415, 420, 416, 417, 414, 419, 418, 381, + 382, 196, 422, 447, 217, 392, 395, 466, 0, 204, + 198, 0, 0, 0, 0, 0, 0, 0, 197, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 268, 0, 445, 446, 233, 0, 0, 199, 0, 0, + 334, 341, 333, 0, 0, 441, 0, 0, 0, 0, + 0, 0, 0, 0, 295, 256, 275, 358, 302, 359, + 276, 328, 327, 329, 304, 0, 410, 305, 0, 194, + 0, 409, 0, 0, 421, 214, 0, 0, 436, 167, + 366, 215, 266, 254, 357, 332, 206, 278, 407, 293, + 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 176, 177, 163, 0, 0, 0, 229, 153, + 0, 0, 0, 154, 0, 0, 156, 157, 0, 0, + 0, 0, 158, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 354, + 195, 207, 435, 220, 240, 238, 255, 290, 315, 322, + 351, 394, 400, 401, 425, 426, 427, 429, 243, 318, + 247, 219, 372, 218, 303, 281, 353, 433, 434, 362, + 235, 0, 187, 200, 297, 0, 369, 263, 321, 398, + 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 453, 239, 0, 0, 0, 201, + 211, 224, 237, 252, 0, 262, 274, 277, 282, 283, + 287, 291, 309, 310, 311, 312, 335, 336, 339, 340, + 343, 344, 348, 349, 350, 355, 356, 364, 172, 373, + 384, 386, 387, 388, 389, 399, 402, 403, 443, 444, + 460, 461, 430, 184, 0, 190, 0, 191, 193, 0, + 189, 0, 0, 342, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 246, 0, 0, 0, 0, 0, + 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 161, 459, 178, 0, 299, 0, + 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 151, 0, 0, 0, 0, 0, + 0, 0, 160, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 450, 0, 0, 0, 0, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, + 0, 0, 0, 288, 179, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 183, 0, 0, 0, 338, 0, + 0, 166, 186, 298, 0, 0, 0, 232, 0, 377, + 0, 449, 2490, 265, 0, 376, 300, 442, 0, 0, + 448, 0, 424, 458, 463, 258, 0, 222, 405, 248, + 241, 0, 0, 0, 271, 360, 236, 292, 0, 0, + 0, 228, 0, 0, 0, 404, 439, 188, 319, 440, + 462, 155, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 272, 0, 0, 0, + 346, 212, 0, 0, 0, 0, 452, 0, 244, 0, + 454, 168, 391, 390, 0, 279, 0, 169, 159, 370, + 170, 289, 192, 0, 467, 208, 294, 432, 150, 264, + 337, 0, 347, 185, 365, 314, 316, 313, 317, 269, + 164, 171, 0, 367, 393, 437, 210, 411, 162, 165, + 173, 383, 174, 175, 0, 307, 253, 257, 273, 284, + 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 0, + 204, 198, 0, 0, 0, 0, 0, 0, 0, 197, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 268, 0, 445, 446, 233, 0, 0, 199, 0, + 0, 334, 341, 333, 0, 0, 441, 0, 0, 0, + 0, 0, 0, 0, 0, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 0, 410, 305, 0, + 194, 0, 409, 0, 0, 421, 214, 0, 0, 436, + 167, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 0, 0, 345, 378, 221, 451, 406, 249, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 180, 181, 0, 0, 182, 0, 0, + 0, 0, 0, 176, 177, 163, 0, 0, 0, 229, + 153, 0, 0, 0, 154, 0, 0, 156, 157, 0, + 0, 0, 0, 158, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 0, 187, 200, 297, 0, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 331, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 453, 239, 0, 0, 0, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 172, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 430, 184, 0, 190, 0, 191, 193, + 0, 189, 0, 0, 342, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, + 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 161, 459, 178, 0, 299, + 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 151, 0, 0, 0, 0, + 0, 0, 0, 160, 0, 0, 0, 0, 0, 2377, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 450, 0, 0, 0, 0, 361, + 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, + 0, 0, 0, 0, 288, 179, 0, 0, 0, 0, + 0, 0, 0, 296, 0, 183, 0, 0, 0, 338, + 0, 0, 166, 186, 298, 0, 0, 0, 232, 0, + 377, 0, 449, 0, 265, 0, 376, 300, 442, 0, + 0, 448, 0, 424, 458, 463, 258, 0, 222, 405, + 248, 241, 0, 0, 0, 271, 360, 236, 292, 0, + 0, 0, 228, 0, 0, 0, 404, 439, 188, 319, + 440, 462, 155, 259, 396, 260, 423, 251, 223, 363, + 202, 0, 0, 0, 242, 286, 0, 0, 465, 456, + 213, 261, 371, 375, 352, 209, 431, 320, 330, 225, + 227, 226, 203, 397, 438, 216, 230, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 272, 0, 0, + 0, 346, 212, 0, 0, 0, 0, 452, 0, 244, + 0, 454, 168, 391, 390, 0, 279, 0, 169, 159, + 370, 170, 289, 192, 0, 467, 208, 294, 432, 150, + 264, 337, 0, 347, 185, 365, 314, 316, 313, 317, + 269, 164, 171, 0, 367, 393, 437, 210, 411, 162, + 165, 173, 383, 174, 175, 0, 307, 253, 257, 273, + 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 379, 380, 413, 428, + 385, 267, 306, 308, 415, 420, 416, 417, 414, 419, + 418, 381, 382, 196, 422, 447, 217, 392, 395, 466, + 0, 204, 198, 0, 0, 0, 0, 0, 0, 0, + 197, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 268, 0, 445, 446, 233, 0, 0, 199, + 0, 0, 334, 341, 333, 0, 0, 441, 0, 0, + 0, 0, 0, 0, 0, 0, 295, 256, 275, 358, + 302, 359, 276, 328, 327, 329, 304, 0, 410, 305, + 0, 194, 0, 409, 0, 0, 421, 214, 0, 0, + 436, 167, 366, 215, 266, 254, 357, 332, 206, 278, + 407, 293, 301, 0, 0, 345, 378, 221, 451, 406, + 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 180, 181, 0, 0, 182, 0, + 0, 0, 0, 0, 176, 177, 163, 0, 0, 0, + 229, 153, 0, 0, 0, 154, 0, 0, 156, 157, + 0, 0, 0, 0, 158, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 354, 195, 207, 435, 220, 240, 238, 255, 290, + 315, 322, 351, 394, 400, 401, 425, 426, 427, 429, + 243, 318, 247, 219, 372, 218, 303, 281, 353, 433, + 434, 362, 235, 0, 187, 200, 297, 0, 369, 263, + 321, 398, 323, 285, 234, 464, 326, 368, 468, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 453, 239, 0, 0, + 0, 201, 211, 224, 237, 252, 0, 262, 274, 277, + 282, 283, 287, 291, 309, 310, 311, 312, 335, 336, + 339, 340, 343, 344, 348, 349, 350, 355, 356, 364, + 172, 373, 384, 386, 387, 388, 389, 399, 402, 403, + 443, 444, 460, 461, 430, 184, 0, 190, 1575, 191, + 193, 0, 189, 0, 0, 342, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 246, 0, 0, 0, + 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 161, 459, 178, 0, + 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 151, 0, 0, 0, + 0, 0, 0, 0, 160, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 450, 0, 0, 0, 0, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 325, 0, 0, 0, 0, 288, 179, 0, 0, 0, + 0, 0, 0, 0, 296, 0, 183, 0, 0, 0, + 338, 0, 0, 166, 186, 298, 0, 0, 0, 232, + 0, 377, 0, 449, 0, 265, 0, 376, 300, 442, + 0, 0, 448, 0, 424, 458, 463, 258, 0, 222, + 405, 248, 241, 0, 0, 0, 271, 360, 236, 292, + 0, 0, 0, 228, 0, 0, 0, 404, 439, 188, + 319, 440, 462, 155, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 272, 0, + 0, 0, 346, 212, 0, 0, 0, 0, 452, 0, + 244, 0, 454, 168, 391, 390, 0, 279, 0, 169, + 159, 370, 170, 289, 192, 0, 467, 208, 294, 432, + 150, 264, 337, 0, 347, 185, 365, 314, 316, 313, + 317, 269, 164, 171, 0, 367, 393, 437, 210, 411, + 162, 165, 173, 383, 174, 175, 0, 307, 253, 257, + 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 0, 204, 198, 0, 0, 0, 0, 0, 0, + 0, 197, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 268, 0, 445, 446, 233, 0, 0, + 199, 0, 0, 334, 341, 333, 0, 0, 441, 0, + 0, 0, 0, 0, 0, 0, 0, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 0, 410, + 305, 0, 194, 0, 409, 0, 0, 421, 214, 0, + 0, 436, 167, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 0, 0, 345, 378, 221, 451, + 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 180, 181, 0, 0, 182, + 0, 0, 0, 0, 0, 176, 177, 163, 0, 0, + 0, 229, 153, 0, 0, 0, 154, 0, 0, 156, + 157, 0, 0, 0, 0, 158, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 0, 187, 200, 297, 0, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 453, 239, 0, + 0, 0, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 172, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 430, 184, 0, 190, 0, + 191, 193, 0, 189, 0, 0, 342, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 246, 0, 0, + 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 161, 459, 178, + 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 151, 0, 0, + 0, 0, 0, 0, 0, 160, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 450, 0, 0, 0, + 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 325, 0, 0, 144, 0, 288, 179, 0, 0, + 0, 0, 0, 0, 0, 296, 0, 183, 0, 0, + 0, 338, 0, 0, 166, 186, 298, 0, 0, 0, + 232, 0, 377, 0, 449, 0, 265, 0, 376, 300, + 442, 0, 0, 448, 0, 424, 458, 463, 258, 0, + 222, 405, 248, 241, 0, 0, 0, 271, 360, 236, + 292, 0, 0, 0, 228, 0, 0, 0, 404, 439, + 188, 319, 440, 462, 155, 259, 396, 260, 423, 251, + 223, 363, 202, 0, 0, 0, 242, 286, 0, 0, + 465, 456, 213, 261, 371, 375, 352, 209, 431, 320, + 330, 225, 227, 226, 203, 397, 438, 216, 230, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 272, + 0, 0, 0, 346, 212, 0, 0, 0, 0, 452, + 0, 244, 0, 454, 168, 391, 390, 0, 279, 0, + 169, 159, 370, 170, 289, 192, 0, 467, 208, 294, + 432, 150, 264, 337, 0, 347, 185, 365, 314, 316, + 313, 317, 269, 164, 171, 0, 367, 393, 437, 210, + 411, 162, 165, 173, 383, 174, 175, 0, 307, 253, + 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 379, 380, + 413, 428, 385, 267, 306, 308, 415, 420, 416, 417, + 414, 419, 418, 381, 382, 196, 422, 447, 217, 392, + 395, 466, 0, 204, 198, 0, 0, 0, 0, 0, + 0, 0, 197, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 268, 0, 445, 446, 233, 0, + 0, 199, 0, 0, 334, 341, 333, 0, 0, 441, + 0, 0, 0, 0, 0, 0, 0, 0, 295, 256, + 275, 358, 302, 359, 276, 328, 327, 329, 304, 0, + 410, 305, 0, 194, 0, 409, 0, 0, 421, 214, + 0, 0, 436, 167, 366, 215, 266, 254, 357, 332, + 206, 278, 407, 293, 301, 0, 0, 345, 378, 221, + 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 180, 181, 0, 0, + 182, 0, 0, 0, 0, 0, 176, 177, 163, 0, + 0, 0, 229, 153, 0, 0, 0, 154, 0, 0, + 156, 157, 0, 0, 0, 0, 158, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 354, 195, 207, 435, 220, 240, 238, + 255, 290, 315, 322, 351, 394, 400, 401, 425, 426, + 427, 429, 243, 318, 247, 219, 372, 218, 303, 281, + 353, 433, 434, 362, 235, 0, 187, 200, 297, 0, + 369, 263, 321, 398, 323, 285, 234, 464, 326, 368, + 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 453, 239, + 0, 0, 0, 201, 211, 224, 237, 252, 0, 262, + 274, 277, 282, 283, 287, 291, 309, 310, 311, 312, + 335, 336, 339, 340, 343, 344, 348, 349, 350, 355, + 356, 364, 172, 373, 384, 386, 387, 388, 389, 399, + 402, 403, 443, 444, 460, 461, 430, 184, 0, 190, + 0, 191, 193, 0, 189, 0, 0, 342, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 246, 0, + 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 161, 459, + 178, 0, 299, 0, 0, 457, 408, 324, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 151, 0, + 0, 0, 0, 0, 0, 0, 160, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 450, 0, 0, + 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 325, 0, 0, 0, 0, 288, 179, 0, + 0, 0, 0, 0, 0, 0, 296, 0, 183, 0, + 0, 0, 338, 0, 0, 166, 186, 298, 0, 0, + 0, 232, 0, 377, 0, 449, 0, 265, 0, 376, + 300, 442, 0, 0, 448, 0, 424, 458, 463, 258, + 0, 222, 405, 248, 241, 0, 0, 0, 271, 360, + 236, 292, 0, 0, 0, 228, 0, 0, 0, 404, + 439, 188, 319, 440, 462, 155, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 272, 0, 0, 0, 346, 212, 0, 0, 0, 0, + 452, 0, 244, 0, 454, 168, 391, 390, 0, 279, + 0, 169, 159, 370, 170, 289, 192, 0, 467, 208, + 294, 432, 150, 264, 337, 0, 347, 185, 365, 314, + 316, 313, 317, 269, 164, 171, 0, 367, 393, 437, + 210, 411, 162, 165, 173, 383, 174, 175, 0, 307, + 253, 257, 273, 284, 0, 374, 412, 455, 0, 205, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 0, 204, 198, 0, 0, 0, 0, + 0, 0, 0, 197, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 268, 0, 445, 446, 233, + 0, 0, 199, 0, 0, 334, 341, 333, 0, 0, + 441, 0, 0, 0, 0, 0, 0, 0, 0, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 0, 410, 305, 0, 194, 0, 409, 0, 0, 421, + 214, 0, 0, 436, 167, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 0, 0, 345, 378, + 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 180, 181, 0, + 0, 182, 0, 0, 0, 0, 0, 176, 177, 163, + 0, 0, 0, 229, 153, 0, 0, 0, 154, 0, + 0, 156, 157, 0, 0, 0, 0, 158, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 0, 187, 200, 297, + 0, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 147, 147, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 453, - 0, 0, 0, 0, 0, 0, 0, 453, 453, 453, - 0, 0, 0, 453, 147, 0, 93, 0, 453, 0, - 0, 0, 680, 679, 682, 683, 684, 685, 0, 0, - 0, 681, 2225, 3138, 3139, 0, 3916, 3904, 0, 61, - 62, 68, 0, 69, 0, 0, 0, 0, 0, 0, - 54, 56, 0, 0, 0, 0, 81, 0, 0, 0, + 239, 0, 0, 0, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 172, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 430, 184, 0, + 190, 0, 191, 193, 0, 189, 0, 0, 342, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 246, + 0, 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 3130, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 699, 700, 701, 702, 703, 704, - 705, 706, 707, 708, 709, 710, 711, 712, 713, 714, - 715, 716, 717, 718, 719, 720, 721, 722, 723, 724, - 725, 726, 727, 728, 729, 730, 731, 732, 733, 734, - 735, 736, 737, 738, 739, 740, 0, 0, 0, 0, + 459, 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2089, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1133, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 450, 0, + 0, 0, 0, 361, 270, 1459, 1458, 1468, 1469, 1461, + 1462, 1463, 1464, 1465, 1466, 1467, 1460, 0, 0, 1470, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 413, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 330, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 238, 0, 0, 0, 0, 0, 0, 0, 237, - 224, 0, 0, 0, 0, 0, 0, 0, 2366, 2370, - 0, 159, 176, 177, 0, 289, 0, 458, 439, 392, - 311, 461, 460, 54, 56, 0, 0, 0, 0, 81, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1103, 0, 0, 0, 0, 0, 0, 0, 0, 158, - 0, 0, 0, 0, 459, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 147, 0, 0, 242, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 433, 0, 0, 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 147, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 325, 0, 0, 0, 0, 288, 0, + 0, 0, 0, 0, 0, 0, 0, 296, 0, 183, + 0, 0, 0, 338, 0, 0, 0, 186, 298, 0, + 0, 0, 232, 0, 377, 0, 449, 0, 265, 0, + 376, 300, 442, 0, 0, 448, 0, 424, 458, 463, + 258, 0, 222, 405, 248, 241, 0, 0, 0, 271, + 360, 236, 292, 0, 0, 0, 228, 0, 0, 0, + 404, 439, 188, 319, 440, 462, 0, 259, 396, 260, + 423, 251, 223, 363, 202, 0, 0, 0, 242, 286, + 0, 0, 465, 456, 213, 261, 371, 375, 352, 209, + 431, 320, 330, 225, 227, 226, 203, 397, 438, 216, + 230, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 272, 0, 0, 0, 346, 212, 0, 0, 0, + 0, 452, 0, 244, 0, 454, 0, 391, 390, 0, + 279, 0, 0, 0, 370, 0, 289, 192, 0, 467, + 208, 294, 432, 0, 264, 337, 0, 347, 185, 365, + 314, 316, 313, 317, 269, 0, 0, 0, 367, 393, + 437, 210, 411, 0, 0, 0, 383, 0, 0, 0, + 307, 253, 257, 273, 284, 0, 374, 412, 455, 0, + 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 453, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 453, 0, 312, 0, 0, 0, 2369, - 278, 178, 0, 0, 0, 2363, 0, 2364, 2365, 286, - 1105, 179, 0, 2361, 2368, 325, 0, 0, 164, 182, - 288, 0, 0, 0, 225, 1100, 362, 0, 432, 457, - 256, 0, 361, 290, 425, 0, 0, 431, 0, 407, - 440, 444, 250, 0, 215, 389, 240, 234, 0, 0, - 0, 262, 347, 229, 282, 0, 0, 0, 221, 0, - 0, 0, 388, 422, 184, 306, 423, 443, 153, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 0, 0, - 0, 147, 0, 0, 0, 0, 0, 271, 263, 3133, - 3136, 0, 334, 206, 0, 3134, 3135, 0, 435, 0, - 236, 0, 437, 166, 375, 374, 0, 270, 0, 167, - 157, 357, 168, 279, 188, 0, 447, 202, 284, 415, - 456, 255, 324, 0, 335, 181, 352, 302, 304, 301, - 305, 260, 162, 169, 0, 354, 377, 420, 204, 395, - 160, 163, 171, 367, 172, 173, 453, 296, 245, 249, - 264, 275, 0, 360, 396, 438, 0, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 453, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 0, 198, 193, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 259, - 0, 428, 429, 226, 0, 0, 194, 0, 0, 321, - 329, 320, 0, 0, 424, 0, 0, 453, 0, 0, - 453, 0, 0, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 0, 394, 295, 0, 189, 0, - 393, 0, 0, 404, 207, 0, 0, 419, 165, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 0, 0, 333, 363, 214, 434, 390, 241, 0, 326, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 174, 175, 161, 0, 0, 0, 222, 151, 0, 0, - 0, 152, 0, 0, 154, 155, 0, 0, 0, 0, - 156, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 0, - 183, 195, 287, 0, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 0, 0, 0, 0, 0, - 0, 453, 0, 0, 0, 0, 318, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 436, 232, 0, 0, 0, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 170, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 0, - 180, 0, 186, 0, 187, 0, 0, 185, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 848, 988, 0, 453, 413, 748, 992, 835, - 858, 1001, 864, 866, 929, 811, 906, 330, 855, 812, - 2191, 2192, 2193, 0, 803, 1048, 804, 836, 238, 1046, - 962, 907, 990, 892, 922, 932, 237, 224, 899, 898, - 979, 847, 846, 927, 975, 989, 0, 0, 159, 757, - 177, 756, 289, 0, 147, 439, 392, 311, 0, 0, - 890, 0, 741, 742, 875, 931, 823, 918, 994, 856, - 923, 995, 93, 0, 0, 0, 0, 515, 680, 679, - 682, 683, 684, 685, 0, 0, 158, 681, 686, 687, - 688, 0, 885, 928, 1006, 802, 1065, 671, 807, 755, - 0, 980, 843, 844, 242, 0, 0, 0, 0, 0, - 0, 0, 888, 905, 947, 872, 0, 433, 934, 943, - 957, 865, 348, 261, 0, 0, 0, 0, 668, 669, - 0, 0, 0, 0, 773, 0, 670, 453, 817, 666, - 699, 700, 701, 702, 703, 704, 705, 706, 707, 708, - 709, 710, 711, 712, 713, 714, 715, 716, 717, 718, - 719, 720, 721, 722, 723, 724, 725, 726, 727, 728, - 729, 730, 731, 732, 733, 734, 735, 736, 737, 738, - 739, 740, 672, 0, 0, 0, 822, 800, 841, 949, - 801, 799, 312, 814, 744, 978, 873, 278, 178, 984, - 871, 771, 937, 818, 966, 859, 286, 816, 179, 813, - 819, 857, 325, 946, 952, 753, 182, 288, 963, 837, - 850, 225, 0, 362, 924, 432, 660, 256, 910, 361, - 290, 425, 938, 986, 431, 860, 407, 440, 444, 250, - 893, 215, 389, 240, 234, 842, 956, 806, 262, 347, - 229, 282, 876, 930, 838, 221, 941, 917, 968, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 964, 951, 970, 833, 820, - 825, 821, 849, 987, 271, 263, 971, 969, 851, 334, - 206, 903, 896, 889, 758, 435, 1002, 236, 953, 437, - 166, 375, 374, 863, 270, 954, 167, 157, 357, 168, - 279, 188, 974, 447, 202, 284, 415, 659, 255, 324, - 926, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 950, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 993, 296, 245, 249, 264, 275, 925, - 360, 396, 438, 919, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 948, 198, 193, 982, 965, 912, - 878, 884, 808, 0, 192, 879, 880, 881, 882, 883, - 944, 840, 852, 832, 920, 831, 259, 936, 428, 429, - 226, 747, 997, 194, 815, 996, 321, 329, 320, 999, - 998, 424, 983, 913, 902, 900, 809, 981, 911, 901, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 904, 394, 295, 0, 189, 0, 393, 991, 1008, - 404, 207, 826, 958, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 940, 1005, 333, - 363, 214, 434, 390, 241, 759, 326, 772, 765, 767, - 766, 763, 764, 762, 761, 760, 774, 745, 746, 749, - 750, 751, 895, 985, 810, 754, 961, 768, 769, 770, - 933, 1003, 743, 222, 692, 786, 787, 788, 693, 789, - 790, 694, 695, 791, 792, 793, 794, 696, 795, 796, - 797, 775, 776, 777, 778, 779, 780, 781, 782, 785, - 783, 784, 0, 891, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 752, 183, 195, 287, - 1004, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 959, 916, 0, 868, 870, 869, 828, 830, - 829, 827, 1007, 318, 977, 798, 805, 824, 834, 839, - 845, 853, 854, 862, 867, 877, 886, 887, 897, 908, - 909, 915, 939, 942, 955, 960, 967, 972, 973, 436, - 232, 894, 914, 945, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 874, 180, 0, 186, - 0, 187, 0, 861, 185, 976, 1000, 921, 935, 848, - 988, 0, 0, 413, 748, 992, 835, 858, 1001, 864, - 866, 929, 811, 906, 330, 855, 812, 0, 0, 0, - 0, 803, 657, 804, 836, 238, 656, 962, 907, 990, - 892, 922, 932, 237, 224, 899, 898, 979, 847, 846, - 927, 975, 989, 0, 0, 159, 757, 177, 756, 289, - 0, 0, 439, 392, 311, 0, 0, 890, 0, 741, - 742, 875, 931, 823, 918, 994, 856, 923, 995, 93, - 0, 1380, 0, 0, 515, 680, 679, 682, 683, 684, - 685, 0, 0, 158, 681, 686, 687, 688, 0, 885, - 928, 1006, 802, 654, 671, 807, 755, 0, 980, 843, - 844, 242, 0, 0, 0, 0, 0, 0, 0, 888, - 905, 947, 872, 0, 433, 934, 943, 957, 865, 348, - 261, 0, 0, 0, 0, 668, 669, 2149, 0, 0, - 0, 773, 0, 670, 0, 817, 666, 699, 700, 701, - 702, 703, 704, 705, 706, 707, 708, 709, 710, 711, - 712, 713, 714, 715, 716, 717, 718, 719, 720, 721, - 722, 723, 724, 725, 726, 727, 728, 729, 730, 731, - 732, 733, 734, 735, 736, 737, 738, 739, 740, 672, - 0, 0, 0, 822, 800, 841, 949, 801, 799, 312, - 814, 744, 978, 873, 278, 178, 984, 871, 771, 937, - 818, 966, 859, 286, 816, 179, 813, 819, 857, 325, - 946, 952, 753, 182, 288, 963, 837, 850, 225, 0, - 362, 924, 432, 660, 256, 910, 361, 290, 425, 938, - 986, 431, 860, 407, 440, 444, 250, 893, 215, 389, - 240, 234, 842, 956, 806, 262, 347, 229, 282, 876, - 930, 838, 221, 941, 917, 968, 388, 422, 184, 306, - 423, 443, 153, 251, 380, 252, 406, 243, 216, 350, - 203, 414, 307, 317, 218, 220, 219, 197, 381, 421, - 209, 223, 964, 951, 970, 833, 820, 825, 821, 849, - 987, 271, 263, 971, 969, 851, 334, 206, 903, 896, - 889, 758, 435, 1002, 236, 953, 437, 166, 375, 374, - 863, 270, 954, 167, 157, 357, 168, 279, 188, 974, - 447, 202, 284, 415, 659, 255, 324, 926, 335, 181, - 352, 302, 304, 301, 305, 260, 162, 169, 950, 354, - 377, 420, 204, 395, 160, 163, 171, 367, 172, 173, - 993, 296, 245, 249, 264, 275, 925, 360, 396, 438, - 919, 199, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 364, 397, 411, 369, 258, 399, 403, 400, 401, - 398, 402, 365, 366, 191, 405, 430, 210, 376, 379, - 446, 948, 198, 193, 982, 965, 912, 878, 884, 808, - 0, 192, 879, 880, 881, 882, 883, 944, 840, 852, - 832, 920, 831, 259, 936, 428, 429, 226, 747, 997, - 194, 815, 996, 321, 329, 320, 999, 998, 424, 983, - 913, 902, 900, 809, 981, 911, 901, 285, 248, 266, - 345, 292, 346, 267, 315, 314, 316, 294, 904, 394, - 295, 0, 189, 0, 393, 991, 1008, 404, 207, 826, - 958, 419, 165, 353, 208, 257, 246, 344, 319, 200, - 269, 391, 283, 291, 940, 1005, 333, 363, 214, 434, - 390, 241, 759, 326, 772, 765, 767, 766, 763, 764, - 762, 761, 760, 774, 745, 746, 749, 750, 751, 895, - 985, 810, 754, 961, 768, 769, 770, 933, 1003, 743, - 222, 692, 786, 787, 788, 693, 789, 790, 694, 695, - 791, 792, 793, 794, 696, 795, 796, 797, 775, 776, - 777, 778, 779, 780, 781, 782, 785, 783, 784, 0, - 891, 341, 190, 201, 418, 213, 233, 231, 247, 280, - 303, 309, 339, 378, 384, 385, 408, 409, 410, 412, - 235, 0, 239, 212, 358, 211, 293, 272, 340, 416, - 417, 349, 228, 752, 183, 195, 287, 1004, 356, 254, - 308, 382, 310, 276, 227, 445, 313, 355, 448, 959, - 916, 0, 868, 870, 869, 828, 830, 829, 827, 1007, - 318, 977, 798, 805, 824, 834, 839, 845, 853, 854, - 862, 867, 877, 886, 887, 897, 908, 909, 915, 939, - 942, 955, 960, 967, 972, 973, 436, 232, 894, 914, - 945, 196, 205, 217, 230, 244, 253, 265, 268, 273, - 274, 277, 281, 297, 298, 299, 300, 322, 323, 327, - 328, 331, 332, 336, 337, 338, 342, 343, 351, 170, - 359, 368, 370, 371, 372, 373, 383, 386, 387, 426, - 427, 441, 442, 874, 180, 0, 186, 0, 187, 0, - 861, 185, 976, 1000, 921, 935, 848, 988, 0, 0, - 413, 748, 992, 835, 858, 1001, 864, 866, 929, 811, - 906, 330, 855, 812, 0, 0, 0, 0, 803, 657, - 804, 836, 238, 656, 962, 907, 990, 892, 922, 932, - 237, 224, 899, 898, 979, 847, 846, 927, 975, 989, - 0, 0, 159, 757, 177, 756, 289, 0, 0, 439, - 392, 311, 0, 0, 890, 0, 741, 742, 875, 931, - 823, 918, 994, 856, 923, 995, 93, 0, 0, 0, - 0, 515, 680, 679, 682, 683, 684, 685, 0, 0, - 158, 681, 686, 687, 688, 0, 885, 928, 1006, 802, - 654, 671, 807, 755, 3991, 980, 843, 844, 242, 0, - 0, 0, 0, 0, 0, 0, 888, 905, 947, 872, - 0, 433, 934, 943, 957, 865, 348, 261, 0, 0, - 0, 0, 668, 669, 0, 0, 0, 0, 773, 0, - 670, 0, 817, 666, 699, 700, 701, 702, 703, 704, - 705, 706, 707, 708, 709, 710, 711, 712, 713, 714, - 715, 716, 717, 718, 719, 720, 721, 722, 723, 724, - 725, 726, 727, 728, 729, 730, 731, 732, 733, 734, - 735, 736, 737, 738, 739, 740, 672, 0, 0, 0, - 822, 800, 841, 949, 801, 799, 312, 814, 744, 978, - 873, 278, 178, 984, 871, 771, 937, 818, 966, 859, - 286, 816, 179, 813, 819, 857, 325, 946, 952, 753, - 182, 288, 963, 837, 850, 225, 0, 362, 924, 432, - 660, 256, 910, 361, 290, 425, 938, 986, 431, 860, - 407, 440, 444, 250, 893, 215, 389, 240, 234, 842, - 956, 806, 262, 347, 229, 282, 876, 930, 838, 221, - 941, 917, 968, 388, 422, 184, 306, 423, 443, 153, - 251, 380, 252, 406, 243, 216, 350, 203, 414, 307, - 317, 218, 220, 219, 197, 381, 421, 209, 223, 964, - 951, 970, 833, 820, 825, 821, 849, 987, 271, 263, - 971, 969, 851, 334, 206, 903, 896, 889, 758, 435, - 1002, 236, 953, 437, 166, 375, 374, 863, 270, 954, - 167, 157, 357, 168, 279, 188, 974, 447, 202, 284, - 415, 659, 255, 324, 926, 335, 181, 352, 302, 304, - 301, 305, 260, 162, 169, 950, 354, 377, 420, 204, - 395, 160, 163, 171, 367, 172, 173, 993, 296, 245, - 249, 264, 275, 925, 360, 396, 438, 919, 199, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 364, 397, - 411, 369, 258, 399, 403, 400, 401, 398, 402, 365, - 366, 191, 405, 430, 210, 376, 379, 446, 948, 198, - 193, 982, 965, 912, 878, 884, 808, 0, 192, 879, - 880, 881, 882, 883, 944, 840, 852, 832, 920, 831, - 259, 936, 428, 429, 226, 747, 997, 194, 815, 996, - 321, 329, 320, 999, 998, 424, 983, 913, 902, 900, - 809, 981, 911, 901, 285, 248, 266, 345, 292, 346, - 267, 315, 314, 316, 294, 904, 394, 295, 0, 189, - 0, 393, 991, 1008, 404, 207, 826, 958, 419, 165, - 353, 208, 257, 246, 344, 319, 200, 269, 391, 283, - 291, 940, 1005, 333, 363, 214, 434, 390, 241, 759, - 326, 772, 765, 767, 766, 763, 764, 762, 761, 760, - 774, 745, 746, 749, 750, 751, 895, 985, 810, 754, - 961, 768, 769, 770, 933, 1003, 743, 222, 692, 786, - 787, 788, 693, 789, 790, 694, 695, 791, 792, 793, - 794, 696, 795, 796, 797, 775, 776, 777, 778, 779, - 780, 781, 782, 785, 783, 784, 0, 891, 341, 190, - 201, 418, 213, 233, 231, 247, 280, 303, 309, 339, - 378, 384, 385, 408, 409, 410, 412, 235, 0, 239, - 212, 358, 211, 293, 272, 340, 416, 417, 349, 228, - 752, 183, 195, 287, 1004, 356, 254, 308, 382, 310, - 276, 227, 445, 313, 355, 448, 959, 916, 0, 868, - 870, 869, 828, 830, 829, 827, 1007, 318, 977, 798, - 805, 824, 834, 839, 845, 853, 854, 862, 867, 877, - 886, 887, 897, 908, 909, 915, 939, 942, 955, 960, - 967, 972, 973, 436, 232, 894, 914, 945, 196, 205, - 217, 230, 244, 253, 265, 268, 273, 274, 277, 281, - 297, 298, 299, 300, 322, 323, 327, 328, 331, 332, - 336, 337, 338, 342, 343, 351, 170, 359, 368, 370, - 371, 372, 373, 383, 386, 387, 426, 427, 441, 442, - 874, 180, 0, 186, 0, 187, 0, 861, 185, 976, - 1000, 921, 935, 848, 988, 0, 0, 413, 748, 992, - 835, 858, 1001, 864, 866, 929, 811, 906, 330, 855, - 812, 0, 0, 0, 0, 803, 657, 804, 836, 238, - 656, 962, 907, 990, 892, 922, 932, 237, 224, 899, - 898, 979, 847, 846, 927, 975, 989, 0, 0, 159, - 757, 177, 756, 289, 0, 0, 439, 392, 311, 0, - 0, 890, 0, 741, 742, 875, 931, 823, 918, 994, - 856, 923, 995, 93, 0, 1380, 0, 0, 515, 680, - 679, 682, 683, 684, 685, 0, 0, 158, 681, 686, - 687, 688, 0, 885, 928, 1006, 802, 654, 671, 807, - 755, 0, 980, 843, 844, 242, 0, 0, 0, 0, - 0, 0, 0, 888, 905, 947, 872, 0, 433, 934, - 943, 957, 865, 348, 261, 0, 0, 0, 0, 668, - 669, 0, 0, 0, 0, 773, 0, 670, 0, 817, - 666, 699, 700, 701, 702, 703, 704, 705, 706, 707, - 708, 709, 710, 711, 712, 713, 714, 715, 716, 717, - 718, 719, 720, 721, 722, 723, 724, 725, 726, 727, - 728, 729, 730, 731, 732, 733, 734, 735, 736, 737, - 738, 739, 740, 672, 0, 0, 0, 822, 800, 841, - 949, 801, 799, 312, 814, 744, 978, 873, 278, 178, - 984, 871, 771, 937, 818, 966, 859, 286, 816, 179, - 813, 819, 857, 325, 946, 952, 753, 182, 288, 963, - 837, 850, 225, 0, 362, 924, 432, 660, 256, 910, - 361, 290, 425, 938, 986, 431, 860, 407, 440, 444, - 250, 893, 215, 389, 240, 234, 842, 956, 806, 262, - 347, 229, 282, 876, 930, 838, 221, 941, 917, 968, - 388, 422, 184, 306, 423, 443, 153, 251, 380, 252, - 406, 243, 216, 350, 203, 414, 307, 317, 218, 220, - 219, 197, 381, 421, 209, 223, 964, 951, 970, 833, - 820, 825, 821, 849, 987, 271, 263, 971, 969, 851, - 334, 206, 903, 896, 889, 758, 435, 1002, 236, 953, - 437, 166, 375, 374, 863, 270, 954, 167, 157, 357, - 168, 279, 188, 974, 447, 202, 284, 415, 659, 255, - 324, 926, 335, 181, 352, 302, 304, 301, 305, 260, - 162, 169, 950, 354, 377, 420, 204, 395, 160, 163, - 171, 367, 172, 173, 993, 296, 245, 249, 264, 275, - 925, 360, 396, 438, 919, 199, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 364, 397, 411, 369, 258, - 399, 403, 400, 401, 398, 402, 365, 366, 191, 405, - 430, 210, 376, 379, 446, 948, 198, 193, 982, 965, - 912, 878, 884, 808, 0, 192, 879, 880, 881, 882, - 883, 944, 840, 852, 832, 920, 831, 259, 936, 428, - 429, 226, 747, 997, 194, 815, 996, 321, 329, 320, - 999, 998, 424, 983, 913, 902, 900, 809, 981, 911, - 901, 285, 248, 266, 345, 292, 346, 267, 315, 314, - 316, 294, 904, 394, 295, 0, 189, 0, 393, 991, - 1008, 404, 207, 826, 958, 419, 165, 353, 208, 257, - 246, 344, 319, 200, 269, 391, 283, 291, 940, 1005, - 333, 363, 214, 434, 390, 241, 759, 326, 772, 765, - 767, 766, 763, 764, 762, 761, 760, 774, 745, 746, - 749, 750, 751, 895, 985, 810, 754, 961, 768, 769, - 770, 933, 1003, 743, 222, 692, 786, 787, 788, 693, - 789, 790, 694, 695, 791, 792, 793, 794, 696, 795, - 796, 797, 775, 776, 777, 778, 779, 780, 781, 782, - 785, 783, 784, 0, 891, 341, 190, 201, 418, 213, - 233, 231, 247, 280, 303, 309, 339, 378, 384, 385, - 408, 409, 410, 412, 235, 0, 239, 212, 358, 211, - 293, 272, 340, 416, 417, 349, 228, 752, 183, 195, - 287, 1004, 356, 254, 308, 382, 310, 276, 227, 445, - 313, 355, 448, 959, 916, 0, 868, 870, 869, 828, - 830, 829, 827, 1007, 318, 977, 798, 805, 824, 834, - 839, 845, 853, 854, 862, 867, 877, 886, 887, 897, - 908, 909, 915, 939, 942, 955, 960, 967, 972, 973, - 436, 232, 894, 914, 945, 196, 205, 217, 230, 244, - 253, 265, 268, 273, 274, 277, 281, 297, 298, 299, - 300, 322, 323, 327, 328, 331, 332, 336, 337, 338, - 342, 343, 351, 170, 359, 368, 370, 371, 372, 373, - 383, 386, 387, 426, 427, 441, 442, 874, 180, 0, - 186, 0, 187, 0, 861, 185, 976, 1000, 921, 935, - 848, 988, 0, 0, 413, 748, 992, 835, 858, 1001, - 864, 866, 929, 811, 906, 330, 855, 812, 0, 0, - 0, 0, 803, 657, 804, 836, 238, 656, 962, 907, - 990, 892, 922, 932, 237, 224, 899, 898, 979, 847, - 846, 927, 975, 989, 0, 0, 159, 757, 177, 756, - 289, 0, 0, 439, 392, 311, 0, 0, 890, 0, - 741, 742, 875, 931, 823, 918, 994, 856, 923, 995, - 93, 0, 0, 0, 0, 515, 680, 679, 682, 683, - 684, 685, 0, 0, 158, 681, 686, 687, 688, 0, - 885, 928, 1006, 802, 654, 671, 807, 755, 0, 980, - 843, 844, 242, 0, 0, 0, 0, 0, 0, 0, - 888, 905, 947, 872, 0, 433, 934, 943, 957, 865, - 348, 261, 0, 0, 0, 0, 668, 669, 2149, 0, - 0, 0, 773, 0, 670, 0, 817, 666, 699, 700, - 701, 702, 703, 704, 705, 706, 707, 708, 709, 710, - 711, 712, 713, 714, 715, 716, 717, 718, 719, 720, - 721, 722, 723, 724, 725, 726, 727, 728, 729, 730, - 731, 732, 733, 734, 735, 736, 737, 738, 739, 740, - 672, 0, 0, 0, 822, 800, 841, 949, 801, 799, - 312, 814, 744, 978, 873, 278, 178, 984, 871, 771, - 937, 818, 966, 859, 286, 816, 179, 813, 819, 857, - 325, 946, 952, 753, 182, 288, 963, 837, 850, 225, - 0, 362, 924, 432, 660, 256, 910, 361, 290, 425, - 938, 986, 431, 860, 407, 440, 444, 250, 893, 215, - 389, 240, 234, 842, 956, 806, 262, 347, 229, 282, - 876, 930, 838, 221, 941, 917, 968, 388, 422, 184, - 306, 423, 443, 153, 251, 380, 252, 406, 243, 216, - 350, 203, 414, 307, 317, 218, 220, 219, 197, 381, - 421, 209, 223, 964, 951, 970, 833, 820, 825, 821, - 849, 987, 271, 263, 971, 969, 851, 334, 206, 903, - 896, 889, 758, 435, 1002, 236, 953, 437, 166, 375, - 374, 863, 270, 954, 167, 157, 357, 168, 279, 188, - 974, 447, 202, 284, 415, 659, 255, 324, 926, 335, - 181, 352, 302, 304, 301, 305, 260, 162, 169, 950, - 354, 377, 420, 204, 395, 160, 163, 171, 367, 172, - 173, 993, 296, 245, 249, 264, 275, 925, 360, 396, - 438, 919, 199, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 364, 397, 411, 369, 258, 399, 403, 400, - 401, 398, 402, 365, 366, 191, 405, 430, 210, 376, - 379, 446, 948, 198, 193, 982, 965, 912, 878, 884, - 808, 0, 192, 879, 880, 881, 882, 883, 944, 840, - 852, 832, 920, 831, 259, 936, 428, 429, 226, 747, - 997, 194, 815, 996, 321, 329, 320, 999, 998, 424, - 983, 913, 902, 900, 809, 981, 911, 901, 285, 248, - 266, 345, 292, 346, 267, 315, 314, 316, 294, 904, - 394, 295, 0, 189, 0, 393, 991, 1008, 404, 207, - 826, 958, 419, 165, 353, 208, 257, 246, 344, 319, - 200, 269, 391, 283, 291, 940, 1005, 333, 363, 214, - 434, 390, 241, 759, 326, 772, 765, 767, 766, 763, - 764, 762, 761, 760, 774, 745, 746, 749, 750, 751, - 895, 985, 810, 754, 961, 768, 769, 770, 933, 1003, - 743, 222, 692, 786, 787, 788, 693, 789, 790, 694, - 695, 791, 792, 793, 794, 696, 795, 796, 797, 775, - 776, 777, 778, 779, 780, 781, 782, 785, 783, 784, - 0, 891, 341, 190, 201, 418, 213, 233, 231, 247, - 280, 303, 309, 339, 378, 384, 385, 408, 409, 410, - 412, 235, 0, 239, 212, 358, 211, 293, 272, 340, - 416, 417, 349, 228, 752, 183, 195, 287, 1004, 356, - 254, 308, 382, 310, 276, 227, 445, 313, 355, 448, - 959, 916, 0, 868, 870, 869, 828, 830, 829, 827, - 1007, 318, 977, 798, 805, 824, 834, 839, 845, 853, - 854, 862, 867, 877, 886, 887, 897, 908, 909, 915, - 939, 942, 955, 960, 967, 972, 973, 436, 232, 894, - 914, 945, 196, 205, 217, 230, 244, 253, 265, 268, - 273, 274, 277, 281, 297, 298, 299, 300, 322, 323, - 327, 328, 331, 332, 336, 337, 338, 342, 343, 351, - 170, 359, 368, 370, 371, 372, 373, 383, 386, 387, - 426, 427, 441, 442, 874, 180, 0, 186, 0, 187, - 0, 861, 185, 976, 1000, 921, 935, 848, 988, 0, - 0, 413, 748, 992, 835, 858, 1001, 864, 866, 929, - 811, 906, 330, 855, 812, 0, 0, 0, 0, 803, - 657, 804, 836, 238, 656, 962, 907, 990, 892, 922, - 932, 237, 224, 899, 898, 979, 847, 846, 927, 975, - 989, 0, 0, 159, 757, 177, 756, 289, 0, 0, - 439, 392, 311, 0, 0, 890, 0, 741, 742, 875, - 931, 823, 918, 994, 856, 923, 995, 93, 0, 0, - 0, 0, 515, 680, 679, 682, 683, 684, 685, 0, - 0, 158, 681, 686, 687, 688, 0, 885, 928, 1006, - 802, 654, 671, 807, 755, 0, 980, 843, 844, 242, - 0, 0, 0, 0, 0, 0, 0, 888, 905, 947, - 872, 0, 433, 934, 943, 957, 865, 348, 261, 0, - 0, 0, 0, 668, 669, 650, 0, 0, 0, 773, - 0, 670, 0, 817, 666, 699, 700, 701, 702, 703, - 704, 705, 706, 707, 708, 709, 710, 711, 712, 713, - 714, 715, 716, 717, 718, 719, 720, 721, 722, 723, - 724, 725, 726, 727, 728, 729, 730, 731, 732, 733, - 734, 735, 736, 737, 738, 739, 740, 672, 0, 0, - 0, 822, 800, 841, 949, 801, 799, 312, 814, 744, - 978, 873, 278, 178, 984, 871, 771, 937, 818, 966, - 859, 286, 816, 179, 813, 819, 857, 325, 946, 952, - 753, 182, 288, 963, 837, 850, 225, 0, 362, 924, - 432, 660, 256, 910, 361, 290, 425, 938, 986, 431, - 860, 407, 440, 444, 250, 893, 215, 389, 240, 234, - 842, 956, 806, 262, 347, 229, 282, 876, 930, 838, - 221, 941, 917, 968, 388, 422, 184, 306, 423, 443, - 153, 251, 380, 252, 406, 243, 216, 350, 203, 414, - 307, 317, 218, 220, 219, 197, 381, 421, 209, 223, - 964, 951, 970, 833, 820, 825, 821, 849, 987, 271, - 263, 971, 969, 851, 334, 206, 903, 896, 889, 758, - 435, 1002, 236, 953, 437, 166, 375, 374, 863, 270, - 954, 167, 157, 357, 168, 279, 188, 974, 447, 202, - 284, 415, 659, 255, 324, 926, 335, 181, 352, 302, - 304, 301, 305, 260, 162, 169, 950, 354, 377, 420, - 204, 395, 160, 163, 171, 367, 172, 173, 993, 296, - 245, 249, 264, 275, 925, 360, 396, 438, 919, 199, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 364, - 397, 411, 369, 258, 399, 403, 400, 401, 398, 402, - 365, 366, 191, 405, 430, 210, 376, 379, 446, 948, - 198, 193, 982, 965, 912, 878, 884, 808, 0, 192, - 879, 880, 881, 882, 883, 944, 840, 852, 832, 920, - 831, 259, 936, 428, 429, 226, 747, 997, 194, 815, - 996, 321, 329, 320, 999, 998, 424, 983, 913, 902, - 900, 809, 981, 911, 901, 285, 248, 266, 345, 292, - 346, 267, 315, 314, 316, 294, 904, 394, 295, 0, - 189, 0, 393, 991, 1008, 404, 207, 826, 958, 419, - 165, 353, 208, 257, 246, 344, 319, 200, 269, 391, - 283, 291, 940, 1005, 333, 363, 214, 434, 390, 241, - 759, 326, 772, 765, 767, 766, 763, 764, 762, 761, - 760, 774, 745, 746, 749, 750, 751, 895, 985, 810, - 754, 961, 768, 769, 770, 933, 1003, 743, 222, 692, - 786, 787, 788, 693, 789, 790, 694, 695, 791, 792, - 793, 794, 696, 795, 796, 797, 775, 776, 777, 778, - 779, 780, 781, 782, 785, 783, 784, 0, 891, 341, - 190, 201, 418, 213, 233, 231, 247, 280, 303, 309, - 339, 378, 384, 385, 408, 409, 410, 412, 235, 0, - 239, 212, 358, 211, 293, 272, 340, 416, 417, 349, - 228, 752, 183, 195, 287, 1004, 356, 254, 308, 382, - 310, 276, 227, 445, 313, 355, 448, 959, 916, 0, - 868, 870, 869, 828, 830, 829, 827, 1007, 318, 977, - 798, 805, 824, 834, 839, 845, 853, 854, 862, 867, - 877, 886, 887, 897, 908, 909, 915, 939, 942, 955, - 960, 967, 972, 973, 436, 232, 894, 914, 945, 196, - 205, 217, 230, 244, 253, 265, 268, 273, 274, 277, - 281, 297, 298, 299, 300, 322, 323, 327, 328, 331, - 332, 336, 337, 338, 342, 343, 351, 170, 359, 368, - 370, 371, 372, 373, 383, 386, 387, 426, 427, 441, - 442, 874, 180, 0, 186, 0, 187, 0, 861, 185, - 976, 1000, 921, 935, 848, 988, 0, 0, 413, 748, - 992, 835, 858, 1001, 864, 866, 929, 811, 906, 330, - 855, 812, 0, 0, 0, 0, 803, 657, 804, 836, - 238, 656, 962, 907, 990, 892, 922, 932, 237, 224, - 899, 898, 979, 847, 846, 927, 975, 989, 0, 0, - 159, 757, 177, 756, 289, 0, 0, 439, 392, 311, - 0, 0, 890, 0, 741, 742, 875, 931, 823, 918, - 994, 856, 2348, 995, 93, 0, 0, 0, 0, 515, - 680, 2350, 682, 683, 684, 685, 0, 0, 158, 681, - 686, 687, 688, 2349, 885, 928, 1006, 802, 654, 671, - 807, 755, 0, 980, 843, 844, 242, 0, 0, 0, - 0, 0, 0, 0, 888, 905, 947, 872, 0, 433, - 934, 943, 957, 865, 348, 261, 0, 0, 0, 0, - 668, 669, 0, 0, 0, 0, 773, 0, 670, 0, - 817, 666, 699, 700, 701, 702, 703, 704, 705, 706, - 707, 708, 709, 710, 711, 712, 713, 714, 715, 716, - 717, 718, 719, 720, 721, 722, 723, 724, 725, 726, - 727, 728, 729, 730, 731, 732, 733, 734, 735, 736, - 737, 738, 739, 740, 672, 0, 0, 0, 822, 800, - 841, 949, 801, 799, 312, 814, 744, 978, 873, 278, - 178, 984, 871, 771, 937, 818, 966, 859, 286, 816, - 179, 813, 819, 857, 325, 946, 952, 753, 182, 288, - 963, 837, 850, 225, 0, 362, 924, 432, 660, 256, - 910, 361, 290, 425, 938, 986, 431, 860, 407, 440, - 444, 250, 893, 215, 389, 240, 234, 842, 956, 806, - 262, 347, 229, 282, 876, 930, 838, 221, 941, 917, - 968, 388, 422, 184, 306, 423, 443, 153, 251, 380, - 252, 406, 243, 216, 350, 203, 414, 307, 317, 218, - 220, 219, 197, 381, 421, 209, 223, 964, 951, 970, - 833, 820, 825, 821, 849, 987, 271, 263, 971, 969, - 851, 334, 206, 903, 896, 889, 758, 435, 1002, 236, - 953, 437, 166, 375, 374, 863, 270, 954, 167, 157, - 357, 168, 279, 188, 974, 447, 202, 284, 415, 659, - 255, 324, 926, 335, 181, 352, 302, 304, 301, 305, - 260, 162, 169, 950, 354, 377, 420, 204, 395, 160, - 163, 171, 367, 172, 173, 993, 296, 245, 249, 264, - 275, 925, 360, 396, 438, 919, 199, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 364, 397, 411, 369, - 258, 399, 403, 400, 401, 398, 402, 365, 366, 191, - 405, 430, 210, 376, 379, 446, 948, 198, 193, 982, - 965, 912, 878, 884, 808, 0, 192, 879, 880, 881, - 882, 883, 944, 840, 852, 832, 920, 831, 259, 936, - 428, 429, 226, 747, 997, 194, 815, 996, 321, 329, - 320, 999, 998, 424, 983, 913, 902, 900, 809, 981, - 911, 901, 285, 248, 266, 345, 292, 346, 267, 315, - 314, 316, 294, 904, 394, 295, 0, 189, 0, 393, - 991, 1008, 404, 207, 826, 958, 419, 165, 353, 208, - 257, 246, 344, 319, 200, 269, 391, 283, 291, 940, - 1005, 333, 363, 214, 434, 390, 241, 759, 326, 772, - 765, 767, 766, 763, 764, 762, 761, 760, 774, 745, - 746, 749, 750, 751, 895, 985, 810, 754, 961, 768, - 769, 770, 933, 1003, 743, 222, 692, 786, 787, 788, - 693, 789, 790, 694, 695, 791, 792, 793, 794, 696, - 795, 796, 797, 775, 776, 777, 778, 779, 780, 781, - 782, 785, 783, 784, 0, 891, 341, 190, 201, 418, - 213, 233, 231, 247, 280, 303, 309, 339, 378, 384, - 385, 408, 409, 410, 412, 235, 0, 239, 212, 358, - 211, 293, 272, 340, 416, 417, 349, 228, 752, 183, - 195, 287, 1004, 356, 254, 308, 382, 310, 276, 227, - 445, 313, 355, 448, 959, 916, 0, 868, 870, 869, - 828, 830, 829, 827, 1007, 318, 977, 798, 805, 824, - 834, 839, 845, 853, 854, 862, 867, 877, 886, 887, - 897, 908, 909, 915, 939, 942, 955, 960, 967, 972, - 973, 436, 232, 894, 914, 945, 196, 205, 217, 230, - 244, 253, 265, 268, 273, 274, 277, 281, 297, 298, - 299, 300, 322, 323, 327, 328, 331, 332, 336, 337, - 338, 342, 343, 351, 170, 359, 368, 370, 371, 372, - 373, 383, 386, 387, 426, 427, 441, 442, 874, 180, - 0, 186, 0, 187, 0, 861, 185, 976, 1000, 921, - 935, 848, 988, 0, 0, 413, 748, 992, 835, 858, - 1001, 864, 866, 929, 811, 906, 330, 855, 812, 0, - 0, 0, 0, 803, 1048, 804, 836, 238, 1046, 962, - 907, 990, 892, 922, 932, 237, 224, 899, 898, 979, - 847, 846, 927, 975, 989, 0, 0, 159, 757, 177, - 756, 289, 0, 0, 439, 392, 311, 0, 0, 890, - 0, 741, 742, 875, 931, 823, 918, 994, 856, 923, - 995, 93, 0, 1380, 0, 0, 515, 680, 679, 682, - 683, 684, 685, 0, 0, 158, 681, 686, 687, 688, - 0, 885, 928, 1006, 802, 1065, 671, 807, 755, 0, - 980, 843, 844, 242, 0, 0, 0, 0, 0, 0, - 0, 888, 905, 947, 872, 0, 433, 934, 943, 957, - 865, 348, 261, 0, 0, 0, 0, 668, 669, 0, - 0, 0, 0, 773, 0, 670, 0, 817, 666, 699, - 700, 701, 702, 703, 704, 705, 706, 707, 708, 709, - 710, 711, 712, 713, 714, 715, 716, 717, 718, 719, - 720, 721, 722, 723, 724, 725, 726, 727, 728, 729, - 730, 731, 732, 733, 734, 735, 736, 737, 738, 739, - 740, 672, 0, 0, 0, 822, 800, 841, 949, 801, - 799, 312, 814, 744, 978, 873, 278, 178, 984, 871, - 771, 937, 818, 966, 859, 286, 816, 179, 813, 819, - 857, 325, 946, 952, 753, 182, 288, 963, 837, 850, - 225, 0, 362, 924, 432, 660, 256, 910, 361, 290, - 425, 938, 986, 431, 860, 407, 440, 444, 250, 893, - 215, 389, 240, 234, 842, 956, 806, 262, 347, 229, - 282, 876, 930, 838, 221, 941, 917, 968, 388, 422, - 184, 306, 423, 443, 153, 251, 380, 252, 406, 243, - 216, 350, 203, 414, 307, 317, 218, 220, 219, 197, - 381, 421, 209, 223, 964, 951, 970, 833, 820, 825, - 821, 849, 987, 271, 263, 971, 969, 851, 334, 206, - 903, 896, 889, 758, 435, 1002, 236, 953, 437, 166, - 375, 374, 863, 270, 954, 167, 157, 357, 168, 279, - 188, 974, 447, 202, 284, 415, 659, 255, 324, 926, - 335, 181, 352, 302, 304, 301, 305, 260, 162, 169, - 950, 354, 377, 420, 204, 395, 160, 163, 171, 367, - 172, 173, 993, 296, 245, 249, 264, 275, 925, 360, - 396, 438, 919, 199, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 364, 397, 411, 369, 258, 399, 403, - 400, 401, 398, 402, 365, 366, 191, 405, 430, 210, - 376, 379, 446, 948, 198, 193, 982, 965, 912, 878, - 884, 808, 0, 192, 879, 880, 881, 882, 883, 944, - 840, 852, 832, 920, 831, 259, 936, 428, 429, 226, - 747, 997, 194, 815, 996, 321, 329, 320, 999, 998, - 424, 983, 913, 902, 900, 809, 981, 911, 901, 285, - 248, 266, 345, 292, 346, 267, 315, 314, 316, 294, - 904, 394, 295, 0, 189, 0, 393, 991, 1008, 404, - 207, 826, 958, 419, 165, 353, 208, 257, 246, 344, - 319, 200, 269, 391, 283, 291, 940, 1005, 333, 363, - 214, 434, 390, 241, 759, 326, 772, 765, 767, 766, - 763, 764, 762, 761, 760, 774, 745, 746, 749, 750, - 751, 895, 985, 810, 754, 961, 768, 769, 770, 933, - 1003, 743, 222, 692, 786, 787, 788, 693, 789, 790, - 694, 695, 791, 792, 793, 794, 696, 795, 796, 797, - 775, 776, 777, 778, 779, 780, 781, 782, 785, 783, - 784, 0, 891, 341, 190, 201, 418, 213, 233, 231, - 247, 280, 303, 309, 339, 378, 384, 385, 408, 409, - 410, 412, 235, 0, 239, 212, 358, 211, 293, 272, - 340, 416, 417, 349, 228, 752, 183, 195, 287, 1004, - 356, 254, 308, 382, 310, 276, 227, 445, 313, 355, - 448, 959, 916, 0, 868, 870, 869, 828, 830, 829, - 827, 1007, 318, 977, 798, 805, 824, 834, 839, 845, - 853, 854, 862, 867, 877, 886, 887, 897, 908, 909, - 915, 939, 942, 955, 960, 967, 972, 973, 436, 232, - 894, 914, 945, 196, 205, 217, 230, 244, 253, 265, - 268, 273, 274, 277, 281, 297, 298, 299, 300, 322, - 323, 327, 328, 331, 332, 336, 337, 338, 342, 343, - 351, 170, 359, 368, 370, 371, 372, 373, 383, 386, - 387, 426, 427, 441, 442, 874, 180, 0, 186, 0, - 187, 0, 861, 185, 976, 1000, 921, 935, 848, 988, - 0, 0, 413, 748, 992, 835, 858, 1001, 864, 866, - 929, 811, 906, 330, 855, 812, 0, 0, 0, 0, - 803, 657, 804, 836, 238, 656, 962, 907, 990, 892, - 922, 932, 237, 224, 899, 898, 979, 847, 846, 927, - 975, 989, 0, 0, 159, 757, 177, 756, 289, 0, - 0, 439, 392, 311, 0, 0, 890, 0, 741, 742, - 875, 931, 823, 918, 994, 856, 923, 995, 93, 0, - 0, 0, 0, 515, 680, 2254, 682, 683, 684, 685, - 0, 0, 158, 681, 686, 687, 688, 0, 885, 928, - 1006, 802, 654, 671, 807, 755, 0, 980, 843, 844, - 242, 0, 0, 0, 0, 0, 0, 0, 888, 905, - 947, 872, 0, 433, 934, 943, 957, 865, 348, 261, - 0, 0, 0, 0, 668, 669, 2149, 0, 0, 0, - 773, 0, 670, 0, 817, 666, 699, 700, 701, 702, - 703, 704, 705, 706, 707, 708, 709, 710, 711, 712, - 713, 714, 715, 716, 717, 718, 719, 720, 721, 722, - 723, 724, 725, 726, 727, 728, 729, 730, 731, 732, - 733, 734, 735, 736, 737, 738, 739, 740, 672, 0, - 0, 0, 822, 800, 841, 949, 801, 799, 312, 814, - 744, 978, 873, 278, 178, 984, 871, 771, 937, 818, - 966, 859, 286, 816, 179, 813, 819, 857, 325, 946, - 952, 753, 182, 288, 963, 837, 850, 225, 0, 362, - 924, 432, 660, 256, 910, 361, 290, 425, 938, 986, - 431, 860, 407, 440, 444, 250, 893, 215, 389, 240, - 234, 842, 956, 806, 262, 347, 229, 282, 876, 930, - 838, 221, 941, 917, 968, 388, 422, 184, 306, 423, - 443, 153, 251, 380, 252, 406, 243, 216, 350, 203, - 414, 307, 317, 218, 220, 219, 197, 381, 421, 209, - 223, 964, 951, 970, 833, 820, 825, 821, 849, 987, - 271, 263, 971, 969, 851, 334, 206, 903, 896, 889, - 758, 435, 1002, 236, 953, 437, 166, 375, 374, 863, - 270, 954, 167, 157, 357, 168, 279, 188, 974, 447, - 202, 284, 415, 659, 255, 324, 926, 335, 181, 352, - 302, 304, 301, 305, 260, 162, 169, 950, 354, 377, - 420, 204, 395, 160, 163, 171, 367, 172, 173, 993, - 296, 245, 249, 264, 275, 925, 360, 396, 438, 919, - 199, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 364, 397, 411, 369, 258, 399, 403, 400, 401, 398, - 402, 365, 366, 191, 405, 430, 210, 376, 379, 446, - 948, 198, 193, 982, 965, 912, 878, 884, 808, 0, - 192, 879, 880, 881, 882, 883, 944, 840, 852, 832, - 920, 831, 259, 936, 428, 429, 226, 747, 997, 194, - 815, 996, 321, 329, 320, 999, 998, 424, 983, 913, - 902, 900, 809, 981, 911, 901, 285, 248, 266, 345, - 292, 346, 267, 315, 314, 316, 294, 904, 394, 295, - 0, 189, 0, 393, 991, 1008, 404, 207, 826, 958, - 419, 165, 353, 208, 257, 246, 344, 319, 200, 269, - 391, 283, 291, 940, 1005, 333, 363, 214, 434, 390, - 241, 759, 326, 772, 765, 767, 766, 763, 764, 762, - 761, 760, 774, 745, 746, 749, 750, 751, 895, 985, - 810, 754, 961, 768, 769, 770, 933, 1003, 743, 222, - 692, 786, 787, 788, 693, 789, 790, 694, 695, 791, - 792, 793, 794, 696, 795, 796, 797, 775, 776, 777, - 778, 779, 780, 781, 782, 785, 783, 784, 0, 891, - 341, 190, 201, 418, 213, 233, 231, 247, 280, 303, - 309, 339, 378, 384, 385, 408, 409, 410, 412, 235, - 0, 239, 212, 358, 211, 293, 272, 340, 416, 417, - 349, 228, 752, 183, 195, 287, 1004, 356, 254, 308, - 382, 310, 276, 227, 445, 313, 355, 448, 959, 916, - 0, 868, 870, 869, 828, 830, 829, 827, 1007, 318, - 977, 798, 805, 824, 834, 839, 845, 853, 854, 862, - 867, 877, 886, 887, 897, 908, 909, 915, 939, 942, - 955, 960, 967, 972, 973, 436, 232, 894, 914, 945, - 196, 205, 217, 230, 244, 253, 265, 268, 273, 274, - 277, 281, 297, 298, 299, 300, 322, 323, 327, 328, - 331, 332, 336, 337, 338, 342, 343, 351, 170, 359, - 368, 370, 371, 372, 373, 383, 386, 387, 426, 427, - 441, 442, 874, 180, 0, 186, 0, 187, 0, 861, - 185, 976, 1000, 921, 935, 848, 988, 0, 0, 413, - 748, 992, 835, 858, 1001, 864, 866, 929, 811, 906, - 330, 855, 812, 0, 0, 0, 0, 803, 657, 804, - 836, 238, 656, 962, 907, 990, 892, 922, 932, 237, - 224, 899, 898, 979, 847, 846, 927, 975, 989, 0, - 0, 159, 757, 177, 756, 289, 0, 0, 439, 392, - 311, 0, 0, 890, 0, 741, 742, 875, 931, 823, - 918, 994, 856, 923, 995, 93, 0, 0, 0, 0, - 515, 680, 2251, 682, 683, 684, 685, 0, 0, 158, - 681, 686, 687, 688, 0, 885, 928, 1006, 802, 654, - 671, 807, 755, 0, 980, 843, 844, 242, 0, 0, - 0, 0, 0, 0, 0, 888, 905, 947, 872, 0, - 433, 934, 943, 957, 865, 348, 261, 0, 0, 0, - 0, 668, 669, 2149, 0, 0, 0, 773, 0, 670, - 0, 817, 666, 699, 700, 701, 702, 703, 704, 705, - 706, 707, 708, 709, 710, 711, 712, 713, 714, 715, - 716, 717, 718, 719, 720, 721, 722, 723, 724, 725, - 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, - 736, 737, 738, 739, 740, 672, 0, 0, 0, 822, - 800, 841, 949, 801, 799, 312, 814, 744, 978, 873, - 278, 178, 984, 871, 771, 937, 818, 966, 859, 286, - 816, 179, 813, 819, 857, 325, 946, 952, 753, 182, - 288, 963, 837, 850, 225, 0, 362, 924, 432, 660, - 256, 910, 361, 290, 425, 938, 986, 431, 860, 407, - 440, 444, 250, 893, 215, 389, 240, 234, 842, 956, - 806, 262, 347, 229, 282, 876, 930, 838, 221, 941, - 917, 968, 388, 422, 184, 306, 423, 443, 153, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 964, 951, - 970, 833, 820, 825, 821, 849, 987, 271, 263, 971, - 969, 851, 334, 206, 903, 896, 889, 758, 435, 1002, - 236, 953, 437, 166, 375, 374, 863, 270, 954, 167, - 157, 357, 168, 279, 188, 974, 447, 202, 284, 415, - 659, 255, 324, 926, 335, 181, 352, 302, 304, 301, - 305, 260, 162, 169, 950, 354, 377, 420, 204, 395, - 160, 163, 171, 367, 172, 173, 993, 296, 245, 249, - 264, 275, 925, 360, 396, 438, 919, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 948, 198, 193, - 982, 965, 912, 878, 884, 808, 0, 192, 879, 880, - 881, 882, 883, 944, 840, 852, 832, 920, 831, 259, - 936, 428, 429, 226, 747, 997, 194, 815, 996, 321, - 329, 320, 999, 998, 424, 983, 913, 902, 900, 809, - 981, 911, 901, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 904, 394, 295, 0, 189, 0, - 393, 991, 1008, 404, 207, 826, 958, 419, 165, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 940, 1005, 333, 363, 214, 434, 390, 241, 759, 326, - 772, 765, 767, 766, 763, 764, 762, 761, 760, 774, - 745, 746, 749, 750, 751, 895, 985, 810, 754, 961, - 768, 769, 770, 933, 1003, 743, 222, 692, 786, 787, - 788, 693, 789, 790, 694, 695, 791, 792, 793, 794, - 696, 795, 796, 797, 775, 776, 777, 778, 779, 780, - 781, 782, 785, 783, 784, 0, 891, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 752, - 183, 195, 287, 1004, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 959, 916, 0, 868, 870, - 869, 828, 830, 829, 827, 1007, 318, 977, 798, 805, - 824, 834, 839, 845, 853, 854, 862, 867, 877, 886, - 887, 897, 908, 909, 915, 939, 942, 955, 960, 967, - 972, 973, 436, 232, 894, 914, 945, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 170, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 874, - 180, 0, 186, 0, 187, 0, 861, 185, 976, 1000, - 921, 935, 848, 988, 0, 40, 413, 748, 992, 835, - 858, 1001, 864, 866, 929, 811, 906, 330, 855, 812, - 0, 0, 0, 0, 803, 657, 804, 836, 238, 656, - 962, 907, 990, 892, 922, 932, 237, 224, 899, 898, - 979, 847, 846, 927, 975, 989, 0, 0, 159, 757, - 177, 756, 289, 0, 0, 439, 392, 311, 0, 0, - 890, 0, 741, 742, 875, 931, 823, 918, 994, 856, - 923, 995, 93, 0, 0, 0, 0, 515, 680, 679, - 682, 683, 684, 685, 0, 0, 158, 681, 686, 687, - 688, 0, 885, 928, 1006, 802, 654, 671, 807, 755, - 0, 980, 843, 844, 242, 0, 0, 0, 0, 0, - 0, 0, 888, 905, 947, 872, 0, 433, 934, 943, - 957, 865, 348, 261, 0, 0, 0, 0, 668, 669, - 0, 0, 0, 0, 773, 0, 670, 0, 817, 666, - 699, 700, 701, 702, 703, 704, 705, 706, 707, 708, - 709, 710, 711, 712, 713, 714, 715, 716, 717, 718, - 719, 720, 721, 722, 723, 724, 725, 726, 727, 728, - 729, 730, 731, 732, 733, 734, 735, 736, 737, 738, - 739, 740, 672, 0, 0, 0, 822, 800, 841, 949, - 801, 799, 312, 814, 744, 1470, 873, 278, 178, 984, - 871, 771, 937, 818, 966, 859, 286, 816, 179, 813, - 819, 857, 325, 946, 952, 753, 182, 288, 963, 837, - 850, 225, 0, 362, 924, 432, 660, 256, 910, 361, - 290, 425, 938, 986, 431, 860, 407, 440, 444, 250, - 893, 215, 389, 240, 234, 842, 956, 806, 262, 347, - 229, 282, 876, 930, 838, 221, 941, 917, 968, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 964, 951, 970, 833, 820, - 825, 821, 849, 987, 271, 263, 971, 969, 851, 334, - 206, 903, 896, 889, 758, 435, 1002, 236, 953, 437, - 166, 375, 374, 863, 270, 954, 167, 157, 357, 168, - 279, 188, 974, 447, 202, 284, 415, 659, 255, 324, - 926, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 950, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 993, 296, 245, 249, 264, 275, 925, - 360, 396, 438, 919, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 948, 198, 193, 982, 965, 912, - 878, 884, 808, 0, 192, 879, 880, 881, 882, 883, - 944, 840, 852, 832, 920, 831, 259, 936, 428, 429, - 226, 747, 997, 194, 815, 996, 321, 329, 320, 999, - 998, 424, 983, 913, 902, 900, 809, 981, 911, 901, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 904, 394, 295, 0, 189, 0, 393, 991, 1008, - 404, 207, 826, 958, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 940, 1005, 333, - 363, 214, 434, 390, 241, 759, 326, 772, 765, 767, - 766, 763, 764, 762, 761, 760, 774, 745, 746, 749, - 750, 751, 895, 985, 810, 754, 961, 768, 769, 770, - 933, 1003, 743, 222, 692, 786, 787, 788, 693, 789, - 790, 694, 695, 791, 792, 793, 794, 696, 795, 796, - 797, 775, 776, 777, 778, 779, 780, 781, 782, 785, - 783, 784, 0, 891, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 752, 183, 195, 287, - 1468, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 959, 916, 0, 868, 870, 869, 828, 830, - 829, 827, 1007, 318, 977, 798, 805, 824, 834, 839, - 845, 853, 854, 862, 867, 877, 886, 887, 897, 908, - 909, 915, 939, 942, 955, 960, 967, 972, 973, 436, - 232, 894, 914, 945, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 874, 180, 0, 186, - 0, 187, 0, 861, 185, 976, 1000, 921, 935, 848, - 988, 0, 0, 413, 748, 992, 835, 858, 1001, 864, - 866, 929, 811, 906, 330, 855, 812, 0, 0, 0, - 0, 803, 657, 804, 836, 238, 656, 962, 907, 990, - 892, 922, 932, 237, 224, 899, 898, 979, 847, 846, - 927, 975, 989, 0, 0, 159, 757, 177, 756, 289, - 0, 0, 439, 392, 311, 0, 0, 890, 0, 741, - 742, 875, 931, 823, 918, 994, 856, 923, 995, 93, - 0, 2025, 0, 0, 515, 680, 679, 682, 683, 684, - 685, 0, 0, 158, 681, 686, 687, 688, 0, 885, - 928, 1006, 802, 654, 671, 807, 755, 0, 980, 843, - 844, 242, 0, 0, 0, 0, 0, 0, 0, 888, - 905, 947, 872, 0, 433, 934, 943, 957, 865, 348, - 261, 0, 0, 0, 0, 668, 669, 0, 0, 0, - 0, 773, 0, 670, 0, 817, 666, 699, 700, 701, - 702, 703, 704, 705, 706, 707, 708, 709, 710, 711, - 712, 713, 714, 715, 716, 717, 718, 719, 720, 721, - 722, 723, 724, 725, 726, 727, 728, 729, 730, 731, - 732, 733, 734, 735, 736, 737, 738, 739, 740, 672, - 0, 0, 0, 822, 800, 841, 949, 801, 799, 312, - 814, 744, 978, 873, 278, 178, 984, 871, 771, 937, - 818, 966, 859, 286, 816, 179, 813, 819, 857, 325, - 946, 952, 753, 182, 288, 963, 837, 850, 225, 0, - 362, 924, 432, 660, 256, 910, 361, 290, 425, 938, - 986, 431, 860, 407, 440, 444, 250, 893, 215, 389, - 240, 234, 842, 956, 806, 262, 347, 229, 282, 876, - 930, 838, 221, 941, 917, 968, 388, 422, 184, 306, - 423, 443, 153, 251, 380, 252, 406, 243, 216, 350, - 203, 414, 307, 317, 218, 220, 219, 197, 381, 421, - 209, 223, 964, 951, 970, 833, 820, 825, 821, 849, - 987, 271, 263, 971, 969, 851, 334, 206, 903, 896, - 889, 758, 435, 1002, 236, 953, 437, 166, 375, 374, - 863, 270, 954, 167, 157, 357, 168, 279, 188, 974, - 447, 202, 284, 415, 659, 255, 324, 926, 335, 181, - 352, 302, 304, 301, 305, 260, 162, 169, 950, 354, - 377, 420, 204, 395, 160, 163, 171, 367, 172, 173, - 993, 296, 245, 249, 264, 275, 925, 360, 396, 438, - 919, 199, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 364, 397, 411, 369, 258, 399, 403, 400, 401, - 398, 402, 365, 366, 191, 405, 430, 210, 376, 379, - 446, 948, 198, 193, 982, 965, 912, 878, 884, 808, - 0, 192, 879, 880, 881, 882, 883, 944, 840, 852, - 832, 920, 831, 259, 936, 428, 429, 226, 747, 997, - 194, 815, 996, 321, 329, 320, 999, 998, 424, 983, - 913, 902, 900, 809, 981, 911, 901, 285, 248, 266, - 345, 292, 346, 267, 315, 314, 316, 294, 904, 394, - 295, 0, 189, 0, 393, 991, 1008, 404, 207, 826, - 958, 419, 165, 353, 208, 257, 246, 344, 319, 200, - 269, 391, 283, 291, 940, 1005, 333, 363, 214, 434, - 390, 241, 759, 326, 772, 765, 767, 766, 763, 764, - 762, 761, 760, 774, 745, 746, 749, 750, 751, 895, - 985, 810, 754, 961, 768, 769, 770, 933, 1003, 743, - 222, 692, 786, 787, 788, 693, 789, 790, 694, 695, - 791, 792, 793, 794, 696, 795, 796, 797, 775, 776, - 777, 778, 779, 780, 781, 782, 785, 783, 784, 0, - 891, 341, 190, 201, 418, 213, 233, 231, 247, 280, - 303, 309, 339, 378, 384, 385, 408, 409, 410, 412, - 235, 0, 239, 212, 358, 211, 293, 272, 340, 416, - 417, 349, 228, 752, 183, 195, 287, 1004, 356, 254, - 308, 382, 310, 276, 227, 445, 313, 355, 448, 959, - 916, 0, 868, 870, 869, 828, 830, 829, 827, 1007, - 318, 977, 798, 805, 824, 834, 839, 845, 853, 854, - 862, 867, 877, 886, 887, 897, 908, 909, 915, 939, - 942, 955, 960, 967, 972, 973, 436, 232, 894, 914, - 945, 196, 205, 217, 230, 244, 253, 265, 268, 273, - 274, 277, 281, 297, 298, 299, 300, 322, 323, 327, - 328, 331, 332, 336, 337, 338, 342, 343, 351, 170, - 359, 368, 370, 371, 372, 373, 383, 386, 387, 426, - 427, 441, 442, 874, 180, 0, 186, 0, 187, 0, - 861, 185, 976, 1000, 921, 935, 848, 988, 0, 0, - 413, 748, 992, 835, 858, 1001, 864, 866, 929, 811, - 906, 330, 855, 812, 0, 0, 0, 0, 803, 657, - 804, 836, 238, 656, 962, 907, 990, 892, 922, 932, - 237, 224, 899, 898, 979, 847, 846, 927, 975, 989, - 0, 0, 159, 757, 177, 756, 289, 0, 0, 439, - 392, 311, 0, 0, 890, 0, 741, 742, 875, 931, - 823, 918, 994, 856, 923, 995, 93, 0, 0, 0, - 0, 515, 680, 679, 682, 683, 684, 685, 0, 0, - 158, 681, 686, 687, 688, 0, 885, 928, 1006, 802, - 654, 671, 807, 755, 0, 980, 843, 844, 242, 0, - 0, 0, 0, 0, 0, 0, 888, 905, 947, 872, - 0, 433, 934, 943, 957, 865, 348, 261, 0, 0, - 0, 0, 668, 669, 0, 0, 0, 0, 773, 0, - 670, 0, 817, 666, 699, 700, 701, 702, 703, 704, - 705, 706, 707, 708, 709, 710, 711, 712, 713, 714, - 715, 716, 717, 718, 719, 720, 721, 722, 723, 724, - 725, 726, 727, 728, 729, 730, 731, 732, 733, 734, - 735, 736, 737, 738, 739, 740, 672, 0, 0, 0, - 822, 800, 841, 949, 801, 799, 312, 814, 744, 978, - 873, 278, 178, 984, 871, 771, 937, 818, 966, 859, - 286, 816, 179, 813, 819, 857, 325, 946, 952, 753, - 182, 288, 963, 837, 850, 225, 0, 362, 924, 432, - 660, 256, 910, 361, 290, 425, 938, 986, 431, 860, - 407, 440, 444, 250, 893, 215, 389, 240, 234, 842, - 956, 806, 262, 347, 229, 282, 876, 930, 838, 221, - 941, 917, 968, 388, 422, 184, 306, 423, 443, 153, - 251, 380, 252, 406, 243, 216, 350, 203, 414, 307, - 317, 218, 220, 219, 197, 381, 421, 209, 223, 964, - 951, 970, 833, 820, 825, 821, 849, 987, 271, 263, - 971, 969, 851, 334, 206, 903, 896, 889, 758, 435, - 1002, 236, 953, 437, 166, 375, 374, 863, 270, 954, - 167, 157, 357, 168, 279, 188, 974, 447, 202, 284, - 415, 659, 255, 324, 926, 335, 181, 352, 302, 304, - 301, 305, 260, 162, 169, 950, 354, 377, 420, 204, - 395, 160, 163, 171, 367, 172, 173, 993, 296, 245, - 249, 264, 275, 925, 360, 396, 438, 919, 199, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 364, 397, - 411, 369, 258, 399, 403, 400, 401, 398, 402, 365, - 366, 191, 405, 430, 210, 376, 379, 446, 948, 198, - 193, 982, 965, 912, 878, 884, 808, 0, 192, 879, - 880, 881, 882, 883, 944, 840, 852, 832, 920, 831, - 259, 936, 428, 429, 226, 747, 997, 194, 815, 996, - 321, 329, 320, 999, 998, 424, 983, 913, 902, 900, - 809, 981, 911, 901, 285, 248, 266, 345, 292, 346, - 267, 315, 314, 316, 294, 904, 394, 295, 0, 189, - 0, 393, 991, 1008, 404, 207, 826, 958, 419, 165, - 353, 208, 257, 246, 344, 319, 200, 269, 391, 283, - 291, 940, 1005, 333, 363, 214, 434, 390, 241, 759, - 326, 772, 765, 767, 766, 763, 764, 762, 761, 760, - 774, 745, 746, 749, 750, 751, 895, 985, 810, 754, - 961, 768, 769, 770, 933, 1003, 743, 222, 692, 786, - 787, 788, 693, 789, 790, 694, 695, 791, 792, 793, - 794, 696, 795, 796, 797, 775, 776, 777, 778, 779, - 780, 781, 782, 785, 783, 784, 0, 891, 341, 190, - 201, 418, 213, 233, 231, 247, 280, 303, 309, 339, - 378, 384, 385, 408, 409, 410, 412, 235, 0, 239, - 212, 358, 211, 293, 272, 340, 416, 417, 349, 228, - 752, 183, 195, 287, 1004, 356, 254, 308, 382, 310, - 276, 227, 445, 313, 355, 448, 959, 916, 0, 868, - 870, 869, 828, 830, 829, 827, 1007, 318, 977, 798, - 805, 824, 834, 839, 845, 853, 854, 862, 867, 877, - 886, 887, 897, 908, 909, 915, 939, 942, 955, 960, - 967, 972, 973, 436, 232, 894, 914, 945, 196, 205, - 217, 230, 244, 253, 265, 268, 273, 274, 277, 281, - 297, 298, 299, 300, 322, 323, 327, 328, 331, 332, - 336, 337, 338, 342, 343, 351, 170, 359, 368, 370, - 371, 372, 373, 383, 386, 387, 426, 427, 441, 442, - 874, 180, 0, 186, 0, 187, 0, 861, 185, 976, - 1000, 921, 935, 848, 988, 0, 0, 413, 748, 992, - 835, 858, 1001, 864, 866, 929, 811, 906, 330, 855, - 812, 0, 0, 0, 0, 803, 1048, 804, 836, 238, - 1046, 962, 907, 990, 892, 922, 932, 237, 224, 899, - 898, 979, 847, 846, 927, 975, 989, 0, 0, 159, - 757, 177, 756, 289, 0, 0, 439, 392, 311, 0, - 0, 890, 0, 741, 742, 875, 931, 823, 918, 994, - 856, 923, 995, 93, 0, 0, 0, 0, 515, 680, - 679, 682, 683, 684, 685, 0, 0, 158, 681, 686, - 687, 688, 0, 885, 928, 1006, 802, 1065, 671, 807, - 755, 0, 980, 843, 844, 242, 0, 0, 0, 0, - 0, 0, 0, 888, 905, 947, 872, 0, 433, 934, - 943, 957, 865, 348, 261, 0, 0, 0, 0, 668, - 669, 0, 0, 0, 0, 773, 0, 670, 0, 817, - 666, 699, 700, 701, 702, 703, 704, 705, 706, 707, - 708, 709, 710, 711, 712, 713, 714, 715, 716, 717, - 718, 719, 720, 721, 722, 723, 724, 725, 726, 727, - 728, 729, 730, 731, 732, 733, 734, 735, 736, 737, - 738, 739, 740, 672, 0, 0, 0, 822, 800, 841, - 949, 801, 799, 312, 814, 744, 978, 873, 278, 178, - 984, 871, 771, 937, 818, 966, 859, 286, 816, 179, - 813, 819, 857, 325, 946, 952, 753, 182, 288, 963, - 837, 850, 225, 0, 362, 924, 432, 660, 256, 910, - 361, 290, 425, 938, 986, 431, 860, 407, 440, 444, - 250, 893, 215, 389, 240, 234, 842, 956, 806, 262, - 347, 229, 282, 876, 930, 838, 221, 941, 917, 968, - 388, 422, 184, 306, 423, 443, 153, 251, 380, 252, - 406, 243, 216, 350, 203, 414, 307, 317, 218, 220, - 219, 197, 381, 421, 209, 223, 964, 951, 970, 833, - 820, 825, 821, 849, 987, 271, 263, 971, 969, 851, - 334, 206, 903, 896, 889, 758, 435, 1002, 236, 953, - 437, 166, 375, 374, 863, 270, 954, 167, 157, 357, - 168, 279, 188, 974, 447, 202, 284, 415, 659, 255, - 324, 926, 335, 181, 352, 302, 304, 301, 305, 260, - 162, 169, 950, 354, 377, 420, 204, 395, 160, 163, - 171, 367, 172, 173, 993, 296, 245, 249, 264, 275, - 925, 360, 396, 438, 919, 199, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 364, 397, 411, 369, 258, - 399, 403, 400, 401, 398, 402, 365, 366, 191, 405, - 430, 210, 376, 379, 446, 948, 198, 193, 982, 965, - 912, 878, 884, 808, 0, 192, 879, 880, 881, 882, - 883, 944, 840, 852, 832, 920, 831, 259, 936, 428, - 429, 226, 747, 997, 194, 815, 996, 321, 329, 320, - 999, 998, 424, 983, 913, 902, 900, 809, 981, 911, - 901, 285, 248, 266, 345, 292, 346, 267, 315, 314, - 316, 294, 904, 394, 295, 0, 189, 0, 393, 991, - 1008, 404, 207, 826, 958, 419, 165, 353, 208, 257, - 246, 344, 319, 200, 269, 391, 283, 291, 940, 1005, - 333, 363, 214, 434, 390, 241, 759, 326, 772, 765, - 767, 766, 763, 764, 762, 761, 760, 774, 745, 746, - 749, 750, 751, 895, 985, 810, 754, 961, 768, 769, - 770, 933, 1003, 743, 222, 692, 786, 787, 788, 693, - 789, 790, 694, 695, 791, 792, 793, 794, 696, 795, - 796, 797, 775, 776, 777, 778, 779, 780, 781, 782, - 785, 783, 784, 0, 891, 341, 190, 201, 418, 213, - 233, 231, 247, 280, 303, 309, 339, 378, 384, 385, - 408, 409, 410, 412, 235, 0, 239, 212, 358, 211, - 293, 272, 340, 416, 417, 349, 228, 752, 183, 195, - 287, 1004, 356, 254, 308, 382, 310, 276, 227, 445, - 313, 355, 448, 959, 916, 0, 868, 870, 869, 828, - 830, 829, 827, 1007, 318, 977, 798, 805, 824, 834, - 839, 845, 853, 854, 862, 867, 877, 886, 887, 897, - 908, 909, 915, 939, 942, 955, 960, 967, 972, 973, - 436, 232, 894, 914, 945, 196, 205, 217, 230, 244, - 253, 265, 268, 273, 274, 277, 281, 297, 298, 299, - 300, 322, 323, 327, 328, 331, 332, 336, 337, 338, - 342, 343, 351, 170, 359, 368, 370, 371, 372, 373, - 383, 386, 387, 426, 427, 441, 442, 874, 180, 0, - 186, 0, 187, 0, 861, 185, 976, 1000, 921, 935, - 848, 988, 0, 0, 413, 748, 992, 835, 858, 1001, - 864, 866, 929, 811, 906, 330, 855, 812, 0, 0, - 0, 0, 803, 1048, 804, 836, 238, 1046, 962, 907, - 990, 892, 922, 932, 237, 224, 899, 898, 979, 847, - 846, 927, 975, 989, 0, 0, 159, 757, 177, 756, - 289, 0, 0, 439, 392, 311, 0, 0, 890, 0, - 741, 742, 875, 931, 823, 918, 994, 856, 923, 995, - 93, 0, 0, 0, 0, 515, 680, 679, 682, 683, - 684, 685, 0, 0, 158, 681, 686, 687, 688, 0, - 885, 928, 1006, 802, 1065, 671, 807, 755, 0, 980, - 843, 844, 242, 0, 0, 0, 0, 0, 0, 0, - 888, 905, 947, 872, 0, 433, 934, 943, 957, 865, - 348, 261, 0, 0, 0, 0, 668, 669, 0, 0, - 0, 0, 773, 0, 670, 0, 817, 666, 699, 700, - 701, 702, 703, 704, 705, 706, 707, 708, 709, 710, - 711, 712, 713, 714, 715, 716, 717, 718, 719, 720, - 721, 722, 723, 724, 725, 726, 727, 728, 729, 730, - 731, 732, 733, 734, 735, 736, 737, 738, 739, 740, - 672, 0, 0, 0, 822, 800, 841, 949, 801, 799, - 312, 814, 744, 978, 873, 278, 178, 984, 871, 771, - 937, 818, 966, 859, 286, 816, 179, 813, 819, 857, - 325, 946, 952, 753, 182, 288, 963, 837, 850, 225, - 0, 362, 924, 432, 660, 256, 4236, 361, 290, 425, - 938, 986, 431, 860, 407, 440, 444, 250, 893, 215, - 389, 240, 234, 842, 956, 806, 262, 347, 229, 282, - 876, 930, 838, 221, 941, 917, 968, 388, 422, 184, - 306, 423, 443, 153, 251, 380, 252, 406, 243, 216, - 350, 203, 414, 307, 317, 218, 220, 219, 197, 381, - 421, 209, 223, 964, 951, 970, 833, 820, 825, 821, - 849, 987, 271, 263, 971, 969, 851, 334, 206, 903, - 896, 889, 758, 435, 1002, 236, 953, 437, 166, 375, - 374, 863, 270, 954, 167, 157, 357, 168, 279, 188, - 974, 447, 202, 284, 415, 659, 255, 324, 926, 335, - 181, 352, 302, 304, 301, 305, 260, 162, 169, 950, - 354, 377, 420, 204, 395, 160, 163, 171, 367, 172, - 173, 993, 296, 245, 249, 264, 275, 925, 360, 396, - 438, 919, 199, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 364, 397, 411, 369, 258, 399, 403, 400, - 401, 398, 402, 365, 366, 191, 405, 430, 210, 376, - 379, 446, 948, 198, 193, 982, 965, 912, 878, 884, - 808, 0, 192, 879, 880, 881, 882, 883, 944, 840, - 852, 832, 920, 831, 259, 936, 428, 429, 226, 747, - 997, 194, 815, 996, 321, 329, 320, 999, 998, 424, - 983, 913, 902, 900, 809, 981, 911, 901, 285, 248, - 266, 345, 292, 346, 267, 315, 314, 316, 294, 904, - 394, 295, 0, 189, 0, 393, 991, 1008, 404, 207, - 826, 958, 419, 165, 353, 208, 257, 246, 344, 319, - 200, 269, 391, 283, 291, 940, 1005, 333, 363, 214, - 434, 390, 241, 759, 326, 772, 765, 767, 766, 763, - 764, 762, 761, 760, 774, 745, 746, 749, 750, 751, - 895, 985, 810, 754, 961, 768, 769, 770, 933, 1003, - 743, 222, 692, 786, 787, 788, 693, 789, 790, 694, - 695, 791, 792, 793, 794, 696, 795, 796, 797, 775, - 776, 777, 778, 779, 780, 781, 782, 785, 783, 784, - 0, 891, 341, 190, 201, 418, 213, 233, 231, 247, - 280, 303, 309, 339, 378, 384, 385, 408, 409, 410, - 412, 235, 0, 239, 212, 358, 211, 293, 272, 340, - 416, 417, 349, 228, 752, 183, 195, 287, 1004, 356, - 254, 308, 382, 310, 276, 227, 445, 313, 355, 448, - 959, 916, 0, 868, 870, 869, 828, 830, 829, 827, - 1007, 318, 977, 798, 805, 824, 834, 839, 845, 853, - 854, 862, 867, 877, 886, 887, 897, 908, 909, 915, - 939, 942, 955, 960, 967, 972, 973, 436, 232, 894, - 914, 945, 196, 205, 217, 230, 244, 253, 265, 268, - 273, 274, 277, 281, 297, 298, 299, 300, 322, 323, - 327, 328, 331, 332, 336, 337, 338, 342, 343, 351, - 170, 359, 368, 370, 371, 372, 373, 383, 386, 387, - 426, 427, 441, 442, 874, 180, 0, 186, 0, 187, - 0, 861, 185, 976, 1000, 921, 935, 848, 988, 0, - 0, 413, 748, 992, 835, 858, 1001, 864, 866, 929, - 811, 906, 330, 855, 812, 0, 0, 0, 0, 803, - 1048, 804, 836, 238, 1046, 962, 907, 990, 892, 922, - 932, 237, 224, 899, 898, 979, 847, 846, 927, 975, - 989, 0, 0, 159, 757, 177, 756, 289, 0, 0, - 439, 392, 311, 0, 0, 890, 0, 741, 742, 875, - 931, 823, 918, 994, 856, 923, 995, 93, 0, 0, - 0, 0, 515, 680, 679, 682, 683, 684, 685, 0, - 0, 158, 681, 686, 687, 688, 0, 885, 928, 1006, - 802, 1065, 671, 807, 755, 0, 980, 843, 844, 242, - 0, 0, 0, 0, 0, 0, 0, 888, 905, 947, - 872, 0, 433, 934, 943, 957, 865, 348, 261, 0, - 0, 0, 0, 668, 669, 0, 0, 0, 0, 773, - 0, 670, 0, 817, 666, 699, 700, 701, 702, 703, - 704, 705, 706, 707, 708, 709, 710, 711, 712, 713, - 714, 715, 716, 717, 718, 719, 720, 721, 722, 723, - 724, 725, 726, 727, 728, 729, 730, 731, 732, 733, - 734, 735, 736, 737, 738, 739, 740, 672, 0, 0, - 0, 822, 800, 841, 949, 801, 799, 312, 814, 744, - 978, 873, 278, 178, 984, 871, 771, 937, 818, 966, - 859, 286, 816, 179, 813, 819, 857, 325, 946, 952, - 753, 182, 288, 963, 837, 850, 225, 0, 362, 924, - 432, 660, 256, 910, 361, 290, 425, 938, 986, 431, - 860, 407, 440, 444, 250, 893, 215, 389, 240, 234, - 842, 956, 806, 262, 347, 229, 282, 876, 930, 838, - 221, 941, 917, 968, 388, 422, 184, 306, 423, 443, - 153, 251, 380, 252, 406, 243, 216, 350, 203, 414, - 307, 317, 218, 220, 219, 197, 381, 421, 209, 223, - 964, 951, 970, 833, 820, 825, 821, 849, 987, 271, - 263, 971, 969, 851, 334, 206, 903, 896, 889, 758, - 435, 1002, 236, 953, 437, 166, 375, 374, 863, 270, - 954, 167, 157, 357, 168, 279, 188, 974, 447, 202, - 284, 415, 659, 255, 324, 926, 335, 181, 352, 302, - 304, 301, 305, 260, 162, 169, 950, 354, 377, 420, - 204, 395, 160, 163, 171, 367, 172, 173, 993, 296, - 245, 249, 264, 275, 925, 360, 396, 438, 919, 199, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 364, - 397, 411, 369, 258, 399, 403, 400, 401, 398, 402, - 365, 366, 191, 405, 430, 210, 376, 379, 446, 948, - 198, 193, 982, 965, 912, 878, 884, 808, 0, 192, - 879, 880, 881, 882, 883, 944, 840, 852, 832, 920, - 831, 259, 936, 428, 429, 226, 747, 997, 194, 815, - 996, 321, 329, 320, 999, 998, 424, 983, 913, 902, - 900, 809, 981, 911, 901, 285, 248, 266, 345, 292, - 346, 267, 315, 314, 316, 294, 904, 394, 295, 0, - 189, 0, 393, 991, 1008, 404, 207, 826, 958, 419, - 165, 353, 208, 257, 246, 344, 319, 200, 269, 391, - 283, 291, 940, 1005, 333, 363, 214, 434, 390, 241, - 759, 326, 772, 765, 767, 766, 763, 764, 762, 761, - 760, 774, 745, 746, 749, 750, 751, 2257, 2258, 2259, - 754, 961, 768, 769, 770, 933, 1003, 743, 222, 692, - 786, 787, 788, 693, 789, 790, 694, 695, 791, 792, - 793, 794, 696, 795, 796, 797, 775, 776, 777, 778, - 779, 780, 781, 782, 785, 783, 784, 0, 891, 341, - 190, 201, 418, 213, 233, 231, 247, 280, 303, 309, - 339, 378, 384, 385, 408, 409, 410, 412, 235, 0, - 239, 212, 358, 211, 293, 272, 340, 416, 417, 349, - 228, 752, 183, 195, 287, 1004, 356, 254, 308, 382, - 310, 276, 227, 445, 313, 355, 448, 959, 916, 0, - 868, 870, 869, 828, 830, 829, 827, 1007, 318, 977, - 798, 805, 824, 834, 839, 845, 853, 854, 862, 867, - 877, 886, 887, 897, 908, 909, 915, 939, 942, 955, - 960, 967, 972, 973, 436, 232, 894, 914, 945, 196, - 205, 217, 230, 244, 253, 265, 268, 273, 274, 277, - 281, 297, 298, 299, 300, 322, 323, 327, 328, 331, - 332, 336, 337, 338, 342, 343, 351, 170, 359, 368, - 370, 371, 372, 373, 383, 386, 387, 426, 427, 441, - 442, 874, 180, 0, 186, 0, 187, 0, 861, 185, - 976, 1000, 921, 935, 1755, 1934, 0, 3348, 413, 1789, - 1938, 1738, 1768, 1955, 1774, 1777, 1858, 1704, 1827, 330, - 1765, 1705, 0, 0, 0, 1743, 1692, 1756, 1693, 1740, - 238, 1736, 1899, 1830, 1936, 1809, 1851, 1861, 237, 224, - 1819, 1818, 1924, 1754, 1753, 1856, 1913, 1935, 1808, 0, - 159, 176, 177, 1945, 289, 1910, 458, 439, 392, 311, - 461, 460, 1804, 1919, 1825, 1888, 1787, 1860, 1720, 1843, - 1940, 1766, 1852, 1941, 93, 0, 1380, 0, 0, 1103, - 0, 0, 0, 0, 0, 0, 0, 0, 158, 0, - 1848, 1932, 1759, 459, 1799, 1857, 1960, 1691, 1844, 0, - 1696, 1707, 1954, 1925, 1750, 1751, 242, 0, 0, 0, - 0, 0, 0, 0, 1802, 1826, 1878, 1784, 0, 433, - 1863, 1873, 1891, 1776, 348, 261, 0, 0, 0, 0, - 0, 0, 0, 0, 1745, 0, 1841, 0, 0, 0, - 1712, 1698, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1798, 0, 0, 0, 1719, 1689, - 1747, 1880, 1690, 1688, 312, 1708, 1893, 3350, 1785, 278, - 178, 1929, 1783, 1782, 1867, 1713, 1903, 1769, 286, 1711, - 179, 1706, 1714, 1767, 325, 1877, 1885, 164, 182, 288, - 1900, 1741, 1758, 225, 2091, 362, 1853, 432, 457, 256, - 1834, 361, 290, 425, 1868, 1931, 431, 1770, 407, 440, - 444, 250, 1810, 215, 389, 240, 234, 1749, 1890, 1695, - 262, 347, 229, 282, 1788, 1859, 1742, 221, 1871, 1842, - 1905, 388, 422, 184, 306, 423, 443, 153, 251, 380, - 252, 406, 243, 216, 350, 203, 414, 307, 317, 218, - 220, 219, 197, 381, 421, 209, 223, 1901, 1884, 1907, - 1735, 1715, 1726, 1716, 1757, 1933, 271, 263, 1908, 1906, - 1760, 334, 206, 1823, 1816, 1803, 1881, 435, 1956, 236, - 1886, 437, 166, 375, 374, 1773, 270, 1887, 167, 157, - 357, 168, 279, 188, 1912, 447, 202, 284, 415, 456, - 255, 324, 1855, 335, 181, 352, 302, 304, 301, 305, - 260, 162, 169, 1883, 354, 377, 420, 204, 395, 160, - 163, 171, 367, 172, 173, 1939, 296, 245, 249, 264, - 275, 1854, 360, 396, 438, 1845, 199, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 364, 397, 411, 369, - 258, 399, 403, 400, 401, 398, 402, 365, 366, 191, - 405, 430, 210, 376, 379, 446, 1879, 198, 193, 1927, - 1902, 1836, 1791, 1797, 1697, 0, 192, 1792, 1793, 1794, - 1795, 1796, 1875, 1746, 1762, 1734, 1849, 1733, 259, 1866, - 428, 429, 226, 1709, 1947, 194, 1710, 1946, 321, 329, - 320, 1950, 1948, 424, 1928, 1837, 1822, 1820, 1702, 1926, - 1835, 1821, 285, 248, 266, 345, 292, 346, 267, 315, - 314, 316, 294, 1824, 394, 295, 0, 189, 0, 393, - 1937, 1962, 404, 207, 1728, 1894, 419, 165, 353, 208, - 257, 246, 344, 319, 200, 269, 391, 283, 291, 1870, - 1959, 333, 363, 214, 434, 390, 241, 1724, 326, 1727, - 1722, 1725, 1723, 1828, 1829, 1942, 1943, 1944, 1882, 1717, - 0, 1920, 1921, 0, 1815, 1930, 1703, 0, 1898, 174, - 175, 161, 1862, 1957, 1775, 222, 151, 1699, 1700, 1701, - 152, 1805, 1806, 154, 155, 1916, 1915, 1914, 1917, 156, - 1951, 1949, 1952, 1718, 1739, 1761, 1811, 1812, 1814, 1846, - 1847, 1892, 1865, 1874, 1748, 1807, 341, 190, 201, 418, - 213, 233, 231, 247, 280, 303, 309, 339, 378, 384, - 385, 408, 409, 410, 412, 235, 0, 239, 212, 358, - 211, 293, 272, 340, 416, 417, 349, 228, 1833, 183, - 195, 287, 3349, 356, 254, 308, 382, 310, 276, 227, - 445, 313, 355, 448, 1895, 1840, 0, 1779, 1781, 1780, - 1730, 1732, 1731, 1729, 1961, 318, 1922, 1687, 1694, 1721, - 1737, 1744, 1752, 1763, 1764, 1772, 1778, 1790, 1800, 1801, - 1817, 1831, 1832, 1839, 1869, 1872, 1889, 1897, 1904, 1909, - 1911, 436, 232, 1813, 1838, 1876, 196, 205, 217, 230, - 244, 253, 265, 268, 273, 274, 277, 281, 297, 298, - 299, 300, 322, 323, 327, 328, 331, 332, 336, 337, - 338, 342, 343, 351, 170, 359, 368, 370, 371, 372, - 373, 383, 386, 387, 426, 427, 441, 442, 1786, 180, - 0, 186, 0, 187, 0, 1771, 185, 1918, 1953, 1850, - 1864, 1755, 1934, 0, 1896, 413, 1789, 1938, 1738, 1768, - 1955, 1774, 1777, 1858, 1704, 1827, 330, 1765, 1705, 0, - 0, 0, 1743, 1692, 1756, 1693, 1740, 238, 1736, 1899, - 1830, 1936, 1809, 1851, 1861, 237, 224, 1819, 1818, 1924, - 1754, 1753, 1856, 1913, 1935, 1808, 0, 159, 176, 177, - 1945, 289, 1910, 458, 439, 392, 311, 461, 460, 1804, - 1919, 1825, 1888, 1787, 1860, 1720, 1843, 1940, 1766, 1852, - 1941, 0, 0, 0, 0, 0, 1103, 0, 0, 0, - 0, 0, 0, 0, 0, 158, 0, 1848, 1932, 1759, - 459, 1799, 1857, 1960, 1691, 1844, 0, 1696, 1707, 1954, - 1925, 1750, 1751, 242, 0, 0, 0, 0, 0, 0, - 0, 1802, 1826, 1878, 1784, 0, 433, 1863, 1873, 1891, - 1776, 348, 261, 0, 0, 0, 0, 0, 0, 0, - 0, 1745, 0, 1841, 0, 0, 0, 1712, 1698, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1798, 0, 0, 0, 1719, 1689, 1747, 1880, 1690, - 1688, 312, 1708, 1893, 1923, 1785, 278, 178, 1929, 1783, - 1782, 1867, 1713, 1903, 1769, 286, 1711, 179, 1706, 1714, - 1767, 325, 1877, 1885, 164, 182, 288, 1900, 1741, 1758, - 225, 2091, 362, 1853, 432, 457, 256, 1834, 361, 290, - 425, 1868, 1931, 431, 1770, 407, 440, 444, 250, 1810, - 215, 389, 240, 234, 1749, 1890, 1695, 262, 347, 229, - 282, 1788, 1859, 1742, 221, 1871, 1842, 1905, 388, 422, - 184, 306, 423, 443, 153, 251, 380, 252, 406, 243, - 216, 350, 203, 414, 307, 317, 218, 220, 219, 197, - 381, 421, 209, 223, 1901, 1884, 1907, 1735, 1715, 1726, - 1716, 1757, 1933, 271, 263, 1908, 1906, 1760, 334, 206, - 1823, 1816, 1803, 1881, 435, 1956, 236, 1886, 437, 166, - 375, 374, 1773, 270, 1887, 167, 157, 357, 168, 279, - 188, 1912, 447, 202, 284, 415, 456, 255, 324, 1855, - 335, 181, 352, 302, 304, 301, 305, 260, 162, 169, - 1883, 354, 377, 420, 204, 395, 160, 163, 171, 367, - 172, 173, 1939, 296, 245, 249, 264, 275, 1854, 360, - 396, 438, 1845, 199, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 364, 397, 411, 369, 258, 399, 403, - 400, 401, 398, 402, 365, 366, 191, 405, 430, 210, - 376, 379, 446, 1879, 198, 193, 1927, 1902, 1836, 1791, - 1797, 1697, 0, 192, 1792, 1793, 1794, 1795, 1796, 1875, - 1746, 1762, 1734, 1849, 1733, 259, 1866, 428, 429, 226, - 1709, 1947, 194, 1710, 1946, 321, 329, 320, 1950, 1948, - 424, 1928, 1837, 1822, 1820, 1702, 1926, 1835, 1821, 285, - 248, 266, 345, 292, 346, 267, 315, 314, 316, 294, - 1824, 394, 295, 0, 189, 0, 393, 1937, 1962, 404, - 207, 1728, 1894, 419, 165, 353, 208, 257, 246, 344, - 319, 200, 269, 391, 283, 291, 1870, 1959, 333, 363, - 214, 434, 390, 241, 1724, 326, 1727, 1722, 1725, 1723, - 1828, 1829, 1942, 1943, 1944, 1882, 1717, 0, 1920, 1921, - 0, 1815, 1930, 1703, 0, 1898, 174, 175, 161, 1862, - 1957, 1775, 222, 151, 1699, 1700, 1701, 152, 1805, 1806, - 154, 155, 1916, 1915, 1914, 1917, 156, 1951, 1949, 1952, - 1718, 1739, 1761, 1811, 1812, 1814, 1846, 1847, 1892, 1865, - 1874, 1748, 1807, 341, 190, 201, 418, 213, 233, 231, - 247, 280, 303, 309, 339, 378, 384, 385, 408, 409, - 410, 412, 235, 0, 239, 212, 358, 211, 293, 272, - 340, 416, 417, 349, 228, 1833, 183, 195, 287, 1958, - 356, 254, 308, 382, 310, 276, 227, 445, 313, 355, - 448, 1895, 1840, 0, 1779, 1781, 1780, 1730, 1732, 1731, - 1729, 1961, 318, 1922, 1687, 1694, 1721, 1737, 1744, 1752, - 1763, 1764, 1772, 1778, 1790, 1800, 1801, 1817, 1831, 1832, - 1839, 1869, 1872, 1889, 1897, 1904, 1909, 1911, 436, 232, - 1813, 1838, 1876, 196, 205, 217, 230, 244, 253, 265, - 268, 273, 274, 277, 281, 297, 298, 299, 300, 322, - 323, 327, 328, 331, 332, 336, 337, 338, 342, 343, - 351, 170, 359, 368, 370, 371, 372, 373, 383, 386, - 387, 426, 427, 441, 442, 1786, 180, 0, 186, 0, - 187, 0, 1771, 185, 1918, 1953, 1850, 1864, 1755, 1934, - 0, 1896, 413, 1789, 1938, 1738, 1768, 1955, 1774, 1777, - 1858, 1704, 1827, 330, 1765, 1705, 0, 0, 0, 1743, - 1692, 1756, 1693, 1740, 238, 1736, 1899, 1830, 1936, 1809, - 1851, 1861, 237, 224, 1819, 1818, 1924, 1754, 1753, 1856, - 1913, 1935, 1808, 0, 159, 176, 177, 1945, 289, 1910, - 0, 439, 392, 311, 0, 0, 1804, 1919, 1825, 1888, - 1787, 1860, 1720, 1843, 1940, 1766, 1852, 1941, 0, 0, - 0, 0, 0, 515, 0, 0, 0, 0, 0, 0, - 0, 0, 158, 0, 1848, 1932, 1759, 0, 1799, 1857, - 1960, 1691, 1844, 0, 1696, 1707, 1954, 1925, 1750, 1751, - 242, 0, 0, 0, 0, 0, 0, 0, 1802, 1826, - 1878, 1784, 0, 433, 1863, 1873, 1891, 1776, 348, 261, - 0, 0, 0, 0, 0, 0, 2960, 0, 1745, 0, - 1841, 0, 0, 0, 1712, 1698, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1798, 0, - 0, 0, 1719, 1689, 1747, 1880, 1690, 1688, 312, 1708, - 1893, 1923, 1785, 278, 178, 1929, 1783, 1782, 1867, 1713, - 1903, 1769, 286, 1711, 179, 1706, 1714, 1767, 325, 1877, - 1885, 164, 182, 288, 1900, 1741, 1758, 225, 0, 362, - 1853, 432, 2188, 256, 1834, 361, 290, 425, 1868, 1931, - 431, 1770, 407, 440, 444, 250, 1810, 215, 389, 240, - 234, 1749, 1890, 1695, 262, 347, 229, 282, 1788, 1859, - 1742, 221, 1871, 1842, 1905, 388, 422, 184, 306, 423, - 443, 153, 251, 380, 252, 406, 243, 216, 350, 203, - 414, 307, 317, 218, 220, 219, 197, 381, 421, 209, - 223, 1901, 1884, 1907, 1735, 1715, 1726, 1716, 1757, 1933, - 271, 263, 1908, 1906, 1760, 334, 206, 1823, 1816, 1803, - 1881, 435, 1956, 236, 1886, 437, 166, 375, 374, 1773, - 270, 1887, 167, 157, 357, 168, 279, 188, 1912, 447, - 202, 284, 415, 2187, 255, 324, 1855, 335, 181, 352, - 302, 304, 301, 305, 260, 162, 169, 1883, 354, 377, - 420, 204, 395, 160, 163, 171, 367, 172, 173, 1939, - 296, 245, 249, 264, 275, 1854, 360, 396, 438, 1845, - 199, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 364, 397, 411, 369, 258, 399, 403, 400, 401, 398, - 402, 365, 366, 191, 405, 430, 210, 376, 379, 446, - 1879, 198, 193, 1927, 1902, 1836, 1791, 1797, 1697, 0, - 192, 1792, 1793, 1794, 1795, 1796, 1875, 1746, 1762, 1734, - 1849, 1733, 259, 1866, 428, 429, 226, 1709, 1947, 194, - 1710, 1946, 321, 329, 320, 1950, 1948, 424, 1928, 1837, - 1822, 1820, 1702, 1926, 1835, 1821, 285, 248, 266, 345, - 292, 346, 267, 315, 314, 316, 294, 1824, 394, 295, - 0, 189, 0, 393, 1937, 1962, 404, 207, 1728, 1894, - 419, 165, 353, 208, 257, 246, 344, 319, 200, 269, - 391, 283, 291, 1870, 1959, 333, 363, 214, 434, 390, - 241, 1724, 326, 1727, 1722, 1725, 1723, 1828, 1829, 1942, - 1943, 1944, 1882, 1717, 0, 1920, 1921, 0, 1815, 1930, - 1703, 0, 1898, 174, 175, 161, 1862, 1957, 1775, 222, - 151, 1699, 1700, 1701, 152, 1805, 1806, 154, 155, 1916, - 1915, 1914, 1917, 156, 1951, 1949, 1952, 1718, 1739, 1761, - 1811, 1812, 1814, 1846, 1847, 1892, 1865, 1874, 1748, 1807, - 341, 190, 201, 418, 213, 233, 231, 247, 280, 303, - 309, 339, 378, 384, 385, 408, 409, 410, 412, 235, - 0, 239, 212, 358, 211, 293, 272, 340, 416, 417, - 349, 228, 1833, 183, 195, 287, 1958, 356, 254, 308, - 382, 310, 276, 227, 445, 313, 355, 448, 1895, 1840, - 0, 1779, 1781, 1780, 1730, 1732, 1731, 1729, 1961, 318, - 1922, 1687, 1694, 1721, 1737, 1744, 1752, 1763, 1764, 1772, - 1778, 1790, 1800, 1801, 1817, 1831, 1832, 1839, 1869, 1872, - 1889, 1897, 1904, 1909, 1911, 436, 232, 1813, 1838, 1876, - 196, 205, 217, 230, 244, 253, 265, 268, 273, 274, - 277, 281, 297, 298, 299, 300, 322, 323, 327, 328, - 331, 332, 336, 337, 338, 342, 343, 351, 170, 359, - 368, 370, 371, 372, 373, 383, 386, 387, 426, 427, - 441, 442, 1786, 180, 0, 186, 0, 187, 0, 1771, - 185, 1918, 1953, 1850, 1864, 1755, 1934, 0, 1896, 413, - 1789, 1938, 1738, 1768, 1955, 1774, 1777, 1858, 1704, 1827, - 330, 1765, 1705, 0, 0, 0, 1743, 1692, 1756, 1693, - 1740, 238, 1736, 1899, 1830, 1936, 1809, 1851, 1861, 237, - 224, 1819, 1818, 1924, 1754, 1753, 1856, 1913, 1935, 1808, - 0, 159, 176, 177, 1945, 289, 1910, 0, 439, 392, - 311, 0, 0, 1804, 1919, 1825, 1888, 1787, 1860, 1720, - 1843, 1940, 1766, 1852, 1941, 0, 0, 0, 0, 0, - 515, 0, 0, 0, 0, 0, 0, 0, 0, 158, - 0, 1848, 1932, 1759, 0, 1799, 1857, 1960, 1691, 1844, - 0, 1696, 1707, 1954, 1925, 1750, 1751, 242, 0, 0, - 0, 0, 0, 0, 0, 1802, 1826, 1878, 1784, 0, - 433, 1863, 1873, 1891, 1776, 348, 261, 0, 0, 0, - 0, 0, 0, 2182, 0, 1745, 0, 1841, 0, 0, - 0, 1712, 1698, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1798, 0, 0, 0, 1719, - 1689, 1747, 1880, 1690, 1688, 312, 1708, 1893, 1923, 1785, - 278, 178, 1929, 1783, 1782, 1867, 1713, 1903, 1769, 286, - 1711, 179, 1706, 1714, 1767, 325, 1877, 1885, 164, 182, - 288, 1900, 1741, 1758, 225, 0, 362, 1853, 432, 2188, - 256, 1834, 361, 290, 425, 1868, 1931, 431, 1770, 407, - 440, 444, 250, 1810, 215, 389, 240, 234, 1749, 1890, - 1695, 262, 347, 229, 282, 1788, 1859, 1742, 221, 1871, - 1842, 1905, 388, 422, 184, 306, 423, 443, 153, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 1901, 1884, - 1907, 1735, 1715, 1726, 1716, 1757, 1933, 271, 263, 1908, - 1906, 1760, 334, 206, 1823, 1816, 1803, 1881, 435, 1956, - 236, 1886, 437, 166, 375, 374, 1773, 270, 1887, 167, - 157, 357, 168, 279, 188, 1912, 447, 202, 284, 415, - 2187, 255, 324, 1855, 335, 181, 352, 302, 304, 301, - 305, 260, 162, 169, 1883, 354, 377, 420, 204, 395, - 160, 163, 171, 367, 172, 173, 1939, 296, 245, 249, - 264, 275, 1854, 360, 396, 438, 1845, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 1879, 198, 193, - 1927, 1902, 1836, 1791, 1797, 1697, 0, 192, 1792, 1793, - 1794, 1795, 1796, 1875, 1746, 1762, 1734, 1849, 1733, 259, - 1866, 428, 429, 226, 1709, 1947, 194, 1710, 1946, 321, - 329, 320, 1950, 1948, 424, 1928, 1837, 1822, 1820, 1702, - 1926, 1835, 1821, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 1824, 394, 295, 0, 189, 0, - 393, 1937, 1962, 404, 207, 1728, 1894, 419, 165, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 1870, 1959, 333, 363, 214, 434, 390, 241, 1724, 326, - 1727, 1722, 1725, 1723, 1828, 1829, 1942, 1943, 1944, 1882, - 1717, 0, 1920, 1921, 0, 1815, 1930, 1703, 0, 1898, - 174, 175, 161, 1862, 1957, 1775, 222, 151, 1699, 1700, - 1701, 152, 1805, 1806, 154, 155, 1916, 1915, 1914, 1917, - 156, 1951, 1949, 1952, 1718, 1739, 1761, 1811, 1812, 1814, - 1846, 1847, 1892, 1865, 1874, 1748, 1807, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 1833, - 183, 195, 287, 1958, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 1895, 1840, 0, 1779, 1781, - 1780, 1730, 1732, 1731, 1729, 1961, 318, 1922, 1687, 1694, - 1721, 1737, 1744, 1752, 1763, 1764, 1772, 1778, 1790, 1800, - 1801, 1817, 1831, 1832, 1839, 1869, 1872, 1889, 1897, 1904, - 1909, 1911, 436, 232, 1813, 1838, 1876, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 170, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 1786, - 180, 0, 186, 0, 187, 0, 1771, 185, 1918, 1953, - 1850, 1864, 1755, 1934, 0, 1896, 413, 1789, 1938, 1738, - 1768, 1955, 1774, 1777, 1858, 1704, 1827, 330, 1765, 1705, - 0, 0, 0, 1743, 1692, 1756, 1693, 1740, 238, 1736, - 1899, 1830, 1936, 1809, 1851, 1861, 237, 224, 1819, 1818, - 1924, 1754, 1753, 1856, 1913, 1935, 1808, 0, 159, 176, - 177, 1945, 289, 1910, 0, 439, 392, 311, 0, 0, - 1804, 1919, 1825, 1888, 1787, 1860, 1720, 1843, 1940, 1766, - 1852, 1941, 0, 0, 0, 0, 0, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 1848, 1932, - 1759, 0, 1799, 1857, 1960, 1691, 1844, 0, 1696, 1707, - 1954, 1925, 1750, 1751, 242, 0, 0, 0, 0, 0, - 0, 0, 1802, 1826, 1878, 1784, 0, 433, 1863, 1873, - 1891, 1776, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 1745, 0, 1841, 0, 0, 0, 1712, 1698, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1798, 0, 0, 0, 1719, 1689, 1747, 1880, - 1690, 1688, 312, 1708, 1893, 1923, 1785, 278, 178, 1929, - 1783, 1782, 1867, 1713, 1903, 1769, 286, 1711, 179, 1706, - 1714, 1767, 325, 1877, 1885, 164, 182, 288, 1900, 1741, - 1758, 225, 0, 362, 1853, 432, 2188, 256, 1834, 361, - 290, 425, 1868, 1931, 431, 1770, 407, 440, 444, 250, - 1810, 215, 389, 240, 234, 1749, 1890, 1695, 262, 347, - 229, 282, 1788, 1859, 1742, 221, 1871, 1842, 1905, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 1901, 1884, 1907, 1735, 1715, - 1726, 1716, 1757, 1933, 271, 263, 1908, 1906, 1760, 334, - 206, 1823, 1816, 1803, 1881, 435, 1956, 236, 1886, 437, - 166, 375, 374, 1773, 270, 1887, 167, 157, 357, 168, - 279, 188, 1912, 447, 202, 284, 415, 2187, 255, 324, - 1855, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 1883, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 1939, 296, 245, 249, 264, 275, 1854, - 360, 396, 438, 1845, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 1879, 198, 193, 1927, 1902, 1836, - 1791, 1797, 1697, 0, 192, 1792, 1793, 1794, 1795, 1796, - 1875, 1746, 1762, 1734, 1849, 1733, 259, 1866, 428, 429, - 226, 1709, 1947, 194, 1710, 1946, 321, 329, 320, 1950, - 1948, 424, 1928, 1837, 1822, 1820, 1702, 1926, 1835, 1821, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 1824, 394, 295, 0, 189, 0, 393, 1937, 1962, - 404, 207, 1728, 1894, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 1870, 1959, 333, - 363, 214, 434, 390, 241, 1724, 326, 1727, 1722, 1725, - 1723, 1828, 1829, 1942, 1943, 1944, 1882, 1717, 0, 1920, - 1921, 0, 1815, 1930, 1703, 0, 1898, 174, 175, 161, - 1862, 1957, 1775, 222, 151, 1699, 1700, 1701, 152, 1805, - 1806, 154, 155, 1916, 1915, 1914, 1917, 156, 1951, 1949, - 1952, 1718, 1739, 1761, 1811, 1812, 1814, 1846, 1847, 1892, - 1865, 1874, 1748, 1807, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 1833, 183, 195, 287, - 1958, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 1895, 1840, 0, 1779, 1781, 1780, 1730, 1732, - 1731, 1729, 1961, 318, 1922, 1687, 1694, 1721, 1737, 1744, - 1752, 1763, 1764, 1772, 1778, 1790, 1800, 1801, 1817, 1831, - 1832, 1839, 1869, 1872, 1889, 1897, 1904, 1909, 1911, 436, - 232, 1813, 1838, 1876, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 1786, 180, 0, 186, - 0, 187, 0, 1771, 185, 1918, 1953, 1850, 1864, 848, - 988, 0, 0, 413, 1053, 992, 835, 858, 1001, 864, - 866, 929, 811, 906, 330, 855, 812, 0, 0, 0, - 0, 803, 1048, 804, 836, 238, 1046, 962, 907, 990, - 892, 922, 932, 237, 224, 899, 898, 979, 847, 846, - 927, 975, 989, 0, 0, 159, 176, 177, 1086, 289, - 0, 458, 439, 392, 311, 461, 460, 890, 0, 1060, - 1073, 875, 931, 823, 918, 994, 856, 923, 995, 0, - 0, 0, 0, 0, 515, 0, 0, 0, 0, 0, - 0, 0, 0, 158, 0, 1068, 1082, 1049, 459, 885, - 928, 1006, 802, 1065, 0, 807, 1037, 0, 980, 843, - 844, 242, 0, 0, 0, 0, 0, 0, 0, 888, - 905, 947, 872, 0, 433, 934, 943, 957, 865, 348, - 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1064, 0, 0, 0, 817, 1033, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1054, - 0, 0, 0, 822, 800, 841, 949, 801, 799, 312, - 814, 1075, 978, 873, 278, 178, 984, 871, 1052, 937, - 818, 966, 859, 286, 816, 179, 813, 819, 857, 325, - 946, 952, 164, 182, 288, 963, 837, 850, 225, 3051, - 362, 924, 432, 2270, 256, 910, 361, 290, 425, 938, - 986, 431, 860, 407, 440, 444, 250, 893, 215, 389, - 240, 234, 842, 956, 806, 262, 347, 229, 282, 876, - 930, 838, 221, 941, 917, 968, 388, 422, 184, 306, - 423, 443, 153, 251, 380, 252, 406, 243, 216, 350, - 203, 414, 307, 317, 218, 220, 219, 197, 381, 421, - 209, 223, 964, 951, 970, 833, 820, 825, 821, 849, - 987, 271, 263, 971, 969, 851, 334, 206, 903, 896, - 889, 1071, 435, 1002, 236, 953, 437, 166, 375, 374, - 863, 270, 954, 167, 157, 357, 168, 279, 188, 974, - 447, 202, 284, 415, 2269, 255, 324, 926, 335, 181, - 352, 302, 304, 301, 305, 260, 162, 169, 950, 354, - 377, 420, 204, 395, 160, 163, 171, 367, 172, 173, - 993, 296, 245, 249, 264, 275, 925, 360, 396, 438, - 919, 199, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 364, 397, 411, 369, 258, 399, 403, 400, 401, - 398, 402, 365, 366, 191, 405, 430, 210, 376, 379, - 446, 948, 198, 193, 982, 965, 912, 878, 884, 808, - 0, 192, 879, 880, 881, 882, 883, 944, 840, 852, - 832, 920, 831, 259, 936, 428, 429, 226, 1038, 997, - 194, 815, 996, 321, 329, 320, 999, 998, 424, 983, - 913, 902, 900, 809, 981, 911, 901, 285, 248, 266, - 345, 292, 346, 267, 315, 314, 316, 294, 904, 394, - 295, 0, 189, 0, 393, 991, 1008, 404, 207, 826, - 958, 419, 165, 353, 208, 257, 246, 344, 319, 200, - 269, 391, 283, 291, 940, 1005, 333, 363, 214, 434, - 390, 241, 1043, 326, 1045, 1041, 1044, 1042, 1061, 1062, - 1083, 1084, 1085, 1072, 1039, 0, 1080, 1081, 0, 895, - 985, 810, 0, 961, 174, 175, 161, 933, 1003, 1051, - 222, 151, 1034, 1035, 1036, 152, 1055, 1056, 154, 155, - 1078, 1077, 1076, 1079, 156, 1088, 1087, 1089, 1040, 1047, - 1050, 1057, 1058, 1059, 1066, 1067, 1074, 1069, 1070, 0, - 891, 341, 190, 201, 418, 213, 233, 231, 247, 280, - 303, 309, 339, 378, 384, 385, 408, 409, 410, 412, - 235, 0, 239, 212, 358, 211, 293, 272, 340, 416, - 417, 349, 228, 1063, 183, 195, 287, 1004, 356, 254, - 308, 382, 310, 276, 227, 445, 313, 355, 448, 959, - 916, 0, 868, 870, 869, 828, 830, 829, 827, 1007, - 318, 977, 798, 805, 824, 834, 839, 845, 853, 854, - 862, 867, 877, 886, 887, 897, 908, 909, 915, 939, - 942, 955, 960, 967, 972, 973, 436, 232, 894, 914, - 945, 196, 205, 217, 230, 244, 253, 265, 268, 273, - 274, 277, 281, 297, 298, 299, 300, 322, 323, 327, - 328, 331, 332, 336, 337, 338, 342, 343, 351, 170, - 359, 368, 370, 371, 372, 373, 383, 386, 387, 426, - 427, 441, 442, 874, 180, 0, 186, 0, 187, 0, - 861, 185, 976, 1000, 921, 935, 848, 988, 0, 0, - 413, 1053, 992, 835, 858, 1001, 864, 866, 929, 811, - 906, 330, 855, 812, 0, 0, 0, 0, 803, 1048, - 804, 836, 238, 1046, 962, 907, 990, 892, 922, 932, - 237, 224, 899, 898, 979, 847, 846, 927, 975, 989, - 0, 0, 159, 176, 177, 1086, 289, 0, 458, 439, - 392, 311, 461, 460, 890, 0, 1060, 1073, 875, 931, - 823, 918, 994, 856, 923, 995, 0, 0, 0, 0, - 0, 515, 0, 0, 0, 0, 0, 0, 0, 0, - 158, 0, 1068, 1082, 1049, 459, 885, 928, 1006, 802, - 1065, 0, 807, 1037, 0, 980, 843, 844, 242, 0, - 0, 0, 0, 0, 0, 0, 888, 905, 947, 872, - 0, 433, 934, 943, 957, 865, 348, 261, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1064, 0, - 0, 0, 817, 1033, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 1054, 0, 0, 0, - 822, 800, 841, 949, 801, 799, 312, 814, 1075, 978, - 873, 278, 178, 984, 871, 1052, 937, 818, 966, 859, - 286, 816, 179, 813, 819, 857, 325, 946, 952, 164, - 182, 288, 963, 837, 850, 225, 0, 362, 924, 432, - 2270, 256, 910, 361, 290, 425, 938, 986, 431, 860, - 407, 440, 444, 250, 893, 215, 389, 240, 234, 842, - 956, 806, 262, 347, 229, 282, 876, 930, 838, 221, - 941, 917, 968, 388, 422, 184, 306, 423, 443, 153, - 251, 380, 252, 406, 243, 216, 350, 203, 414, 307, - 317, 218, 220, 219, 197, 381, 421, 209, 223, 964, - 951, 970, 833, 820, 825, 821, 849, 987, 271, 263, - 971, 969, 851, 334, 206, 903, 896, 889, 1071, 435, - 1002, 236, 953, 437, 166, 375, 374, 863, 270, 954, - 167, 157, 357, 168, 279, 188, 974, 447, 202, 284, - 415, 2269, 255, 324, 926, 335, 181, 352, 302, 304, - 301, 305, 260, 162, 169, 950, 354, 377, 420, 204, - 395, 160, 163, 171, 367, 172, 173, 993, 296, 245, - 249, 264, 275, 925, 360, 396, 438, 919, 199, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 364, 397, - 411, 369, 258, 399, 403, 400, 401, 398, 402, 365, - 366, 191, 405, 430, 210, 376, 379, 446, 948, 198, - 193, 982, 965, 912, 878, 884, 808, 0, 192, 879, - 880, 881, 882, 883, 944, 840, 852, 832, 920, 831, - 259, 936, 428, 429, 226, 1038, 997, 194, 815, 996, - 321, 329, 320, 999, 998, 424, 983, 913, 902, 900, - 809, 981, 911, 901, 285, 248, 266, 345, 292, 346, - 267, 315, 314, 316, 294, 904, 394, 295, 0, 189, - 0, 393, 991, 1008, 404, 207, 826, 958, 419, 165, - 353, 208, 257, 246, 344, 319, 200, 269, 391, 283, - 291, 940, 1005, 333, 363, 214, 434, 390, 241, 1043, - 326, 1045, 1041, 1044, 1042, 1061, 1062, 1083, 1084, 1085, - 1072, 1039, 0, 1080, 1081, 0, 895, 985, 810, 0, - 961, 174, 175, 161, 933, 1003, 1051, 222, 151, 1034, - 1035, 1036, 152, 1055, 1056, 154, 155, 1078, 1077, 1076, - 1079, 156, 1088, 1087, 1089, 1040, 1047, 1050, 1057, 1058, - 1059, 1066, 1067, 1074, 1069, 1070, 0, 891, 341, 190, - 201, 418, 213, 233, 231, 247, 280, 303, 309, 339, - 378, 384, 385, 408, 409, 410, 412, 235, 0, 239, - 212, 358, 211, 293, 272, 340, 416, 417, 349, 228, - 1063, 183, 195, 287, 1004, 356, 254, 308, 382, 310, - 276, 227, 445, 313, 355, 448, 959, 916, 0, 868, - 870, 869, 828, 830, 829, 827, 1007, 318, 977, 798, - 805, 824, 834, 839, 845, 853, 854, 862, 867, 877, - 886, 887, 897, 908, 909, 915, 939, 942, 955, 960, - 967, 972, 973, 436, 232, 894, 914, 945, 196, 205, - 217, 230, 244, 253, 265, 268, 273, 274, 277, 281, - 297, 298, 299, 300, 322, 323, 327, 328, 331, 332, - 336, 337, 338, 342, 343, 351, 170, 359, 368, 370, - 371, 372, 373, 383, 386, 387, 426, 427, 441, 442, - 874, 180, 0, 186, 0, 187, 0, 861, 185, 976, - 1000, 921, 935, 848, 988, 0, 0, 413, 1053, 992, - 835, 858, 1001, 864, 866, 929, 811, 906, 330, 855, - 812, 0, 0, 0, 0, 803, 1048, 804, 836, 238, - 1046, 962, 907, 990, 892, 922, 932, 237, 224, 899, - 898, 979, 847, 846, 927, 975, 989, 0, 0, 159, - 176, 177, 1086, 289, 0, 0, 439, 392, 311, 0, - 0, 890, 0, 1060, 1073, 875, 931, 823, 918, 994, - 856, 923, 995, 0, 0, 0, 0, 0, 515, 0, - 0, 0, 0, 0, 0, 0, 0, 158, 0, 1068, - 1082, 1049, 0, 885, 928, 1006, 802, 1065, 0, 807, - 1037, 0, 980, 843, 844, 242, 0, 0, 0, 0, - 0, 0, 0, 888, 905, 947, 872, 0, 433, 934, - 943, 957, 865, 348, 261, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1064, 0, 0, 0, 817, - 1033, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 1054, 0, 0, 0, 822, 800, 841, - 949, 801, 799, 312, 814, 1075, 978, 873, 278, 178, - 984, 871, 1052, 937, 818, 966, 859, 286, 816, 179, - 813, 819, 857, 325, 946, 952, 164, 182, 288, 963, - 837, 850, 225, 0, 362, 924, 432, 1032, 256, 910, - 361, 290, 425, 938, 986, 431, 860, 407, 440, 444, - 250, 893, 215, 389, 240, 234, 842, 956, 806, 262, - 347, 229, 282, 876, 930, 838, 221, 941, 917, 968, - 388, 422, 184, 306, 423, 443, 153, 251, 380, 252, - 406, 243, 216, 350, 203, 414, 307, 317, 218, 220, - 219, 197, 381, 421, 209, 223, 964, 951, 970, 833, - 820, 825, 821, 849, 987, 271, 263, 971, 969, 851, - 334, 206, 903, 896, 889, 1071, 435, 1002, 236, 953, - 437, 166, 375, 374, 863, 270, 954, 167, 157, 357, - 168, 279, 188, 974, 447, 202, 284, 415, 1031, 255, - 324, 926, 335, 181, 352, 302, 304, 301, 305, 260, - 162, 169, 950, 354, 377, 420, 204, 395, 160, 163, - 171, 367, 172, 173, 993, 296, 245, 249, 264, 275, - 925, 360, 396, 438, 919, 199, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 364, 397, 411, 369, 258, - 399, 403, 400, 401, 398, 402, 365, 366, 191, 405, - 430, 210, 376, 379, 446, 948, 198, 193, 982, 965, - 912, 878, 884, 808, 0, 192, 879, 880, 881, 882, - 883, 944, 840, 852, 832, 920, 831, 259, 936, 428, - 429, 226, 1038, 997, 194, 815, 996, 321, 329, 320, - 999, 998, 424, 983, 913, 902, 900, 809, 981, 911, - 901, 285, 248, 266, 345, 292, 346, 267, 315, 314, - 316, 294, 904, 394, 295, 0, 189, 0, 393, 991, - 1008, 404, 207, 826, 958, 419, 165, 353, 208, 257, - 246, 344, 319, 200, 269, 391, 283, 291, 940, 1005, - 333, 363, 214, 434, 390, 241, 1043, 326, 1045, 1041, - 1044, 1042, 1061, 1062, 1083, 1084, 1085, 1072, 1039, 0, - 1080, 1081, 0, 895, 985, 810, 0, 961, 174, 175, - 161, 933, 1003, 1051, 222, 151, 1034, 1035, 1036, 152, - 1055, 1056, 154, 155, 1078, 1077, 1076, 1079, 156, 1088, - 1087, 1089, 1040, 1047, 1050, 1057, 1058, 1059, 1066, 1067, - 1074, 1069, 1070, 0, 891, 341, 190, 201, 418, 213, - 233, 231, 247, 280, 303, 309, 339, 378, 384, 385, - 408, 409, 410, 412, 235, 0, 239, 212, 358, 211, - 293, 272, 340, 416, 417, 349, 228, 1063, 183, 195, - 287, 1004, 356, 254, 308, 382, 310, 276, 227, 445, - 313, 355, 448, 959, 916, 0, 868, 870, 869, 828, - 830, 829, 827, 1007, 318, 977, 798, 805, 824, 834, - 839, 845, 853, 854, 862, 867, 877, 886, 887, 897, - 908, 909, 915, 939, 942, 955, 960, 967, 972, 973, - 436, 232, 894, 914, 945, 196, 205, 217, 230, 244, - 253, 265, 268, 273, 274, 277, 281, 297, 298, 299, - 300, 322, 323, 327, 328, 331, 332, 336, 337, 338, - 342, 343, 351, 170, 359, 368, 370, 371, 372, 373, - 383, 386, 387, 426, 427, 441, 442, 874, 180, 0, - 186, 0, 187, 0, 861, 185, 976, 1000, 921, 935, - 848, 988, 0, 0, 413, 1053, 992, 835, 858, 1001, - 864, 866, 929, 811, 906, 330, 855, 812, 0, 0, - 0, 0, 803, 1048, 804, 836, 238, 1046, 962, 907, - 990, 892, 922, 932, 237, 224, 899, 898, 979, 847, - 846, 927, 975, 989, 0, 0, 159, 176, 177, 1086, - 289, 0, 0, 439, 392, 311, 0, 0, 890, 0, - 1060, 1073, 875, 931, 823, 918, 994, 856, 923, 995, - 0, 0, 0, 0, 0, 515, 0, 0, 0, 0, - 0, 0, 0, 0, 158, 0, 1068, 1082, 1049, 0, - 885, 928, 1006, 802, 1065, 0, 807, 1037, 0, 980, - 843, 844, 242, 0, 0, 0, 0, 0, 0, 0, - 888, 905, 947, 872, 0, 433, 934, 943, 957, 865, - 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1064, 0, 0, 0, 817, 1033, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1054, 0, 0, 0, 822, 800, 841, 949, 801, 799, - 312, 814, 1075, 978, 873, 278, 178, 984, 871, 1052, - 937, 818, 966, 859, 286, 816, 179, 813, 819, 857, - 325, 946, 952, 164, 182, 288, 963, 837, 850, 225, - 0, 362, 924, 432, 1032, 256, 910, 361, 290, 425, - 938, 986, 431, 860, 407, 440, 444, 250, 893, 215, - 389, 240, 234, 842, 956, 806, 262, 347, 229, 282, - 876, 930, 838, 221, 941, 917, 968, 388, 422, 184, - 306, 423, 443, 153, 251, 380, 252, 406, 243, 216, - 350, 203, 414, 307, 317, 218, 220, 219, 197, 381, - 421, 209, 223, 964, 951, 970, 833, 820, 825, 821, - 849, 987, 271, 263, 971, 969, 851, 334, 206, 903, - 896, 889, 1071, 435, 1002, 236, 953, 437, 166, 375, - 374, 863, 270, 954, 167, 157, 357, 168, 279, 188, - 974, 447, 202, 284, 415, 1031, 255, 324, 926, 335, - 181, 352, 302, 304, 301, 305, 260, 162, 169, 950, - 354, 377, 420, 204, 395, 160, 163, 171, 367, 172, - 173, 993, 296, 245, 249, 264, 275, 925, 360, 396, - 438, 919, 199, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 364, 397, 411, 369, 258, 399, 403, 400, - 401, 398, 402, 365, 366, 191, 405, 430, 210, 376, - 379, 446, 948, 198, 193, 982, 965, 912, 878, 884, - 808, 0, 192, 879, 880, 881, 882, 883, 944, 840, - 852, 832, 920, 831, 259, 936, 428, 429, 226, 1038, - 997, 194, 1026, 996, 321, 329, 320, 999, 998, 424, - 983, 913, 902, 900, 809, 981, 911, 901, 285, 248, - 266, 345, 292, 346, 267, 315, 314, 316, 1022, 904, - 394, 295, 0, 189, 0, 393, 991, 1008, 404, 207, - 826, 958, 419, 165, 353, 208, 257, 246, 344, 1027, - 1025, 1016, 1017, 283, 291, 940, 1005, 333, 363, 214, - 434, 390, 241, 1043, 326, 1045, 1041, 1044, 1042, 1061, - 1062, 1083, 1084, 1085, 1072, 1039, 0, 1080, 1081, 0, - 895, 985, 810, 0, 961, 174, 175, 161, 933, 1003, - 1051, 222, 151, 1034, 1035, 1036, 152, 1055, 1056, 154, - 155, 1078, 1077, 1076, 1079, 156, 1088, 1087, 1089, 1040, - 1047, 1050, 1057, 1058, 1059, 1066, 1067, 1074, 1069, 1070, - 0, 891, 341, 190, 201, 418, 213, 233, 231, 247, - 280, 303, 309, 339, 378, 384, 385, 408, 409, 410, - 412, 235, 0, 239, 212, 358, 211, 293, 272, 340, - 416, 417, 349, 228, 1063, 183, 195, 287, 1004, 356, - 254, 308, 382, 310, 276, 227, 445, 313, 355, 448, - 959, 916, 0, 868, 870, 869, 828, 830, 829, 827, - 1007, 318, 977, 798, 805, 824, 834, 839, 845, 853, - 854, 862, 867, 877, 886, 887, 897, 908, 909, 915, - 939, 942, 955, 960, 967, 972, 973, 436, 232, 894, - 914, 945, 196, 205, 217, 230, 244, 253, 265, 268, - 273, 274, 277, 281, 297, 298, 299, 300, 322, 323, - 327, 328, 331, 332, 336, 337, 338, 1023, 1024, 351, - 170, 359, 368, 370, 371, 372, 373, 383, 386, 387, - 426, 427, 441, 442, 874, 180, 0, 186, 0, 187, - 0, 861, 185, 976, 1000, 921, 935, 848, 988, 0, - 0, 413, 1053, 992, 835, 858, 1001, 864, 866, 929, - 811, 906, 330, 855, 812, 0, 0, 0, 0, 803, - 1048, 804, 836, 238, 1046, 962, 907, 990, 892, 922, - 932, 237, 224, 899, 898, 979, 847, 846, 927, 975, - 989, 0, 0, 159, 176, 177, 1086, 289, 0, 0, - 439, 392, 311, 0, 0, 890, 0, 1060, 1073, 875, - 931, 823, 918, 994, 856, 923, 995, 0, 0, 0, - 0, 0, 515, 0, 0, 0, 0, 0, 0, 0, - 0, 158, 0, 1068, 1082, 1049, 0, 885, 928, 1006, - 802, 1065, 0, 807, 1037, 0, 980, 843, 844, 242, - 0, 0, 0, 0, 0, 0, 0, 888, 905, 947, - 872, 0, 433, 934, 943, 957, 865, 348, 261, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1064, - 0, 0, 0, 817, 1033, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1054, 0, 0, - 0, 822, 800, 841, 949, 801, 799, 312, 814, 1075, - 978, 873, 278, 178, 984, 871, 1052, 937, 818, 966, - 859, 286, 816, 179, 813, 819, 857, 325, 946, 952, - 164, 182, 288, 963, 837, 850, 225, 0, 362, 924, - 432, 1032, 256, 910, 361, 290, 425, 938, 986, 431, - 860, 407, 440, 444, 250, 893, 215, 389, 240, 234, - 842, 956, 806, 262, 347, 229, 282, 876, 930, 838, - 221, 941, 917, 968, 388, 422, 184, 306, 423, 443, - 153, 251, 380, 252, 406, 243, 216, 350, 203, 414, - 307, 317, 218, 220, 219, 197, 381, 421, 209, 223, - 964, 951, 970, 833, 820, 825, 821, 849, 987, 271, - 263, 971, 969, 851, 334, 206, 903, 896, 889, 1071, - 435, 1002, 236, 953, 437, 166, 375, 374, 863, 270, - 954, 167, 157, 357, 168, 279, 188, 974, 447, 202, - 284, 415, 1031, 255, 324, 926, 335, 181, 352, 302, - 304, 301, 305, 260, 162, 169, 950, 354, 377, 420, - 204, 395, 160, 163, 171, 367, 172, 173, 993, 296, - 245, 249, 264, 275, 925, 360, 396, 438, 919, 199, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 364, - 397, 411, 369, 258, 399, 403, 400, 401, 398, 402, - 365, 366, 191, 405, 1550, 210, 376, 379, 446, 948, - 198, 193, 982, 965, 912, 878, 884, 808, 0, 192, - 879, 880, 881, 882, 883, 944, 840, 852, 832, 920, - 831, 259, 936, 428, 429, 226, 1038, 997, 194, 815, - 996, 321, 329, 320, 999, 998, 424, 983, 913, 902, - 900, 809, 981, 911, 901, 285, 248, 266, 345, 292, - 346, 267, 315, 314, 316, 294, 904, 394, 295, 0, - 189, 0, 393, 991, 1008, 404, 207, 826, 958, 419, - 165, 353, 208, 257, 246, 344, 319, 200, 269, 391, - 283, 291, 940, 1005, 333, 363, 214, 434, 390, 241, - 1043, 326, 1045, 1041, 1044, 1042, 1061, 1062, 1083, 1084, - 1085, 1072, 1039, 0, 1080, 1081, 0, 895, 985, 810, - 0, 961, 174, 175, 161, 933, 1003, 1051, 222, 151, - 1034, 1035, 1036, 152, 1055, 1056, 154, 155, 1078, 1077, - 1076, 1079, 156, 1088, 1087, 1089, 1040, 1047, 1050, 1057, - 1058, 1059, 1066, 1067, 1074, 1069, 1070, 0, 891, 341, - 190, 201, 418, 213, 233, 231, 247, 280, 303, 309, - 339, 378, 384, 385, 408, 409, 410, 412, 235, 0, - 239, 212, 358, 211, 293, 272, 340, 416, 417, 349, - 228, 1063, 183, 195, 287, 1004, 356, 254, 308, 382, - 310, 276, 227, 445, 313, 355, 448, 959, 916, 0, - 868, 870, 869, 828, 830, 829, 827, 1007, 318, 977, - 798, 805, 824, 834, 839, 845, 853, 854, 862, 867, - 877, 886, 887, 897, 908, 909, 915, 939, 942, 955, - 960, 967, 972, 973, 436, 232, 894, 914, 945, 196, - 205, 217, 230, 244, 253, 265, 268, 273, 274, 277, - 281, 297, 298, 299, 300, 322, 323, 327, 328, 331, - 332, 336, 337, 338, 342, 343, 351, 170, 359, 368, - 370, 371, 372, 373, 383, 386, 387, 426, 427, 441, - 442, 874, 180, 0, 186, 0, 187, 0, 861, 185, - 976, 1000, 921, 935, 848, 988, 0, 0, 413, 1053, - 992, 835, 858, 1001, 864, 866, 929, 811, 906, 330, - 855, 812, 0, 0, 0, 0, 803, 1048, 804, 836, - 238, 1046, 962, 907, 990, 892, 922, 932, 237, 224, - 899, 898, 979, 847, 846, 927, 975, 989, 0, 0, - 159, 176, 177, 1086, 289, 0, 0, 439, 392, 311, - 0, 0, 890, 0, 1060, 1073, 875, 931, 823, 918, - 994, 856, 923, 995, 0, 0, 0, 0, 0, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 158, 0, - 1068, 1082, 1049, 0, 885, 928, 1006, 802, 1065, 0, - 807, 1037, 0, 980, 843, 844, 242, 0, 0, 0, - 0, 0, 0, 0, 888, 905, 947, 872, 0, 433, - 934, 943, 957, 865, 348, 261, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 1064, 0, 0, 0, - 817, 1033, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1054, 0, 0, 0, 822, 800, - 841, 949, 801, 799, 312, 814, 1075, 978, 873, 278, - 178, 984, 871, 1052, 937, 818, 966, 859, 286, 816, - 179, 813, 819, 857, 325, 946, 952, 164, 182, 288, - 963, 837, 850, 225, 0, 362, 924, 432, 1032, 256, - 910, 361, 290, 425, 938, 986, 431, 860, 407, 440, - 444, 250, 893, 215, 389, 240, 234, 842, 956, 806, - 262, 347, 229, 282, 876, 930, 838, 221, 941, 917, - 968, 388, 422, 184, 306, 423, 443, 153, 251, 380, - 252, 406, 243, 216, 350, 203, 414, 307, 317, 218, - 220, 219, 197, 381, 421, 209, 223, 964, 951, 970, - 833, 820, 825, 821, 849, 987, 271, 263, 971, 969, - 851, 334, 206, 903, 896, 889, 1071, 435, 1002, 236, - 953, 437, 166, 375, 374, 863, 270, 954, 167, 157, - 357, 168, 279, 188, 974, 447, 202, 284, 415, 1031, - 255, 324, 926, 335, 181, 352, 302, 304, 301, 305, - 260, 162, 169, 950, 354, 377, 420, 204, 395, 160, - 163, 171, 367, 172, 173, 993, 296, 245, 249, 264, - 275, 925, 360, 396, 438, 919, 199, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 364, 397, 411, 369, - 258, 399, 403, 400, 401, 398, 402, 365, 366, 191, - 405, 1013, 210, 376, 379, 446, 948, 198, 193, 982, - 965, 912, 878, 884, 808, 0, 192, 879, 880, 881, - 882, 883, 944, 840, 852, 832, 920, 831, 259, 936, - 428, 429, 226, 1038, 997, 194, 1026, 996, 321, 329, - 320, 999, 998, 424, 983, 913, 902, 900, 809, 981, - 911, 901, 285, 248, 266, 345, 292, 346, 267, 315, - 314, 316, 1022, 904, 394, 295, 0, 189, 0, 393, - 991, 1008, 404, 207, 826, 958, 419, 165, 353, 208, - 257, 246, 344, 1027, 1025, 1016, 1017, 283, 291, 940, - 1005, 333, 363, 214, 434, 390, 241, 1043, 326, 1045, - 1041, 1044, 1042, 1061, 1062, 1083, 1084, 1085, 1072, 1039, - 0, 1080, 1081, 0, 895, 985, 810, 0, 961, 174, - 175, 161, 933, 1003, 1051, 222, 151, 1034, 1035, 1036, - 152, 1055, 1056, 154, 155, 1078, 1077, 1076, 1079, 156, - 1088, 1087, 1089, 1040, 1047, 1050, 1057, 1058, 1059, 1066, - 1067, 1074, 1069, 1070, 0, 891, 341, 190, 201, 418, - 213, 233, 231, 247, 280, 303, 309, 339, 378, 384, - 385, 408, 409, 410, 412, 235, 0, 239, 212, 358, - 211, 293, 272, 340, 416, 417, 349, 228, 1063, 183, - 195, 287, 1004, 356, 254, 308, 382, 310, 276, 227, - 445, 313, 355, 448, 959, 916, 0, 868, 870, 869, - 828, 830, 829, 827, 1007, 318, 977, 798, 805, 824, - 834, 839, 845, 853, 854, 862, 867, 877, 886, 887, - 897, 908, 909, 915, 939, 942, 955, 960, 967, 972, - 973, 436, 232, 894, 914, 945, 196, 205, 217, 230, - 244, 253, 265, 268, 273, 274, 277, 281, 297, 298, - 299, 300, 322, 323, 327, 328, 331, 332, 336, 337, - 338, 1023, 1024, 351, 170, 359, 368, 370, 371, 372, - 373, 383, 386, 387, 426, 427, 441, 442, 874, 180, - 0, 186, 0, 187, 0, 861, 185, 976, 1000, 921, - 935, 1755, 1934, 0, 1896, 413, 1789, 1938, 1738, 1768, - 1955, 1774, 1777, 1858, 1704, 1827, 330, 1765, 1705, 0, - 0, 0, 1743, 1692, 1756, 1693, 1740, 238, 1736, 1899, - 1830, 1936, 1809, 1851, 1861, 237, 224, 1819, 1818, 1924, - 1754, 1753, 1856, 1913, 1935, 1808, 0, 0, 0, 0, - 1945, 289, 1910, 0, 439, 392, 311, 0, 0, 1804, - 1919, 1825, 1888, 1787, 1860, 1720, 1843, 1940, 1766, 1852, - 1941, 0, 0, 0, 0, 0, 3102, 0, 3097, 3105, - 3107, 3106, 0, 0, 0, 3099, 0, 1848, 1932, 1759, - 0, 1799, 1857, 1960, 1691, 1844, 0, 1696, 1707, 1954, - 1925, 1750, 1751, 242, 0, 0, 0, 0, 0, 0, - 0, 1802, 1826, 1878, 1784, 0, 433, 1863, 1873, 1891, - 1776, 348, 261, 0, 0, 0, 0, 0, 0, 0, - 0, 1745, 0, 1841, 0, 0, 0, 1712, 1698, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1798, 0, 0, 0, 1719, 1689, 1747, 1880, 1690, - 1688, 312, 1708, 1893, 1923, 1785, 278, 0, 1929, 1783, - 1782, 1867, 1713, 1903, 1769, 286, 1711, 179, 1706, 1714, - 1767, 325, 1877, 1885, 0, 182, 288, 1900, 1741, 1758, - 225, 0, 362, 1853, 432, 0, 256, 1834, 361, 290, - 425, 1868, 1931, 431, 1770, 407, 440, 444, 250, 1810, - 215, 389, 240, 234, 1749, 1890, 1695, 262, 347, 229, - 282, 1788, 1859, 1742, 221, 1871, 1842, 1905, 388, 422, - 184, 306, 423, 443, 3100, 251, 380, 252, 406, 243, - 216, 350, 203, 414, 307, 317, 218, 220, 219, 197, - 381, 421, 209, 223, 1901, 1884, 1907, 1735, 1715, 1726, - 1716, 1757, 1933, 271, 263, 1908, 1906, 1760, 334, 206, - 1823, 1816, 1803, 1881, 435, 1956, 236, 1886, 437, 0, - 375, 374, 1773, 270, 1887, 0, 0, 357, 3101, 279, - 188, 1912, 447, 202, 284, 415, 0, 255, 324, 1855, - 335, 181, 352, 302, 304, 301, 305, 260, 0, 0, - 1883, 354, 377, 420, 204, 395, 0, 0, 0, 367, - 0, 0, 1939, 296, 245, 249, 264, 275, 1854, 360, - 396, 438, 1845, 199, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 364, 397, 411, 369, 258, 399, 403, - 400, 401, 398, 402, 365, 366, 191, 405, 430, 210, - 376, 379, 446, 1879, 198, 193, 1927, 1902, 1836, 1791, - 1797, 1697, 0, 192, 1792, 1793, 1794, 1795, 1796, 1875, - 1746, 1762, 1734, 1849, 1733, 259, 1866, 428, 429, 226, - 1709, 1947, 194, 1710, 1946, 321, 329, 320, 1950, 1948, - 424, 1928, 1837, 1822, 1820, 1702, 1926, 1835, 1821, 285, - 248, 266, 345, 292, 346, 267, 315, 314, 316, 294, - 1824, 394, 295, 0, 189, 0, 393, 1937, 1962, 404, - 207, 1728, 1894, 419, 0, 353, 208, 257, 246, 344, - 319, 200, 269, 391, 283, 291, 1870, 1959, 333, 363, - 214, 434, 390, 241, 1724, 326, 1727, 1722, 1725, 1723, - 1828, 1829, 1942, 1943, 1944, 1882, 1717, 0, 1920, 1921, - 0, 1815, 1930, 1703, 0, 1898, 0, 0, 0, 1862, - 1957, 1775, 222, 0, 1699, 1700, 1701, 0, 1805, 1806, - 0, 0, 1916, 1915, 1914, 1917, 0, 1951, 1949, 1952, - 1718, 1739, 1761, 1811, 1812, 1814, 1846, 1847, 1892, 1865, - 1874, 1748, 1807, 341, 190, 201, 418, 213, 233, 231, - 247, 280, 303, 309, 339, 378, 384, 385, 408, 409, - 410, 412, 235, 0, 239, 212, 358, 211, 293, 272, - 340, 416, 417, 349, 228, 1833, 183, 195, 287, 1958, - 356, 254, 308, 382, 310, 276, 227, 445, 313, 355, - 448, 1895, 1840, 0, 1779, 1781, 1780, 1730, 1732, 1731, - 1729, 1961, 318, 1922, 1687, 1694, 1721, 1737, 1744, 1752, - 1763, 1764, 1772, 1778, 1790, 1800, 1801, 1817, 1831, 1832, - 1839, 1869, 1872, 1889, 1897, 1904, 1909, 1911, 436, 232, - 1813, 1838, 1876, 196, 205, 217, 230, 244, 253, 265, - 268, 273, 274, 277, 281, 297, 298, 299, 300, 322, - 323, 327, 328, 331, 332, 336, 337, 338, 342, 343, - 351, 0, 359, 368, 370, 371, 372, 373, 383, 386, - 387, 426, 427, 441, 442, 1786, 180, 0, 186, 0, - 187, 0, 1771, 185, 1918, 1953, 1850, 1864, 1755, 1934, - 0, 1896, 413, 1789, 1938, 1738, 1768, 1955, 1774, 1777, - 1858, 1704, 1827, 330, 1765, 1705, 0, 0, 0, 1743, - 1692, 1756, 1693, 1740, 238, 1736, 1899, 1830, 1936, 1809, - 1851, 1861, 237, 224, 1819, 1818, 1924, 1754, 1753, 1856, - 1913, 1935, 1808, 0, 0, 0, 0, 1945, 289, 1910, - 0, 439, 392, 311, 0, 0, 1804, 1919, 1825, 1888, - 1787, 1860, 1720, 1843, 1940, 1766, 1852, 1941, 0, 0, - 0, 0, 0, 3102, 0, 3378, 0, 0, 0, 0, - 0, 0, 0, 0, 1848, 1932, 1759, 0, 1799, 1857, - 1960, 1691, 1844, 0, 1696, 1707, 1954, 1925, 1750, 1751, - 242, 0, 0, 0, 0, 0, 0, 0, 1802, 1826, - 1878, 1784, 0, 433, 1863, 1873, 1891, 1776, 348, 261, - 0, 0, 0, 0, 0, 0, 0, 0, 1745, 0, - 1841, 0, 0, 0, 1712, 1698, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1798, 0, - 0, 0, 1719, 1689, 1747, 1880, 1690, 1688, 312, 1708, - 1893, 1923, 1785, 278, 0, 1929, 1783, 1782, 1867, 1713, - 1903, 1769, 286, 1711, 179, 1706, 1714, 1767, 325, 1877, - 1885, 0, 182, 288, 1900, 1741, 1758, 225, 0, 362, - 1853, 432, 0, 256, 1834, 361, 290, 425, 1868, 1931, - 431, 1770, 407, 440, 444, 250, 1810, 215, 389, 240, - 234, 1749, 1890, 1695, 262, 347, 229, 282, 1788, 1859, - 1742, 221, 1871, 1842, 1905, 388, 422, 184, 306, 423, - 443, 0, 251, 380, 252, 406, 243, 216, 350, 203, - 414, 307, 317, 218, 220, 219, 197, 381, 421, 209, - 223, 1901, 1884, 1907, 1735, 1715, 1726, 1716, 1757, 1933, - 271, 263, 1908, 1906, 1760, 334, 206, 1823, 1816, 1803, - 1881, 435, 1956, 236, 1886, 437, 0, 375, 374, 1773, - 270, 1887, 0, 0, 357, 0, 279, 188, 1912, 447, - 202, 284, 415, 0, 255, 324, 1855, 335, 181, 352, - 302, 304, 301, 305, 260, 0, 0, 1883, 354, 377, - 420, 204, 395, 0, 0, 0, 367, 0, 0, 1939, - 296, 245, 249, 264, 275, 1854, 360, 396, 438, 1845, - 199, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 364, 397, 411, 369, 258, 399, 403, 400, 401, 398, - 402, 365, 366, 191, 405, 430, 210, 376, 379, 446, - 1879, 198, 193, 1927, 1902, 1836, 1791, 1797, 1697, 0, - 192, 1792, 1793, 1794, 1795, 1796, 1875, 1746, 1762, 1734, - 1849, 1733, 259, 1866, 428, 429, 226, 1709, 1947, 194, - 1710, 1946, 321, 329, 320, 1950, 1948, 424, 1928, 1837, - 1822, 1820, 1702, 1926, 1835, 1821, 285, 248, 266, 345, - 292, 346, 267, 315, 314, 316, 294, 1824, 394, 295, - 0, 189, 0, 393, 1937, 1962, 404, 207, 1728, 1894, - 419, 0, 353, 208, 257, 246, 344, 319, 200, 269, - 391, 283, 291, 1870, 1959, 333, 363, 214, 434, 390, - 241, 1724, 326, 1727, 1722, 1725, 1723, 1828, 1829, 1942, - 1943, 1944, 1882, 1717, 0, 1920, 1921, 0, 1815, 1930, - 1703, 0, 1898, 0, 0, 0, 1862, 1957, 1775, 222, - 0, 1699, 1700, 1701, 0, 1805, 1806, 0, 0, 1916, - 1915, 1914, 1917, 0, 1951, 1949, 1952, 1718, 1739, 1761, - 1811, 1812, 1814, 1846, 1847, 1892, 1865, 1874, 1748, 1807, - 341, 190, 201, 418, 213, 233, 231, 247, 280, 303, - 309, 339, 378, 384, 385, 408, 409, 410, 412, 235, - 0, 239, 212, 358, 211, 293, 272, 340, 416, 417, - 349, 228, 1833, 183, 195, 287, 1958, 356, 254, 308, - 382, 310, 276, 227, 445, 313, 355, 448, 1895, 1840, - 0, 1779, 1781, 1780, 1730, 1732, 1731, 1729, 1961, 318, - 1922, 1687, 1694, 1721, 1737, 1744, 1752, 1763, 1764, 1772, - 1778, 1790, 1800, 1801, 1817, 1831, 1832, 1839, 1869, 1872, - 1889, 1897, 1904, 1909, 1911, 436, 232, 1813, 1838, 1876, - 196, 205, 217, 230, 244, 253, 265, 268, 273, 274, - 277, 281, 297, 298, 299, 300, 322, 323, 327, 328, - 331, 332, 336, 337, 338, 342, 343, 351, 0, 359, - 368, 370, 371, 372, 373, 383, 386, 387, 426, 427, - 441, 442, 1786, 180, 0, 186, 0, 187, 0, 1771, - 185, 1918, 1953, 1850, 1864, 1755, 1934, 0, 1896, 413, - 1789, 1938, 1738, 1768, 1955, 1774, 1777, 1858, 1704, 1827, - 330, 1765, 1705, 0, 0, 0, 1743, 1692, 1756, 1693, - 1740, 238, 1736, 1899, 1830, 1936, 1809, 1851, 1861, 237, - 224, 1819, 1818, 1924, 1754, 1753, 1856, 1913, 1935, 1808, - 0, 0, 0, 0, 1945, 289, 1910, 0, 439, 392, - 311, 0, 0, 1804, 1919, 1825, 1888, 1787, 1860, 1720, - 1843, 1940, 1766, 1852, 1941, 0, 0, 0, 0, 0, - 1103, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1848, 1932, 1759, 0, 1799, 1857, 1960, 1691, 1844, - 0, 1696, 1707, 1954, 1925, 1750, 1751, 242, 0, 0, - 0, 0, 0, 0, 0, 1802, 1826, 1878, 1784, 0, - 433, 1863, 1873, 1891, 1776, 348, 261, 0, 0, 0, - 0, 0, 0, 3556, 0, 1745, 0, 1841, 0, 0, - 0, 1712, 1698, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1798, 0, 0, 0, 1719, - 1689, 1747, 1880, 1690, 1688, 312, 1708, 1893, 1923, 1785, - 278, 0, 1929, 1783, 1782, 1867, 1713, 1903, 1769, 286, - 1711, 179, 1706, 1714, 1767, 325, 1877, 1885, 0, 182, - 288, 1900, 1741, 1758, 225, 0, 362, 1853, 432, 0, - 256, 1834, 361, 290, 425, 1868, 1931, 431, 1770, 407, - 440, 444, 250, 1810, 215, 389, 240, 234, 1749, 1890, - 1695, 262, 347, 229, 282, 1788, 1859, 1742, 221, 1871, - 1842, 1905, 388, 422, 184, 306, 423, 443, 0, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 1901, 1884, - 1907, 1735, 1715, 1726, 1716, 1757, 1933, 271, 263, 1908, - 1906, 1760, 334, 206, 1823, 1816, 1803, 1881, 435, 1956, - 236, 1886, 437, 0, 375, 374, 1773, 270, 1887, 0, - 0, 357, 0, 279, 188, 1912, 447, 202, 284, 415, - 0, 255, 324, 1855, 335, 181, 352, 302, 304, 301, - 305, 260, 0, 0, 1883, 354, 377, 420, 204, 395, - 0, 0, 0, 367, 0, 0, 1939, 296, 245, 249, - 264, 275, 1854, 360, 396, 438, 1845, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 1879, 198, 193, - 1927, 1902, 1836, 1791, 1797, 1697, 0, 192, 1792, 1793, - 1794, 1795, 1796, 1875, 1746, 1762, 1734, 1849, 1733, 259, - 1866, 428, 429, 226, 1709, 1947, 194, 1710, 1946, 321, - 329, 320, 1950, 1948, 424, 1928, 1837, 1822, 1820, 1702, - 1926, 1835, 1821, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 1824, 394, 295, 0, 189, 0, - 393, 1937, 1962, 404, 207, 1728, 1894, 419, 0, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 1870, 1959, 333, 363, 214, 434, 390, 241, 1724, 326, - 1727, 1722, 1725, 1723, 1828, 1829, 1942, 1943, 1944, 1882, - 1717, 0, 1920, 1921, 0, 1815, 1930, 1703, 0, 1898, - 0, 0, 0, 1862, 1957, 1775, 222, 0, 1699, 1700, - 1701, 0, 1805, 1806, 0, 0, 1916, 1915, 1914, 1917, - 0, 1951, 1949, 1952, 1718, 1739, 1761, 1811, 1812, 1814, - 1846, 1847, 1892, 1865, 1874, 1748, 1807, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 1833, - 183, 195, 287, 1958, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 1895, 1840, 0, 1779, 1781, - 1780, 1730, 1732, 1731, 1729, 1961, 318, 1922, 1687, 1694, - 1721, 1737, 1744, 1752, 1763, 1764, 1772, 1778, 1790, 1800, - 1801, 1817, 1831, 1832, 1839, 1869, 1872, 1889, 1897, 1904, - 1909, 1911, 436, 232, 1813, 1838, 1876, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 0, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 1786, - 180, 0, 186, 0, 187, 0, 1771, 185, 1918, 1953, - 1850, 1864, 1755, 1934, 0, 1896, 413, 1789, 1938, 1738, - 1768, 1955, 1774, 1777, 1858, 1704, 1827, 330, 1765, 1705, - 0, 0, 0, 1743, 1692, 1756, 1693, 1740, 238, 1736, - 1899, 1830, 1936, 1809, 1851, 1861, 237, 224, 1819, 1818, - 1924, 1754, 1753, 1856, 1913, 1935, 1808, 0, 0, 0, - 0, 1945, 289, 1910, 0, 439, 392, 311, 0, 0, - 1804, 1919, 1825, 1888, 1787, 1860, 1720, 1843, 1940, 1766, - 1852, 1941, 0, 0, 0, 0, 0, 1103, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1848, 1932, - 1759, 0, 1799, 1857, 1960, 1691, 1844, 0, 1696, 1707, - 1954, 1925, 1750, 1751, 242, 0, 0, 0, 0, 0, - 0, 0, 1802, 1826, 1878, 1784, 0, 433, 1863, 1873, - 1891, 1776, 348, 261, 0, 0, 0, 0, 0, 0, - 2973, 0, 1745, 0, 1841, 0, 0, 0, 1712, 1698, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1798, 0, 0, 0, 1719, 1689, 1747, 1880, - 1690, 1688, 312, 1708, 1893, 1923, 1785, 278, 0, 1929, - 1783, 1782, 1867, 1713, 1903, 1769, 286, 1711, 179, 1706, - 1714, 1767, 325, 1877, 1885, 0, 182, 288, 1900, 1741, - 1758, 225, 0, 362, 1853, 432, 0, 256, 1834, 361, - 290, 425, 1868, 1931, 431, 1770, 407, 440, 444, 250, - 1810, 215, 389, 240, 234, 1749, 1890, 1695, 262, 347, - 229, 282, 1788, 1859, 1742, 221, 1871, 1842, 1905, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 1901, 1884, 1907, 1735, 1715, - 1726, 1716, 1757, 1933, 271, 263, 1908, 1906, 1760, 334, - 206, 1823, 1816, 1803, 1881, 435, 1956, 236, 1886, 437, - 0, 375, 374, 1773, 270, 1887, 0, 0, 357, 0, - 279, 188, 1912, 447, 202, 284, 415, 0, 255, 324, - 1855, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 1883, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 1939, 296, 245, 249, 264, 275, 1854, - 360, 396, 438, 1845, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 1879, 198, 193, 1927, 1902, 1836, - 1791, 1797, 1697, 0, 192, 1792, 1793, 1794, 1795, 1796, - 1875, 1746, 1762, 1734, 1849, 1733, 259, 1866, 428, 429, - 226, 1709, 1947, 194, 1710, 1946, 321, 329, 320, 1950, - 1948, 424, 1928, 1837, 1822, 1820, 1702, 1926, 1835, 1821, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 1824, 394, 295, 0, 189, 0, 393, 1937, 1962, - 404, 207, 1728, 1894, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 1870, 1959, 333, - 363, 214, 434, 390, 241, 1724, 326, 1727, 1722, 1725, - 1723, 1828, 1829, 1942, 1943, 1944, 1882, 1717, 0, 1920, - 1921, 0, 1815, 1930, 1703, 0, 1898, 0, 0, 0, - 1862, 1957, 1775, 222, 0, 1699, 1700, 1701, 0, 1805, - 1806, 0, 0, 1916, 1915, 1914, 1917, 0, 1951, 1949, - 1952, 1718, 1739, 1761, 1811, 1812, 1814, 1846, 1847, 1892, - 1865, 1874, 1748, 1807, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 1833, 183, 195, 287, - 1958, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 1895, 1840, 0, 1779, 1781, 1780, 1730, 1732, - 1731, 1729, 1961, 318, 1922, 1687, 1694, 1721, 1737, 1744, - 1752, 1763, 1764, 1772, 1778, 1790, 1800, 1801, 1817, 1831, - 1832, 1839, 1869, 1872, 1889, 1897, 1904, 1909, 1911, 436, - 232, 1813, 1838, 1876, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 1786, 180, 0, 186, - 0, 187, 0, 1771, 185, 1918, 1953, 1850, 1864, 1755, - 1934, 0, 1896, 413, 1789, 1938, 1738, 1768, 1955, 1774, - 1777, 1858, 1704, 1827, 330, 1765, 1705, 0, 0, 0, - 1743, 1692, 1756, 1693, 1740, 238, 1736, 1899, 1830, 1936, - 1809, 1851, 1861, 237, 224, 1819, 1818, 1924, 1754, 1753, - 1856, 1913, 1935, 1808, 0, 0, 0, 0, 1945, 289, - 1910, 0, 439, 392, 311, 0, 0, 1804, 1919, 1825, - 1888, 1787, 1860, 1720, 1843, 1940, 1766, 1852, 1941, 0, - 0, 0, 0, 0, 149, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1848, 1932, 1759, 0, 1799, - 1857, 1960, 1691, 1844, 0, 1696, 1707, 1954, 1925, 1750, - 1751, 242, 0, 0, 0, 0, 0, 0, 0, 1802, - 1826, 1878, 1784, 0, 433, 1863, 1873, 1891, 1776, 348, - 261, 0, 0, 0, 0, 0, 0, 2703, 0, 1745, - 0, 1841, 0, 0, 0, 1712, 1698, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1798, - 0, 0, 0, 1719, 1689, 1747, 1880, 1690, 1688, 312, - 1708, 1893, 1923, 1785, 278, 0, 1929, 1783, 1782, 1867, - 1713, 1903, 1769, 286, 1711, 179, 1706, 1714, 1767, 325, - 1877, 1885, 0, 182, 288, 1900, 1741, 1758, 225, 0, - 362, 1853, 432, 0, 256, 1834, 361, 290, 425, 1868, - 1931, 431, 1770, 407, 440, 444, 250, 1810, 215, 389, - 240, 234, 1749, 1890, 1695, 262, 347, 229, 282, 1788, - 1859, 1742, 221, 1871, 1842, 1905, 388, 422, 184, 306, - 423, 443, 0, 251, 380, 252, 406, 243, 216, 350, - 203, 414, 307, 317, 218, 220, 219, 197, 381, 421, - 209, 223, 1901, 1884, 1907, 1735, 1715, 1726, 1716, 1757, - 1933, 271, 263, 1908, 1906, 1760, 334, 206, 1823, 1816, - 1803, 1881, 435, 1956, 236, 1886, 437, 0, 375, 374, - 1773, 270, 1887, 0, 0, 357, 0, 279, 188, 1912, - 447, 202, 284, 415, 0, 255, 324, 1855, 335, 181, - 352, 302, 304, 301, 305, 260, 0, 0, 1883, 354, - 377, 420, 204, 395, 0, 0, 0, 367, 0, 0, - 1939, 296, 245, 249, 264, 275, 1854, 360, 396, 438, - 1845, 199, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 364, 397, 411, 369, 258, 399, 403, 400, 401, - 398, 402, 365, 366, 191, 405, 430, 210, 376, 379, - 446, 1879, 198, 193, 1927, 1902, 1836, 1791, 1797, 1697, - 0, 192, 1792, 1793, 1794, 1795, 1796, 1875, 1746, 1762, - 1734, 1849, 1733, 259, 1866, 428, 429, 226, 1709, 1947, - 194, 1710, 1946, 321, 329, 320, 1950, 1948, 424, 1928, - 1837, 1822, 1820, 1702, 1926, 1835, 1821, 285, 248, 266, - 345, 292, 346, 267, 315, 314, 316, 294, 1824, 394, - 295, 0, 189, 0, 393, 1937, 1962, 404, 207, 1728, - 1894, 419, 0, 353, 208, 257, 246, 344, 319, 200, - 269, 391, 283, 291, 1870, 1959, 333, 363, 214, 434, - 390, 241, 1724, 326, 1727, 1722, 1725, 1723, 1828, 1829, - 1942, 1943, 1944, 1882, 1717, 0, 1920, 1921, 0, 1815, - 1930, 1703, 0, 1898, 0, 0, 0, 1862, 1957, 1775, - 222, 0, 1699, 1700, 1701, 0, 1805, 1806, 0, 0, - 1916, 1915, 1914, 1917, 0, 1951, 1949, 1952, 1718, 1739, - 1761, 1811, 1812, 1814, 1846, 1847, 1892, 1865, 1874, 1748, - 1807, 341, 190, 201, 418, 213, 233, 231, 247, 280, - 303, 309, 339, 378, 384, 385, 408, 409, 410, 412, - 235, 0, 239, 212, 358, 211, 293, 272, 340, 416, - 417, 349, 228, 1833, 183, 195, 287, 1958, 356, 254, - 308, 382, 310, 276, 227, 445, 313, 355, 448, 1895, - 1840, 0, 1779, 1781, 1780, 1730, 1732, 1731, 1729, 1961, - 318, 1922, 1687, 1694, 1721, 1737, 1744, 1752, 1763, 1764, - 1772, 1778, 1790, 1800, 1801, 1817, 1831, 1832, 1839, 1869, - 1872, 1889, 1897, 1904, 1909, 1911, 436, 232, 1813, 1838, - 1876, 196, 205, 217, 230, 244, 253, 265, 268, 273, - 274, 277, 281, 297, 298, 299, 300, 322, 323, 327, - 328, 331, 332, 336, 337, 338, 342, 343, 351, 0, - 359, 368, 370, 371, 372, 373, 383, 386, 387, 426, - 427, 441, 442, 1786, 180, 0, 186, 0, 187, 0, - 1771, 185, 1918, 1953, 1850, 1864, 1755, 1934, 0, 1896, - 413, 1789, 1938, 1738, 1768, 1955, 1774, 1777, 1858, 1704, - 1827, 330, 1765, 1705, 0, 0, 0, 1743, 1692, 1756, - 1693, 1740, 238, 1736, 1899, 1830, 1936, 1809, 1851, 1861, - 237, 224, 1819, 1818, 1924, 1754, 1753, 1856, 1913, 1935, - 1808, 0, 0, 0, 0, 1945, 289, 1910, 0, 439, - 392, 311, 0, 0, 1804, 1919, 1825, 1888, 1787, 1860, - 1720, 1843, 1940, 1766, 1852, 1941, 0, 0, 0, 0, - 0, 1103, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1848, 1932, 1759, 0, 1799, 1857, 1960, 1691, - 1844, 0, 1696, 1707, 1954, 1925, 1750, 1751, 242, 0, - 0, 0, 0, 0, 0, 0, 1802, 1826, 1878, 1784, - 0, 433, 1863, 1873, 1891, 1776, 348, 261, 0, 0, - 0, 0, 0, 0, 0, 0, 1745, 0, 1841, 0, - 0, 0, 1712, 1698, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 1798, 0, 0, 0, - 1719, 1689, 1747, 1880, 1690, 1688, 312, 1708, 1893, 1923, - 1785, 278, 0, 1929, 1783, 1782, 1867, 1713, 1903, 1769, - 286, 1711, 179, 1706, 1714, 1767, 325, 1877, 1885, 0, - 182, 288, 1900, 1741, 1758, 225, 0, 362, 1853, 432, - 0, 256, 1834, 361, 290, 425, 1868, 1931, 431, 1770, - 407, 440, 444, 250, 1810, 215, 389, 240, 234, 1749, - 1890, 1695, 262, 347, 229, 282, 1788, 1859, 1742, 221, - 1871, 1842, 1905, 388, 422, 184, 306, 423, 443, 0, - 251, 380, 252, 406, 243, 216, 350, 203, 414, 307, - 317, 218, 220, 219, 197, 381, 421, 209, 223, 1901, - 1884, 1907, 1735, 1715, 1726, 1716, 1757, 1933, 271, 263, - 1908, 1906, 1760, 334, 206, 1823, 1816, 1803, 1881, 435, - 1956, 236, 1886, 437, 0, 375, 374, 1773, 270, 1887, - 0, 0, 357, 0, 279, 188, 1912, 447, 202, 284, - 415, 0, 255, 324, 1855, 335, 181, 352, 302, 304, - 301, 305, 260, 0, 0, 1883, 354, 377, 420, 204, - 395, 0, 0, 0, 367, 0, 0, 1939, 296, 245, - 249, 264, 275, 1854, 360, 396, 438, 1845, 199, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 364, 397, - 411, 369, 258, 399, 403, 400, 401, 398, 402, 365, - 366, 191, 405, 430, 210, 376, 379, 446, 1879, 198, - 193, 1927, 1902, 1836, 1791, 1797, 1697, 0, 192, 1792, - 1793, 1794, 1795, 1796, 1875, 1746, 1762, 1734, 1849, 1733, - 259, 1866, 428, 429, 226, 1709, 1947, 194, 1710, 1946, - 321, 329, 320, 1950, 1948, 424, 1928, 1837, 1822, 1820, - 1702, 1926, 1835, 1821, 285, 248, 266, 345, 292, 346, - 267, 315, 314, 316, 294, 1824, 394, 295, 0, 189, - 0, 393, 1937, 1962, 404, 207, 1728, 1894, 419, 2233, - 353, 208, 257, 246, 344, 319, 200, 269, 391, 283, - 291, 1870, 1959, 333, 363, 214, 434, 390, 241, 1724, - 326, 1727, 1722, 1725, 1723, 1828, 1829, 1942, 1943, 1944, - 1882, 1717, 0, 1920, 1921, 0, 1815, 1930, 1703, 0, - 1898, 0, 0, 0, 1862, 1957, 1775, 222, 0, 1699, - 1700, 1701, 0, 1805, 1806, 0, 0, 1916, 1915, 1914, - 1917, 0, 1951, 1949, 1952, 1718, 1739, 1761, 1811, 1812, - 1814, 1846, 1847, 1892, 1865, 1874, 1748, 1807, 341, 190, - 201, 418, 213, 233, 231, 247, 280, 303, 309, 339, - 378, 384, 385, 408, 409, 410, 412, 235, 0, 239, - 212, 358, 211, 293, 272, 340, 416, 417, 349, 228, - 1833, 183, 195, 287, 1958, 356, 254, 308, 382, 310, - 276, 227, 445, 313, 355, 448, 1895, 1840, 0, 1779, - 1781, 1780, 1730, 1732, 1731, 1729, 1961, 318, 1922, 1687, - 1694, 1721, 1737, 1744, 1752, 1763, 1764, 1772, 1778, 1790, - 1800, 1801, 1817, 1831, 1832, 1839, 1869, 1872, 1889, 1897, - 1904, 1909, 1911, 436, 232, 1813, 1838, 1876, 196, 205, - 217, 230, 244, 253, 265, 268, 273, 274, 277, 281, - 297, 298, 299, 300, 322, 323, 327, 328, 331, 332, - 336, 337, 338, 342, 343, 351, 0, 359, 368, 370, - 371, 372, 373, 383, 386, 387, 426, 427, 441, 442, - 1786, 180, 0, 186, 0, 187, 0, 1771, 185, 1918, - 1953, 1850, 1864, 1755, 1934, 0, 1896, 413, 1789, 1938, - 1738, 1768, 1955, 1774, 1777, 1858, 1704, 1827, 330, 1765, - 1705, 0, 0, 0, 1743, 1692, 1756, 1693, 1740, 238, - 1736, 1899, 1830, 1936, 1809, 1851, 1861, 237, 224, 1819, - 1818, 1924, 1754, 1753, 1856, 1913, 1935, 1808, 0, 0, - 0, 0, 1945, 289, 1910, 0, 439, 392, 311, 0, - 0, 1804, 1919, 1825, 1888, 1787, 1860, 1720, 1843, 1940, - 1766, 1852, 1941, 0, 0, 0, 0, 0, 1103, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1848, - 1932, 1759, 0, 1799, 1857, 1960, 1691, 1844, 0, 1696, - 1707, 1954, 1925, 1750, 1751, 242, 0, 0, 0, 0, - 0, 0, 0, 1802, 1826, 1878, 1784, 0, 433, 1863, - 1873, 1891, 1776, 348, 261, 0, 0, 0, 0, 0, - 0, 0, 0, 1745, 0, 1841, 0, 0, 0, 1712, - 1698, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 1798, 0, 0, 0, 1719, 1689, 1747, - 1880, 1690, 1688, 312, 1708, 1893, 1923, 1785, 278, 0, - 1929, 1783, 1782, 1867, 1713, 1903, 1769, 286, 1711, 179, - 1706, 1714, 1767, 325, 1877, 1885, 0, 182, 288, 1900, - 1741, 1758, 225, 0, 362, 1853, 432, 0, 256, 1834, - 361, 290, 425, 1868, 1931, 431, 1770, 407, 440, 444, - 250, 1810, 215, 389, 240, 234, 1749, 1890, 1695, 262, - 347, 229, 282, 1788, 1859, 1742, 221, 1871, 1842, 1905, - 388, 422, 184, 306, 423, 443, 0, 251, 380, 252, - 406, 243, 216, 350, 203, 414, 307, 317, 218, 220, - 219, 197, 381, 421, 209, 223, 1901, 1884, 1907, 1735, - 1715, 1726, 1716, 1757, 1933, 271, 263, 1908, 1906, 1760, - 334, 206, 1823, 1816, 1803, 1881, 435, 1956, 236, 1886, - 437, 0, 375, 374, 1773, 270, 1887, 0, 0, 357, - 0, 279, 188, 1912, 447, 202, 284, 415, 0, 255, - 324, 1855, 335, 181, 352, 302, 304, 301, 305, 260, - 0, 0, 1883, 354, 377, 420, 204, 395, 0, 0, - 0, 367, 0, 0, 1939, 296, 245, 249, 264, 275, - 1854, 360, 396, 438, 1845, 199, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 364, 397, 411, 369, 258, - 399, 403, 400, 401, 398, 402, 365, 366, 191, 405, - 430, 210, 376, 379, 446, 1879, 198, 193, 1927, 1902, - 1836, 1791, 1797, 1697, 0, 192, 1792, 1793, 1794, 1795, - 1796, 1875, 1746, 1762, 1734, 1849, 1733, 259, 1866, 428, - 429, 226, 1709, 1947, 194, 1710, 1946, 321, 329, 320, - 1950, 1948, 424, 1928, 1837, 1822, 1820, 1702, 1926, 1835, - 1821, 285, 248, 266, 345, 292, 346, 267, 315, 314, - 316, 294, 1824, 394, 295, 0, 189, 0, 393, 1937, - 1962, 404, 207, 1728, 1894, 419, 0, 353, 208, 257, - 246, 344, 319, 200, 269, 391, 283, 291, 1870, 1959, - 333, 363, 214, 434, 390, 241, 1724, 326, 1727, 1722, - 1725, 1723, 1828, 1829, 1942, 1943, 1944, 1882, 1717, 0, - 1920, 1921, 0, 1815, 1930, 1703, 0, 1898, 0, 0, - 0, 1862, 1957, 1775, 222, 0, 1699, 1700, 1701, 0, - 1805, 1806, 0, 0, 1916, 1915, 1914, 1917, 0, 1951, - 1949, 1952, 1718, 1739, 1761, 1811, 1812, 1814, 1846, 1847, - 1892, 1865, 1874, 1748, 1807, 341, 190, 201, 418, 213, - 233, 231, 247, 280, 303, 309, 339, 378, 384, 385, - 408, 409, 410, 412, 235, 0, 239, 212, 358, 211, - 293, 272, 340, 416, 417, 349, 228, 1833, 183, 195, - 287, 1958, 356, 254, 308, 382, 310, 276, 227, 445, - 313, 355, 448, 1895, 1840, 0, 1779, 1781, 1780, 1730, - 1732, 1731, 1729, 1961, 318, 1922, 1687, 1694, 1721, 1737, - 1744, 1752, 1763, 1764, 1772, 1778, 1790, 1800, 1801, 1817, - 1831, 1832, 1839, 1869, 1872, 1889, 1897, 1904, 1909, 1911, - 436, 232, 1813, 1838, 1876, 196, 205, 217, 230, 244, - 253, 265, 268, 273, 274, 277, 281, 297, 298, 299, - 300, 3717, 323, 327, 328, 331, 332, 336, 337, 338, - 342, 343, 351, 0, 359, 368, 370, 371, 372, 373, - 383, 386, 387, 426, 427, 441, 442, 1786, 180, 0, - 186, 0, 187, 0, 1771, 185, 1918, 1953, 1850, 1864, - 1755, 1934, 0, 1896, 413, 1789, 1938, 1738, 1768, 1955, - 1774, 1777, 1858, 1704, 1827, 330, 1765, 1705, 0, 0, - 0, 1743, 1692, 1756, 1693, 1740, 238, 1736, 1899, 1830, - 1936, 1809, 1851, 1861, 237, 224, 1819, 1818, 1924, 1754, - 1753, 1856, 1913, 1935, 1808, 0, 0, 0, 0, 1945, - 289, 1910, 0, 439, 392, 311, 0, 0, 1804, 1919, - 1825, 1888, 1787, 1860, 1720, 1843, 1940, 1766, 1852, 1941, - 0, 0, 0, 0, 0, 1103, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 1848, 1932, 1759, 0, - 1799, 1857, 1960, 1691, 1844, 0, 1696, 1707, 1954, 1925, - 1750, 1751, 242, 0, 0, 0, 0, 0, 0, 0, - 1802, 1826, 1878, 1784, 0, 433, 1863, 1873, 1891, 1776, - 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, - 1745, 0, 1841, 0, 0, 0, 1712, 1698, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1798, 0, 0, 0, 1719, 1689, 1747, 1880, 1690, 1688, - 312, 1708, 1893, 1923, 1785, 278, 0, 1929, 1783, 1782, - 1867, 1713, 1903, 1769, 286, 1711, 179, 1706, 1714, 1767, - 325, 1877, 1885, 0, 182, 288, 1900, 1741, 1758, 225, - 0, 362, 1853, 432, 0, 256, 1834, 361, 290, 425, - 1868, 1931, 431, 1770, 407, 440, 444, 250, 1810, 215, - 389, 240, 234, 1749, 1890, 1695, 262, 347, 229, 282, - 1788, 1859, 1742, 221, 1871, 1842, 1905, 388, 422, 184, - 306, 423, 443, 0, 251, 380, 252, 406, 243, 216, - 350, 203, 414, 307, 317, 218, 220, 219, 197, 381, - 421, 209, 223, 1901, 1884, 1907, 1735, 1715, 1726, 1716, - 1757, 1933, 271, 263, 1908, 1906, 1760, 334, 206, 1823, - 1816, 1803, 1881, 435, 1956, 236, 1886, 437, 0, 375, - 374, 1773, 270, 1887, 0, 0, 357, 0, 279, 188, - 1912, 447, 202, 284, 415, 0, 255, 324, 1855, 335, - 181, 352, 302, 304, 301, 305, 260, 0, 0, 1883, - 354, 377, 420, 204, 395, 0, 0, 0, 367, 0, - 0, 1939, 296, 245, 249, 264, 275, 1854, 360, 396, - 438, 1845, 199, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 364, 397, 411, 369, 258, 399, 403, 400, - 401, 398, 402, 365, 366, 191, 405, 430, 210, 376, - 379, 446, 1879, 198, 193, 1927, 1902, 1836, 1791, 1797, - 1697, 0, 192, 1792, 1793, 1794, 1795, 1796, 1875, 1746, - 1762, 1734, 1849, 1733, 259, 1866, 428, 429, 226, 1709, - 1947, 194, 1710, 1946, 321, 329, 320, 1950, 1948, 424, - 1928, 1837, 1822, 1820, 1702, 1926, 1835, 1821, 285, 248, - 266, 345, 292, 346, 267, 315, 314, 316, 294, 1824, - 394, 295, 0, 189, 0, 393, 1937, 1962, 404, 207, - 1728, 1894, 419, 0, 353, 208, 257, 246, 344, 319, - 200, 269, 391, 283, 291, 1870, 1959, 333, 363, 214, - 434, 390, 241, 1724, 326, 1727, 1722, 1725, 1723, 1828, - 1829, 1942, 1943, 1944, 1882, 1717, 0, 1920, 1921, 0, - 1815, 1930, 1703, 0, 1898, 0, 0, 0, 1862, 1957, - 1775, 222, 0, 1699, 1700, 1701, 0, 1805, 1806, 0, - 0, 1916, 1915, 1914, 1917, 0, 1951, 1949, 1952, 1718, - 1739, 1761, 1811, 1812, 1814, 1846, 1847, 1892, 1865, 1874, - 1748, 1807, 341, 190, 201, 418, 213, 233, 231, 247, - 280, 303, 309, 339, 378, 384, 385, 408, 409, 410, - 412, 235, 0, 239, 212, 358, 211, 293, 272, 340, - 416, 417, 349, 228, 1833, 183, 195, 287, 1958, 356, - 254, 308, 382, 310, 276, 227, 445, 313, 355, 448, - 1895, 1840, 0, 1779, 1781, 1780, 1730, 1732, 1731, 1729, - 1961, 318, 1922, 1687, 1694, 1721, 1737, 1744, 1752, 1763, - 1764, 1772, 1778, 1790, 1800, 1801, 1817, 1831, 1832, 1839, - 1869, 1872, 1889, 1897, 1904, 1909, 1911, 436, 232, 1813, - 1838, 1876, 196, 205, 217, 230, 244, 253, 265, 268, - 273, 274, 277, 281, 297, 298, 299, 300, 322, 323, - 327, 328, 331, 332, 336, 337, 338, 342, 343, 351, - 0, 359, 368, 370, 371, 372, 373, 383, 386, 387, - 426, 427, 441, 442, 1786, 180, 0, 186, 0, 187, - 0, 1771, 185, 1918, 1953, 1850, 1864, 1755, 1934, 0, - 1896, 413, 1789, 1938, 1738, 1768, 1955, 1774, 1777, 1858, - 1704, 1827, 330, 1765, 1705, 0, 0, 0, 1743, 1692, - 1756, 1693, 1740, 238, 1736, 1899, 1830, 1936, 1809, 1851, - 1861, 237, 224, 1819, 1818, 1924, 1754, 1753, 1856, 1913, - 1935, 1808, 0, 0, 0, 0, 1945, 289, 1910, 0, - 439, 392, 311, 0, 0, 1804, 1919, 1825, 1888, 1787, - 1860, 1720, 1843, 1940, 1766, 1852, 1941, 0, 0, 0, - 0, 0, 3993, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 1848, 1932, 1759, 0, 1799, 1857, 1960, - 1691, 1844, 0, 1696, 1707, 1954, 1925, 1750, 1751, 242, - 0, 0, 0, 0, 0, 0, 0, 1802, 1826, 1878, - 1784, 0, 433, 1863, 1873, 1891, 1776, 348, 261, 0, - 0, 0, 0, 0, 0, 0, 0, 1745, 0, 1841, - 0, 0, 0, 1712, 1698, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1798, 0, 0, - 0, 1719, 1689, 1747, 1880, 1690, 1688, 312, 1708, 1893, - 1923, 1785, 278, 0, 1929, 1783, 1782, 1867, 1713, 1903, - 1769, 286, 1711, 179, 1706, 1714, 1767, 325, 1877, 1885, - 0, 182, 288, 1900, 1741, 1758, 225, 0, 362, 1853, - 432, 0, 256, 1834, 361, 290, 425, 1868, 1931, 431, - 1770, 407, 440, 444, 250, 1810, 215, 389, 240, 234, - 1749, 1890, 1695, 262, 347, 229, 282, 1788, 1859, 1742, - 221, 1871, 1842, 1905, 388, 422, 184, 306, 423, 443, - 0, 251, 380, 252, 406, 243, 216, 350, 203, 414, - 307, 317, 218, 220, 219, 197, 381, 421, 209, 223, - 1901, 1884, 1907, 1735, 1715, 1726, 3996, 3997, 3998, 271, - 263, 1908, 1906, 1760, 334, 206, 1823, 1816, 1803, 1881, - 435, 1956, 236, 1886, 437, 0, 375, 374, 1773, 270, - 1887, 0, 0, 357, 0, 279, 188, 1912, 447, 202, - 284, 415, 0, 255, 324, 1855, 335, 181, 352, 302, - 304, 301, 305, 260, 0, 0, 1883, 354, 377, 420, - 204, 395, 0, 0, 0, 367, 0, 0, 1939, 296, - 245, 249, 264, 275, 1854, 360, 396, 438, 1845, 199, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 364, - 397, 411, 369, 258, 399, 403, 400, 401, 398, 402, - 365, 366, 191, 405, 430, 210, 376, 379, 446, 1879, - 198, 193, 1927, 1902, 1836, 1791, 1797, 1697, 0, 192, - 1792, 1793, 1794, 1795, 1796, 1875, 1746, 1762, 1734, 1849, - 1733, 259, 1866, 428, 429, 226, 1709, 1947, 194, 1710, - 1946, 321, 329, 320, 1950, 1948, 424, 1928, 1837, 1822, - 1820, 1702, 1926, 1835, 1821, 285, 248, 266, 345, 292, - 346, 267, 315, 314, 316, 294, 1824, 394, 295, 0, - 189, 0, 393, 1937, 1962, 404, 207, 1728, 1894, 419, - 0, 353, 208, 257, 246, 344, 319, 200, 269, 391, - 283, 291, 1870, 1959, 333, 363, 214, 434, 390, 241, - 1724, 326, 1727, 1722, 1725, 1723, 1828, 1829, 1942, 1943, - 1944, 1882, 1717, 0, 1920, 1921, 0, 1815, 1930, 1703, - 0, 1898, 0, 0, 0, 1862, 1957, 1775, 222, 0, - 1699, 1700, 1701, 0, 1805, 1806, 0, 0, 1916, 1915, - 1914, 1917, 0, 1951, 1949, 1952, 1718, 1739, 1761, 1811, - 1812, 1814, 1846, 1847, 1892, 1865, 1874, 1748, 1807, 341, - 190, 201, 418, 213, 233, 231, 247, 280, 303, 309, - 339, 378, 384, 385, 408, 409, 410, 412, 235, 0, - 239, 212, 358, 211, 293, 272, 340, 416, 417, 349, - 228, 1833, 183, 195, 287, 1958, 356, 254, 308, 382, - 310, 276, 227, 445, 313, 355, 448, 1895, 1840, 0, - 1779, 1781, 1780, 1730, 1732, 1731, 1729, 1961, 318, 1922, - 1687, 1694, 1721, 1737, 1744, 1752, 1763, 1764, 1772, 1778, - 1790, 1800, 1801, 1817, 1831, 1832, 1839, 1869, 1872, 1889, - 1897, 1904, 1909, 1911, 436, 232, 1813, 1838, 1876, 196, - 205, 217, 230, 244, 253, 265, 268, 273, 274, 277, - 281, 297, 298, 299, 300, 322, 323, 327, 328, 331, - 332, 336, 337, 338, 342, 343, 351, 0, 359, 368, - 370, 371, 372, 373, 383, 386, 387, 426, 427, 441, - 442, 1786, 180, 0, 186, 0, 187, 0, 1771, 185, - 1918, 1953, 1850, 1864, 1755, 1934, 0, 1896, 413, 1789, - 1938, 1738, 1768, 1955, 1774, 1777, 1858, 1704, 1827, 330, - 1765, 1705, 0, 0, 0, 1743, 1692, 1756, 1693, 1740, - 238, 1736, 1899, 1830, 1936, 1809, 1851, 1861, 237, 224, - 1819, 1818, 1924, 1754, 1753, 1856, 1913, 1935, 1808, 0, - 0, 0, 0, 1945, 289, 1910, 0, 439, 392, 311, - 0, 0, 1804, 1919, 1825, 1888, 1787, 1860, 1720, 1843, - 1940, 1766, 1852, 1941, 0, 0, 0, 0, 0, 3102, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1848, 1932, 1759, 0, 1799, 1857, 1960, 1691, 1844, 0, - 1696, 1707, 1954, 1925, 1750, 1751, 242, 0, 0, 0, - 0, 0, 0, 0, 1802, 1826, 1878, 1784, 0, 433, - 1863, 1873, 1891, 1776, 348, 261, 0, 0, 0, 0, - 0, 0, 0, 0, 1745, 0, 1841, 0, 0, 0, - 1712, 1698, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1798, 0, 0, 0, 1719, 1689, - 1747, 1880, 1690, 1688, 312, 1708, 1893, 1923, 1785, 278, - 0, 1929, 1783, 1782, 1867, 1713, 1903, 1769, 286, 1711, - 179, 1706, 1714, 1767, 325, 1877, 1885, 0, 182, 288, - 1900, 1741, 1758, 225, 0, 362, 1853, 432, 0, 256, - 1834, 361, 290, 425, 1868, 1931, 431, 1770, 407, 440, - 444, 250, 1810, 215, 389, 240, 234, 1749, 1890, 1695, - 262, 347, 229, 282, 1788, 1859, 1742, 221, 1871, 1842, - 1905, 388, 422, 184, 306, 423, 443, 0, 251, 380, - 252, 406, 243, 216, 350, 203, 414, 307, 317, 218, - 220, 219, 197, 381, 421, 209, 223, 1901, 1884, 1907, - 1735, 1715, 1726, 1716, 1757, 1933, 271, 263, 1908, 1906, - 1760, 334, 206, 1823, 1816, 1803, 1881, 435, 1956, 236, - 1886, 437, 0, 375, 374, 1773, 270, 1887, 0, 0, - 357, 0, 279, 188, 1912, 447, 202, 284, 415, 0, - 255, 324, 1855, 335, 181, 352, 302, 304, 301, 305, - 260, 0, 0, 1883, 354, 377, 420, 204, 395, 0, - 0, 0, 367, 0, 0, 1939, 296, 245, 249, 264, - 275, 1854, 360, 396, 438, 1845, 199, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 364, 397, 411, 369, - 258, 399, 403, 400, 401, 398, 402, 365, 366, 191, - 405, 430, 210, 376, 379, 446, 1879, 198, 193, 1927, - 1902, 1836, 1791, 1797, 1697, 0, 192, 1792, 1793, 1794, - 1795, 1796, 1875, 1746, 1762, 1734, 1849, 1733, 259, 1866, - 428, 429, 226, 1709, 1947, 194, 1710, 1946, 321, 329, - 320, 1950, 1948, 424, 1928, 1837, 1822, 1820, 1702, 1926, - 1835, 1821, 285, 248, 266, 345, 292, 346, 267, 315, - 314, 316, 294, 1824, 394, 295, 0, 189, 0, 393, - 1937, 1962, 404, 207, 1728, 1894, 419, 0, 353, 208, - 257, 246, 344, 319, 200, 269, 391, 283, 291, 1870, - 1959, 333, 363, 214, 434, 390, 241, 1724, 326, 1727, - 1722, 1725, 1723, 1828, 1829, 1942, 1943, 1944, 1882, 1717, - 0, 1920, 1921, 0, 1815, 1930, 1703, 0, 1898, 0, - 0, 0, 1862, 1957, 1775, 222, 0, 1699, 1700, 1701, - 0, 1805, 1806, 0, 0, 1916, 1915, 1914, 1917, 0, - 1951, 1949, 1952, 1718, 1739, 1761, 1811, 1812, 1814, 1846, - 1847, 1892, 1865, 1874, 1748, 1807, 341, 190, 201, 418, - 213, 233, 231, 247, 280, 303, 309, 339, 378, 384, - 385, 408, 409, 410, 412, 235, 0, 239, 212, 358, - 211, 293, 272, 340, 416, 417, 349, 228, 1833, 183, - 195, 287, 1958, 356, 254, 308, 382, 310, 276, 227, - 445, 313, 355, 448, 1895, 1840, 0, 1779, 1781, 1780, - 1730, 1732, 1731, 1729, 1961, 318, 1922, 1687, 1694, 1721, - 1737, 1744, 1752, 1763, 1764, 1772, 1778, 1790, 1800, 1801, - 1817, 1831, 1832, 1839, 1869, 1872, 1889, 1897, 1904, 1909, - 1911, 436, 232, 1813, 1838, 1876, 196, 205, 217, 230, - 244, 253, 265, 268, 273, 274, 277, 281, 297, 298, - 299, 300, 322, 323, 327, 328, 331, 332, 336, 337, - 338, 342, 343, 351, 0, 359, 368, 370, 371, 372, - 373, 383, 386, 387, 426, 427, 441, 442, 1786, 180, - 0, 186, 0, 187, 0, 1771, 185, 1918, 1953, 1850, - 1864, 1755, 1934, 0, 1896, 413, 1789, 1938, 1738, 1768, - 1955, 1774, 1777, 1858, 1704, 1827, 330, 1765, 1705, 0, - 0, 0, 1743, 1692, 1756, 1693, 1740, 238, 1736, 1899, - 1830, 1936, 1809, 1851, 1861, 237, 224, 1819, 1818, 1924, - 1754, 1753, 1856, 1913, 1935, 1808, 0, 0, 0, 0, - 1945, 289, 1910, 0, 439, 392, 311, 0, 0, 1804, - 1919, 1825, 1888, 1787, 1860, 1720, 1843, 1940, 1766, 1852, - 1941, 0, 0, 0, 0, 0, 149, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1848, 1932, 1759, - 0, 1799, 1857, 1960, 1691, 1844, 0, 1696, 1707, 1954, - 1925, 1750, 1751, 242, 0, 0, 0, 0, 0, 0, - 0, 1802, 1826, 1878, 1784, 0, 433, 1863, 1873, 1891, - 1776, 348, 261, 0, 0, 0, 0, 0, 0, 0, - 0, 1745, 0, 1841, 0, 0, 0, 1712, 1698, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1798, 0, 0, 0, 1719, 1689, 1747, 1880, 1690, - 1688, 312, 1708, 1893, 1923, 1785, 278, 0, 1929, 1783, - 1782, 1867, 1713, 1903, 1769, 286, 1711, 179, 1706, 1714, - 1767, 325, 1877, 1885, 0, 182, 288, 1900, 1741, 1758, - 225, 0, 362, 1853, 432, 0, 256, 1834, 361, 290, - 425, 1868, 1931, 431, 1770, 407, 440, 444, 250, 1810, - 215, 389, 240, 234, 1749, 1890, 1695, 262, 347, 229, - 282, 1788, 1859, 1742, 221, 1871, 1842, 1905, 388, 422, - 184, 306, 423, 443, 0, 251, 380, 252, 406, 243, - 216, 350, 203, 414, 307, 317, 218, 220, 219, 197, - 381, 421, 209, 223, 1901, 1884, 1907, 1735, 1715, 1726, - 1716, 1757, 1933, 271, 263, 1908, 1906, 1760, 334, 206, - 1823, 1816, 1803, 1881, 435, 1956, 236, 1886, 437, 0, - 375, 374, 1773, 270, 1887, 0, 0, 357, 0, 279, - 188, 1912, 447, 202, 284, 415, 0, 255, 324, 1855, - 335, 181, 352, 302, 304, 301, 305, 260, 0, 0, - 1883, 354, 377, 420, 204, 395, 0, 0, 0, 367, - 0, 0, 1939, 296, 245, 249, 264, 275, 1854, 360, - 396, 438, 1845, 199, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 364, 397, 411, 369, 258, 399, 403, - 400, 401, 398, 402, 365, 366, 191, 405, 430, 210, - 376, 379, 446, 1879, 198, 193, 1927, 1902, 1836, 1791, - 1797, 1697, 0, 192, 1792, 1793, 1794, 1795, 1796, 1875, - 1746, 1762, 1734, 1849, 1733, 259, 1866, 428, 429, 226, - 1709, 1947, 194, 1710, 1946, 321, 329, 320, 1950, 1948, - 424, 1928, 1837, 1822, 1820, 1702, 1926, 1835, 1821, 285, - 248, 266, 345, 292, 346, 267, 315, 314, 316, 294, - 1824, 394, 295, 0, 189, 0, 393, 1937, 1962, 404, - 207, 1728, 1894, 419, 0, 353, 208, 257, 246, 344, - 319, 200, 269, 391, 283, 291, 1870, 1959, 333, 363, - 214, 434, 390, 241, 1724, 326, 1727, 1722, 1725, 1723, - 1828, 1829, 1942, 1943, 1944, 1882, 1717, 0, 1920, 1921, - 0, 1815, 1930, 1703, 0, 1898, 0, 0, 0, 1862, - 1957, 1775, 222, 0, 1699, 1700, 1701, 0, 1805, 1806, - 0, 0, 1916, 1915, 1914, 1917, 0, 1951, 1949, 1952, - 1718, 1739, 1761, 1811, 1812, 1814, 1846, 1847, 1892, 1865, - 1874, 1748, 1807, 341, 190, 201, 418, 213, 233, 231, - 247, 280, 303, 309, 339, 378, 384, 385, 408, 409, - 410, 412, 235, 0, 239, 212, 358, 211, 293, 272, - 340, 416, 417, 349, 228, 1833, 183, 195, 287, 1958, - 356, 254, 308, 382, 310, 276, 227, 445, 313, 355, - 448, 1895, 1840, 0, 1779, 1781, 1780, 1730, 1732, 1731, - 1729, 1961, 318, 1922, 1687, 1694, 1721, 1737, 1744, 1752, - 1763, 1764, 1772, 1778, 1790, 1800, 1801, 1817, 1831, 1832, - 1839, 1869, 1872, 1889, 1897, 1904, 1909, 1911, 436, 232, - 1813, 1838, 1876, 196, 205, 217, 230, 244, 253, 265, - 268, 273, 274, 277, 281, 297, 298, 299, 300, 322, - 323, 327, 328, 331, 332, 336, 337, 338, 342, 343, - 351, 0, 359, 368, 370, 371, 372, 373, 383, 386, - 387, 426, 427, 441, 442, 1786, 180, 0, 186, 0, - 187, 0, 1771, 185, 1918, 1953, 1850, 1864, 546, 413, - 540, 551, 533, 0, 0, 0, 0, 0, 0, 0, - 330, 0, 0, 597, 0, 0, 0, 0, 0, 0, - 0, 238, 0, 0, 541, 0, 0, 0, 0, 237, - 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 289, 0, 0, 439, 392, - 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 595, 0, 594, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 242, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 433, 0, 0, 0, 0, 348, 261, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 532, - 531, 534, 0, 0, 0, 312, 0, 0, 0, 539, - 278, 0, 0, 0, 0, 0, 0, 0, 0, 286, - 0, 179, 0, 0, 0, 325, 543, 0, 0, 182, - 288, 547, 0, 0, 225, 0, 362, 0, 432, 0, - 256, 0, 361, 290, 425, 0, 550, 431, 0, 407, - 440, 444, 250, 0, 215, 389, 240, 234, 0, 0, - 0, 262, 347, 229, 282, 0, 0, 0, 221, 0, - 0, 0, 388, 422, 184, 306, 423, 443, 535, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 271, 263, 0, - 0, 0, 334, 206, 0, 0, 0, 0, 435, 0, - 236, 0, 437, 0, 375, 374, 538, 270, 0, 0, - 0, 357, 0, 279, 188, 0, 447, 202, 284, 415, - 0, 255, 324, 0, 335, 181, 352, 302, 304, 301, - 305, 260, 0, 0, 0, 600, 377, 420, 204, 395, - 536, 537, 544, 545, 548, 549, 552, 296, 245, 249, - 264, 275, 0, 360, 396, 438, 0, 199, 555, 556, - 557, 558, 559, 560, 561, 562, 563, 564, 565, 566, - 567, 568, 569, 570, 571, 572, 573, 574, 575, 576, - 577, 578, 579, 580, 581, 582, 583, 584, 585, 586, - 587, 588, 589, 590, 591, 592, 593, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 0, 198, 193, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 259, - 0, 428, 429, 226, 0, 0, 194, 0, 0, 321, - 329, 320, 0, 0, 424, 0, 0, 0, 0, 0, - 0, 0, 0, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 0, 394, 295, 0, 189, 0, - 393, 0, 0, 404, 207, 0, 0, 419, 0, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 0, 0, 333, 363, 214, 434, 390, 241, 0, 326, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 222, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 0, - 183, 195, 287, 0, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 318, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 436, 232, 0, 0, 0, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 542, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 0, - 180, 0, 186, 0, 187, 0, 0, 185, 546, 413, - 540, 551, 533, 0, 0, 0, 0, 0, 0, 0, - 330, 0, 0, 525, 0, 0, 0, 0, 0, 0, - 0, 238, 0, 0, 541, 0, 0, 0, 0, 237, - 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 289, 0, 0, 439, 392, - 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 595, 0, 594, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 242, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 433, 0, 0, 0, 0, 348, 261, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 532, - 531, 534, 0, 0, 0, 312, 0, 0, 0, 539, - 278, 0, 0, 0, 0, 0, 0, 0, 0, 286, - 0, 179, 0, 0, 0, 325, 543, 0, 0, 182, - 288, 547, 0, 0, 225, 0, 362, 0, 432, 0, - 256, 0, 361, 290, 425, 0, 550, 431, 0, 407, - 440, 444, 250, 0, 215, 389, 240, 234, 0, 0, - 0, 262, 347, 229, 282, 0, 0, 0, 221, 0, - 0, 0, 388, 422, 184, 306, 423, 443, 535, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 271, 263, 0, - 0, 0, 334, 206, 0, 0, 0, 0, 435, 0, - 236, 0, 437, 0, 375, 374, 538, 270, 0, 0, - 0, 357, 0, 279, 188, 0, 447, 202, 284, 415, - 0, 255, 324, 0, 335, 181, 352, 302, 304, 301, - 305, 260, 0, 0, 0, 528, 377, 420, 204, 395, - 536, 537, 544, 545, 548, 549, 552, 296, 245, 249, - 264, 275, 0, 360, 396, 438, 0, 199, 555, 556, - 557, 558, 559, 560, 561, 562, 563, 564, 565, 566, - 567, 568, 569, 570, 571, 572, 573, 574, 575, 576, - 577, 578, 579, 580, 581, 582, 583, 584, 585, 586, - 587, 588, 589, 590, 591, 592, 593, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 0, 198, 193, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 259, - 0, 428, 429, 226, 0, 0, 194, 0, 0, 321, - 329, 320, 0, 0, 424, 0, 0, 0, 0, 0, - 0, 0, 0, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 0, 394, 295, 0, 189, 0, - 393, 0, 0, 404, 207, 0, 0, 419, 0, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 0, 0, 333, 363, 214, 434, 390, 241, 0, 326, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 222, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 0, - 183, 195, 287, 0, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 318, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 436, 232, 0, 0, 0, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 542, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 413, - 180, 0, 186, 0, 187, 0, 0, 185, 0, 0, - 330, 0, 0, 0, 0, 0, 0, 1409, 0, 0, - 0, 238, 0, 0, 0, 0, 0, 0, 0, 237, - 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 159, 176, 177, 0, 289, 0, 458, 439, 392, - 311, 461, 460, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1410, 0, 1411, 0, 0, 0, 0, 0, 0, 158, - 0, 0, 0, 0, 459, 0, 1405, 1406, 1404, 0, - 0, 0, 0, 0, 0, 0, 0, 242, 0, 0, - 0, 0, 0, 0, 0, 1407, 0, 0, 0, 0, - 433, 0, 0, 0, 0, 348, 261, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 312, 0, 0, 0, 0, - 278, 178, 0, 0, 0, 0, 0, 0, 0, 286, - 0, 179, 0, 0, 0, 325, 0, 0, 164, 182, - 288, 0, 0, 0, 225, 0, 362, 0, 432, 457, - 256, 0, 361, 290, 425, 0, 0, 431, 0, 407, - 440, 444, 250, 0, 215, 389, 240, 234, 0, 0, - 0, 262, 347, 229, 282, 0, 0, 0, 221, 0, - 0, 0, 388, 422, 184, 306, 423, 443, 153, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 271, 263, 0, - 0, 0, 334, 206, 0, 0, 0, 0, 435, 0, - 236, 0, 437, 166, 375, 374, 0, 270, 0, 167, - 157, 357, 168, 279, 188, 0, 447, 202, 284, 415, - 456, 255, 324, 0, 335, 181, 352, 302, 304, 301, - 305, 260, 162, 169, 0, 354, 377, 420, 204, 395, - 160, 163, 171, 367, 172, 173, 0, 296, 245, 249, - 264, 275, 0, 360, 396, 438, 0, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 0, 198, 193, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 259, - 0, 428, 429, 226, 0, 0, 194, 0, 0, 321, - 329, 320, 0, 0, 424, 0, 0, 0, 0, 0, - 0, 0, 0, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 0, 394, 295, 0, 189, 0, - 393, 0, 0, 404, 207, 0, 0, 419, 165, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 0, 0, 333, 363, 214, 434, 390, 241, 0, 326, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 174, 175, 161, 0, 0, 0, 222, 151, 0, 0, - 0, 152, 0, 0, 154, 155, 0, 0, 0, 0, - 156, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 0, - 183, 195, 287, 0, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 318, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 436, 232, 0, 0, 0, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 170, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 413, - 180, 0, 186, 0, 187, 0, 0, 185, 0, 0, - 330, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 238, 0, 0, 0, 0, 0, 0, 0, 237, - 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 159, 176, 177, 0, 289, 0, 458, 439, 392, - 311, 461, 460, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1103, 0, 0, 0, 0, 0, 0, 0, 0, 158, - 0, 0, 0, 0, 459, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 242, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 433, 0, 0, 0, 0, 348, 261, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 312, 0, 0, 0, 0, - 278, 178, 0, 0, 0, 0, 0, 0, 0, 286, - 1105, 179, 0, 1101, 0, 325, 0, 0, 164, 182, - 288, 0, 0, 0, 225, 1100, 362, 0, 432, 457, - 256, 0, 361, 290, 425, 0, 0, 431, 0, 407, - 440, 444, 250, 0, 215, 389, 240, 234, 0, 0, - 0, 262, 347, 229, 282, 0, 0, 0, 221, 0, - 0, 0, 388, 422, 184, 306, 423, 443, 153, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 271, 263, 0, - 0, 0, 334, 206, 0, 0, 0, 0, 435, 0, - 236, 0, 437, 166, 375, 374, 0, 270, 0, 167, - 157, 357, 168, 279, 188, 0, 447, 202, 284, 415, - 456, 255, 324, 0, 335, 181, 352, 302, 304, 301, - 305, 260, 162, 169, 0, 354, 377, 420, 204, 395, - 160, 163, 171, 367, 172, 173, 0, 296, 245, 249, - 264, 275, 0, 360, 396, 438, 0, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 0, 198, 193, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 259, - 0, 428, 429, 226, 0, 0, 194, 0, 0, 321, - 329, 320, 0, 0, 424, 0, 0, 0, 0, 0, - 0, 0, 0, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 0, 394, 295, 0, 189, 0, - 393, 0, 0, 404, 207, 0, 0, 419, 165, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 0, 0, 333, 363, 214, 434, 390, 241, 0, 326, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 174, 175, 161, 0, 0, 0, 222, 151, 0, 0, - 0, 152, 0, 0, 154, 155, 0, 0, 0, 0, - 156, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 0, - 183, 195, 287, 0, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 318, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 436, 232, 0, 0, 0, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 170, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 413, - 180, 0, 186, 0, 187, 0, 0, 185, 0, 0, - 330, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 238, 0, 0, 0, 0, 0, 0, 0, 237, - 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 159, 176, 177, 0, 289, 0, 458, 439, 392, - 311, 461, 460, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1410, 0, 1411, 0, 0, 0, 0, 0, 0, 158, - 0, 0, 0, 0, 459, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 242, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 433, 0, 0, 0, 0, 348, 261, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 312, 0, 0, 0, 0, - 278, 178, 0, 0, 0, 0, 0, 0, 0, 286, - 0, 179, 0, 0, 0, 325, 0, 0, 164, 182, - 288, 0, 0, 0, 225, 2181, 362, 0, 432, 457, - 256, 0, 361, 290, 425, 0, 0, 431, 0, 407, - 440, 444, 250, 0, 215, 389, 240, 234, 0, 0, - 0, 262, 347, 229, 282, 0, 0, 0, 221, 0, - 0, 0, 388, 422, 184, 306, 423, 443, 153, 251, - 380, 252, 406, 243, 216, 350, 203, 414, 307, 317, - 218, 220, 219, 197, 381, 421, 209, 223, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 271, 263, 0, - 0, 0, 334, 206, 0, 0, 0, 0, 435, 0, - 236, 0, 437, 166, 375, 374, 0, 270, 0, 167, - 157, 357, 168, 279, 188, 0, 447, 202, 284, 415, - 456, 255, 324, 0, 335, 181, 352, 302, 304, 301, - 305, 260, 162, 169, 0, 354, 377, 420, 204, 395, - 160, 163, 171, 367, 172, 173, 0, 296, 245, 249, - 264, 275, 0, 360, 396, 438, 0, 199, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 364, 397, 411, - 369, 258, 399, 403, 400, 401, 398, 402, 365, 366, - 191, 405, 430, 210, 376, 379, 446, 0, 198, 193, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 259, - 0, 428, 429, 226, 0, 0, 194, 0, 0, 321, - 329, 320, 0, 0, 424, 0, 0, 0, 0, 0, - 0, 0, 0, 285, 248, 266, 345, 292, 346, 267, - 315, 314, 316, 294, 0, 394, 295, 0, 189, 0, - 393, 0, 0, 404, 207, 0, 0, 419, 165, 353, - 208, 257, 246, 344, 319, 200, 269, 391, 283, 291, - 0, 0, 333, 363, 214, 434, 390, 241, 0, 326, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 174, 175, 161, 0, 0, 0, 222, 151, 0, 0, - 0, 152, 0, 0, 154, 155, 0, 0, 0, 0, - 156, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 341, 190, 201, - 418, 213, 233, 231, 247, 280, 303, 309, 339, 378, - 384, 385, 408, 409, 410, 412, 235, 0, 239, 212, - 358, 211, 293, 272, 340, 416, 417, 349, 228, 0, - 183, 195, 287, 0, 356, 254, 308, 382, 310, 276, - 227, 445, 313, 355, 448, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 318, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 436, 232, 0, 0, 0, 196, 205, 217, - 230, 244, 253, 265, 268, 273, 274, 277, 281, 297, - 298, 299, 300, 322, 323, 327, 328, 331, 332, 336, - 337, 338, 342, 343, 351, 170, 359, 368, 370, 371, - 372, 373, 383, 386, 387, 426, 427, 441, 442, 0, - 180, 0, 186, 0, 187, 40, 413, 185, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 1345, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 0, 0, 0, 0, 632, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 88, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 633, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 643, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 626, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 3229, 0, 0, 0, 0, 3231, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1968, 0, 1970, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1968, 0, 1966, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3111, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3695, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3693, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3231, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3247, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3242, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3240, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3238, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1968, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1153, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1142, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 458, 439, 392, 311, 461, 460, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 379, 380, 413, 428, 385, 267, 306, 308, 415, 420, + 416, 417, 414, 419, 418, 381, 382, 196, 422, 447, + 217, 392, 395, 466, 0, 204, 198, 0, 0, 0, + 0, 0, 0, 0, 197, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 268, 0, 445, 446, + 233, 0, 0, 199, 0, 0, 334, 341, 333, 0, + 0, 441, 0, 0, 0, 0, 0, 0, 0, 0, + 295, 256, 275, 358, 302, 359, 276, 328, 327, 329, + 304, 0, 410, 305, 0, 194, 0, 409, 0, 0, + 421, 214, 0, 0, 436, 0, 366, 215, 266, 254, + 357, 332, 206, 278, 407, 293, 301, 0, 0, 345, + 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 354, 195, 207, 435, 220, + 240, 238, 255, 290, 315, 322, 351, 394, 400, 401, + 425, 426, 427, 429, 243, 318, 247, 219, 372, 218, + 303, 281, 353, 433, 434, 362, 235, 0, 187, 200, + 297, 0, 369, 263, 321, 398, 323, 285, 234, 464, + 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 453, 239, 0, 0, 0, 201, 211, 224, 237, 252, + 0, 262, 274, 277, 282, 283, 287, 291, 309, 310, + 311, 312, 335, 336, 339, 340, 343, 344, 348, 349, + 350, 355, 356, 364, 0, 373, 384, 386, 387, 388, + 389, 399, 402, 403, 443, 444, 460, 461, 430, 184, + 0, 190, 0, 191, 193, 0, 189, 0, 0, 342, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 246, 0, 0, 0, 0, 0, 0, 0, 245, 231, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 459, 0, 0, 299, 0, 0, 457, 408, 324, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 705, + 1133, 706, 708, 709, 710, 711, 0, 0, 0, 707, + 2273, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 450, + 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 325, 0, 0, 0, 0, 288, + 0, 0, 0, 0, 0, 0, 0, 0, 296, 0, + 183, 0, 0, 0, 338, 0, 0, 0, 186, 298, + 0, 0, 0, 702, 0, 377, 0, 449, 0, 265, + 0, 376, 300, 442, 0, 0, 448, 0, 424, 458, + 463, 258, 0, 222, 405, 248, 241, 0, 0, 0, + 271, 360, 236, 292, 0, 0, 0, 228, 0, 0, + 0, 404, 439, 188, 319, 440, 462, 0, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 272, 0, 0, 0, 346, 212, 0, 0, + 0, 0, 452, 0, 244, 0, 454, 0, 391, 390, + 0, 279, 0, 0, 0, 370, 0, 289, 192, 0, + 467, 208, 294, 432, 0, 264, 337, 0, 347, 185, + 365, 314, 316, 313, 317, 269, 0, 0, 0, 367, + 393, 437, 210, 411, 0, 0, 0, 383, 0, 0, + 0, 307, 253, 257, 273, 284, 0, 374, 412, 455, + 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 0, 204, 198, 0, 0, + 0, 0, 0, 0, 0, 197, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 268, 0, 703, + 704, 233, 0, 0, 199, 0, 0, 334, 341, 333, + 0, 0, 441, 0, 0, 0, 0, 0, 0, 0, + 0, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 0, 410, 305, 0, 194, 0, 409, 0, + 0, 421, 214, 0, 0, 436, 0, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 0, 0, + 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 0, 187, + 200, 297, 0, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 453, 239, 0, 0, 0, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 0, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 430, + 184, 0, 190, 0, 191, 193, 0, 189, 0, 0, + 342, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 0, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 459, 0, 0, 299, 0, 0, 457, 408, + 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 151, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, + 288, 0, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 0, 0, 0, 186, + 298, 0, 0, 0, 232, 0, 377, 0, 449, 0, + 265, 0, 376, 300, 442, 0, 0, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 155, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 0, 0, 452, 0, 244, 0, 454, 0, 391, + 390, 0, 279, 0, 0, 0, 370, 0, 289, 192, + 0, 467, 208, 294, 432, 0, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 0, 0, 0, + 367, 393, 437, 210, 411, 0, 0, 0, 383, 0, + 0, 0, 307, 253, 257, 273, 284, 0, 374, 412, + 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 0, 0, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 0, 0, 0, + 0, 0, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 0, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 229, 153, 0, 0, + 0, 154, 0, 0, 156, 157, 0, 0, 0, 0, + 158, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 0, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 0, 0, 633, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 0, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 430, 184, 0, 190, 0, 191, 193, 0, 189, 0, + 0, 342, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, + 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 459, 0, 0, 299, 0, 0, 457, + 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 151, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, + 0, 288, 0, 0, 0, 0, 0, 0, 0, 0, + 296, 0, 183, 0, 0, 0, 338, 0, 0, 0, + 186, 298, 0, 0, 0, 232, 0, 377, 0, 449, + 0, 265, 0, 376, 300, 442, 0, 0, 448, 0, + 424, 458, 463, 258, 0, 222, 405, 248, 241, 0, + 0, 0, 271, 360, 236, 292, 0, 0, 0, 228, + 0, 0, 0, 404, 439, 188, 319, 440, 462, 155, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 272, 0, 0, 0, 346, 212, + 0, 0, 0, 0, 452, 0, 244, 0, 454, 0, + 391, 390, 0, 279, 0, 0, 0, 370, 0, 289, + 192, 0, 467, 208, 294, 432, 0, 264, 337, 0, + 347, 185, 365, 314, 316, 313, 317, 269, 0, 0, + 0, 367, 393, 437, 210, 411, 0, 0, 0, 383, + 0, 0, 0, 307, 253, 257, 273, 284, 0, 374, + 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 0, 204, 198, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 268, + 0, 445, 446, 233, 0, 0, 199, 0, 0, 334, + 341, 333, 0, 0, 441, 0, 0, 0, 0, 0, + 0, 0, 0, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 0, 410, 305, 0, 194, 0, + 409, 0, 0, 421, 214, 0, 0, 436, 0, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 229, 153, 0, + 0, 0, 154, 0, 0, 156, 157, 0, 0, 0, + 0, 158, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 0, 187, 200, 297, 0, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 453, 239, 0, 0, 0, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 0, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 430, 184, 0, 190, 0, 191, 193, 0, 189, + 0, 0, 342, 0, 0, 4327, 0, 0, 0, 0, + 0, 0, 0, 246, 4325, 0, 0, 0, 0, 0, + 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 459, 0, 0, 299, 0, 0, + 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 616, 617, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 250, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, + 0, 0, 288, 0, 0, 0, 0, 0, 0, 0, + 0, 296, 0, 183, 0, 0, 0, 338, 0, 0, + 0, 186, 298, 0, 0, 0, 232, 0, 377, 0, + 449, 0, 265, 0, 376, 300, 442, 0, 0, 448, + 0, 424, 458, 463, 258, 0, 222, 405, 248, 241, + 0, 0, 0, 271, 360, 236, 292, 0, 0, 0, + 228, 0, 0, 0, 404, 439, 188, 319, 440, 462, + 0, 259, 396, 260, 423, 251, 223, 363, 202, 0, + 0, 0, 242, 286, 0, 0, 465, 456, 213, 261, + 371, 375, 352, 209, 431, 320, 330, 225, 227, 226, + 203, 397, 438, 216, 230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 272, 0, 0, 0, 346, + 212, 0, 0, 0, 0, 452, 0, 244, 0, 454, + 0, 391, 390, 0, 279, 0, 4326, 0, 370, 0, + 289, 192, 0, 467, 208, 294, 432, 0, 264, 337, + 0, 347, 185, 365, 314, 316, 313, 317, 269, 0, + 0, 0, 367, 393, 437, 210, 411, 0, 0, 0, + 383, 0, 0, 0, 307, 253, 257, 273, 284, 0, + 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 379, 380, 413, 428, 385, 267, + 306, 308, 415, 420, 416, 417, 414, 419, 418, 381, + 382, 196, 422, 447, 217, 392, 395, 466, 0, 204, + 198, 0, 0, 0, 0, 0, 0, 0, 197, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 268, 0, 445, 446, 233, 0, 0, 199, 0, 0, + 334, 341, 333, 0, 0, 441, 0, 0, 0, 0, + 0, 0, 0, 0, 295, 256, 275, 358, 302, 359, + 276, 328, 327, 329, 304, 0, 410, 305, 0, 194, + 0, 409, 0, 0, 421, 214, 0, 0, 436, 0, + 366, 215, 266, 254, 357, 332, 206, 278, 407, 293, + 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 229, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 354, + 195, 207, 435, 220, 240, 238, 255, 290, 315, 322, + 351, 394, 400, 401, 425, 426, 427, 429, 243, 318, + 247, 219, 372, 218, 303, 281, 353, 433, 434, 362, + 235, 0, 187, 200, 297, 0, 369, 263, 321, 398, + 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 453, 239, 0, 0, 0, 201, + 211, 224, 237, 252, 0, 262, 274, 277, 282, 283, + 287, 291, 309, 310, 311, 312, 335, 336, 339, 340, + 343, 344, 348, 349, 350, 355, 356, 364, 0, 373, + 384, 386, 387, 388, 389, 399, 402, 403, 443, 444, + 460, 461, 430, 184, 0, 190, 0, 191, 193, 0, + 189, 0, 0, 342, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 246, 0, 0, 0, 0, 0, + 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 459, 0, 0, 299, 0, + 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 2919, 0, 450, 0, 0, 0, 0, 361, 270, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, + 0, 0, 0, 288, 0, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 183, 0, 0, 0, 338, 0, + 0, 0, 186, 298, 0, 0, 0, 232, 0, 377, + 0, 449, 0, 265, 0, 376, 300, 442, 0, 0, + 448, 0, 424, 458, 463, 258, 0, 222, 405, 248, + 241, 0, 0, 0, 271, 360, 236, 292, 2920, 2921, + 0, 228, 0, 0, 0, 404, 439, 188, 319, 440, + 462, 0, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 272, 0, 0, 0, + 346, 212, 0, 0, 0, 0, 452, 0, 244, 0, + 454, 0, 391, 390, 0, 279, 0, 0, 0, 370, + 0, 289, 192, 0, 467, 208, 294, 432, 0, 264, + 337, 0, 347, 185, 365, 314, 316, 313, 317, 269, + 0, 0, 0, 367, 393, 437, 210, 411, 0, 0, + 0, 383, 0, 0, 0, 307, 253, 257, 273, 284, + 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 0, + 204, 198, 0, 0, 0, 0, 0, 0, 0, 197, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 268, 0, 445, 446, 233, 0, 0, 199, 0, + 0, 334, 341, 333, 0, 0, 441, 0, 0, 0, + 0, 0, 0, 0, 0, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 0, 410, 305, 0, + 194, 0, 409, 0, 0, 421, 214, 0, 0, 436, + 0, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 0, 0, 345, 378, 221, 451, 406, 249, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 229, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 0, 187, 200, 297, 0, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 331, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 453, 239, 0, 0, 0, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 0, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 430, 184, 0, 190, 0, 191, 193, + 0, 189, 0, 0, 342, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, + 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, + 0, 0, 0, 2420, 0, 0, 459, 0, 0, 299, + 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2856, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 450, 0, 0, 0, 0, 361, + 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, + 0, 0, 0, 2419, 288, 0, 0, 0, 0, 0, + 0, 0, 0, 296, 0, 183, 0, 0, 0, 338, + 0, 0, 0, 186, 298, 0, 0, 0, 232, 0, + 377, 0, 449, 0, 265, 0, 376, 300, 442, 0, + 0, 448, 0, 424, 458, 463, 258, 0, 222, 405, + 248, 241, 0, 0, 0, 271, 360, 236, 292, 0, + 0, 0, 228, 0, 0, 0, 404, 439, 188, 319, + 440, 462, 0, 259, 396, 260, 423, 251, 223, 363, + 202, 0, 0, 0, 242, 286, 0, 0, 465, 456, + 213, 261, 371, 375, 352, 209, 431, 320, 330, 225, + 227, 226, 203, 397, 438, 216, 230, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 272, 0, 0, + 0, 346, 212, 0, 0, 0, 0, 452, 0, 244, + 0, 454, 0, 391, 390, 0, 279, 0, 0, 0, + 370, 0, 289, 192, 0, 467, 208, 294, 432, 0, + 264, 337, 0, 347, 185, 365, 314, 316, 313, 317, + 269, 0, 0, 0, 367, 393, 437, 210, 411, 0, + 0, 0, 383, 0, 0, 0, 307, 253, 257, 273, + 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 379, 380, 413, 428, + 385, 267, 306, 308, 415, 420, 416, 417, 414, 419, + 418, 381, 382, 196, 422, 447, 217, 392, 395, 466, + 0, 204, 198, 0, 0, 0, 0, 0, 0, 0, + 197, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 268, 0, 445, 446, 233, 0, 0, 199, + 0, 0, 334, 341, 333, 0, 0, 441, 0, 0, + 0, 0, 0, 0, 0, 0, 295, 256, 275, 358, + 302, 359, 276, 328, 327, 329, 304, 0, 410, 305, + 0, 194, 0, 409, 0, 0, 421, 214, 0, 0, + 436, 0, 366, 215, 266, 254, 357, 332, 206, 278, + 407, 293, 301, 0, 0, 345, 378, 221, 451, 406, + 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 354, 195, 207, 435, 220, 240, 238, 255, 290, + 315, 322, 351, 394, 400, 401, 425, 426, 427, 429, + 243, 318, 247, 219, 372, 218, 303, 281, 353, 433, + 434, 362, 235, 0, 187, 200, 297, 0, 369, 263, + 321, 398, 323, 285, 234, 464, 326, 368, 468, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 453, 239, 0, 0, + 0, 201, 211, 224, 237, 252, 0, 262, 274, 277, + 282, 283, 287, 291, 309, 310, 311, 312, 335, 336, + 339, 340, 343, 344, 348, 349, 350, 355, 356, 364, + 0, 373, 384, 386, 387, 388, 389, 399, 402, 403, + 443, 444, 460, 461, 430, 184, 0, 190, 0, 191, + 193, 0, 189, 0, 0, 342, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 246, 0, 0, 0, + 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 459, 0, 0, + 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 616, 617, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 450, 0, 0, 0, 0, + 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 325, 0, 0, 0, 0, 288, 0, 0, 0, 0, + 0, 0, 0, 0, 296, 0, 183, 0, 0, 0, + 338, 0, 0, 0, 186, 298, 0, 0, 0, 232, + 0, 377, 0, 449, 0, 265, 0, 376, 300, 442, + 0, 0, 448, 0, 424, 458, 463, 258, 0, 222, + 405, 248, 241, 0, 0, 0, 271, 360, 236, 292, + 0, 0, 0, 228, 0, 0, 0, 404, 439, 188, + 319, 440, 462, 0, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 272, 0, + 0, 0, 346, 212, 0, 0, 0, 0, 452, 0, + 244, 0, 454, 0, 391, 390, 0, 279, 0, 0, + 0, 370, 0, 289, 192, 0, 467, 208, 294, 432, + 0, 264, 337, 0, 347, 185, 365, 314, 316, 313, + 317, 269, 0, 0, 0, 367, 393, 437, 210, 411, + 0, 0, 0, 383, 0, 0, 0, 307, 253, 257, + 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 0, 204, 198, 0, 0, 0, 0, 0, 0, + 0, 197, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 268, 0, 445, 446, 233, 0, 0, + 199, 0, 0, 334, 341, 333, 0, 0, 441, 0, + 0, 0, 0, 0, 0, 0, 0, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 0, 410, + 305, 0, 194, 0, 409, 0, 0, 421, 214, 0, + 0, 436, 0, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 0, 0, 345, 378, 221, 451, + 406, 249, 0, 0, 0, 0, 2040, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 0, 187, 200, 297, 0, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 453, 239, 0, + 0, 0, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 0, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 430, 184, 0, 190, 0, + 191, 193, 0, 189, 0, 0, 342, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 246, 1592, 0, + 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 459, 0, + 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1591, 1133, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 450, 0, 0, 0, + 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 325, 0, 0, 0, 0, 288, 0, 0, 0, + 0, 0, 0, 0, 0, 296, 0, 183, 0, 0, + 0, 338, 0, 0, 0, 186, 298, 0, 0, 0, + 232, 0, 377, 0, 449, 0, 265, 0, 376, 300, + 442, 0, 0, 448, 0, 424, 458, 463, 258, 0, + 222, 405, 248, 241, 0, 0, 0, 271, 360, 236, + 292, 0, 0, 0, 228, 0, 0, 0, 404, 439, + 188, 319, 440, 462, 0, 259, 396, 260, 423, 251, + 223, 363, 202, 0, 0, 0, 242, 286, 0, 0, + 465, 456, 213, 261, 371, 375, 352, 209, 431, 320, + 330, 225, 227, 226, 203, 397, 438, 216, 230, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 272, + 0, 0, 0, 346, 212, 0, 0, 0, 0, 452, + 0, 244, 0, 454, 0, 391, 390, 0, 279, 0, + 0, 0, 370, 0, 289, 192, 0, 467, 208, 294, + 432, 0, 264, 337, 0, 347, 185, 365, 314, 316, + 313, 317, 269, 0, 0, 0, 367, 393, 437, 210, + 411, 0, 0, 0, 383, 0, 0, 0, 307, 253, + 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 379, 380, + 413, 428, 385, 267, 306, 308, 415, 420, 416, 417, + 414, 419, 418, 381, 382, 196, 422, 447, 217, 392, + 395, 466, 0, 204, 198, 0, 0, 0, 0, 0, + 0, 0, 197, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 268, 0, 445, 446, 233, 0, + 0, 199, 0, 0, 334, 341, 333, 0, 0, 441, + 0, 0, 0, 0, 0, 0, 0, 0, 295, 256, + 275, 358, 302, 359, 276, 328, 327, 329, 304, 0, + 410, 305, 0, 194, 0, 409, 0, 0, 421, 214, + 0, 0, 436, 0, 366, 215, 266, 254, 357, 332, + 206, 278, 407, 293, 301, 0, 0, 345, 378, 221, + 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 354, 195, 207, 435, 220, 240, 238, + 255, 290, 315, 322, 351, 394, 400, 401, 425, 426, + 427, 429, 243, 318, 247, 219, 372, 218, 303, 281, + 353, 433, 434, 362, 235, 0, 187, 200, 297, 0, + 369, 263, 321, 398, 323, 285, 234, 464, 326, 368, + 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 453, 239, + 0, 0, 0, 201, 211, 224, 237, 252, 0, 262, + 274, 277, 282, 283, 287, 291, 309, 310, 311, 312, + 335, 336, 339, 340, 343, 344, 348, 349, 350, 355, + 356, 364, 0, 373, 384, 386, 387, 388, 389, 399, + 402, 403, 443, 444, 460, 461, 430, 184, 0, 190, + 0, 191, 193, 0, 189, 0, 0, 342, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 246, 0, + 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 459, + 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 616, 617, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 450, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 459, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 457, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 456, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 0, 0, 0, 0, 632, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2970, 633, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 626, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 0, 0, 0, 0, 632, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 633, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 626, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 503, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 505, 502, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 2441, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 2327, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 1539, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 143, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 159, 176, - 177, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 158, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 178, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 164, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 166, 375, 374, 0, 270, 0, 167, 157, 357, 168, - 279, 188, 0, 447, 202, 284, 415, 148, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 162, - 169, 0, 354, 377, 420, 204, 395, 160, 163, 171, - 367, 172, 173, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 165, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 174, 175, 161, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 170, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 1422, 1421, 1431, 1432, 1424, 1425, - 1426, 1427, 1428, 1429, 1430, 1423, 0, 0, 1433, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, + 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 680, 679, - 682, 683, 684, 685, 0, 0, 0, 681, 2225, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, + 0, 0, 325, 0, 0, 0, 0, 288, 0, 0, + 0, 0, 0, 0, 0, 0, 296, 0, 183, 0, + 0, 0, 338, 0, 0, 0, 186, 298, 0, 0, + 0, 232, 0, 377, 0, 449, 0, 265, 0, 376, + 300, 442, 0, 0, 448, 0, 424, 458, 463, 258, + 0, 222, 405, 248, 241, 0, 0, 0, 271, 360, + 236, 292, 0, 0, 0, 228, 0, 0, 0, 404, + 439, 188, 319, 440, 462, 0, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 272, 0, 0, 0, 346, 212, 0, 0, 0, 0, + 452, 0, 244, 0, 454, 0, 391, 390, 0, 279, + 0, 0, 0, 370, 0, 289, 192, 0, 467, 208, + 294, 432, 0, 264, 337, 0, 347, 185, 365, 314, + 316, 313, 317, 269, 0, 0, 0, 367, 393, 437, + 210, 411, 0, 0, 0, 383, 0, 0, 0, 307, + 253, 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 0, 204, 198, 0, 0, 0, 0, + 0, 0, 0, 197, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 268, 0, 445, 446, 233, + 0, 0, 199, 0, 0, 334, 341, 333, 0, 0, + 441, 0, 0, 0, 0, 0, 0, 0, 0, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 0, 410, 305, 0, 194, 0, 409, 0, 0, 421, + 214, 0, 0, 436, 0, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 0, 0, 345, 378, + 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 0, 187, 200, 297, + 0, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 611, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2753, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 453, + 239, 0, 0, 0, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 0, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 430, 184, 0, + 190, 0, 191, 193, 0, 189, 0, 0, 342, 0, + 0, 3451, 0, 0, 0, 0, 0, 0, 0, 246, + 0, 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, + 459, 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 450, 0, + 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 1105, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 2756, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 325, 0, 0, 0, 0, 288, 0, + 0, 0, 0, 0, 0, 0, 0, 296, 0, 183, + 0, 0, 0, 338, 0, 0, 0, 186, 298, 0, + 0, 0, 232, 0, 377, 0, 449, 0, 265, 0, + 376, 300, 442, 0, 0, 448, 0, 424, 458, 463, + 258, 0, 222, 405, 248, 241, 0, 0, 0, 271, + 360, 236, 292, 0, 0, 0, 228, 0, 0, 0, + 404, 439, 188, 319, 440, 462, 0, 259, 396, 260, + 423, 251, 223, 363, 202, 0, 0, 0, 242, 286, + 0, 0, 465, 456, 213, 261, 371, 375, 352, 209, + 431, 320, 330, 225, 227, 226, 203, 397, 438, 216, + 230, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 272, 0, 0, 0, 346, 212, 0, 0, 0, + 0, 452, 0, 244, 0, 454, 0, 391, 390, 0, + 279, 0, 0, 0, 370, 0, 289, 192, 0, 467, + 208, 294, 432, 0, 264, 337, 0, 347, 185, 365, + 314, 316, 313, 317, 269, 0, 0, 0, 367, 393, + 437, 210, 411, 0, 0, 0, 383, 0, 0, 0, + 307, 253, 257, 273, 284, 0, 374, 412, 455, 0, + 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 153, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 151, 0, 0, 0, 152, 0, - 0, 154, 155, 0, 0, 0, 0, 156, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 4091, 0, 0, 0, 0, 0, 0, 0, 238, 4089, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 595, 0, 594, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 379, 380, 413, 428, 385, 267, 306, 308, 415, 420, + 416, 417, 414, 419, 418, 381, 382, 196, 422, 447, + 217, 392, 395, 466, 0, 204, 198, 0, 0, 0, + 0, 0, 0, 0, 197, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 268, 0, 445, 446, + 233, 0, 0, 199, 0, 0, 334, 341, 333, 0, + 0, 441, 0, 0, 0, 0, 0, 0, 0, 0, + 295, 256, 275, 358, 302, 359, 276, 328, 327, 329, + 304, 0, 410, 305, 0, 194, 0, 409, 0, 0, + 421, 214, 0, 0, 436, 0, 366, 215, 266, 254, + 357, 332, 206, 278, 407, 293, 301, 0, 0, 345, + 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 354, 195, 207, 435, 220, + 240, 238, 255, 290, 315, 322, 351, 394, 400, 401, + 425, 426, 427, 429, 243, 318, 247, 219, 372, 218, + 303, 281, 353, 433, 434, 362, 235, 0, 187, 200, + 297, 0, 369, 263, 321, 398, 323, 285, 234, 464, + 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 453, 239, 0, 0, 0, 201, 211, 224, 237, 252, + 0, 262, 274, 277, 282, 283, 287, 291, 309, 310, + 311, 312, 335, 336, 339, 340, 343, 344, 348, 349, + 350, 355, 356, 364, 0, 373, 384, 386, 387, 388, + 389, 399, 402, 403, 443, 444, 460, 461, 430, 184, + 0, 190, 0, 191, 193, 0, 189, 0, 0, 342, + 0, 0, 3449, 0, 0, 0, 0, 0, 0, 0, + 246, 0, 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 4090, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, + 0, 459, 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, + 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 0, + 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 450, + 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2826, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 2827, 2828, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 325, 0, 0, 0, 0, 288, + 0, 0, 0, 0, 0, 0, 0, 0, 296, 0, + 183, 0, 0, 0, 338, 0, 0, 0, 186, 298, + 0, 0, 0, 232, 0, 377, 0, 449, 0, 265, + 0, 376, 300, 442, 0, 0, 448, 0, 424, 458, + 463, 258, 0, 222, 405, 248, 241, 0, 0, 0, + 271, 360, 236, 292, 0, 0, 0, 228, 0, 0, + 0, 404, 439, 188, 319, 440, 462, 0, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 272, 0, 0, 0, 346, 212, 0, 0, + 0, 0, 452, 0, 244, 0, 454, 0, 391, 390, + 0, 279, 0, 0, 0, 370, 0, 289, 192, 0, + 467, 208, 294, 432, 0, 264, 337, 0, 347, 185, + 365, 314, 316, 313, 317, 269, 0, 0, 0, 367, + 393, 437, 210, 411, 0, 0, 0, 383, 0, 0, + 0, 307, 253, 257, 273, 284, 0, 374, 412, 455, + 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 0, 204, 198, 0, 0, + 0, 0, 0, 0, 0, 197, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 268, 0, 445, + 446, 233, 0, 0, 199, 0, 0, 334, 341, 333, + 0, 0, 441, 0, 0, 0, 0, 0, 0, 0, + 0, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 0, 410, 305, 0, 194, 0, 409, 0, + 0, 421, 214, 0, 0, 436, 0, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 0, 0, + 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 0, 187, + 200, 297, 0, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, - 0, 0, 0, 0, 0, 0, 2370, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2764, 0, 0, + 0, 453, 239, 0, 0, 0, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 0, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 430, + 184, 0, 190, 0, 191, 193, 0, 189, 0, 0, + 342, 0, 0, 3447, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 0, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 459, 0, 0, 299, 0, 0, 457, 408, + 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 2369, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, + 288, 0, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 0, 0, 0, 186, + 298, 0, 0, 0, 232, 0, 377, 0, 449, 0, + 265, 0, 376, 300, 442, 0, 0, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 0, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 0, 0, 452, 0, 244, 0, 454, 0, 391, + 390, 0, 279, 0, 0, 0, 370, 0, 289, 192, + 0, 467, 208, 294, 432, 0, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 0, 0, 0, + 367, 393, 437, 210, 411, 0, 0, 0, 383, 0, + 0, 0, 307, 253, 257, 273, 284, 0, 374, 412, + 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, + 0, 0, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 0, 0, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 0, 0, 0, + 0, 0, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 0, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 0, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 595, 0, 594, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 0, 0, 0, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 0, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 430, 184, 0, 190, 0, 191, 193, 0, 189, 0, + 0, 342, 0, 0, 3445, 0, 0, 0, 0, 0, + 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, + 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 459, 0, 0, 299, 0, 0, 457, + 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, + 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 2000, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, + 0, 288, 0, 0, 0, 0, 0, 0, 0, 0, + 296, 0, 183, 0, 0, 0, 338, 0, 0, 0, + 186, 298, 0, 0, 0, 232, 0, 377, 0, 449, + 0, 265, 0, 376, 300, 442, 0, 0, 448, 0, + 424, 458, 463, 258, 0, 222, 405, 248, 241, 0, + 0, 0, 271, 360, 236, 292, 0, 0, 0, 228, + 0, 0, 0, 404, 439, 188, 319, 440, 462, 0, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 272, 0, 0, 0, 346, 212, + 0, 0, 0, 0, 452, 0, 244, 0, 454, 0, + 391, 390, 0, 279, 0, 0, 0, 370, 0, 289, + 192, 0, 467, 208, 294, 432, 0, 264, 337, 0, + 347, 185, 365, 314, 316, 313, 317, 269, 0, 0, + 0, 367, 393, 437, 210, 411, 0, 0, 0, 383, + 0, 0, 0, 307, 253, 257, 273, 284, 0, 374, + 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 1556, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 0, 204, 198, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 268, + 0, 445, 446, 233, 0, 0, 199, 0, 0, 334, + 341, 333, 0, 0, 441, 0, 0, 0, 0, 0, + 0, 0, 0, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 0, 410, 305, 0, 194, 0, + 409, 0, 0, 421, 214, 0, 0, 436, 0, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 1555, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 0, 187, 200, 297, 0, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 453, 239, 0, 0, 0, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 0, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 430, 184, 0, 190, 0, 191, 193, 0, 189, + 0, 0, 342, 0, 0, 3440, 0, 0, 0, 0, + 0, 0, 0, 246, 0, 0, 0, 0, 0, 0, + 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 459, 0, 0, 299, 0, 0, + 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, + 0, 0, 288, 0, 0, 0, 0, 0, 0, 0, + 0, 296, 0, 183, 0, 0, 0, 338, 0, 0, + 0, 186, 298, 0, 0, 0, 232, 0, 377, 0, + 449, 0, 265, 0, 376, 300, 442, 0, 0, 448, + 0, 424, 458, 463, 258, 0, 222, 405, 248, 241, + 0, 0, 0, 271, 360, 236, 292, 0, 0, 0, + 228, 0, 0, 0, 404, 439, 188, 319, 440, 462, + 0, 259, 396, 260, 423, 251, 223, 363, 202, 0, + 0, 0, 242, 286, 0, 0, 465, 456, 213, 261, + 371, 375, 352, 209, 431, 320, 330, 225, 227, 226, + 203, 397, 438, 216, 230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 272, 0, 0, 0, 346, + 212, 0, 0, 0, 0, 452, 0, 244, 0, 454, + 0, 391, 390, 0, 279, 0, 0, 0, 370, 0, + 289, 192, 0, 467, 208, 294, 432, 0, 264, 337, + 0, 347, 185, 365, 314, 316, 313, 317, 269, 0, + 0, 0, 367, 393, 437, 210, 411, 0, 0, 0, + 383, 0, 0, 0, 307, 253, 257, 273, 284, 0, + 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, + 0, 0, 0, 0, 379, 380, 413, 428, 385, 267, + 306, 308, 415, 420, 416, 417, 414, 419, 418, 381, + 382, 196, 422, 447, 217, 392, 395, 466, 0, 204, + 198, 0, 0, 0, 0, 0, 0, 0, 197, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 268, 0, 445, 446, 233, 0, 0, 199, 0, 0, + 334, 341, 333, 0, 0, 441, 0, 0, 0, 0, + 0, 0, 0, 0, 295, 256, 275, 358, 302, 359, + 276, 328, 327, 329, 304, 0, 410, 305, 0, 194, + 0, 409, 0, 0, 421, 214, 0, 0, 436, 0, + 366, 215, 266, 254, 357, 332, 206, 278, 407, 293, + 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 595, 0, 594, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 354, + 195, 207, 435, 220, 240, 238, 255, 290, 315, 322, + 351, 394, 400, 401, 425, 426, 427, 429, 243, 318, + 247, 219, 372, 218, 303, 281, 353, 433, 434, 362, + 235, 0, 187, 200, 297, 0, 369, 263, 321, 398, + 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 453, 239, 0, 0, 0, 201, + 211, 224, 237, 252, 0, 262, 274, 277, 282, 283, + 287, 291, 309, 310, 311, 312, 335, 336, 339, 340, + 343, 344, 348, 349, 350, 355, 356, 364, 0, 373, + 384, 386, 387, 388, 389, 399, 402, 403, 443, 444, + 460, 461, 430, 184, 0, 190, 0, 191, 193, 0, + 189, 0, 0, 342, 0, 0, 3427, 0, 0, 0, + 0, 0, 0, 0, 246, 0, 0, 0, 0, 0, + 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 459, 0, 0, 299, 0, + 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, + 0, 0, 0, 288, 0, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 183, 0, 0, 0, 338, 0, + 0, 0, 186, 298, 0, 0, 0, 232, 0, 377, + 0, 449, 0, 265, 0, 376, 300, 442, 0, 0, + 448, 0, 424, 458, 463, 258, 0, 222, 405, 248, + 241, 0, 0, 0, 271, 360, 236, 292, 0, 0, + 0, 228, 0, 0, 0, 404, 439, 188, 319, 440, + 462, 0, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 272, 0, 0, 0, + 346, 212, 0, 0, 0, 0, 452, 0, 244, 0, + 454, 0, 391, 390, 0, 279, 0, 0, 0, 370, + 0, 289, 192, 0, 467, 208, 294, 432, 0, 264, + 337, 0, 347, 185, 365, 314, 316, 313, 317, 269, + 0, 0, 0, 367, 393, 437, 210, 411, 0, 0, + 0, 383, 0, 0, 0, 307, 253, 257, 273, 284, + 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 3204, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 0, + 204, 198, 0, 0, 0, 0, 0, 0, 0, 197, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 268, 0, 445, 446, 233, 0, 0, 199, 0, + 0, 334, 341, 333, 0, 0, 441, 0, 0, 0, + 0, 0, 0, 0, 0, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 0, 410, 305, 0, + 194, 0, 409, 0, 0, 421, 214, 0, 0, 436, + 0, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 0, 187, 200, 297, 0, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 453, 239, 0, 0, 0, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 0, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 430, 184, 0, 190, 0, 191, 193, + 0, 189, 0, 0, 342, 0, 0, 3425, 0, 0, + 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, + 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 459, 0, 0, 299, + 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, + 0, 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 3195, 0, 0, 0, 0, 1103, 0, 0, + 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 450, 0, 0, 0, 0, 361, + 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, + 0, 0, 0, 0, 288, 0, 0, 0, 0, 0, + 0, 0, 0, 296, 0, 183, 0, 0, 0, 338, + 0, 0, 0, 186, 298, 0, 0, 0, 232, 0, + 377, 0, 449, 0, 265, 0, 376, 300, 442, 0, + 0, 448, 0, 424, 458, 463, 258, 0, 222, 405, + 248, 241, 0, 0, 0, 271, 360, 236, 292, 0, + 0, 0, 228, 0, 0, 0, 404, 439, 188, 319, + 440, 462, 0, 259, 396, 260, 423, 251, 223, 363, + 202, 0, 0, 0, 242, 286, 0, 0, 465, 456, + 213, 261, 371, 375, 352, 209, 431, 320, 330, 225, + 227, 226, 203, 397, 438, 216, 230, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 272, 0, 0, + 0, 346, 212, 0, 0, 0, 0, 452, 0, 244, + 0, 454, 0, 391, 390, 0, 279, 0, 0, 0, + 370, 0, 289, 192, 0, 467, 208, 294, 432, 0, + 264, 337, 0, 347, 185, 365, 314, 316, 313, 317, + 269, 0, 0, 0, 367, 393, 437, 210, 411, 0, + 0, 0, 383, 0, 0, 0, 307, 253, 257, 273, + 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 379, 380, 413, 428, + 385, 267, 306, 308, 415, 420, 416, 417, 414, 419, + 418, 381, 382, 196, 422, 447, 217, 392, 395, 466, + 0, 204, 198, 0, 0, 0, 0, 0, 0, 0, + 197, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 268, 0, 445, 446, 233, 0, 0, 199, + 0, 0, 334, 341, 333, 0, 0, 441, 0, 0, + 0, 0, 0, 0, 0, 0, 295, 256, 275, 358, + 302, 359, 276, 328, 327, 329, 304, 0, 410, 305, + 0, 194, 0, 409, 0, 0, 421, 214, 0, 0, + 436, 0, 366, 215, 266, 254, 357, 332, 206, 278, + 407, 293, 301, 0, 0, 345, 378, 221, 451, 406, + 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 354, 195, 207, 435, 220, 240, 238, 255, 290, + 315, 322, 351, 394, 400, 401, 425, 426, 427, 429, + 243, 318, 247, 219, 372, 218, 303, 281, 353, 433, + 434, 362, 235, 0, 187, 200, 297, 0, 369, 263, + 321, 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, + 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, + 0, 0, 0, 0, 0, 0, 453, 239, 0, 0, + 0, 201, 211, 224, 237, 252, 0, 262, 274, 277, + 282, 283, 287, 291, 309, 310, 311, 312, 335, 336, + 339, 340, 343, 344, 348, 349, 350, 355, 356, 364, + 0, 373, 384, 386, 387, 388, 389, 399, 402, 403, + 443, 444, 460, 461, 430, 184, 0, 190, 0, 191, + 193, 0, 189, 0, 0, 342, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 246, 0, 0, 0, + 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 459, 0, 0, + 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, + 0, 0, 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 0, 0, 0, 0, 1103, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 450, 0, 0, 0, 0, + 361, 270, 0, 0, 0, 0, 0, 0, 3364, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 325, 0, 0, 0, 0, 288, 0, 0, 0, 0, + 0, 0, 0, 0, 296, 0, 183, 0, 0, 0, + 338, 0, 0, 0, 186, 298, 0, 0, 0, 232, + 0, 377, 0, 449, 0, 265, 0, 376, 300, 442, + 0, 0, 448, 0, 424, 458, 463, 258, 0, 222, + 405, 248, 241, 0, 0, 0, 271, 360, 236, 292, + 0, 0, 0, 228, 0, 0, 0, 404, 439, 188, + 319, 440, 462, 0, 259, 396, 260, 423, 251, 223, + 363, 202, 0, 0, 0, 242, 286, 0, 0, 465, + 456, 213, 261, 371, 375, 352, 209, 431, 320, 330, + 225, 227, 226, 203, 397, 438, 216, 230, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 272, 0, + 0, 0, 346, 212, 0, 0, 0, 0, 452, 0, + 244, 0, 454, 0, 391, 390, 0, 279, 0, 0, + 0, 370, 0, 289, 192, 0, 467, 208, 294, 432, + 0, 264, 337, 0, 347, 185, 365, 314, 316, 313, + 317, 269, 0, 0, 0, 367, 393, 437, 210, 411, + 0, 0, 0, 383, 0, 0, 0, 307, 253, 257, + 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 379, 380, 413, + 428, 385, 267, 306, 308, 415, 420, 416, 417, 414, + 419, 418, 381, 382, 196, 422, 447, 217, 392, 395, + 466, 0, 204, 198, 0, 0, 0, 0, 0, 0, + 0, 197, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 268, 0, 445, 446, 233, 0, 0, + 199, 0, 0, 334, 341, 333, 0, 0, 441, 0, + 0, 0, 0, 0, 0, 0, 0, 295, 256, 275, + 358, 302, 359, 276, 328, 327, 329, 304, 0, 410, + 305, 0, 194, 0, 409, 0, 0, 421, 214, 0, + 0, 436, 0, 366, 215, 266, 254, 357, 332, 206, + 278, 407, 293, 301, 0, 0, 345, 378, 221, 451, + 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 354, 195, 207, 435, 220, 240, 238, 255, + 290, 315, 322, 351, 394, 400, 401, 425, 426, 427, + 429, 243, 318, 247, 219, 372, 218, 303, 281, 353, + 433, 434, 362, 235, 0, 187, 200, 297, 0, 369, + 263, 321, 398, 323, 285, 234, 464, 326, 368, 468, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 453, 239, 0, + 0, 0, 201, 211, 224, 237, 252, 0, 262, 274, + 277, 282, 283, 287, 291, 309, 310, 311, 312, 335, + 336, 339, 340, 343, 344, 348, 349, 350, 355, 356, + 364, 0, 373, 384, 386, 387, 388, 389, 399, 402, + 403, 443, 444, 460, 461, 430, 184, 0, 190, 0, + 191, 193, 0, 189, 0, 0, 342, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 246, 0, 0, + 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 459, 0, + 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 3355, 0, 0, 0, 0, 0, 1133, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 450, 0, 0, 0, + 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 325, 0, 0, 0, 0, 288, 0, 0, 0, + 0, 0, 0, 0, 0, 296, 0, 183, 0, 0, + 0, 338, 0, 0, 0, 186, 298, 0, 0, 0, + 232, 0, 377, 0, 449, 0, 265, 0, 376, 300, + 442, 0, 0, 448, 0, 424, 458, 463, 258, 0, + 222, 405, 248, 241, 0, 0, 0, 271, 360, 236, + 292, 0, 0, 0, 228, 0, 0, 0, 404, 439, + 188, 319, 440, 462, 0, 259, 396, 260, 423, 251, + 223, 363, 202, 0, 0, 0, 242, 286, 0, 0, + 465, 456, 213, 261, 371, 375, 352, 209, 431, 320, + 330, 225, 227, 226, 203, 397, 438, 216, 230, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 272, + 0, 0, 0, 346, 212, 0, 0, 0, 0, 452, + 0, 244, 0, 454, 0, 391, 390, 0, 279, 0, + 0, 0, 370, 0, 289, 192, 0, 467, 208, 294, + 432, 0, 264, 337, 0, 347, 185, 365, 314, 316, + 313, 317, 269, 0, 0, 0, 367, 393, 437, 210, + 411, 0, 0, 0, 383, 0, 0, 0, 307, 253, + 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 379, 380, + 413, 428, 385, 267, 306, 308, 415, 420, 416, 417, + 414, 419, 418, 381, 382, 196, 422, 447, 217, 392, + 395, 466, 0, 204, 198, 0, 0, 0, 0, 0, + 0, 0, 197, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 268, 0, 445, 446, 233, 0, + 0, 199, 0, 0, 334, 341, 333, 0, 0, 441, + 0, 0, 0, 0, 0, 0, 0, 0, 295, 256, + 275, 358, 302, 359, 276, 328, 327, 329, 304, 0, + 410, 305, 0, 194, 0, 409, 0, 0, 421, 214, + 0, 0, 436, 0, 366, 215, 266, 254, 357, 332, + 206, 278, 407, 293, 301, 0, 0, 345, 378, 221, + 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 354, 195, 207, 435, 220, 240, 238, + 255, 290, 315, 322, 351, 394, 400, 401, 425, 426, + 427, 429, 243, 318, 247, 219, 372, 218, 303, 281, + 353, 433, 434, 362, 235, 0, 187, 200, 297, 0, + 369, 263, 321, 398, 323, 285, 234, 464, 326, 368, + 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 453, 239, + 0, 0, 0, 201, 211, 224, 237, 252, 0, 262, + 274, 277, 282, 283, 287, 291, 309, 310, 311, 312, + 335, 336, 339, 340, 343, 344, 348, 349, 350, 355, + 356, 364, 0, 373, 384, 386, 387, 388, 389, 399, + 402, 403, 443, 444, 460, 461, 430, 184, 0, 190, + 0, 191, 193, 0, 189, 0, 0, 342, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 246, 0, + 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 459, + 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, + 0, 0, 94, 0, 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 0, + 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 450, 0, 0, + 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, - 2492, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 325, 0, 0, 0, 0, 288, 0, 0, + 0, 0, 0, 0, 0, 0, 296, 0, 183, 0, + 0, 0, 338, 0, 0, 0, 186, 298, 0, 0, + 0, 232, 0, 377, 0, 449, 0, 265, 0, 376, + 300, 442, 0, 0, 448, 0, 424, 458, 463, 258, + 0, 222, 405, 248, 241, 0, 0, 0, 271, 360, + 236, 292, 0, 0, 0, 228, 0, 0, 0, 404, + 439, 188, 319, 440, 462, 0, 259, 396, 260, 423, + 251, 223, 363, 202, 0, 0, 0, 242, 286, 0, + 0, 465, 456, 213, 261, 371, 375, 352, 209, 431, + 320, 330, 225, 227, 226, 203, 397, 438, 216, 230, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 272, 0, 0, 0, 346, 212, 0, 0, 0, 0, + 452, 0, 244, 0, 454, 0, 391, 390, 0, 279, + 0, 0, 0, 370, 0, 289, 192, 0, 467, 208, + 294, 432, 0, 264, 337, 0, 347, 185, 365, 314, + 316, 313, 317, 269, 0, 0, 0, 367, 393, 437, + 210, 411, 0, 0, 0, 383, 0, 0, 0, 307, + 253, 257, 273, 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 379, + 380, 413, 428, 385, 267, 306, 308, 415, 420, 416, + 417, 414, 419, 418, 381, 382, 196, 422, 447, 217, + 392, 395, 466, 0, 204, 198, 0, 0, 0, 0, + 0, 0, 0, 197, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 268, 0, 445, 446, 233, + 0, 0, 199, 0, 0, 334, 341, 333, 0, 0, + 441, 0, 0, 0, 0, 0, 0, 0, 0, 295, + 256, 275, 358, 302, 359, 276, 328, 327, 329, 304, + 0, 410, 305, 0, 194, 0, 409, 0, 0, 421, + 214, 0, 0, 436, 0, 366, 215, 266, 254, 357, + 332, 206, 278, 407, 293, 301, 0, 0, 345, 378, + 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 2590, 2591, 224, 0, 0, + 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 0, + 0, 0, 0, 0, 354, 195, 207, 435, 220, 240, + 238, 255, 290, 315, 322, 351, 394, 400, 401, 425, + 426, 427, 429, 243, 318, 247, 219, 372, 218, 303, + 281, 353, 433, 434, 362, 235, 0, 187, 200, 297, + 0, 369, 263, 321, 398, 323, 285, 234, 464, 326, + 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 453, + 239, 0, 0, 0, 201, 211, 224, 237, 252, 0, + 262, 274, 277, 282, 283, 287, 291, 309, 310, 311, + 312, 335, 336, 339, 340, 343, 344, 348, 349, 350, + 355, 356, 364, 0, 373, 384, 386, 387, 388, 389, + 399, 402, 403, 443, 444, 460, 461, 430, 184, 0, + 190, 0, 191, 193, 0, 189, 0, 0, 342, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 246, + 0, 0, 0, 0, 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, + 459, 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 450, 0, + 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, + 0, 2541, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 325, 0, 0, 0, 0, 288, 0, + 0, 0, 0, 0, 0, 0, 0, 296, 0, 183, + 0, 0, 0, 338, 0, 0, 0, 186, 298, 0, + 0, 0, 232, 0, 377, 0, 449, 0, 265, 0, + 376, 300, 442, 0, 0, 448, 0, 424, 458, 463, + 258, 0, 222, 405, 248, 241, 0, 0, 0, 271, + 360, 236, 292, 0, 0, 0, 228, 0, 0, 0, + 404, 439, 188, 319, 440, 462, 0, 259, 396, 260, + 423, 251, 223, 363, 202, 0, 0, 0, 242, 286, + 0, 0, 465, 456, 213, 261, 371, 375, 352, 209, + 431, 320, 330, 225, 227, 226, 203, 397, 438, 216, + 230, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 272, 0, 0, 0, 346, 212, 0, 0, 0, + 0, 452, 0, 244, 0, 454, 0, 391, 390, 0, + 279, 0, 0, 0, 370, 0, 289, 192, 0, 467, + 208, 294, 432, 0, 264, 337, 0, 347, 185, 365, + 314, 316, 313, 317, 269, 0, 0, 0, 367, 393, + 437, 210, 411, 0, 0, 0, 383, 0, 0, 0, + 307, 253, 257, 273, 284, 0, 374, 412, 455, 0, + 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, + 379, 380, 413, 428, 385, 267, 306, 308, 415, 420, + 416, 417, 414, 419, 418, 381, 382, 196, 422, 447, + 217, 392, 395, 466, 0, 204, 198, 0, 0, 0, + 0, 0, 0, 0, 197, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 268, 0, 445, 446, + 233, 0, 0, 199, 0, 0, 334, 341, 333, 0, + 0, 441, 0, 0, 0, 0, 0, 0, 0, 0, + 295, 256, 275, 358, 302, 359, 276, 328, 327, 329, + 304, 0, 410, 305, 0, 194, 0, 409, 0, 0, + 421, 214, 0, 0, 436, 0, 366, 215, 266, 254, + 357, 332, 206, 278, 407, 293, 301, 0, 0, 345, + 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 1103, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 354, 195, 207, 435, 220, + 240, 238, 255, 290, 315, 322, 351, 394, 400, 401, + 425, 426, 427, 429, 243, 318, 247, 219, 372, 218, + 303, 281, 353, 433, 434, 362, 235, 0, 187, 200, + 297, 0, 369, 263, 321, 398, 323, 285, 234, 464, + 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 453, 239, 0, 0, 0, 201, 211, 224, 237, 252, + 0, 262, 274, 277, 282, 283, 287, 291, 309, 310, + 311, 312, 335, 336, 339, 340, 343, 344, 348, 349, + 350, 355, 356, 364, 0, 373, 384, 386, 387, 388, + 389, 399, 402, 403, 443, 444, 460, 461, 430, 184, + 0, 190, 0, 191, 193, 0, 189, 0, 0, 342, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 246, 0, 0, 0, 0, 0, 0, 2685, 2684, 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 459, 0, 0, 299, 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 450, + 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2764, 0, 0, + 0, 0, 0, 0, 325, 0, 0, 0, 0, 288, + 0, 0, 0, 0, 0, 0, 0, 0, 296, 0, + 183, 0, 0, 0, 338, 0, 0, 0, 186, 298, + 0, 0, 0, 232, 0, 377, 0, 449, 0, 265, + 0, 376, 300, 442, 0, 0, 448, 0, 424, 458, + 463, 258, 0, 222, 405, 248, 241, 0, 0, 0, + 271, 360, 236, 292, 0, 0, 0, 228, 0, 0, + 0, 404, 439, 188, 319, 440, 462, 0, 259, 396, + 260, 423, 251, 223, 363, 202, 0, 0, 0, 242, + 286, 0, 0, 465, 456, 213, 261, 371, 375, 352, + 209, 431, 320, 330, 225, 227, 226, 203, 397, 438, + 216, 230, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 272, 0, 0, 0, 346, 212, 0, 0, + 0, 0, 452, 0, 244, 0, 454, 0, 391, 390, + 0, 279, 0, 0, 0, 370, 0, 289, 192, 0, + 467, 208, 294, 432, 0, 264, 337, 0, 347, 185, + 365, 314, 316, 313, 317, 269, 0, 0, 0, 367, + 393, 437, 210, 411, 0, 0, 0, 383, 0, 0, + 0, 307, 253, 257, 273, 284, 0, 374, 412, 455, + 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 379, 380, 413, 428, 385, 267, 306, 308, 415, + 420, 416, 417, 414, 419, 418, 381, 382, 196, 422, + 447, 217, 392, 395, 466, 0, 204, 198, 0, 0, + 0, 0, 0, 0, 0, 197, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 268, 0, 445, + 446, 233, 0, 0, 199, 0, 0, 334, 341, 333, + 0, 0, 441, 0, 0, 0, 0, 0, 0, 0, + 0, 295, 256, 275, 358, 302, 359, 276, 328, 327, + 329, 304, 0, 410, 305, 0, 194, 0, 409, 0, + 0, 421, 214, 0, 0, 436, 0, 366, 215, 266, + 254, 357, 332, 206, 278, 407, 293, 301, 0, 0, + 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 354, 195, 207, 435, + 220, 240, 238, 255, 290, 315, 322, 351, 394, 400, + 401, 425, 426, 427, 429, 243, 318, 247, 219, 372, + 218, 303, 281, 353, 433, 434, 362, 235, 0, 187, + 200, 297, 0, 369, 263, 321, 398, 323, 285, 234, + 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, + 0, 453, 239, 0, 0, 0, 201, 211, 224, 237, + 252, 0, 262, 274, 277, 282, 283, 287, 291, 309, + 310, 311, 312, 335, 336, 339, 340, 343, 344, 348, + 349, 350, 355, 356, 364, 0, 373, 384, 386, 387, + 388, 389, 399, 402, 403, 443, 444, 460, 461, 430, + 184, 0, 190, 0, 191, 193, 0, 189, 0, 0, + 342, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 246, 0, 0, 0, 0, 0, 0, 0, 245, + 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 459, 0, 0, 299, 0, 0, 457, 408, + 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1133, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, + 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 515, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, + 288, 0, 0, 0, 0, 0, 0, 0, 0, 296, + 0, 183, 0, 0, 0, 338, 0, 0, 0, 186, + 298, 0, 0, 0, 232, 0, 377, 0, 449, 0, + 265, 0, 376, 300, 442, 0, 0, 448, 0, 424, + 458, 463, 258, 0, 222, 405, 248, 241, 0, 0, + 0, 271, 360, 236, 292, 0, 0, 0, 228, 0, + 0, 0, 404, 439, 188, 319, 440, 462, 0, 259, + 396, 260, 423, 251, 223, 363, 202, 0, 0, 0, + 242, 286, 0, 0, 465, 456, 213, 261, 371, 375, + 352, 209, 431, 320, 330, 225, 227, 226, 203, 397, + 438, 216, 230, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 272, 0, 0, 0, 346, 212, 0, + 0, 0, 0, 452, 0, 244, 0, 454, 0, 391, + 390, 0, 279, 0, 0, 0, 370, 0, 289, 192, + 0, 467, 208, 294, 432, 0, 264, 337, 0, 347, + 185, 365, 314, 316, 313, 317, 269, 0, 0, 0, + 367, 393, 437, 210, 411, 0, 0, 0, 383, 0, + 0, 0, 307, 253, 257, 273, 284, 0, 374, 412, + 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 379, 380, 413, 428, 385, 267, 306, 308, + 415, 420, 416, 417, 414, 419, 418, 381, 382, 196, + 422, 447, 217, 392, 395, 466, 0, 204, 198, 0, + 0, 0, 0, 0, 0, 0, 197, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 268, 0, + 445, 446, 233, 0, 0, 199, 0, 0, 334, 341, + 333, 0, 0, 441, 0, 0, 0, 0, 0, 0, + 0, 0, 295, 256, 275, 358, 302, 359, 276, 328, + 327, 329, 304, 0, 410, 305, 0, 194, 0, 409, + 0, 0, 421, 214, 0, 0, 436, 0, 366, 215, + 266, 254, 357, 332, 206, 278, 407, 293, 301, 0, + 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 354, 195, 207, + 435, 220, 240, 238, 255, 290, 315, 322, 351, 394, + 400, 401, 425, 426, 427, 429, 243, 318, 247, 219, + 372, 218, 303, 281, 353, 433, 434, 362, 235, 0, + 187, 200, 297, 0, 369, 263, 321, 398, 323, 285, + 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 453, 239, 0, 0, 0, 201, 211, 224, + 237, 252, 0, 262, 274, 277, 282, 283, 287, 291, + 309, 310, 311, 312, 335, 336, 339, 340, 343, 344, + 348, 349, 350, 355, 356, 364, 0, 373, 384, 386, + 387, 388, 389, 399, 402, 403, 443, 444, 460, 461, + 430, 184, 0, 190, 0, 191, 193, 0, 189, 0, + 0, 342, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, + 245, 231, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 459, 0, 0, 299, 0, 0, 457, + 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, + 0, 0, 2856, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 149, 0, 0, + 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, + 0, 288, 0, 0, 0, 0, 0, 0, 0, 0, + 296, 0, 183, 0, 0, 0, 338, 0, 0, 0, + 186, 298, 0, 0, 0, 232, 0, 377, 0, 449, + 0, 265, 0, 376, 300, 442, 0, 0, 448, 0, + 424, 458, 463, 258, 0, 222, 405, 248, 241, 0, + 0, 0, 271, 360, 236, 292, 0, 0, 0, 228, + 0, 0, 0, 404, 439, 188, 319, 440, 462, 0, + 259, 396, 260, 423, 251, 223, 363, 202, 0, 0, + 0, 242, 286, 0, 0, 465, 456, 213, 261, 371, + 375, 352, 209, 431, 320, 330, 225, 227, 226, 203, + 397, 438, 216, 230, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 272, 0, 0, 0, 346, 212, + 0, 0, 0, 0, 452, 0, 244, 0, 454, 0, + 391, 390, 0, 279, 0, 0, 0, 370, 0, 289, + 192, 0, 467, 208, 294, 432, 0, 264, 337, 0, + 347, 185, 365, 314, 316, 313, 317, 269, 0, 0, + 0, 367, 393, 437, 210, 411, 0, 0, 0, 383, + 0, 0, 0, 307, 253, 257, 273, 284, 0, 374, + 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 379, 380, 413, 428, 385, 267, 306, + 308, 415, 420, 416, 417, 414, 419, 418, 381, 382, + 196, 422, 447, 217, 392, 395, 466, 0, 204, 198, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 268, + 0, 445, 446, 233, 0, 0, 199, 0, 0, 334, + 341, 333, 0, 0, 441, 0, 0, 0, 0, 0, + 0, 0, 0, 295, 256, 275, 358, 302, 359, 276, + 328, 327, 329, 304, 0, 410, 305, 0, 194, 0, + 409, 0, 0, 421, 214, 0, 0, 436, 0, 366, + 215, 266, 254, 357, 332, 206, 278, 407, 293, 301, + 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 354, 195, + 207, 435, 220, 240, 238, 255, 290, 315, 322, 351, + 394, 400, 401, 425, 426, 427, 429, 243, 318, 247, + 219, 372, 218, 303, 281, 353, 433, 434, 362, 235, + 0, 187, 200, 297, 0, 369, 263, 321, 398, 323, + 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 453, 239, 0, 0, 0, 201, 211, + 224, 237, 252, 0, 262, 274, 277, 282, 283, 287, + 291, 309, 310, 311, 312, 335, 336, 339, 340, 343, + 344, 348, 349, 350, 355, 356, 364, 0, 373, 384, + 386, 387, 388, 389, 399, 402, 403, 443, 444, 460, + 461, 430, 184, 0, 190, 0, 191, 193, 0, 189, + 0, 0, 342, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 246, 0, 0, 0, 0, 0, 0, + 0, 245, 231, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 459, 0, 0, 299, 0, 0, + 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, + 0, 0, 0, 537, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, + 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 413, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 330, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 238, 0, - 0, 0, 0, 0, 0, 0, 237, 224, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 289, 0, 0, 439, 392, 311, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 462, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, + 0, 0, 288, 0, 0, 0, 0, 0, 0, 0, + 0, 296, 0, 183, 0, 0, 0, 338, 0, 0, + 0, 186, 298, 0, 0, 0, 232, 0, 377, 0, + 449, 0, 265, 0, 376, 300, 442, 0, 0, 448, + 0, 424, 458, 463, 258, 0, 222, 405, 248, 241, + 0, 0, 0, 271, 360, 236, 292, 0, 0, 0, + 228, 0, 0, 0, 404, 439, 188, 319, 440, 462, + 0, 259, 396, 260, 423, 251, 223, 363, 202, 0, + 0, 0, 242, 286, 0, 0, 465, 456, 213, 261, + 371, 375, 352, 209, 431, 320, 330, 225, 227, 226, + 203, 397, 438, 216, 230, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 272, 0, 0, 0, 346, + 212, 0, 0, 0, 0, 452, 0, 244, 0, 454, + 0, 391, 390, 0, 279, 0, 0, 0, 370, 0, + 289, 192, 0, 467, 208, 294, 432, 0, 264, 337, + 0, 347, 185, 365, 314, 316, 313, 317, 269, 0, + 0, 0, 367, 393, 437, 210, 411, 0, 0, 0, + 383, 0, 0, 0, 307, 253, 257, 273, 284, 0, + 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 433, 0, 0, - 0, 0, 348, 261, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 379, 380, 413, 428, 385, 267, + 306, 308, 415, 420, 416, 417, 414, 419, 418, 381, + 382, 196, 422, 447, 217, 392, 395, 466, 0, 204, + 198, 0, 0, 0, 0, 0, 0, 0, 197, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 268, 0, 445, 446, 233, 0, 0, 199, 0, 0, + 334, 341, 333, 0, 0, 441, 0, 0, 0, 0, + 0, 0, 0, 0, 295, 256, 275, 358, 302, 359, + 276, 328, 327, 329, 304, 0, 410, 305, 0, 194, + 0, 409, 0, 0, 421, 214, 0, 0, 436, 0, + 366, 215, 266, 254, 357, 332, 206, 278, 407, 293, + 301, 0, 0, 345, 378, 221, 451, 406, 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 312, 0, 0, 0, 0, 278, 0, 0, - 0, 0, 0, 0, 0, 0, 286, 0, 179, 0, - 0, 0, 325, 0, 0, 0, 182, 288, 0, 0, - 0, 225, 0, 362, 0, 432, 0, 256, 0, 361, - 290, 425, 0, 0, 431, 0, 407, 440, 444, 250, - 0, 215, 389, 240, 234, 0, 0, 0, 262, 347, - 229, 282, 0, 0, 0, 221, 0, 0, 0, 388, - 422, 184, 306, 423, 443, 0, 251, 380, 252, 406, - 243, 216, 350, 203, 414, 307, 317, 218, 220, 219, - 197, 381, 421, 209, 223, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 271, 263, 0, 0, 0, 334, - 206, 0, 0, 0, 0, 435, 0, 236, 0, 437, - 0, 375, 374, 0, 270, 0, 0, 0, 357, 0, - 279, 188, 0, 447, 202, 284, 415, 0, 255, 324, - 0, 335, 181, 352, 302, 304, 301, 305, 260, 0, - 0, 0, 354, 377, 420, 204, 395, 0, 0, 0, - 367, 0, 0, 0, 296, 245, 249, 264, 275, 0, - 360, 396, 438, 0, 199, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 354, + 195, 207, 435, 220, 240, 238, 255, 290, 315, 322, + 351, 394, 400, 401, 425, 426, 427, 429, 243, 318, + 247, 219, 372, 218, 303, 281, 353, 433, 434, 362, + 235, 0, 187, 200, 297, 0, 369, 263, 321, 398, + 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 453, 239, 0, 0, 0, 201, + 211, 224, 237, 252, 0, 262, 274, 277, 282, 283, + 287, 291, 309, 310, 311, 312, 335, 336, 339, 340, + 343, 344, 348, 349, 350, 355, 356, 364, 0, 373, + 384, 386, 387, 388, 389, 399, 402, 403, 443, 444, + 460, 461, 430, 184, 0, 190, 0, 191, 193, 0, + 189, 0, 0, 342, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 246, 0, 0, 0, 0, 0, + 0, 0, 245, 231, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 459, 0, 0, 299, 0, + 0, 457, 408, 324, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 364, 397, 411, 369, 258, 399, - 403, 400, 401, 398, 402, 365, 366, 191, 405, 430, - 210, 376, 379, 446, 0, 198, 193, 0, 0, 0, - 0, 0, 0, 0, 192, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 259, 0, 428, 429, - 226, 0, 0, 194, 0, 0, 321, 329, 320, 0, - 0, 424, 0, 0, 0, 0, 0, 0, 0, 0, - 285, 248, 266, 345, 292, 346, 267, 315, 314, 316, - 294, 0, 394, 295, 0, 189, 0, 393, 0, 0, - 404, 207, 0, 0, 419, 0, 353, 208, 257, 246, - 344, 319, 200, 269, 391, 283, 291, 0, 0, 333, - 363, 214, 434, 390, 241, 0, 326, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 222, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 151, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 341, 190, 201, 418, 213, 233, - 231, 247, 280, 303, 309, 339, 378, 384, 385, 408, - 409, 410, 412, 235, 0, 239, 212, 358, 211, 293, - 272, 340, 416, 417, 349, 228, 0, 183, 195, 287, - 0, 356, 254, 308, 382, 310, 276, 227, 445, 313, - 355, 448, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 318, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 436, - 232, 0, 0, 0, 196, 205, 217, 230, 244, 253, - 265, 268, 273, 274, 277, 281, 297, 298, 299, 300, - 322, 323, 327, 328, 331, 332, 336, 337, 338, 342, - 343, 351, 0, 359, 368, 370, 371, 372, 373, 383, - 386, 387, 426, 427, 441, 442, 40, 180, 0, 186, - 0, 187, 0, 0, 185, 0, 0, 0, 0, 0, - 66, 0, 0, 0, 0, 0, 0, 0, 85, 0, - 0, 43, 40, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 66, 0, 0, 0, - 0, 0, 0, 0, 85, 0, 0, 43, 0, 0, + 250, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 450, 0, 0, 0, 0, 361, 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 93, 0, 0, 0, 0, 3909, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 93, - 3902, 0, 0, 0, 3909, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 3902, 0, 0, 0, - 0, 4229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 40, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 66, 45, 82, 51, - 50, 53, 0, 0, 85, 0, 88, 43, 0, 0, - 0, 0, 3903, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 45, 82, 51, 50, 53, 0, 57, - 84, 83, 88, 0, 0, 0, 52, 0, 3903, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 93, - 0, 0, 0, 0, 3909, 57, 84, 83, 0, 0, - 0, 0, 52, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 3902, 0, 0, 0, - 0, 4228, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 64, 65, 0, 3905, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 3914, - 3906, 3907, 3908, 3912, 3913, 3910, 4230, 3911, 0, 3915, - 0, 0, 64, 65, 73, 3905, 74, 0, 0, 0, - 0, 0, 0, 0, 0, 3914, 3906, 3907, 3908, 3912, - 3913, 3910, 0, 3911, 0, 3915, 0, 0, 0, 79, - 73, 0, 74, 0, 0, 40, 0, 0, 55, 0, - 0, 0, 0, 45, 82, 51, 50, 53, 0, 66, - 0, 0, 88, 0, 0, 79, 0, 85, 3903, 0, - 43, 0, 0, 0, 55, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 57, 84, 83, 0, 0, - 0, 0, 52, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 4225, 0, 0, 0, 3909, 3916, 3904, - 0, 61, 62, 68, 0, 69, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 3902, - 0, 0, 0, 0, 3916, 3904, 0, 61, 62, 68, - 0, 69, 64, 65, 0, 3905, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3914, 3906, 3907, 3908, 3912, - 3913, 3910, 0, 3911, 0, 3915, 0, 0, 0, 0, - 73, 0, 74, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 40, - 0, 0, 0, 0, 0, 79, 0, 0, 0, 0, - 0, 0, 0, 66, 55, 0, 0, 0, 0, 0, - 0, 85, 0, 0, 43, 0, 45, 82, 51, 50, - 53, 0, 0, 0, 0, 88, 0, 0, 0, 0, - 0, 3903, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 40, 0, 0, 57, 84, - 83, 0, 0, 0, 0, 52, 93, 0, 0, 66, - 0, 3909, 0, 0, 0, 0, 0, 85, 0, 0, - 43, 0, 0, 0, 3916, 3904, 0, 61, 62, 68, - 0, 69, 0, 3902, 0, 0, 0, 0, 4217, 0, - 0, 0, 0, 0, 0, 54, 56, 0, 0, 0, - 0, 81, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 93, 0, 0, 64, 65, 3909, 3905, 0, - 0, 54, 56, 0, 0, 0, 0, 81, 3914, 3906, - 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, 3902, - 0, 0, 0, 73, 4136, 74, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 79, 0, - 45, 82, 51, 50, 53, 0, 0, 55, 0, 88, - 0, 0, 0, 0, 0, 3903, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 40, - 0, 0, 57, 84, 83, 0, 0, 0, 0, 52, - 0, 0, 0, 66, 0, 0, 0, 0, 0, 0, - 0, 85, 0, 0, 43, 0, 45, 82, 51, 50, - 53, 0, 0, 0, 0, 88, 0, 0, 0, 0, - 0, 3903, 0, 0, 0, 0, 0, 3916, 3904, 0, - 61, 62, 68, 0, 69, 0, 0, 0, 57, 84, - 83, 54, 56, 0, 0, 52, 93, 81, 0, 64, - 65, 3909, 3905, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 3914, 3906, 3907, 3908, 3912, 3913, 3910, 0, - 3911, 0, 3915, 3902, 0, 0, 0, 73, 0, 74, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 79, 0, 0, 64, 65, 0, 3905, 0, - 0, 55, 0, 0, 0, 0, 0, 0, 3914, 3906, - 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, 0, - 0, 0, 0, 73, 0, 74, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 40, 0, 0, 0, 0, 0, 0, 79, 0, - 45, 82, 51, 50, 53, 66, 0, 55, 0, 88, - 0, 0, 0, 85, 0, 3903, 43, 0, 0, 0, - 0, 3916, 3904, 0, 61, 62, 68, 0, 69, 0, - 0, 0, 57, 84, 83, 0, 0, 0, 0, 52, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 54, 56, 0, 0, 93, 0, - 81, 0, 0, 3909, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3916, 3904, 0, - 61, 62, 68, 0, 69, 3902, 0, 0, 0, 0, - 4128, 0, 0, 0, 0, 0, 0, 0, 0, 64, - 65, 0, 3905, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 3914, 3906, 3907, 3908, 3912, 3913, 3910, 4133, - 3911, 0, 3915, 0, 0, 0, 0, 73, 0, 74, + 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, + 0, 0, 0, 288, 0, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 183, 0, 0, 0, 338, 0, + 0, 0, 186, 298, 0, 0, 0, 232, 0, 377, + 0, 449, 0, 265, 0, 376, 300, 442, 0, 0, + 448, 0, 424, 458, 463, 258, 0, 222, 405, 248, + 241, 0, 0, 0, 271, 360, 236, 292, 0, 0, + 0, 228, 0, 0, 0, 404, 439, 188, 319, 440, + 462, 0, 259, 396, 260, 423, 251, 223, 363, 202, + 0, 0, 0, 242, 286, 0, 0, 465, 456, 213, + 261, 371, 375, 352, 209, 431, 320, 330, 225, 227, + 226, 203, 397, 438, 216, 230, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 272, 0, 0, 0, + 346, 212, 0, 0, 0, 0, 452, 0, 244, 0, + 454, 0, 391, 390, 0, 279, 0, 0, 0, 370, + 0, 289, 192, 0, 467, 208, 294, 432, 0, 264, + 337, 0, 347, 185, 365, 314, 316, 313, 317, 269, + 0, 0, 0, 367, 393, 437, 210, 411, 0, 0, + 0, 383, 0, 0, 0, 307, 253, 257, 273, 284, + 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 379, 380, 413, 428, 385, + 267, 306, 308, 415, 420, 416, 417, 414, 419, 418, + 381, 382, 196, 422, 447, 217, 392, 395, 466, 0, + 204, 198, 0, 0, 0, 0, 0, 0, 0, 197, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 268, 0, 445, 446, 233, 0, 0, 199, 0, + 0, 334, 341, 333, 0, 0, 441, 0, 0, 0, + 0, 0, 0, 0, 0, 295, 256, 275, 358, 302, + 359, 276, 328, 327, 329, 304, 0, 410, 305, 0, + 194, 0, 409, 0, 0, 421, 214, 0, 0, 436, + 0, 366, 215, 266, 254, 357, 332, 206, 278, 407, + 293, 301, 0, 0, 345, 378, 221, 451, 406, 249, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 229, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 354, 195, 207, 435, 220, 240, 238, 255, 290, 315, + 322, 351, 394, 400, 401, 425, 426, 427, 429, 243, + 318, 247, 219, 372, 218, 303, 281, 353, 433, 434, + 362, 235, 0, 187, 200, 297, 0, 369, 263, 321, + 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 331, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 453, 239, 0, 0, 0, + 201, 211, 224, 237, 252, 0, 262, 274, 277, 282, + 283, 287, 291, 309, 310, 311, 312, 335, 336, 339, + 340, 343, 344, 348, 349, 350, 355, 356, 364, 0, + 373, 384, 386, 387, 388, 389, 399, 402, 403, 443, + 444, 460, 461, 430, 184, 0, 190, 0, 191, 193, + 0, 189, 0, 0, 342, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, + 0, 0, 0, 245, 231, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 459, 0, 0, 299, + 0, 0, 457, 408, 324, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 482, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 40, 0, 0, 0, 0, - 0, 0, 79, 0, 0, 0, 0, 0, 0, 66, - 0, 55, 0, 0, 0, 0, 0, 85, 0, 0, - 43, 0, 45, 82, 51, 50, 53, 0, 0, 0, - 0, 88, 0, 0, 0, 0, 0, 3903, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 40, 0, 0, 57, 84, 83, 0, 54, 56, - 0, 52, 93, 0, 81, 66, 0, 3909, 0, 0, - 0, 0, 0, 85, 0, 0, 43, 0, 0, 0, - 0, 3916, 3904, 0, 61, 62, 68, 0, 69, 3902, - 0, 0, 0, 0, 4126, 0, 0, 0, 0, 0, + 0, 250, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 450, 0, 0, 0, 0, 361, + 270, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 54, 56, 0, 0, 93, 0, - 81, 64, 65, 3909, 3905, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 3914, 3906, 3907, 3908, 3912, 3913, - 3910, 0, 3911, 0, 3915, 3902, 0, 0, 0, 73, - 4013, 74, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 79, 0, 45, 82, 51, 50, - 53, 0, 0, 55, 0, 88, 0, 0, 0, 0, - 0, 3903, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 40, 0, 0, 57, 84, - 83, 0, 0, 0, 0, 52, 0, 0, 0, 66, - 0, 0, 0, 0, 0, 0, 0, 85, 0, 0, - 43, 0, 45, 82, 51, 50, 53, 0, 0, 0, - 0, 88, 0, 0, 0, 0, 0, 3903, 0, 0, - 0, 0, 0, 3916, 3904, 0, 61, 62, 68, 0, - 69, 0, 0, 0, 57, 84, 83, 0, 54, 56, - 0, 52, 93, 0, 81, 64, 65, 3909, 3905, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 3914, 3906, - 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, 3902, - 0, 0, 0, 73, 0, 74, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 79, 0, - 0, 64, 65, 0, 3905, 0, 0, 55, 0, 0, - 0, 0, 0, 0, 3914, 3906, 3907, 3908, 3912, 3913, - 3910, 0, 3911, 0, 3915, 0, 0, 0, 0, 73, - 0, 74, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 79, 0, 45, 82, 51, 50, - 53, 0, 0, 55, 0, 88, 0, 0, 0, 0, - 0, 3903, 0, 0, 0, 0, 0, 3916, 3904, 0, - 61, 62, 68, 0, 69, 0, 0, 0, 57, 84, - 83, 0, 0, 0, 0, 52, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 54, 56, 0, 0, 0, 0, 81, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, + 0, 0, 0, 0, 288, 0, 0, 0, 0, 0, + 0, 0, 0, 296, 0, 183, 0, 0, 0, 338, + 0, 0, 0, 186, 298, 0, 0, 0, 232, 0, + 377, 0, 449, 0, 265, 0, 376, 300, 442, 0, + 0, 448, 0, 424, 458, 463, 258, 0, 222, 405, + 248, 241, 0, 0, 0, 271, 360, 236, 292, 0, + 0, 0, 228, 0, 0, 0, 404, 439, 188, 319, + 440, 462, 0, 259, 396, 260, 423, 251, 223, 363, + 202, 0, 0, 0, 242, 286, 0, 0, 465, 456, + 213, 261, 371, 375, 352, 209, 431, 320, 330, 225, + 227, 226, 203, 397, 438, 216, 230, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 272, 0, 0, + 0, 346, 212, 0, 0, 0, 0, 452, 0, 244, + 0, 454, 0, 391, 390, 0, 279, 0, 0, 0, + 370, 0, 289, 192, 0, 467, 208, 294, 432, 0, + 264, 337, 0, 347, 185, 365, 314, 316, 313, 317, + 269, 0, 0, 0, 367, 393, 437, 210, 411, 0, + 0, 0, 383, 0, 0, 0, 307, 253, 257, 273, + 284, 0, 374, 412, 455, 0, 205, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 3916, 3904, 0, 61, 62, 68, 0, - 69, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 64, 65, 0, 3905, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 3914, 3906, - 3907, 3908, 3912, 3913, 3910, 0, 3911, 0, 3915, 0, - 0, 0, 0, 73, 0, 74, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 79, 0, - 0, 0, 0, 0, 0, 0, 0, 55, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 379, 380, 413, 428, + 385, 267, 306, 308, 415, 420, 416, 417, 414, 419, + 418, 381, 382, 196, 422, 447, 217, 392, 395, 466, + 0, 204, 198, 0, 0, 0, 0, 0, 0, 0, + 197, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 268, 0, 445, 446, 233, 0, 0, 199, + 0, 0, 334, 341, 333, 0, 0, 441, 0, 0, + 0, 0, 0, 0, 0, 0, 295, 256, 275, 358, + 302, 359, 276, 328, 327, 329, 304, 0, 410, 305, + 0, 194, 0, 409, 0, 0, 421, 214, 0, 0, + 436, 0, 366, 215, 266, 254, 357, 332, 206, 278, + 407, 293, 301, 0, 0, 345, 378, 221, 451, 406, + 249, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 54, 56, 0, 0, 0, 0, - 81, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 3916, 3904, 0, - 61, 62, 68, 0, 69, 0, 0, 0, 0, 0, + 0, 354, 195, 207, 435, 220, 240, 238, 255, 290, + 315, 322, 351, 394, 400, 401, 425, 426, 427, 429, + 243, 318, 247, 219, 372, 218, 303, 281, 353, 433, + 434, 362, 235, 0, 187, 200, 297, 0, 369, 263, + 321, 398, 323, 285, 234, 464, 326, 368, 468, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 331, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 54, 56, 0, 0, 0, 0, 81, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 453, 239, 0, 0, + 0, 201, 211, 224, 237, 252, 0, 262, 274, 277, + 282, 283, 287, 291, 309, 310, 311, 312, 335, 336, + 339, 340, 343, 344, 348, 349, 350, 355, 356, 364, + 0, 373, 384, 386, 387, 388, 389, 399, 402, 403, + 443, 444, 460, 461, 40, 184, 0, 190, 0, 191, + 193, 0, 189, 0, 0, 0, 0, 0, 67, 0, + 0, 0, 0, 0, 0, 0, 86, 0, 0, 43, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 40, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 94, 67, 0, 0, 0, 0, 4143, 0, 0, + 86, 0, 0, 43, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 4136, 0, + 0, 0, 0, 4495, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 94, 0, 0, 0, 0, + 0, 4143, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4136, 0, 0, 0, 0, 4477, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 45, 83, 52, 51, 54, + 0, 0, 0, 0, 89, 0, 0, 0, 0, 0, + 4137, 0, 0, 0, 0, 0, 0, 40, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 58, 85, 84, + 0, 67, 0, 0, 53, 0, 0, 0, 0, 86, + 0, 0, 43, 0, 0, 0, 0, 0, 0, 45, + 83, 52, 51, 54, 0, 0, 0, 0, 89, 0, + 0, 0, 0, 0, 4137, 0, 0, 0, 0, 0, + 0, 0, 0, 40, 0, 0, 0, 0, 0, 0, + 0, 58, 85, 84, 94, 0, 0, 67, 53, 0, + 4143, 0, 0, 0, 0, 86, 0, 0, 43, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 65, + 66, 4136, 4139, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4148, 4140, 4141, 4142, 4146, 4147, 4144, 0, + 4145, 0, 4149, 0, 0, 0, 0, 74, 0, 75, + 94, 0, 0, 0, 0, 0, 4143, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 80, 65, 66, 0, 4139, 4136, 0, 0, + 0, 56, 4473, 0, 0, 0, 4148, 4140, 4141, 4142, + 4146, 4147, 4144, 0, 4145, 0, 4149, 0, 0, 0, + 0, 74, 0, 75, 0, 0, 0, 0, 45, 83, + 52, 51, 54, 0, 0, 0, 0, 89, 0, 0, + 0, 0, 0, 4137, 0, 0, 80, 0, 0, 0, + 0, 0, 40, 0, 0, 56, 0, 0, 0, 0, + 58, 85, 84, 0, 0, 0, 67, 53, 0, 0, + 0, 0, 0, 0, 86, 4150, 4138, 43, 62, 63, + 69, 0, 70, 0, 45, 83, 52, 51, 54, 0, + 0, 0, 0, 89, 0, 0, 0, 0, 0, 4137, + 0, 0, 0, 0, 0, 0, 40, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 58, 85, 84, 94, + 67, 0, 0, 53, 0, 4143, 0, 0, 86, 4150, + 4138, 43, 62, 63, 69, 0, 70, 0, 0, 0, + 0, 0, 65, 66, 0, 4139, 4136, 0, 0, 0, + 0, 4472, 0, 0, 0, 4148, 4140, 4141, 4142, 4146, + 4147, 4144, 4474, 4145, 0, 4149, 0, 0, 0, 0, + 74, 0, 75, 94, 4469, 0, 0, 0, 0, 4143, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 80, 0, 0, 65, 66, + 4136, 4139, 0, 0, 56, 0, 0, 0, 0, 0, + 0, 4148, 4140, 4141, 4142, 4146, 4147, 4144, 0, 4145, + 0, 4149, 0, 0, 0, 0, 74, 0, 75, 0, + 0, 0, 0, 45, 83, 52, 51, 54, 0, 0, + 0, 0, 89, 0, 0, 0, 0, 0, 4137, 0, + 0, 80, 0, 0, 0, 0, 0, 0, 0, 0, + 56, 0, 0, 55, 57, 58, 85, 84, 0, 82, + 0, 0, 53, 0, 0, 0, 0, 0, 4150, 4138, + 0, 62, 63, 69, 0, 70, 0, 45, 83, 52, + 51, 54, 0, 0, 0, 0, 89, 0, 0, 0, + 0, 0, 4137, 0, 0, 0, 0, 0, 0, 0, + 0, 40, 0, 0, 0, 0, 0, 55, 57, 58, + 85, 84, 0, 82, 0, 67, 53, 0, 0, 0, + 0, 0, 0, 86, 4150, 4138, 43, 62, 63, 69, + 0, 70, 0, 0, 0, 0, 0, 65, 66, 0, + 4139, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 4148, 4140, 4141, 4142, 4146, 4147, 4144, 0, 4145, 0, + 4149, 40, 0, 0, 0, 74, 0, 75, 94, 0, + 0, 0, 0, 0, 4143, 67, 0, 0, 0, 0, + 0, 0, 0, 86, 0, 0, 43, 0, 0, 0, + 80, 65, 66, 0, 4139, 4136, 0, 0, 0, 56, + 4461, 0, 0, 0, 4148, 4140, 4141, 4142, 4146, 4147, + 4144, 0, 4145, 0, 4149, 0, 0, 0, 0, 74, + 0, 75, 0, 0, 0, 0, 0, 0, 94, 0, + 0, 0, 0, 0, 4143, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 80, 0, 0, 0, 0, 0, + 0, 0, 0, 56, 0, 4136, 55, 57, 0, 0, + 4458, 0, 82, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 4150, 4138, 0, 62, 63, 69, 0, + 70, 0, 45, 83, 52, 51, 54, 0, 0, 0, + 0, 89, 0, 0, 0, 0, 0, 4137, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 40, 55, 57, 58, 85, 84, 0, 82, 0, + 0, 53, 0, 0, 0, 67, 0, 4150, 4138, 0, + 62, 63, 69, 86, 70, 0, 43, 0, 0, 0, + 0, 0, 45, 83, 52, 51, 54, 0, 0, 0, + 0, 89, 0, 0, 0, 0, 0, 4137, 0, 0, + 0, 0, 0, 0, 0, 0, 40, 0, 0, 0, + 0, 0, 0, 0, 58, 85, 84, 0, 94, 0, + 67, 53, 0, 0, 4143, 0, 0, 0, 86, 0, + 0, 43, 0, 0, 0, 0, 65, 66, 0, 4139, + 0, 0, 0, 0, 0, 4136, 0, 0, 0, 4148, + 4140, 4141, 4142, 4146, 4147, 4144, 0, 4145, 0, 4149, + 0, 0, 0, 0, 74, 0, 75, 0, 0, 0, + 0, 0, 0, 94, 0, 0, 0, 0, 0, 4143, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 80, + 0, 0, 0, 0, 0, 0, 65, 66, 56, 4139, + 4136, 55, 57, 0, 0, 4376, 0, 82, 0, 4148, + 4140, 4141, 4142, 4146, 4147, 4144, 0, 4145, 0, 4149, + 0, 0, 0, 0, 74, 0, 75, 0, 0, 0, + 0, 0, 45, 83, 52, 51, 54, 0, 0, 0, + 0, 89, 0, 0, 0, 0, 0, 4137, 0, 80, + 0, 0, 0, 0, 0, 55, 57, 0, 56, 0, + 0, 82, 0, 0, 58, 85, 84, 0, 0, 0, + 0, 53, 4150, 4138, 0, 62, 63, 69, 0, 70, + 0, 0, 0, 0, 0, 0, 0, 45, 83, 52, + 51, 54, 0, 0, 0, 0, 89, 0, 0, 0, + 0, 0, 4137, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 58, + 85, 84, 0, 0, 0, 0, 53, 0, 0, 0, + 0, 0, 4150, 4138, 0, 62, 63, 69, 0, 70, + 0, 0, 0, 0, 0, 0, 65, 66, 0, 4139, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 4148, + 4140, 4141, 4142, 4146, 4147, 4144, 4373, 4145, 0, 4149, + 40, 0, 0, 0, 74, 0, 75, 0, 0, 0, + 0, 0, 0, 0, 67, 0, 0, 0, 0, 0, + 0, 0, 86, 0, 0, 43, 0, 0, 0, 80, + 0, 65, 66, 0, 4139, 0, 0, 0, 56, 0, + 0, 0, 0, 0, 4148, 4140, 4141, 4142, 4146, 4147, + 4144, 0, 4145, 0, 4149, 40, 0, 0, 0, 74, + 0, 75, 0, 0, 0, 0, 0, 94, 0, 67, + 0, 0, 0, 4143, 0, 0, 0, 86, 0, 0, + 43, 0, 0, 0, 80, 0, 0, 0, 0, 0, + 55, 57, 0, 56, 4136, 0, 82, 0, 0, 4368, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4150, 4138, 0, 62, 63, 69, 0, 70, + 0, 0, 94, 0, 0, 0, 0, 0, 4143, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 4136, + 55, 57, 0, 0, 4366, 0, 82, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 4150, 4138, 0, + 62, 63, 69, 0, 70, 0, 0, 0, 0, 0, + 0, 45, 83, 52, 51, 54, 0, 0, 0, 0, + 89, 0, 0, 0, 0, 0, 4137, 0, 0, 0, + 0, 0, 0, 0, 0, 40, 0, 0, 0, 0, + 0, 0, 0, 58, 85, 84, 0, 0, 0, 67, + 53, 0, 0, 0, 0, 0, 0, 86, 0, 0, + 43, 0, 0, 0, 0, 0, 45, 83, 52, 51, + 54, 0, 0, 0, 0, 89, 0, 0, 0, 0, + 0, 4137, 0, 0, 0, 0, 0, 0, 0, 0, + 40, 0, 0, 0, 0, 0, 0, 0, 58, 85, + 84, 0, 94, 0, 67, 53, 0, 0, 4143, 0, + 0, 0, 86, 0, 0, 43, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 65, 66, 0, 4139, 4136, + 55, 57, 0, 0, 4251, 0, 82, 0, 4148, 4140, + 4141, 4142, 4146, 4147, 4144, 0, 4145, 0, 4149, 0, + 0, 0, 0, 74, 0, 75, 0, 94, 0, 0, + 0, 0, 0, 4143, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 80, 0, + 65, 66, 0, 4139, 4136, 55, 57, 56, 0, 0, + 0, 82, 0, 4148, 4140, 4141, 4142, 4146, 4147, 4144, + 0, 4145, 0, 4149, 0, 0, 0, 0, 74, 0, + 75, 0, 0, 0, 0, 0, 45, 83, 52, 51, + 54, 0, 0, 0, 0, 89, 0, 0, 0, 0, + 0, 4137, 0, 80, 0, 0, 0, 0, 0, 0, + 0, 0, 56, 0, 0, 0, 0, 0, 58, 85, + 84, 0, 0, 0, 0, 53, 0, 0, 0, 0, + 0, 4150, 4138, 0, 62, 63, 69, 0, 70, 0, + 0, 45, 83, 52, 51, 54, 0, 0, 0, 0, + 89, 0, 0, 0, 0, 0, 4137, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 58, 85, 84, 0, 0, 0, 0, + 53, 0, 0, 0, 0, 0, 4150, 4138, 0, 62, + 63, 69, 0, 70, 0, 0, 0, 0, 0, 0, + 65, 66, 0, 4139, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 4148, 4140, 4141, 4142, 4146, 4147, 4144, + 0, 4145, 0, 4149, 0, 0, 0, 0, 74, 0, + 75, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 80, 0, 65, 66, 0, 4139, 0, + 0, 0, 56, 0, 0, 0, 0, 0, 4148, 4140, + 4141, 4142, 4146, 4147, 4144, 0, 4145, 0, 4149, 0, + 0, 0, 0, 74, 0, 75, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 80, 0, + 0, 0, 0, 0, 0, 0, 0, 56, 0, 55, + 57, 0, 0, 0, 0, 82, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 4150, 4138, 0, 62, + 63, 69, 0, 70, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 55, 57, 0, 0, 0, 0, + 82, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 4150, 4138, 0, 62, 63, 69, 0, 70, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, @@ -9433,26 +10165,32 @@ var yyAct = [...]int{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 54, 56, 0, 0, 0, 0, - 81, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 55, 57, 0, 0, 0, 0, + 82, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 55, + 57, 0, 0, 0, 0, 82, } var yyPact = [...]int{ - 6432, -1000, -488, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 6134, -1000, -489, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2682, - -1000, -1000, 461, -1000, 1277, 420, -1000, -1000, -1000, -1000, - 533, 346, 56225, 982, 51325, 71625, -297, 1679, 70925, 95, - -1000, 95, 381, 53425, 769, 808, 70225, 2539, 2023, 102, - -37, -43, 192, 38018, 37308, 237, 126, 159, 139, 108, - -1000, 59025, 193, -1000, -1000, -1000, -1000, -1000, 52725, 2752, - 2763, 2752, 264, -1000, -1000, 2656, 2680, -1000, -1000, 13650, - -1000, -1000, -1000, -1000, -1000, 28707, -1000, 1170, -1000, 56925, - 39418, 2682, -1000, 974, 964, -149, 925, 925, 790, 925, - 925, -454, 979, -1000, 727, 1353, -1000, -1000, -1000, 1347, - 56925, 64625, 928, 68825, 928, 928, 928, 928, 928, 928, - 928, 928, 50625, 56925, -1000, 1064, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2913, + -1000, -1000, 441, -1000, 1396, 434, -1000, -1000, -1000, -1000, + -1000, 709, 306, 57573, 1157, 54689, 77761, -281, 4488, 77040, + 164, -1000, 164, 421, 53968, 953, 1009, 76319, 2779, 2131, + 166, 39, 35, 236, 39548, 38817, 299, 221, 218, 200, + 208, -1000, 60457, 287, -1000, -1000, -1000, -1000, -1000, 44595, + 2980, 2988, 2980, 339, -1000, -1000, 2890, 2911, -1000, -1000, + 14466, -1000, -1000, -1000, -1000, -1000, 31440, -1000, 1336, -1000, + 58294, 41711, 2913, -1000, 1139, 1124, -124, 1077, 1077, 945, + 1077, 1077, -455, 1151, -1000, 878, 1674, -1000, -1000, -1000, + 1658, 58294, 65504, 1081, 74877, 1081, 1081, 1081, 1081, 1081, + 1081, 1081, 1081, 53247, 58294, -1000, 1283, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, @@ -9482,45 +10220,48 @@ var yyPact = [...]int{ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 56925, - 2729, 2718, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, 2389, 2387, 49925, 2022, 2577, 1382, 352, 1382, - -1000, -1000, 1393, -1000, 826, 825, 821, 815, 799, -6, - 1373, 1408, 2653, -1000, 2276, 2656, 2656, 1373, -1000, -1000, - -1000, -1000, -1000, -1000, 1167, -1000, -1000, 1438, 1438, 446, - 960, 265, 837, 264, 2621, 1341, 2576, 2575, 1771, 2574, - 996, 2573, 2380, -1000, 1063, -1000, -1000, -1, -1000, 2021, - 56925, -1000, -1000, 1740, 1729, 609, 2253, 1060, 2423, -1000, - -1000, 554, 849, 2369, 664, 2369, 2369, 2369, 324, 2369, - 2369, -45, 2369, 2369, 2369, 270, 2369, 310, 2369, 2369, - 2369, 2369, 2369, -1000, 2045, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 58294, + 2966, 2965, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, 2591, 2590, 52526, 575, 2814, 1630, 403, 1630, + -1000, -1000, 1677, -1000, 982, 980, 979, 947, 977, 34, + 1633, 1641, 2887, -1000, 2553, 2890, 2890, 1633, -1000, 976, + -1000, -1000, -1000, -1000, -1000, -1000, 1331, -1000, -1000, 1735, + 1735, 551, 1118, 341, 1000, 339, 2856, 1651, 2813, 2812, + 2156, 2810, 848, 2805, 2585, -1000, 1278, -1000, -1000, 70, + -1000, 2130, 58294, -1000, -1000, 2019, 2018, 613, 2469, 1217, + 2628, -1000, -1000, 660, 806, 2578, 805, 2578, 2578, 2578, + 416, 2578, 2578, 29, 2578, 2578, 2578, 312, 2578, 358, + 2578, 2578, 2578, 2578, 2578, -1000, 2166, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 603, 2170, 2294, - 2422, 146, -1000, -98, -1000, 2620, 720, -1000, -1000, -1000, - 1170, 60425, 2304, -1000, 2276, -1000, -1000, 2042, 977, 593, - -1000, 598, -1000, -1000, -1000, 2602, 2276, 40825, -1000, -1000, - 1115, -1000, 2276, 2276, 1170, 2644, 1170, 1170, 2628, 2627, - 1170, 2043, -1000, 59025, 2571, 1547, 18669, 2487, 1477, 2717, - -1000, 38718, 1062, -1000, 18669, 2183, 2276, 2276, -1000, 1023, - 1148, -1000, 1010, 1046, -1000, -1000, 19386, 19386, 19386, 19386, - 19386, 19386, 19386, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2276, - 1061, 1058, 2276, 2276, 2276, 2276, 2276, -1000, 17235, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 689, + 2455, 2514, 2627, 222, -1000, -58, -1000, 2862, 328, -1000, + -1000, -1000, 1336, 61178, 2537, -1000, 2553, -1000, -1000, 2081, + 1150, 1081, 799, -1000, 512, -1000, -1000, -1000, 2844, 2553, + 10747, -1000, -1000, 1279, -1000, 2553, 2553, 1336, 2868, 1336, + 1336, 2867, 2866, 1336, 2232, -1000, 60457, 2807, 28488, 18894, + 2690, 1798, 2964, -1000, 40990, 1277, -1000, 18894, 1998, 2553, + 2553, -1000, 1219, 1327, -1000, 1199, 1269, -1000, -1000, 19632, + 19632, 19632, 19632, 19632, 19632, 19632, -1000, -1000, -1000, -1000, + -1000, -1000, 2253, 2252, 2251, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, 2553, 1275, 1273, -1000, 2553, + 2553, 2553, 2553, 2553, -1000, 17418, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, - 2276, 2276, 2276, 2276, 2276, 18669, 2276, 2276, 2276, 2276, - 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, - 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, - 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, - 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2553, 2553, + 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, + 2553, 2553, 2553, 18894, 2553, 2553, 2553, 2553, 2553, -1000, + 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, + 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, + 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, + 2553, 2553, 2553, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 2553, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, @@ -9528,6 +10269,7 @@ var yyPact = [...]int{ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, 2553, 2553, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, @@ -9537,76 +10279,78 @@ var yyPact = [...]int{ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2553, 1088, 1088, + 56852, 2551, -46, 30702, -1000, -1000, -1000, -1000, 29226, 64783, + 1521, -1000, -1000, -1000, -1000, 2804, -1000, -1000, 1270, 1269, + 1219, 1211, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 930, - 930, 55525, 2311, -71, 27990, -1000, -1000, -1000, -1000, 26556, - 63925, 1275, -1000, -1000, -1000, -1000, 2568, -1000, -1000, 1047, - 1046, 1023, 1022, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 2913, -1000, 2418, -1000, -1000, 8308, 8308, 8308, 8308, 8308, + 8308, 48921, -1000, -1000, -1000, 2582, 2890, -1000, 74877, 58294, + 898, 2129, 1710, 2128, 76319, 76319, 1077, -1000, 822, 65504, + 65504, -361, 1077, 852, 65504, 844, 2550, 1116, 2543, 1115, + 2141, 58294, 2838, 2625, 58294, 2125, 2123, 76319, 76319, 65504, + 65504, 76319, -1000, -1000, -1000, 27750, -1000, 1353, 2542, 48200, + 47479, 51805, 51805, -1000, -1000, -1000, 973, -1000, 1630, -1000, + 9156, 18894, 1077, 1077, 58294, 58294, 58294, 58294, 58294, -1000, + 58294, -1000, -1000, 1630, -1000, 1630, 1630, 1630, 1633, 2963, + 1633, -1000, -1000, -1000, 1630, 77040, 77040, 18894, -1000, 19632, + 64062, 1367, -1000, -1000, 1630, -1000, 77040, 1020, 1020, 1020, + -1000, 2122, 546, -1000, -1000, -1000, -1000, -1000, 341, -1000, + -1000, -1000, 2786, 2861, 2859, 2121, 848, 848, -1000, 2260, + 848, 2532, -1000, 1647, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 848, 2856, 18156, 74877, + -470, -1000, -1000, 2541, -1000, 447, -1000, -1000, 999, 2622, + 999, 5613, 65504, 65504, 65504, -1000, 2578, 74877, -1000, 2578, + 2578, 2578, 19, 2578, 2578, -1000, -1000, 2578, -1000, -1000, + -1000, 2578, -1000, -1000, 2578, -1000, -1000, -1000, 2578, 2578, + -1000, 2578, 2578, -1000, -1000, -1000, -1000, -1000, 65504, 999, + 542, 2540, 999, 65504, 65504, 1113, 191, -39, -1000, -1000, + -1000, 310, 302, 300, 298, -1000, -1000, -1000, -1000, 294, + 293, -1000, -1000, 58294, 58294, -1000, 2537, 61178, 2853, 23322, + 2821, -1000, 2821, -1000, -1000, -1000, 360, -1000, 58294, 65504, + 76319, 44595, 44595, 44595, 44595, -1000, 2662, 2660, -1000, 2672, + 2671, 2640, 495, 61178, -1000, 2844, 348, 2399, 2232, 2232, + 512, 930, 10747, -1000, 2553, -1000, 61178, 1271, 1134, 1132, + 1128, 2786, -1000, -1000, -1000, -1000, -1000, 1920, 1841, 1957, + 13728, 19632, -1000, -1000, -1000, -1000, -1000, 2980, 2980, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1336, 1753, 2974, + 1527, 2509, -1000, -1000, -1000, 2536, -1000, 1695, 1265, 1914, + 1834, -1000, -1000, -1000, -1000, -1000, -1000, 14466, -1000, 58294, + -1000, 18894, 18894, 18894, 1910, -1000, 43874, -1000, -1000, -1000, + 24060, 1541, 11514, 1904, 1587, 19632, 19632, 19632, 19632, 19632, + 19632, 19632, 19632, 19632, 19632, 19632, 19632, 19632, 19632, 19632, + 1460, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2120, + -1000, 339, 36606, 13728, 36606, 942, 942, 74877, 1357, 1357, + 1357, 1357, 1357, 1357, 59015, -1000, -1000, -1000, 2858, 35130, + 36606, 2858, 2858, 2858, 2858, 2858, 2383, 1600, 60457, 17418, + 44595, 13728, 13728, 13728, 2232, 18894, 18894, 13728, 19632, 13728, + 16680, 15942, 21108, 13728, 13728, 2858, 1642, 1600, 27012, 13728, + -1000, 2232, -1000, -1000, -1000, -1000, 1945, -1000, -1000, -263, + -263, -263, 13728, 13728, 13728, 13728, 2232, 2232, 13728, 13728, + 13728, 13728, 13728, 2232, 2232, 2232, 2232, 13728, 13728, 13728, + 13728, 13728, 13728, 13728, 13728, 13728, 13728, 13728, 13728, -1000, + -1000, -1000, 1941, 56131, 44595, 58294, 2445, 2441, -1000, -1000, + 1252, 29964, 2499, -1000, -41, -55, -46, -1000, -1000, 1316, + -1000, -1000, -1000, 15204, -1000, -1000, -1000, 24798, 2890, -1000, + 40269, -1000, 55, -1000, -1000, -1000, 2565, -1000, 2567, 120, + 527, 2567, 105, 99, 2567, 2567, 2567, -1000, -1000, -1000, + -1000, 121, -1000, -1000, -1000, -1000, -1000, 2581, 2580, -1000, + 2565, 2565, 2565, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 2682, -1000, 2213, 890, -1000, 7729, 7729, 7729, 7729, - 7729, 362, -1000, -1000, -1000, 2379, 2656, -1000, 68825, 56925, - 777, 2019, 1422, 2018, 70225, 70225, 925, -1000, 617, 64625, - 64625, -372, 925, 669, 64625, 684, 2310, 958, 2309, 956, - 2026, 56925, 2600, 2421, 56925, 2015, 2014, 70225, 70225, 64625, - 64625, 70225, -1000, -1000, -1000, 36594, -1000, 1180, 2308, 42925, - 42225, 49225, 49225, -1000, -1000, -1000, 1382, -1000, 1888, 18669, - 925, 925, 56925, 56925, 56925, 56925, 56925, -1000, 56925, -1000, - -1000, 1382, -1000, 1382, 1382, 1382, 1373, 2715, 1373, -1000, - -1000, -1000, 1382, 70925, 70925, 18669, -1000, 19386, 63225, 1173, - -1000, -1000, 1382, 70925, 872, 872, 872, -1000, 2013, 443, - -1000, -1000, -1000, -1000, -1000, 265, -1000, -1000, -1000, 2550, - 2619, 2617, 2012, 996, 996, -1000, 1890, 996, 2299, -1000, - 1333, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, 996, 2621, 17952, 68825, -470, -1000, -1000, - 2307, -1000, 359, -1000, -1000, 833, 2420, 833, 6174, 64625, - 64625, 64625, -1000, 2369, 68825, -1000, 2369, 2369, 2369, -46, - 2369, 2369, -1000, -1000, 2369, -1000, -1000, -1000, 2369, -1000, - -1000, 2369, -1000, -1000, -1000, 2369, 2369, -1000, 2369, 2369, - -1000, -1000, -1000, -1000, -1000, 64625, 833, 401, 2306, 833, - 64625, 64625, 955, 123, -92, -1000, -1000, -1000, 253, 243, - 242, 238, -1000, -1000, -1000, -1000, 232, 228, -1000, -1000, - -1000, 2304, 60425, 2613, 22254, 2586, -1000, 2586, -1000, -1000, - -1000, 391, -1000, 56925, 70225, 52725, 52725, 52725, 52725, -1000, - 2456, 2454, -1000, 2452, 2446, 2439, 438, 60425, -1000, 2602, - 272, 2204, 2043, 2043, 598, 774, 40825, -1000, 2276, -1000, - 60425, 1118, 972, 968, 967, 2550, -1000, -1000, -1000, -1000, - -1000, 2098, 1654, 1570, 12933, 19386, -1000, -1000, -1000, -1000, - -1000, 2752, 2752, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 1170, 1454, 2741, 1269, 2303, -1000, -1000, 2302, -1000, - 1540, 1036, 1642, 1463, -1000, -1000, -1000, -1000, -1000, -1000, - 13650, -1000, 56925, -1000, 18669, 18669, 18669, 1604, -1000, 40118, - -1000, -1000, -1000, 23688, 1280, 10065, 1497, 1272, 19386, 19386, - 19386, 19386, 19386, 19386, 19386, 19386, 19386, 19386, 19386, 19386, - 19386, 19386, 19386, 1564, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, 2009, -1000, 264, 34443, 12933, 34443, 2137, 2137, - 68825, 1126, 1126, 1126, 1126, 1126, 1126, 57625, 2616, 33009, - 34443, 2616, 2616, 2616, 2616, 2616, 2195, 1622, 59025, 17235, - 52725, 12933, 12933, 12933, 2043, 18669, 18669, 12933, 12933, 16518, - 15801, 20820, 12933, 12933, 2616, 1351, 1622, 25839, 2043, 12933, - -1000, -1000, 15084, -1000, -1000, -1000, -1000, -1000, 2043, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -260, -260, -260, - 12933, 12933, 12933, 12933, 2043, 2043, 12933, 12933, 12933, 12933, - 12933, 2043, 2043, 2043, 2043, 12933, 12933, 12933, 12933, 12933, - 12933, 12933, 12933, 12933, 12933, 12933, 12933, 54825, 52725, 56925, - 2261, 2251, -1000, -1000, 1034, 27273, 2274, -1000, -94, -101, - -71, -1000, -1000, 1101, -1000, -1000, -1000, 14367, -1000, -1000, - -1000, 24405, 2656, -1000, 9328, -1000, -1000, -26, -1000, -1000, - -1000, 2326, -1000, 465, 449, 31, 412, 2342, 2342, 2342, - 2342, -1000, -1000, -1000, -1000, 35, -1000, -1000, -1000, -1000, - -1000, 2378, 2377, -1000, 2326, 2326, 2326, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2572, 531, 2566, + 2566, 2566, 2566, 2566, -1000, -1000, -1000, -1000, -1000, 1047, + -1000, -1000, -1000, 18894, 2807, 2722, 2587, 2553, 1120, -456, + 852, 2821, 2837, 2821, 950, -1000, 1249, 2579, 76319, 907, + 2492, -1000, 564, 2374, 1185, 55410, -1000, -1000, -1000, -1000, + -1000, 58294, 58294, 65504, 65504, 65504, 1156, -1000, 58294, 2535, + -1000, -1000, -1000, -1000, -1000, 2481, -1000, 2374, -1000, -1000, + 1234, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 2362, 437, 2340, 2340, 2340, 2340, 2340, -1000, -1000, - -1000, -1000, 895, 895, 895, -1000, 18669, 2571, 2477, 2383, - 2276, 963, -455, 669, 2586, 2599, 2586, 784, -1000, 1032, - 2376, 70225, 763, 2271, -1000, 408, 2113, 1039, 54125, -1000, - -1000, -1000, -1000, -1000, 56925, 56925, 64625, 64625, 64625, 999, - -1000, 56925, 2301, -1000, -1000, -1000, -1000, -1000, 2263, -1000, - 2113, -1000, -1000, 1029, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, @@ -9632,552 +10376,583 @@ var yyPact = [...]int{ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -427, -429, 58294, -1000, -1000, -1000, -1000, -1000, + -1000, 2534, -1000, 2534, -1000, -1000, -1000, 2259, 1600, 2119, + 2114, 2856, -1000, -1000, -1000, -1000, 1660, -1000, -1000, -1000, + -1000, 1630, 58294, 2856, -1000, -1000, -1000, 1600, 1312, 2589, + 2553, 2232, -1000, -1000, -1000, 162, -1000, 160, -1000, -1000, + -1000, 2111, -1000, 19632, 2785, 2783, -1000, 2532, 2532, -1000, + 2532, 848, 59736, 2532, -1000, -1000, 2376, -1000, 274, 2257, + 58294, -1000, 61178, 68, -1000, -102, 73435, -1000, -1000, -1000, + 999, 73435, -1000, 312, 254, -1000, 1110, -1000, 2372, -1000, + -1000, -1000, -1000, 2578, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, 73435, 396, 515, 73435, 2481, 2962, + 316, 2518, -1000, 1646, 1645, -1000, -1000, -1000, -1000, -1000, + -1000, 2881, -1000, 246, 246, -1000, 2553, 2341, -1000, 1224, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 2803, 1521, 1521, 1521, 4945, 564, 2620, 2577, 2619, 446, + -1000, -1000, -1000, -1000, 2654, -1000, 2648, 2641, -1000, -1000, + -1000, 2556, 61178, 44595, -1000, -1000, -1000, 2517, 2553, -1000, + 2232, 74877, 1205, -1000, 61178, 2553, 2553, 2553, 19632, 19632, + 1502, -1000, 19632, 19632, 1489, -1000, 19632, 19632, 1424, -1000, + 2232, 2511, -1000, -1000, 1600, 1221, 4954, -1000, 74156, 64, + 2694, 28488, 28488, 18894, -1000, -1000, -1000, 24798, 2882, -1000, + 2703, 2701, 2961, -1000, -1000, -1000, 1541, 1637, 1615, -1000, + -1000, 1844, -1000, -1000, -1000, -1000, -1000, 1220, 2553, -1000, + -1000, -1000, -1000, -1000, 4380, 2553, 2553, 2553, -1000, -1000, + -1000, -1000, 1904, 19632, 19632, 19632, 1312, 4380, 4802, 1784, + 1911, 1357, 1526, 1526, 1337, 1337, 1337, 1337, 1337, 1546, + 1546, -1000, -1000, -1000, -1000, 2232, -1000, 2368, -1000, -1000, + 2253, 2252, 2251, -1000, -1000, -1000, -1000, 13728, -1000, -1000, + -1000, -1000, -1000, 13728, 13728, 13728, 13728, 13728, 18894, -1000, + 2368, 2368, 2368, -1000, 1652, 1880, 2270, 4745, 2368, 1418, + 2960, 2368, 1416, 2958, 2368, 2164, 19632, 19632, 19632, 2368, + 2368, 13728, 1701, -1000, 18894, 2232, 1286, 2232, 1219, 1211, + 2368, -1000, 2232, 2502, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -426, -427, 56925, -1000, -1000, -1000, -1000, - -1000, -1000, 2300, -1000, 2300, -1000, -1000, 1887, 1622, 2008, - 2007, 2621, -1000, -1000, -1000, -1000, 1379, -1000, -1000, -1000, - -1000, 1382, 56925, 2621, -1000, -1000, -1000, 1622, 1372, 2386, - 2276, 2043, -1000, -1000, -1000, 86, -1000, 81, -1000, -1000, - -1000, 2002, -1000, 19386, 2547, 2544, -1000, 2299, 2299, -1000, - 2299, 996, 58325, 2299, -1000, -1000, 2193, -1000, 173, 1886, - 56925, -1000, 60425, -8, -1000, -129, 67425, -1000, -1000, -1000, - 833, 67425, -1000, 270, 219, -1000, 954, -1000, 2191, -1000, - -1000, -1000, -1000, 2369, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, 67425, 309, 388, 67425, 2263, 2714, - 295, 2298, -1000, 1331, 1325, -1000, -1000, -1000, -1000, -1000, - -1000, 2652, -1000, -1000, 2276, 2129, -1000, 1028, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2567, 1275, - 1275, 1275, 402, 2419, 2368, 2417, 868, -1000, -1000, -1000, - -1000, 2448, -1000, 2438, 2436, -1000, -1000, -1000, 2314, 60425, - 52725, -1000, -1000, -1000, 2297, 2276, 2043, 68825, 1066, -1000, - 60425, 2276, 2276, 2276, 19386, 19386, 1266, -1000, 19386, 19386, - 1261, -1000, 19386, 19386, 1219, -1000, 2043, 2295, -1000, -1000, - 1622, 1026, 4836, -1000, 68125, -16, 2470, 1547, 1547, 18669, - -1000, -1000, -1000, 24405, 2636, -1000, 2486, 2482, 2711, -1000, - -1000, -1000, 1280, 1361, 1349, -1000, -1000, 1650, -1000, -1000, - -1000, -1000, -1000, 1024, 2276, -1000, -1000, -1000, -1000, -1000, - 4941, 2276, 2276, 2276, -1000, -1000, -1000, -1000, 1497, 19386, - 19386, 19386, 1372, 4941, 4987, 1470, 2941, 1126, 1346, 1346, - 1153, 1153, 1153, 1153, 1153, 1283, 1283, -1000, -1000, -1000, - 2043, -1000, 2081, -1000, -1000, -1000, -1000, -1000, -1000, 12933, - -1000, -1000, -1000, -1000, -1000, 12933, 12933, 12933, 12933, 12933, - 18669, -1000, 2081, 2081, 2081, -1000, 1374, 1555, 2031, 2081, - 1194, 2710, 2081, 1189, 2709, 2081, 2275, 19386, 19386, 19386, - 2081, 2081, 12933, 1389, -1000, 18669, 2043, 1122, 2043, 1023, - 1022, -1000, 2081, -1000, 1754, 2293, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, 2501, 2957, 2368, 2232, 2368, + 2368, -143, -143, 2232, 2368, 2232, 2368, 2368, -143, -143, + -143, -143, 2368, 2368, 2368, 2368, 2368, 2368, 2368, 2368, + 2368, 2368, 2368, 2368, -1000, 2232, 1414, 58294, -1000, 2465, + 1414, 2381, 44595, -1000, -1000, 44595, 77040, 26274, -1000, 29226, + -46, -74, -1000, -1000, 2499, -1000, -1000, 1547, -1000, -1000, + 2250, 1600, -1000, 1209, 2807, 251, -1000, -1000, -1000, -1000, + 2573, 46758, -1000, 2740, 1287, 1287, 63341, 75598, 2736, -1000, + -1000, 217, 52, -1000, -1000, -1000, 2017, -1000, 324, 517, + 2567, -1000, -1000, -1000, 2567, 2567, -1000, 2567, 2567, -1000, + -1000, -1000, -1000, 2248, 2248, -1000, -1000, -1000, -1000, 2015, + -1000, 2572, -1000, 2013, -1000, -1000, -1000, -1000, 217, 217, + 217, 217, 217, -1000, 1776, -1000, 2617, 74877, 2852, 58294, + -364, -1000, -1000, -1000, 2947, -1000, -1000, 74877, 62620, 2616, + -1000, -1000, 309, 65504, 553, 770, 303, -1000, 1708, -1000, + -1000, 1108, -1000, 1106, -1000, -1000, -1000, -1000, -1000, -1000, + 58294, 65504, 74877, 2614, 2613, -1000, 51805, -1000, -1000, -1000, + -1000, 2923, 2107, 2105, -1000, 1633, 1630, -1000, 19632, 65504, + -1000, 948, -1000, -1000, -1000, 4380, 19632, 19632, -1000, -1000, + -1000, -1000, 1745, -1000, -1000, -1000, -1000, -44, -1000, -1000, + 1105, 1208, 1204, 73435, 1103, -1000, 340, 65504, -1000, 74877, + -1000, 2954, 2952, 395, 2950, 65504, 2491, -1000, 1635, 1634, + 1614, 1598, 1566, 1563, 1560, 191, 2571, 2570, -1000, 262, + -1000, -81, -1000, -1000, -1000, 23322, 36606, 1521, 1528, -1000, + 1509, 2247, 1405, 1421, -1000, -1000, 1444, 1349, 1050, 1521, + 1055, 450, 1101, 2793, 2788, 706, 704, -1000, 1521, 1055, + 1534, 758, -1000, 1479, 1472, 1467, 1464, 1461, 1452, 1447, + 1426, 748, -1000, -1000, 1521, 1521, 1521, 1521, 1521, 1521, + 1521, 1521, -232, -233, 1521, 1521, 1521, 1521, 1521, 1521, + 1521, 1521, 1521, 1521, 1521, 1521, 1521, 1521, 1521, 1521, + 32178, 1521, -1000, 1164, 788, -1000, -1000, 18894, 2568, -1000, + 18894, -1000, -1000, -1000, -1000, -1000, 74877, 2556, 512, 930, + -1000, 18894, -1000, 2339, -1000, -1000, 1205, 74877, 74877, 74877, + 4583, 1954, 2553, 4566, 1935, 2553, 4036, 1823, 2553, 2844, + 13728, 22584, 2246, 2488, 2245, 2244, -1000, 61, 2684, -1000, + -1000, -1000, 58294, -1000, -1000, -1000, -1000, 2923, 43153, 14466, + -1000, -1000, -1000, -1000, 34392, 13728, -1000, -1000, -1000, -1000, + 1312, 4380, 3336, -1000, 19632, -1000, -1000, 2232, 2368, 2368, + 2368, 2368, 2368, 1600, -1000, -1000, -1000, 521, 1460, 521, + -1000, 1460, 19632, -1000, 19632, 19632, -1000, 19632, 19632, -1000, + -1000, 19632, 2943, 2907, 2014, -287, -1000, 2480, 1588, -1000, + 18894, 1871, -1000, -1000, -1000, -1000, -1000, 19632, 19632, 19632, + -1000, -1000, -1000, -1000, -1000, 72714, -1000, -143, -143, -143, + -143, -143, -1000, -1000, -1000, -1000, -143, -143, -143, -143, + -143, -143, -143, -143, -143, -143, -143, -143, -1000, 296, + 2553, -1000, 25536, 2923, 44595, 2447, 2447, -1000, 1193, -1000, + -1000, -1000, -97, -77, -1000, -1000, -1000, -1000, -1000, 36606, + -1000, -1000, -1000, 516, 2909, 1521, 1521, 1521, 352, 1521, + 1521, 1521, 1521, 1521, -234, -236, 1521, 1521, 1521, 1521, + 1521, 1521, 1521, 1521, 1521, 1521, 1521, 175, 1521, 1521, + 1521, 1521, 1521, 32178, 1521, 49642, 1216, 1041, -1000, -1000, + 75598, 75598, 75598, -1000, 75598, -1000, -1000, -1000, -1000, 50363, + -1000, -1000, 1769, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 2553, -480, 2011, 58294, -1000, 2801, 1407, 38820, 2973, + -1000, 2733, -1000, 2732, 2728, 2243, -1000, -1000, 2369, 2346, + 2334, -1000, 2567, -1000, -1000, -1000, -1000, -1000, 2366, -1000, + 2364, 2487, -1000, 2362, -416, 58294, -1000, -1000, 2553, 2010, + 2612, -1000, -1000, -1000, -1000, 2330, 2486, -1000, 8308, 74877, + 74877, 74877, 795, -298, 705, -1000, 65504, 484, 564, 767, + 2104, -388, 2836, 58294, 65504, -1000, -1000, -1000, 71993, 71993, + -1000, -1000, 18894, -1000, -1000, 2856, -1000, 4380, 2374, -1000, + -1000, 4380, 4380, 1414, 1148, -1000, 65504, 1366, 71272, 1100, + 65504, 394, 244, -1000, 65504, 65504, 2948, 65504, 2481, 316, + 2241, 2240, 2238, 1992, 1991, 1977, 1976, -1000, 58294, 58294, + 2233, 2796, -1000, -1000, 1477, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, 6920, 1421, 1412, 1409, 1406, 1401, -1000, + 46037, 75598, 1225, 1060, -1000, -1000, 2553, -1000, 45316, 50363, + 50363, 50363, 74877, 2715, 2713, 74877, 50363, 50363, 74877, 50363, + 1018, 2102, 2800, 1521, 111, -1000, -1000, -1000, 70551, -1000, + 69830, 870, 51084, 50363, 74877, 58294, 42432, -1000, -1000, -1000, + -1000, 69109, 1973, 74877, 74877, 68388, 67667, 66946, 66225, -1000, + 1003, 18894, 1003, 1928, 1928, 2230, 2228, 2227, 1521, 1521, + 1928, 2224, 38082, 2223, 1013, 1003, 1003, 1003, 1928, 2210, + 399, 1907, 2209, 2144, 2139, 1003, -1000, -250, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2553, + 936, 1099, 952, -8, 1600, 74877, 1600, 2360, -1000, -1000, + 2553, 1263, 74877, -1000, 2295, 2295, 2295, 19632, 19632, 19632, + 19632, 19632, 19632, 19632, 19632, 19632, 61178, -1000, -1000, 1180, + 12, 74877, -1000, 38, -1000, -1000, -1000, 2910, -1000, 2485, + -1000, -1000, -1000, 2232, -1000, 19632, 4380, -1000, -143, -143, + -143, -143, -143, 2232, 2565, 2565, 2565, -1000, 2565, 2566, + 128, -1000, -1000, -1000, 2565, 146, 2565, 145, -1000, 2232, + 2232, 2232, 2229, 3791, 3484, 2676, 2638, 2229, 19632, 19632, + 19632, 2553, -138, -1000, 1600, 18894, 2468, 2375, 2229, -1000, + -1000, 2100, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2289, 2708, 2081, - 2043, 2081, 2081, -193, -193, 2043, 2081, 2043, 2081, 2081, - -193, -193, -193, -193, 2081, 2081, 2081, 2081, 2081, 2081, - 2081, 2081, 2081, 2081, 2081, 2081, 1223, 56925, -1000, 2265, - 1223, 2209, 52725, -1000, -1000, 52725, 70925, 32292, -1000, 26556, - -71, -78, -1000, -1000, 2274, -1000, -1000, 1717, -1000, -1000, - 1885, 1622, -1000, 1019, 2571, 377, 890, -1000, -1000, -1000, - 2363, 59725, -1000, 2511, 1094, 1094, 62525, 69525, 2510, -1000, - -1000, 213, -31, -1000, -1000, -1000, 1709, -1000, 2342, 269, - -1000, 2342, 435, 431, 2342, -1000, 2342, 2342, -1000, -1000, - -1000, -1000, -1000, 1884, 1884, -1000, -1000, -1000, -1000, 1708, - -1000, 2362, -1000, 1688, -1000, -1000, -1000, -1000, 213, 213, - 213, 213, -1000, -1000, -1000, 1691, -1000, 2416, 68825, 2611, - 56925, -377, -1000, -1000, -1000, 2694, -1000, -1000, 68825, 61825, - 2414, -1000, -1000, 279, 64625, 406, 600, 271, -1000, 1419, - -1000, -1000, 952, -1000, 947, -1000, -1000, -1000, -1000, -1000, - -1000, 56925, 64625, 68825, 2413, 2412, -1000, 49225, -1000, -1000, - -1000, -1000, 2689, 2001, 2000, -1000, 1373, 1382, -1000, 19386, - 64625, -1000, 794, -1000, -1000, -1000, 4941, 19386, 19386, -1000, - -1000, -1000, -1000, 1452, -1000, -1000, -1000, -1000, -61, -1000, - -1000, 946, 1017, 1015, 67425, 945, -1000, 302, 64625, -1000, - 68825, -1000, 2705, 2701, 308, 2700, 64625, 2273, -1000, 1321, - 1320, 1305, 1297, 1294, 1291, 123, 2361, 2360, -1000, 200, - -1000, -1000, 22254, 34443, 1275, 1258, -1000, 1175, 1868, 2272, - -1000, 1151, 1106, 1097, 904, 904, -1000, 1275, 904, 2558, - 2552, 374, 1275, 1275, 1275, 1275, 1275, 1275, 1242, 990, - 674, -1000, -1000, 18669, 2357, -1000, 18669, -1000, -1000, -1000, - -1000, -1000, 68825, 2314, 598, 745, -1000, 18669, -1000, 2126, - -1000, -1000, 1066, 68825, 68825, 68825, 4963, 2104, 2276, 4905, - 2010, 2276, 4890, 1873, 2276, 2602, 12933, 22971, 1867, 2270, - 1865, 1859, -1000, -19, 2467, -1000, -1000, -1000, 56925, -1000, - -1000, -1000, -1000, 2689, 52025, 13650, -1000, -1000, -1000, -1000, - 31575, 12933, -1000, -1000, -1000, -1000, 1372, 4941, 4725, -1000, - 19386, -1000, -1000, 2043, 2081, 2081, 2081, 2081, 2081, 1622, - -1000, -1000, -1000, 662, 1564, 662, -1000, 1564, -1000, 19386, - 19386, -1000, 19386, 19386, -1000, -1000, 19386, 4821, 4806, 2292, - -303, -1000, 2180, 1356, -1000, 18669, 1589, -1000, -1000, -1000, - -1000, -1000, 19386, 19386, 19386, -1000, -1000, -1000, -1000, -1000, - 66725, -1000, -193, -193, -193, -193, -193, -1000, -1000, -1000, - -1000, -193, -193, -193, -193, -193, -193, -193, -193, -193, - -193, -193, -193, 373, 2276, -1000, 25122, 2689, 52725, 2199, - 2199, -1000, 1008, -1000, -1000, -1000, -112, -130, -1000, -1000, - -1000, -1000, 34443, -1000, -1000, -1000, 4289, 2678, 1275, 1275, - 1275, 1275, 355, 2566, 1275, 1275, 1275, 1275, 1275, 1275, - -240, -247, 1275, 1275, 1275, 1275, 1275, 1275, 1275, 1275, - 1275, 1275, 1275, 114, 1275, 1275, 1275, 1275, 1275, 29424, - 1275, -1000, 43625, 885, 2483, 887, 895, -1000, 69525, 69525, - 69525, -1000, 69525, -1000, -1000, -1000, 1999, -1000, -1000, 1459, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2276, -480, - 1687, 56925, 2565, 9109, 2739, -1000, 2509, -1000, 2508, 2506, - 1858, -1000, -1000, 2103, -1000, 2099, 2095, -1000, -1000, 2342, - -1000, 2342, -1000, -1000, -1000, 2185, -1000, 2182, 2269, -1000, - 2178, 151, 56925, -1000, -1000, 2610, 1665, 2411, -1000, -1000, - -1000, -1000, 2082, 2268, -1000, 7729, 68825, 68825, 68825, 586, - -313, 400, -1000, 64625, 345, 408, 651, 1998, -392, 2594, - 56925, 64625, -1000, -1000, -1000, 66025, 66025, -1000, -1000, 18669, - -1000, -1000, 2621, -1000, 4941, 2113, -1000, -1000, 4941, 4941, - 1223, 976, -1000, 64625, 1169, 65325, 942, 64625, 305, 212, - -1000, 64625, 64625, 2698, 64625, 2263, 295, 1853, 1845, 1844, - 1661, 1656, 1644, -1000, 56925, 56925, 1843, -1000, -1000, 1171, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 402, 41525, 69525, - 1056, -1000, -1000, 906, -1000, 266, 48525, 47825, 47125, 68825, - 2505, 2503, 46425, 56925, 68825, -1000, -1000, 45725, 1996, 18669, - 68825, -1000, -1000, 2564, 1275, 1716, 1842, 1732, 1732, 2276, - 873, 68825, 781, 938, 747, -33, 1622, 68825, 1622, 2176, - -1000, -1000, 2276, 1166, 68825, -1000, 2039, 2039, 2039, 19386, - 19386, 19386, 19386, 19386, 19386, 19386, 19386, 19386, 60425, -1000, - -1000, 1006, -53, 68825, -1000, -1000, -1000, -1000, -1000, 2687, - -1000, 2266, -1000, -1000, -1000, 2043, -1000, 19386, 4941, -1000, - -193, -193, -193, -193, -193, 2043, 2326, 2326, -1000, 2326, - 2340, -1000, 2326, 74, 2326, 63, -1000, -1000, 2043, 2043, - 2043, 4651, 4634, 4601, 4306, 1754, 19386, 19386, 19386, 2276, - -188, -1000, 1622, 18669, 4291, 3267, 1754, -1000, -1000, 1949, + 2611, 2611, 25536, 2844, -1000, 21846, -1000, 930, -1000, -1000, + 74877, 2478, -1000, 1521, 1250, 1521, 1521, 2913, 2447, -1000, + -1000, 1361, -1000, -1000, -1000, -1000, 159, 1003, 1003, 1003, + 1521, 2799, 1521, 1928, 1928, 2208, 2205, 2204, 1521, 1521, + 1928, 2200, 38082, 2193, 1013, 1003, 1003, 1003, 1928, 2192, + 399, -1000, 1902, 2191, 2106, 1994, 1003, -1000, -260, 2553, + 2356, -1000, 2565, 2565, 2712, 1287, -1000, -1000, -1000, -1000, + -1000, 2563, -1000, -1000, 19632, 2851, -1000, 2562, 1403, -1000, + -1000, -1000, 942, 2190, -1000, -1000, 19632, -1000, -1000, 2553, + 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, 2553, + 2553, -65, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 2189, -1000, 1971, -1000, 1970, -1000, -1000, -1000, 2561, + -1000, 2850, -1000, 58294, 239, 62620, -1000, 8308, 8308, 8308, + -8, 548, 384, -1000, 1734, -1000, -1000, -1000, 2188, 2184, + 2183, 2374, 569, 1728, 503, -1000, 2845, 2182, 2178, 2177, + 2176, 1953, -1000, -1000, 2588, 74877, 2484, -1000, 1600, 1630, + 38, 58294, 244, -1000, -1000, -1000, 65504, 244, -1000, -1000, + 501, 2481, 2481, 65504, 2481, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, 2353, 2345, -1000, -1000, -1000, -1000, -1000, + -1000, 1318, 1411, 330, 327, 51084, 1024, 8308, 8308, 2587, + 1287, -1000, 2711, 1393, -1000, -1000, -1000, -1000, -1000, -1000, + 50363, 2483, -418, -420, 1324, -440, -1000, -1000, -1000, -1000, + 51084, 1521, 1460, 2798, 654, 326, 640, 323, -1000, -1000, + -1000, -1000, 1024, 1260, 1098, -1000, 2710, 50363, 1097, 620, + 322, -1000, 1771, -299, 2483, -1000, 2483, -1000, 2483, -1000, + 2483, -1000, -1000, 1600, -1000, -1000, -1000, -1000, -1000, -1000, + 2175, 2173, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2410, 25122, - 2276, 21537, -1000, -1000, -1000, 68825, 2201, -1000, 1275, 1098, - 1275, 1275, 2682, 2199, -1000, -1000, 1123, -1000, -1000, -1000, - -1000, 152, 913, 913, 913, 1564, 1275, 2563, 1275, 1275, - 1732, 1732, 30141, 1840, 1837, 1836, 1275, 1275, 1732, 1830, - 35877, 1829, 852, 913, 913, 913, 1732, 1828, 375, -1000, - 1693, 1825, 1742, 1786, 913, -1000, -254, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2276, 2174, - -1000, 2326, 2326, 2501, -1000, 1094, -1000, -1000, -1000, -1000, - -1000, 2324, -1000, -1000, 19386, 2609, -1000, 2323, 1207, -1000, - 2137, 1820, -1000, 2276, 2276, 2276, 2276, 19386, -1000, -1000, - 37, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 1819, -1000, 1640, -1000, 1638, -1000, -1000, -420, 2322, - -1000, -1000, -1000, 56925, 198, 61825, -1000, 7729, 7729, 7729, - -33, 344, 307, -1000, 1433, -1000, -1000, -1000, 1818, 1811, - 1798, 2113, 409, 1425, 363, -1000, 2608, 1794, 1793, 1792, - 1791, 1625, -1000, -1000, 2385, 68825, 2264, -1000, 1622, 1382, - 20, 56925, 212, -1000, -1000, -1000, 64625, 212, -1000, -1000, - 380, 2263, 2263, 64625, 2263, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, 2172, 2133, -1000, -1000, -1000, -1000, -1000, 45725, - 855, 7729, 7729, 2383, 1094, -1000, 2498, 887, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, 1945, -1000, 1112, 1112, -1000, - 932, 855, 45725, 1622, 1152, 1275, 1564, -1000, -1000, -1000, - -1000, -1000, -1000, 35877, -1000, -1000, -1000, 1449, 1464, -1000, - 2409, 70225, -1000, 558, 2406, 521, 2137, 2131, -1000, 68825, - -1000, -1000, -1000, -1000, -1000, -1000, 4941, 4941, 2802, 4941, - 4941, 2226, 4941, 4941, 1847, -1000, 30858, 2276, -1000, 2685, - 2677, -1000, -1000, 4941, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 419, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 19386, 19386, 19386, 19386, -1000, 1754, 1754, 1754, 19386, - 2043, 1773, 1622, 19386, 19386, -1000, 1214, -1000, -1000, 2592, - 2153, 2232, -1000, -1000, 12216, 2043, 2474, 2129, -1000, 59025, - 52725, 2126, 2682, 25122, 18669, 18669, 18669, 18669, 2656, -1000, - -272, -1000, 358, 347, 280, -1000, -1000, -1000, -1000, -1000, - 1564, 1275, 30141, 1564, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, 1772, 1770, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -253, 38082, 1789, -1000, 2610, 76319, -1000, 778, 2609, + 535, 942, 2343, -1000, 74877, -1000, -1000, -1000, -1000, -1000, + -1000, 4380, 4380, 2352, 4380, 4380, 2336, 4380, 4380, 2262, + -1000, 33654, 2553, -1000, 8, -1000, 2915, 2908, -1000, -1000, + 4380, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 436, 427, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -259, 35877, 217, 43625, 2591, 2591, 69525, 69525, - 68825, 1754, 2276, 68825, -1000, -1000, -1000, -1000, -1000, 10782, - -1000, 10782, -1000, 10782, 10782, 1754, -1000, 2276, 2276, 2276, - 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, 2276, -1000, - 2073, 2058, -1000, 43625, 264, -1000, -392, 2650, -1000, 198, - -1000, 1767, 658, 695, -1000, 646, 637, 628, 620, 602, - -1000, -1000, -1000, -1000, 2406, 601, 344, -1000, -68, 1623, - 1287, 2556, 307, -1000, 1619, 1615, 1582, 1578, 325, -1000, - -1000, -1000, -1000, 267, 408, -1000, 633, 1765, -1000, -1000, - 403, -1000, -1000, 2538, 2124, -1000, -60, -1000, -1000, 2607, - 212, 2607, 282, 2263, -1000, -1000, 2052, -1000, -1000, 1944, - -1000, -1000, 2321, 69525, 69525, -1000, 45025, -1000, -1000, 44325, - 68825, -1000, 855, 2580, 2579, 1564, -1000, 2117, -1000, 2276, - 428, 1764, 273, -1000, -1000, 990, 563, -1000, -1000, -1000, - -230, -1000, -1000, 19386, 19386, 19386, -1000, 33726, -195, 18669, - 18669, -1000, -1000, 1754, 1754, 1754, 1754, -1000, -1000, -1000, - 187, -1000, -1000, 1754, 1754, 2682, 2676, 2493, -1000, 2276, - -1000, -1000, 2276, 370, -1000, 2656, -1000, 1622, 1622, 1622, - 1622, -1000, -278, 1551, 35877, 2276, 35877, 2276, 2276, 788, - -1000, 1564, -1000, -1000, -1000, -1000, -1000, -1000, 2117, 217, - -1000, 35877, 1275, 1763, 1275, 1275, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, 2102, -483, 19386, 2093, 2081, 2081, 2081, - -1000, 2081, -1000, -1000, -1000, 2078, -1000, 264, 764, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 2536, 2535, 735, 781, - -1000, 1760, 1758, -1000, 645, 1703, 1054, -198, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 607, - 1936, -1000, 356, -1000, -1000, 2669, -392, 19386, -1000, 2531, - 2528, -1000, 64625, 2607, -1000, -1000, -1000, -1000, 213, 213, - 43625, 2383, 2317, -1000, -1000, -1000, -1000, -1000, -1000, 19386, - -1000, 1125, 35877, -1000, 1179, -1000, -1000, -1000, 781, 1128, - 581, 1754, 1754, 1754, 2033, -1000, 7607, 262, -1000, 68825, - -1000, 1622, 2262, -1000, 1622, -1000, -1000, -1000, -1000, 2043, - 233, -330, -1000, -1000, 1237, 18669, 2738, -1000, 2232, 2276, - -1000, 264, -1000, 2276, 2668, -1000, 2043, 68825, 2043, 68825, - 1937, 68825, 1290, -1000, -1000, -1000, -1000, 1539, -1000, 1756, - 1755, 860, -1000, -1000, -1000, 1754, -1000, -1000, -1000, -1000, - -1000, 217, -1000, -1000, 742, 73565, -1000, -1000, -1000, -1000, - 1464, -1000, -1000, -1000, -1000, 1504, -1000, -1000, 1597, 592, - 350, -1000, 2605, -1000, 1503, 4941, 914, 2514, 2516, 2667, - -317, -1000, 2076, 2315, 43625, 4941, 1275, -1000, 2051, -1000, - 68825, 73565, 1464, 1040, 565, 521, -1000, -1000, -1000, 2043, - 33726, 315, -443, -57, 1753, 2260, -1000, 2603, 18669, -1000, - 2466, -311, -336, 2043, 294, 294, 2252, 25122, 2232, 2043, - 1179, -399, -1000, 2039, -1000, 2039, 2043, 2043, 2039, 1498, - -1000, -1000, -1000, 56925, -483, -1000, 217, -1000, 768, -1000, + -1000, 19632, 19632, 19632, 19632, -1000, 2229, 2229, 2229, 19632, + 2232, 2171, 1600, 19632, 19632, -1000, 1395, -1000, -1000, 2827, + -1000, 2423, 61178, 2232, 2460, 2341, 2232, 359, -1000, -1000, + -1000, 60457, 44595, 2482, -1000, 2553, 2339, 2913, 25536, 18894, + 18894, 18894, 18894, 2890, -1000, -272, -1000, 443, 311, -1000, + -1000, -1000, -1000, -1000, -1000, 1460, 1521, 32916, -1000, -1000, + -1000, -1000, -1000, 2170, 2169, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -255, 38082, 220, 49642, 2825, + 2825, 75598, 75598, 74877, 2229, 2553, 74877, -1000, -1000, -1000, + -1000, 2229, -1000, -1000, 2302, 2292, 49642, 339, -1000, -388, + 2880, -1000, 239, -1000, 2168, 851, 861, -1000, 843, 839, + 833, 832, 808, -1000, -1000, -1000, -1000, 2609, 797, 548, + -1000, -60, 1951, 1493, 2792, 384, -1000, 1940, 1937, 1936, + 1924, 413, -1000, -1000, -1000, -1000, 295, 564, -1000, 763, + 2167, -1000, -1000, 555, -1000, -1000, 2776, 2337, -1000, 8, + -1000, 2848, 244, 2848, 392, 2481, -1000, -1000, 2265, -1000, + -1000, 2091, -1000, -1000, 2560, 75598, 75598, 2297, -1000, 74877, + -1000, -1000, -1000, -1000, -1000, 2820, 2817, -1000, -1000, 1024, + 1460, -1000, 1460, -1000, -1000, -1000, -1000, -1000, 50363, 74877, + 50363, 1092, 50363, -1000, -1000, 2553, 1147, -1000, -1000, -1000, + -1000, 2328, -1000, 583, 2165, 319, -1000, -1000, 1164, 785, + -1000, -1000, -1000, -244, -1000, -1000, 19632, 19632, 19632, -1000, + 35868, 2757, 2754, -149, 18894, 18894, -1000, -1000, -1000, -1000, + 2229, 2229, 2229, 2229, -1000, -1000, -1000, 308, -1000, -1000, + 2229, 2229, 2913, 2904, 2709, -1000, 2556, -1000, -1000, 2460, + 359, -1000, 930, -1000, 12990, -1000, 2890, -1000, 1600, 1600, + 1600, 1600, -1000, -274, 1898, 19632, 2553, 2553, 807, -1000, + 1460, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2328, 220, + -1000, 38082, 1521, 2163, 1521, 1521, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, 2325, -484, 19632, 2308, -1000, -1000, -1000, + 2305, -1000, -1000, 906, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 2762, 2761, 905, 936, -1000, 2162, 2159, -1000, 690, + 1974, 1218, -154, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, 762, 2089, -1000, 498, -1000, -1000, + 2901, -388, 19632, -1000, 2757, -1000, 65504, 2848, -1000, -1000, + -1000, -1000, 217, 217, 49642, 2587, 2559, -1000, 1393, 2695, + 19632, -1000, -1000, 1356, 1354, -1000, -1000, 1090, 50363, -1000, + 1393, 58294, 38082, -1000, -1000, -1000, -1000, 936, 1380, 789, + 2229, 2229, 2229, 2272, -1000, 7872, 338, -1000, 2746, 2748, + 2899, -1000, 74877, -1000, 1600, 2477, -1000, 1600, -1000, -1000, + -1000, -1000, 2232, 269, -322, -1000, -1000, 1512, 18894, 2971, + -1000, -1000, -1000, 359, -1000, -1000, -1000, 2553, 2896, -1000, + 2229, 74877, 19632, 2553, 1557, -1000, -1000, -1000, -1000, 1882, + -1000, 2158, 2157, 1014, -1000, -1000, -1000, 2229, -1000, 220, + -301, 339, 929, 79939, -1000, -1000, -1000, -1000, 1789, -1000, + -1000, -1000, -1000, 1856, -1000, -1000, 1879, 662, 496, -1000, + 2847, -1000, 1826, 4380, 1083, -300, -1000, 2301, 2557, 49642, + -1000, 951, 4380, 1521, 1460, 50363, -1000, 2297, 27, -1000, + 79939, 1789, 1214, 787, 535, -1000, -1000, -1000, 2232, 35868, + 373, -446, 10, 2152, 2754, 2895, 2752, 2750, -1000, 2151, + 2473, -1000, 2846, 18894, -1000, 2682, -296, -328, 2232, 405, + 405, 2458, 25536, 2232, -1000, 1393, -394, -1000, 2295, 2229, + 74877, 1825, -1000, -1000, -1000, 58294, -484, -1000, 220, -1000, + 393, -1000, 912, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, 11499, 18669, 106, 35160, 1933, 1932, 73565, 1757, - 73565, 18669, 1918, 1917, 2517, 19386, 73411, 427, -351, -1000, - -353, -1000, -1000, -1000, 1752, -1000, 2314, 1493, 2528, 2666, - 2521, 2518, -1000, 1751, 404, 217, 43625, 2057, 1564, -1000, - 1179, 2481, -1000, 426, 2137, -1000, 521, -1000, 2602, -1000, - -1000, 1750, -232, -1000, 2276, -70, 68825, 2276, -1000, -1000, - 2461, -1000, -1000, -1000, 296, -1000, 1228, 736, 1216, -1000, - 2137, -1000, 2228, -1000, 2051, -295, -1000, -1000, -1000, -1000, - -1000, 2276, 2313, -1000, -1000, 1915, 1914, -1000, 1586, 1542, - -1000, 18669, 1528, 543, 522, 7254, -1000, -1000, -1000, -1000, - -1000, -1000, -489, -1000, 396, -490, 917, -1000, -1000, 1913, - -1000, 2697, 4941, -1000, -491, -1000, -1000, -1000, -1000, -1000, - 1309, -1000, 1748, -1000, 2663, 2659, -1000, 61125, -1000, 2041, - 217, -1000, -1000, 800, -1000, -1000, -230, -1000, 1128, 60425, - 584, 1745, 33726, 2276, -1000, -1000, -321, 1376, -1000, -1000, - -1000, -1000, -1000, -260, -1000, -1000, 1469, 68825, 68825, -1000, - -1000, -1000, 1383, 1375, 73565, -1000, 1481, 73565, 2647, 2638, - 2637, 20, 34443, 73355, 73201, 73565, 73565, 18669, 73029, 73565, - 1443, -1000, 72875, 73565, -1000, -1000, -1000, 1718, 1680, -1000, - -1000, 2759, 2113, 217, -1000, 795, 73565, -1000, 1128, -1000, - 1585, 1536, 2405, 2404, 2137, -1000, 2033, 33726, -331, 296, - -1000, -1000, 2039, 2036, 260, 1371, 73565, -1000, -492, 73565, - -493, 767, 264, 941, 1101, -1000, 514, -1000, 1912, -494, - -495, -496, 903, 18669, -497, 1911, -1000, -1000, -1000, -1000, - 64625, -1000, 2276, -1000, -1000, 2403, 2137, -1000, 2402, 2137, - -104, -105, 2401, -1000, 2033, -345, -1000, -1000, 2400, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 73565, 59025, -1000, -499, - 72819, -500, 6006, -1000, -1000, -1000, 72665, -1000, -1000, -1000, - -1000, 529, -1000, -1000, 2572, -1000, -1000, 72492, 72352, 72326, - 73565, 1516, 8784, 2119, -1000, -1000, 2113, 20103, -1000, 221, - 2399, -384, 2398, 216, 215, -1000, -1000, -106, -1000, -1000, - 2396, 2395, 2696, -1000, -502, -1000, 8611, 1365, 73565, 919, - 73565, 1535, -1000, 18669, -1000, 941, -1000, 19386, 1910, 511, - 18669, -504, 507, 500, 1909, 1754, 2043, 214, -386, 2391, - 2370, -1000, -1000, -1000, 2737, -1000, 2734, 1053, 1053, 8457, - 1364, -1000, -1000, -506, 916, 73565, -1000, 1338, -1000, 4941, - -1000, 1906, 1436, 8245, -1000, -1000, -1000, -1000, -1000, 211, - -387, -1000, -1000, -1000, 891, 1524, -1000, -1000, -1000, 6925, - -1000, -507, 73565, -1000, 504, 421, -1000, -1000, -1000, -1000, - -1000, 910, 6683, -508, 1893, 1849, -1000, 905, 73565, -1000, - -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 12252, 18894, 170, 37344, + 2088, 2084, 79939, 2108, 79939, 18894, 2083, 2079, 2723, 19632, + 79884, 579, -339, -1000, -340, -1000, -1000, -1000, 2150, -1000, + 2556, 1811, 545, 220, 49642, 2299, 989, 1460, -1000, -1000, + -1000, 756, -1000, 576, 942, -1000, 535, -1000, 2844, -1000, + -1000, 2140, -193, -1000, 2553, 5, -1000, 2138, -1000, 2894, + 2892, -1000, 74877, 2553, -1000, -1000, 2677, -1000, -1000, -1000, + 364, -1000, 1497, 926, 1466, -1000, 942, -1000, 2457, -1000, + 2297, 304, -1000, -1000, 2295, -1000, 2555, -1000, 380, 1044, + 1038, -301, -1000, 2076, 2059, -1000, 1773, 1736, -1000, 18894, + 1748, 702, 653, 7780, -1000, -1000, -1000, -1000, -1000, -1000, + -490, -1000, 390, -491, 1040, -1000, -1000, 2040, -1000, 2930, + 4380, -1000, -492, -1000, -1000, -1000, -1000, -1000, 1518, 61899, + -1000, 2278, 220, 2553, -1000, -1000, -1000, -1000, -244, -1000, + 1380, 61178, 641, 2136, 35868, 2553, -1000, 2135, 1883, -1000, + -1000, -302, 1719, -1000, -1000, -1000, -1000, -1000, -263, -1000, + 2553, 807, -1000, 74877, -1000, 363, 351, -1000, -1000, -1000, + -1000, 1624, 1688, 79939, -1000, 1727, 79939, 2879, 2878, 2877, + 38, 36606, 79734, 79679, 79939, 79939, 18894, 79360, 79939, 1743, + -1000, 79415, 79939, -1000, -1000, -1000, -1000, 2990, 2374, 220, + -1000, 20370, 79939, -1000, 1380, -1000, 1853, 1849, 2608, 2606, + 942, -1000, 2272, 35868, -1000, -1000, -324, 364, -1000, 19632, + 2553, 2274, -1000, -1000, 292, 1687, 79939, -1000, -493, 79939, + -495, 921, 339, 1008, 1316, -1000, 625, -1000, 2039, -496, + -497, -498, 959, 18894, -500, 2024, -1000, -1000, 65504, -1000, + 2229, 2232, -1000, -1000, 2605, 942, -1000, 2604, 942, -90, + -92, 2602, -1000, 2272, -330, -1000, 2229, 19632, 2601, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 79210, 60457, -1000, -501, + 79150, -502, 9188, -1000, -1000, -1000, 78945, -1000, -1000, -1000, + -1000, 635, -1000, -1000, 2808, -1000, -1000, 78891, 78742, 78686, + 79939, 1722, 78537, 2456, -1000, -1000, 2374, -1000, -1000, -1000, + 290, 2599, -375, 2598, 278, 277, -1000, -1000, -94, -1000, + -1000, -278, 2229, 2596, 2595, 2929, -1000, -503, -1000, -1000, + 78483, 1683, 79939, 1076, 79939, 1632, -1000, 18894, -1000, 1008, + -1000, 19632, 2022, 619, 18894, -504, 601, 594, 1956, 276, + -376, 2594, 2593, -1000, -1000, -1000, 1810, -278, -1000, 2949, + -1000, 2969, 1213, 1213, 10094, 1682, -1000, -1000, -505, 1075, + 79939, -1000, 1690, -1000, 4380, -1000, 1913, 1715, 9747, -1000, + -1000, -1000, 271, -378, -1000, -1000, -1000, -1000, -1000, 1034, + 1833, -1000, -1000, -1000, 9596, -1000, -506, 79939, -1000, 598, + 587, -1000, -1000, -1000, -1000, -1000, 1074, 9391, -507, 1909, + 1851, -1000, 1065, 79939, -1000, -1000, -1000, } var yyPgo = [...]int{ - 0, 3245, 3244, 3243, 17, 3242, 193, 279, 266, 27, - 3241, 268, 3239, 270, 3238, 30, 22, 20, 36, 3236, - 2895, 2893, 2890, 2877, 34, 3235, 113, 3234, 3232, 2875, - 3231, 3230, 2871, 3229, 3228, 3225, 3223, 3222, 3221, 3220, - 3218, 3217, 2869, 2867, 2865, 3216, 3212, 3210, 2851, 2849, - 2842, 3201, 192, 39, 25, 3200, 4, 3196, 178, 214, - 3190, 3, 3189, 3188, 7, 3186, 3185, 2840, 3183, 3182, - 3180, 3179, 3171, 126, 3170, 2838, 3166, 2836, 3163, 2829, - 2823, 2818, 2816, 2798, 208, 3162, 2794, 2785, 2780, 3161, - 2525, 210, 482, 206, 3160, 1694, 3149, 196, 3147, 191, - 3146, 3144, 3143, 446, 3142, 142, 3141, 332, 144, 143, - 149, 2098, 3139, 53, 136, 310, 3138, 8, 3133, 105, - 3132, 195, 3131, 201, 3130, 174, 203, 173, 3129, 3128, - 131, 3127, 3125, 3123, 190, 3121, 3120, 212, 2383, 3119, - 3118, 170, 3117, 123, 3115, 168, 3114, 3113, 3111, 3107, - 209, 115, 75, 146, 127, 3105, 138, 3103, 3096, 3094, - 3091, 9, 3265, 3090, 134, 176, 3089, 51, 38, 44, - 3087, 50, 3086, 3082, 92, 3068, 3065, 3064, 171, 58, - 3063, 3062, 57, 3058, 63, 74, 3057, 76, 3056, 169, - 3055, 3054, 3053, 3051, 3050, 69, 3049, 80, 3048, 172, - 137, 1256, 3046, 3045, 45, 43, 3043, 55, 24, 10, - 97, 33, 104, 67, 165, 151, 122, 180, 41, 135, - 54, 133, 119, 3038, 207, 161, 188, 111, 70, 3037, - 183, 3036, 106, 189, 166, 167, 185, 3035, 3029, 3021, - 221, 3020, 154, 78, 3018, 116, 2028, 215, 3013, 226, - 130, 3012, 3011, 3009, 3008, 99, 47, 145, 3007, 213, - 211, 219, 114, 3005, 1637, 4618, 6270, 112, 260, 4474, - 204, 187, 3004, 61, 3003, 2999, 2998, 427, 147, 42, - 79, 141, 2997, 139, 29, 84, 2996, 2995, 2993, 2992, - 2991, 2990, 355, 163, 2989, 2986, 59, 2985, 2983, 32, - 26, 16, 14, 88, 124, 200, 199, 198, 2981, 179, - 52, 2980, 2978, 164, 157, 2977, 2976, 2974, 2973, 160, - 107, 184, 2972, 150, 153, 159, 2971, 117, 2970, 2969, - 100, 3329, 156, 2968, 2967, 2962, 140, 129, 2960, 2959, - 2958, 62, 2957, 2956, 2955, 2954, 2953, 98, 48, 56, - 101, 28, 2951, 2949, 2948, 125, 152, 2947, 102, 128, - 64, 46, 2946, 2, 6, 5, 2944, 2927, 2926, 2924, - 2918, 2916, 2915, 2914, 121, 2912, 2911, 95, 2910, 2909, - 2908, 49, 2906, 2905, 2903, 175, 158, 65, 202, 155, - 12, 2901, 2900, 11, 2899, 162, 2898, 77, 2897, 118, - 2886, 2883, 71, 96, 40, 81, 2881, 2873, 82, 2862, - 2847, 83, 2844, 2834, 205, 2499, 2832, 4279, 2820, 177, - 148, 66, 91, 2807, 103, 109, 2805, 94, 2796, 19, - 60, 2791, 13, 15, 132, 2782, 0, 1577, 186, 2776, - 245, 2774, 2768, 68, + 0, 3464, 3461, 3460, 11, 3458, 211, 300, 282, 13, + 3455, 295, 3453, 301, 3447, 26, 23, 17, 31, 3446, + 3104, 3099, 3097, 3092, 29, 3443, 119, 3440, 3439, 3085, + 3438, 3436, 3069, 3435, 3434, 3430, 3428, 3425, 3423, 3422, + 3418, 3417, 3067, 3065, 3063, 3416, 3415, 3412, 3058, 3056, + 3054, 3411, 33, 44, 39, 3410, 4, 3409, 195, 232, + 3407, 5, 3406, 3405, 21, 196, 3404, 3403, 72, 3052, + 3402, 3401, 3400, 3399, 3398, 3397, 145, 3394, 3392, 3034, + 3391, 3029, 3386, 3027, 3024, 3022, 3019, 3017, 222, 3383, + 3015, 3013, 3010, 3382, 2730, 228, 536, 225, 3372, 135, + 2166, 3371, 218, 3370, 213, 3369, 3368, 3367, 492, 3366, + 162, 3365, 340, 159, 160, 166, 321, 3364, 65, 172, + 344, 3363, 10, 3362, 122, 3358, 215, 3356, 224, 3355, + 190, 191, 189, 3350, 3348, 150, 3347, 3346, 3345, 214, + 3337, 3336, 231, 4763, 3330, 3329, 192, 3328, 140, 3327, + 170, 3326, 3325, 3322, 3319, 235, 115, 95, 171, 130, + 3318, 154, 3314, 3313, 3306, 3304, 3302, 3289, 69, 20, + 4206, 3287, 149, 188, 3286, 54, 42, 51, 3285, 52, + 3284, 3283, 132, 3280, 3279, 127, 3278, 187, 73, 3275, + 3273, 3271, 3270, 113, 82, 3269, 60, 3267, 181, 3266, + 3259, 3258, 3257, 3256, 106, 3252, 81, 3251, 185, 223, + 169, 3250, 3248, 45, 48, 3240, 57, 19, 16, 100, + 36, 104, 80, 184, 165, 128, 152, 40, 151, 55, + 142, 197, 3238, 229, 176, 210, 121, 62, 3237, 199, + 3236, 114, 201, 179, 182, 200, 3235, 3234, 3233, 238, + 3232, 175, 588, 3230, 125, 329, 226, 3229, 236, 139, + 3227, 3222, 3221, 3218, 116, 49, 136, 3216, 37, 234, + 233, 237, 43, 77, 3212, 837, 5712, 4537, 7488, 71, + 61, 143, 5499, 41, 208, 3211, 79, 3210, 3209, 3208, + 3907, 163, 53, 89, 153, 3205, 155, 46, 111, 3204, + 3203, 3202, 3201, 3200, 3196, 156, 186, 3195, 3194, 67, + 3193, 3192, 34, 28, 15, 14, 3191, 144, 220, 217, + 216, 3190, 198, 59, 3189, 3188, 180, 138, 3187, 3186, + 3185, 3183, 178, 123, 204, 3181, 202, 118, 134, 3179, + 124, 3178, 3176, 86, 6331, 137, 3175, 3174, 131, 133, + 3173, 3171, 3169, 3168, 63, 3167, 3166, 3, 3165, 108, + 56, 50, 110, 38, 157, 3164, 3162, 194, 3159, 3158, + 147, 168, 3157, 158, 141, 58, 3151, 75, 148, 3149, + 161, 2, 7, 6, 3148, 3147, 3145, 3144, 3141, 3135, + 3134, 3133, 126, 3132, 3131, 103, 96, 76, 3128, 64, + 3127, 3126, 3125, 193, 174, 70, 221, 146, 9, 3124, + 3123, 8, 3122, 177, 3121, 97, 3120, 120, 3119, 3118, + 68, 102, 47, 92, 3116, 3115, 99, 3113, 3110, 98, + 3109, 3108, 227, 2655, 3106, 639, 3102, 209, 173, 78, + 91, 3089, 74, 112, 3071, 101, 3060, 22, 66, 3050, + 35, 25, 207, 3031, 0, 2481, 206, 3008, 129, 3004, + 3002, 164, 2999, } var yyR1 = [...]int{ - 0, 435, 435, 1, 1, 1, 1, 1, 1, 1, + 0, 453, 453, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 89, 4, 4, 9, 14, 6, 6, 10, 10, 10, + 93, 4, 4, 9, 14, 6, 6, 10, 10, 10, 11, 11, 7, 7, 12, 12, 13, 13, 5, 5, - 117, 117, 8, 8, 116, 116, 116, 226, 226, 226, - 226, 223, 223, 118, 118, 115, 115, 123, 15, 15, - 101, 101, 16, 17, 17, 17, 17, 438, 438, 132, - 132, 130, 130, 131, 131, 221, 221, 18, 18, 18, - 230, 230, 235, 235, 235, 238, 238, 238, 238, 209, - 210, 211, 20, 20, 20, 20, 20, 20, 20, 20, - 20, 20, 20, 20, 20, 20, 20, 426, 426, 426, - 427, 427, 427, 427, 427, 391, 391, 406, 406, 406, - 407, 407, 405, 405, 405, 405, 405, 409, 409, 410, - 410, 408, 408, 408, 408, 412, 412, 413, 413, 411, - 411, 411, 411, 411, 411, 411, 411, 411, 411, 411, - 411, 411, 411, 394, 394, 394, 48, 48, 48, 48, - 48, 49, 49, 49, 49, 49, 49, 414, 414, 414, - 414, 414, 414, 414, 414, 414, 414, 414, 414, 414, - 414, 414, 414, 414, 414, 414, 414, 414, 414, 414, - 414, 414, 414, 414, 414, 414, 414, 414, 414, 414, - 415, 415, 416, 416, 416, 416, 416, 416, 416, 416, - 416, 416, 416, 416, 416, 416, 416, 416, 416, 416, - 416, 416, 416, 416, 416, 416, 416, 416, 416, 416, - 416, 416, 416, 416, 416, 416, 416, 416, 416, 416, - 416, 417, 417, 418, 418, 419, 419, 419, 419, 420, - 420, 420, 420, 420, 421, 421, 421, 421, 421, 421, - 421, 422, 422, 423, 423, 3, 2, 372, 372, 373, - 373, 374, 374, 374, 374, 375, 375, 376, 376, 377, - 377, 377, 377, 377, 377, 377, 377, 377, 377, 30, - 30, 30, 30, 30, 30, 261, 261, 258, 258, 258, - 259, 259, 260, 260, 260, 393, 393, 393, 387, 387, - 387, 389, 389, 388, 388, 388, 390, 390, 395, 395, - 395, 395, 395, 397, 397, 397, 397, 397, 397, 398, - 398, 398, 396, 396, 151, 151, 399, 399, 404, 404, - 400, 400, 401, 401, 403, 403, 403, 402, 402, 402, - 402, 296, 296, 167, 167, 65, 65, 66, 66, 66, - 198, 198, 198, 19, 19, 19, 19, 19, 19, 25, - 27, 27, 27, 27, 53, 53, 54, 28, 28, 28, - 28, 55, 55, 56, 31, 31, 31, 31, 31, 31, - 63, 63, 63, 62, 62, 61, 61, 61, 61, 61, - 61, 33, 34, 35, 439, 439, 439, 57, 57, 36, - 36, 36, 39, 39, 39, 40, 40, 40, 37, 38, - 41, 29, 29, 29, 29, 64, 64, 59, 59, 58, - 58, 60, 60, 60, 60, 60, 60, 60, 60, 60, - 60, 60, 60, 32, 32, 32, 32, 32, 32, 24, - 371, 371, 371, 52, 52, 26, 26, 26, 26, 26, + 122, 122, 8, 8, 121, 121, 121, 235, 235, 235, + 235, 232, 232, 123, 123, 120, 120, 128, 15, 15, + 15, 106, 106, 16, 17, 17, 17, 17, 456, 456, + 137, 137, 135, 135, 136, 136, 230, 230, 18, 18, + 18, 239, 239, 244, 244, 244, 247, 247, 247, 247, + 218, 219, 220, 20, 20, 20, 20, 20, 20, 20, + 20, 20, 20, 20, 20, 20, 20, 20, 444, 444, + 444, 445, 445, 445, 445, 445, 272, 272, 272, 272, + 409, 409, 424, 424, 424, 425, 425, 423, 423, 423, + 423, 423, 427, 427, 428, 428, 426, 426, 426, 426, + 430, 430, 431, 431, 429, 429, 429, 429, 429, 429, + 429, 429, 429, 429, 429, 429, 429, 429, 412, 412, + 412, 48, 48, 48, 48, 48, 49, 49, 49, 49, + 49, 49, 432, 432, 432, 432, 432, 432, 432, 432, + 432, 432, 432, 432, 432, 432, 432, 432, 432, 432, + 432, 432, 432, 432, 432, 432, 432, 432, 432, 432, + 432, 432, 432, 432, 432, 433, 433, 434, 434, 434, + 434, 434, 434, 434, 434, 434, 434, 434, 434, 434, + 434, 434, 434, 434, 434, 434, 434, 434, 434, 434, + 434, 434, 434, 434, 434, 434, 434, 434, 434, 434, + 434, 434, 434, 434, 434, 434, 435, 435, 436, 436, + 437, 437, 437, 437, 438, 438, 438, 438, 438, 439, + 439, 439, 439, 439, 439, 439, 440, 440, 441, 441, + 3, 2, 390, 390, 391, 391, 392, 392, 392, 392, + 393, 393, 394, 394, 395, 395, 395, 395, 395, 395, + 395, 395, 395, 395, 30, 30, 30, 30, 30, 30, + 271, 271, 267, 267, 267, 269, 269, 270, 270, 270, + 411, 411, 411, 405, 405, 405, 407, 407, 406, 406, + 406, 408, 408, 413, 413, 413, 413, 413, 415, 415, + 415, 415, 415, 415, 416, 416, 416, 414, 414, 156, + 156, 417, 417, 422, 422, 418, 418, 419, 419, 421, + 421, 421, 420, 420, 420, 420, 309, 309, 175, 175, + 66, 66, 67, 67, 67, 207, 207, 207, 19, 19, + 19, 19, 19, 19, 25, 25, 27, 27, 27, 27, + 53, 53, 54, 28, 28, 28, 28, 55, 55, 56, + 31, 31, 31, 31, 31, 31, 63, 63, 63, 62, + 62, 61, 61, 61, 61, 61, 61, 33, 34, 35, + 457, 457, 457, 57, 57, 36, 36, 36, 39, 39, + 39, 40, 40, 40, 37, 38, 41, 29, 29, 29, + 29, 64, 64, 59, 59, 58, 58, 60, 60, 60, + 60, 60, 60, 60, 60, 60, 60, 60, 60, 32, + 32, 32, 32, 32, 32, 24, 389, 389, 389, 52, + 52, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, - 26, 26, 26, 26, 26, 26, 26, 71, 71, 333, - 334, 334, 334, 334, 334, 334, 334, 334, 320, 320, - 321, 321, 321, 321, 321, 310, 310, 310, 285, 285, - 285, 285, 285, 285, 285, 285, 285, 285, 285, 285, - 285, 285, 285, 285, 284, 284, 284, 284, 288, 288, - 286, 286, 286, 286, 286, 286, 286, 286, 286, 286, - 286, 286, 286, 286, 286, 287, 287, 287, 287, 287, - 287, 287, 287, 289, 289, 289, 289, 289, 290, 290, - 290, 290, 290, 290, 290, 290, 290, 290, 290, 290, - 290, 290, 290, 290, 290, 290, 290, 290, 290, 290, - 290, 290, 290, 290, 290, 290, 290, 291, 291, 291, - 291, 291, 291, 291, 291, 319, 319, 293, 293, 292, - 292, 292, 313, 313, 314, 314, 314, 311, 311, 311, - 312, 312, 297, 297, 297, 297, 297, 297, 297, 297, - 297, 297, 297, 297, 297, 298, 315, 299, 299, 300, - 300, 301, 301, 302, 302, 304, 304, 309, 309, 308, - 308, 308, 308, 308, 308, 305, 305, 305, 305, 305, - 305, 306, 306, 306, 307, 318, 318, 318, 318, 318, - 294, 50, 352, 352, 352, 352, 352, 352, 352, 352, - 352, 352, 352, 352, 357, 357, 252, 252, 253, 253, - 51, 51, 51, 51, 51, 157, 157, 353, 353, 355, - 355, 355, 355, 355, 355, 354, 354, 356, 356, 322, - 322, 351, 351, 350, 350, 349, 349, 349, 349, 349, - 349, 349, 331, 331, 332, 332, 346, 346, 346, 346, - 346, 346, 346, 346, 326, 326, 326, 325, 325, 327, - 327, 330, 330, 330, 348, 348, 347, 347, 323, 323, - 323, 358, 358, 358, 358, 358, 94, 94, 324, 324, - 324, 324, 324, 359, 328, 328, 329, 329, 329, 364, - 365, 363, 363, 363, 363, 363, 158, 158, 158, 335, - 335, 335, 336, 336, 336, 336, 336, 336, 336, 336, - 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, - 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, - 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, - 336, 336, 336, 336, 336, 336, 303, 303, 337, 337, - 337, 337, 337, 434, 434, 434, 338, 338, 338, 338, - 338, 338, 425, 425, 424, 424, 424, 339, 339, 339, - 340, 340, 340, 340, 340, 341, 341, 341, 341, 342, - 342, 343, 343, 344, 344, 345, 345, 368, 368, 368, - 367, 367, 67, 67, 67, 69, 69, 68, 74, 74, - 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, - 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, - 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, - 73, 73, 73, 73, 73, 73, 73, 73, 73, 73, - 73, 73, 73, 197, 197, 197, 257, 257, 362, 360, - 360, 361, 361, 70, 70, 70, 70, 152, 152, 21, - 21, 72, 72, 392, 392, 22, 22, 22, 22, 22, - 22, 22, 22, 22, 22, 366, 366, 366, 23, 23, - 75, 76, 76, 76, 268, 268, 268, 268, 79, 79, - 79, 79, 224, 224, 225, 225, 80, 80, 80, 80, - 81, 81, 81, 81, 77, 77, 77, 77, 77, 77, + 26, 26, 26, 74, 74, 346, 347, 347, 347, 347, + 347, 347, 333, 333, 334, 334, 334, 334, 334, 334, + 323, 323, 323, 298, 298, 298, 298, 298, 298, 298, + 298, 298, 298, 298, 298, 298, 298, 298, 298, 298, + 297, 297, 297, 297, 301, 301, 299, 299, 299, 299, + 299, 299, 299, 299, 299, 299, 299, 299, 299, 299, + 299, 300, 300, 300, 300, 300, 300, 300, 300, 302, + 302, 302, 302, 302, 303, 303, 303, 303, 303, 303, + 303, 303, 303, 303, 303, 303, 303, 303, 303, 303, + 303, 303, 303, 303, 303, 303, 303, 303, 303, 303, + 304, 304, 304, 304, 304, 304, 304, 304, 332, 332, + 306, 306, 305, 305, 305, 326, 326, 327, 327, 327, + 324, 324, 324, 325, 325, 310, 310, 310, 310, 310, + 310, 311, 328, 312, 312, 313, 313, 313, 313, 314, + 314, 315, 315, 315, 317, 317, 322, 322, 321, 321, + 321, 321, 321, 321, 318, 318, 318, 318, 318, 318, + 319, 319, 319, 320, 331, 331, 331, 331, 331, 307, + 50, 366, 366, 366, 366, 366, 366, 366, 366, 366, + 366, 366, 366, 366, 366, 367, 367, 372, 372, 261, + 261, 262, 262, 51, 51, 51, 51, 51, 162, 162, + 368, 368, 370, 370, 370, 370, 370, 370, 370, 369, + 369, 371, 371, 335, 335, 363, 363, 362, 362, 361, + 361, 361, 361, 361, 361, 361, 344, 344, 345, 345, + 358, 358, 358, 358, 358, 358, 358, 358, 339, 339, + 339, 338, 338, 340, 340, 343, 343, 343, 360, 360, + 359, 359, 336, 336, 373, 373, 373, 373, 373, 98, + 98, 337, 337, 337, 374, 341, 341, 342, 342, 342, + 382, 383, 381, 381, 381, 381, 381, 163, 163, 163, + 365, 365, 365, 364, 364, 364, 364, 364, 364, 364, + 364, 364, 364, 364, 364, 364, 364, 364, 364, 364, + 364, 364, 364, 364, 364, 364, 364, 364, 364, 364, + 364, 364, 364, 364, 364, 364, 364, 364, 364, 364, + 364, 364, 99, 99, 99, 316, 316, 348, 348, 348, + 348, 348, 452, 452, 452, 349, 349, 349, 349, 349, + 349, 443, 443, 442, 442, 442, 350, 350, 351, 351, + 351, 352, 352, 354, 354, 268, 268, 355, 355, 356, + 356, 353, 353, 353, 357, 357, 386, 386, 386, 385, + 385, 69, 69, 69, 69, 71, 71, 70, 70, 78, + 78, 76, 76, 76, 76, 76, 76, 76, 76, 76, + 76, 76, 76, 76, 76, 76, 76, 76, 76, 76, + 76, 76, 76, 76, 76, 76, 76, 76, 76, 76, + 76, 76, 76, 76, 76, 76, 76, 76, 76, 76, + 76, 76, 76, 76, 76, 76, 76, 76, 76, 76, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, 77, - 77, 77, 112, 244, 244, 243, 243, 242, 242, 242, - 245, 245, 245, 245, 282, 282, 282, 78, 78, 78, - 90, 90, 85, 85, 88, 88, 88, 91, 91, 92, - 92, 93, 93, 86, 87, 42, 43, 43, 43, 43, - 44, 83, 83, 83, 84, 84, 84, 84, 103, 103, - 441, 441, 441, 82, 442, 95, 96, 96, 98, 98, - 98, 99, 99, 99, 100, 100, 100, 249, 249, 249, - 249, 249, 249, 249, 97, 97, 97, 106, 106, 110, - 110, 110, 110, 109, 109, 109, 109, 200, 200, 205, - 274, 274, 181, 181, 201, 201, 206, 206, 206, 207, - 207, 208, 208, 208, 208, 208, 203, 203, 202, 202, - 204, 168, 168, 168, 168, 168, 168, 169, 169, 169, - 169, 169, 169, 169, 169, 169, 169, 169, 169, 169, - 169, 169, 166, 166, 272, 272, 272, 272, 271, 271, - 271, 114, 114, 119, 119, 121, 121, 121, 121, 121, - 121, 121, 121, 124, 183, 183, 142, 142, 143, 143, - 143, 143, 144, 144, 144, 144, 144, 146, 146, 146, - 147, 147, 147, 147, 147, 147, 148, 149, 149, 145, - 145, 145, 164, 164, 219, 219, 220, 220, 218, 218, - 222, 222, 120, 120, 122, 122, 122, 122, 127, 127, - 128, 128, 129, 129, 256, 256, 279, 279, 133, 133, - 133, 135, 134, 134, 134, 134, 134, 134, 136, 136, - 428, 429, 429, 430, 430, 430, 430, 431, 431, 431, - 431, 431, 431, 431, 431, 431, 431, 432, 432, 433, - 433, 137, 137, 139, 140, 140, 138, 138, 138, 138, - 138, 150, 150, 141, 153, 153, 153, 153, 154, 154, - 111, 111, 111, 111, 111, 111, 111, 111, 241, 241, - 156, 156, 155, 155, 155, 155, 155, 155, 155, 155, - 155, 155, 155, 155, 155, 177, 177, 177, 177, 177, - 177, 159, 159, 159, 159, 159, 159, 159, 105, 105, - 178, 178, 178, 126, 125, 125, 108, 108, 107, 107, - 179, 179, 162, 162, 162, 162, 162, 162, 162, 162, - 162, 162, 162, 162, 162, 162, 162, 162, 162, 162, - 162, 162, 162, 162, 162, 162, 162, 162, 162, 162, - 162, 162, 162, 162, 162, 162, 162, 162, 172, 172, - 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, - 176, 176, 176, 176, 176, 176, 176, 175, 175, 175, - 175, 175, 175, 175, 175, 175, 175, 175, 170, 170, + 77, 77, 77, 77, 77, 68, 68, 281, 281, 73, + 206, 206, 206, 266, 266, 379, 379, 380, 380, 378, + 378, 378, 378, 378, 378, 378, 378, 378, 378, 378, + 378, 378, 378, 378, 378, 378, 378, 378, 378, 378, + 376, 376, 375, 375, 377, 377, 72, 72, 72, 72, + 157, 157, 21, 21, 75, 75, 410, 410, 22, 22, + 22, 22, 22, 22, 22, 22, 22, 22, 384, 384, + 384, 23, 23, 79, 80, 80, 80, 280, 280, 280, + 280, 83, 83, 83, 83, 233, 233, 234, 234, 84, + 84, 84, 84, 85, 85, 85, 85, 81, 81, 81, + 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, + 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, + 81, 81, 81, 81, 81, 81, 81, 81, 81, 81, + 81, 81, 81, 81, 81, 81, 81, 81, 81, 117, + 253, 253, 252, 252, 251, 251, 251, 254, 254, 254, + 254, 295, 295, 295, 82, 82, 82, 94, 94, 89, + 89, 92, 92, 92, 95, 95, 96, 96, 97, 97, + 90, 91, 42, 43, 43, 43, 43, 44, 87, 87, + 87, 88, 88, 88, 88, 108, 108, 459, 459, 459, + 86, 460, 100, 101, 101, 103, 103, 103, 104, 104, + 104, 105, 105, 105, 258, 258, 258, 258, 258, 258, + 258, 102, 102, 102, 111, 111, 115, 115, 115, 115, + 114, 114, 114, 114, 209, 209, 214, 287, 287, 190, + 190, 210, 210, 215, 215, 215, 216, 216, 217, 217, + 217, 217, 217, 212, 212, 211, 211, 213, 176, 176, + 176, 176, 176, 176, 177, 177, 177, 177, 177, 177, + 177, 177, 177, 177, 177, 177, 177, 177, 177, 174, + 174, 285, 285, 285, 285, 284, 284, 284, 119, 119, + 124, 124, 126, 126, 126, 126, 126, 126, 126, 126, + 129, 192, 192, 461, 461, 147, 147, 148, 148, 148, + 148, 149, 149, 149, 149, 149, 151, 151, 151, 152, + 152, 152, 152, 152, 152, 153, 154, 154, 150, 150, + 150, 172, 172, 228, 228, 229, 229, 227, 227, 231, + 231, 125, 125, 127, 127, 127, 127, 132, 132, 133, + 133, 134, 134, 292, 292, 138, 138, 138, 140, 139, + 139, 139, 139, 139, 139, 141, 141, 446, 447, 447, + 448, 448, 448, 448, 449, 449, 449, 449, 449, 449, + 449, 449, 449, 449, 450, 450, 451, 451, 142, 142, + 144, 145, 145, 143, 143, 143, 143, 143, 143, 155, + 155, 146, 158, 158, 158, 158, 159, 159, 116, 116, + 116, 116, 116, 116, 116, 116, 250, 250, 161, 161, + 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, + 160, 160, 160, 186, 186, 186, 186, 186, 186, 164, + 164, 164, 164, 164, 164, 164, 110, 110, 187, 187, + 187, 131, 130, 130, 113, 113, 112, 112, 188, 188, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, - 170, 170, 170, 170, 170, 170, 170, 171, 171, 171, - 171, 171, 171, 171, 171, 171, 171, 171, 171, 171, - 171, 171, 171, 171, 171, 440, 440, 174, 173, 173, - 173, 173, 173, 173, 102, 102, 102, 102, 102, 280, - 280, 281, 281, 281, 281, 281, 281, 281, 281, 281, - 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, - 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, - 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, - 281, 281, 281, 283, 283, 283, 283, 283, 283, 283, - 283, 283, 283, 283, 283, 283, 283, 283, 190, 190, - 104, 104, 188, 188, 189, 191, 191, 187, 187, 187, - 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, - 187, 161, 161, 161, 161, 161, 161, 161, 161, 163, - 163, 163, 192, 192, 180, 180, 113, 193, 193, 194, - 195, 195, 196, 196, 199, 212, 212, 212, 213, 213, - 213, 213, 165, 165, 214, 214, 214, 214, 160, 160, - 160, 160, 160, 160, 160, 443, 443, 217, 217, 216, - 216, 215, 215, 215, 215, 215, 215, 227, 227, 182, - 182, 185, 185, 184, 186, 228, 228, 232, 232, 232, - 232, 229, 229, 233, 233, 233, 233, 236, 236, 237, - 237, 237, 234, 234, 234, 234, 231, 231, 231, 276, - 276, 276, 239, 239, 248, 248, 246, 246, 247, 247, - 240, 240, 295, 295, 295, 255, 255, 254, 254, 254, - 250, 250, 250, 251, 251, 273, 273, 269, 269, 275, - 275, 270, 270, 277, 277, 278, 278, 369, 369, 370, - 370, 370, 316, 316, 380, 380, 317, 317, 381, 381, - 383, 383, 378, 378, 379, 379, 382, 382, 45, 384, - 384, 385, 385, 386, 386, 386, 386, 46, 47, 47, - 47, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 262, 262, 262, - 262, 262, 262, 262, 262, 262, 262, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, - 264, 264, 264, 264, 264, 266, 266, 266, 266, 266, - 266, 266, 266, 266, 266, 266, 266, 266, 266, 266, - 266, 266, 266, 266, 266, 266, 266, 267, 267, 267, - 267, 267, 267, 265, 265, 265, 265, 265, 265, 436, - 437, + 170, 170, 170, 170, 170, 170, 170, 170, 170, 170, + 170, 170, 170, 170, 170, 170, 180, 180, 184, 184, + 184, 184, 184, 184, 184, 184, 184, 184, 184, 184, + 184, 184, 184, 184, 184, 183, 183, 183, 183, 183, + 183, 183, 183, 183, 183, 183, 178, 178, 178, 178, + 178, 178, 178, 178, 178, 178, 178, 178, 178, 178, + 178, 178, 178, 178, 178, 178, 178, 178, 178, 178, + 178, 178, 178, 178, 178, 179, 179, 179, 179, 179, + 179, 179, 179, 179, 179, 185, 185, 185, 185, 185, + 458, 458, 182, 182, 181, 181, 181, 181, 181, 181, + 107, 107, 107, 107, 107, 293, 293, 293, 294, 294, + 294, 294, 294, 294, 294, 294, 294, 294, 294, 294, + 294, 294, 294, 294, 294, 294, 294, 294, 294, 294, + 294, 294, 294, 294, 294, 294, 294, 294, 294, 294, + 294, 294, 294, 294, 294, 294, 294, 294, 294, 294, + 296, 296, 296, 296, 296, 296, 296, 296, 296, 296, + 296, 296, 296, 296, 296, 296, 296, 296, 296, 296, + 65, 65, 199, 199, 109, 109, 197, 197, 198, 200, + 200, 196, 196, 196, 196, 196, 196, 196, 196, 196, + 196, 196, 196, 196, 196, 196, 169, 169, 169, 169, + 169, 169, 169, 169, 169, 169, 169, 171, 171, 171, + 201, 201, 189, 189, 118, 202, 202, 203, 204, 204, + 205, 205, 208, 221, 221, 221, 222, 222, 222, 222, + 173, 173, 173, 223, 223, 223, 223, 166, 166, 165, + 165, 165, 167, 167, 167, 167, 168, 168, 462, 462, + 226, 226, 225, 225, 224, 224, 224, 224, 224, 224, + 236, 236, 191, 191, 194, 194, 193, 195, 237, 237, + 241, 241, 241, 241, 238, 238, 242, 242, 242, 242, + 245, 245, 246, 246, 246, 243, 243, 243, 243, 240, + 240, 240, 289, 289, 289, 248, 248, 257, 257, 255, + 255, 256, 256, 249, 249, 308, 308, 308, 263, 263, + 264, 264, 265, 265, 259, 259, 259, 260, 260, 286, + 286, 282, 282, 288, 288, 283, 283, 290, 290, 291, + 291, 291, 291, 387, 387, 388, 388, 388, 329, 329, + 398, 398, 330, 330, 399, 399, 401, 401, 396, 396, + 397, 397, 400, 400, 45, 402, 402, 403, 403, 404, + 404, 404, 404, 46, 47, 47, 47, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 273, 273, 273, 273, 273, 273, 273, + 273, 273, 273, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 274, 274, 274, 274, 274, 274, 274, 274, 274, + 274, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 275, 275, 275, + 275, 275, 275, 275, 275, 275, 275, 278, 278, 278, + 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, + 278, 278, 278, 278, 278, 278, 278, 278, 279, 279, + 279, 279, 279, 279, 276, 276, 276, 276, 276, 276, + 277, 277, 277, 454, 455, } var yyR2 = [...]int{ @@ -10188,172 +10963,181 @@ var yyR2 = [...]int{ 12, 5, 7, 1, 5, 1, 1, 1, 3, 3, 3, 3, 1, 3, 1, 1, 1, 1, 1, 3, 2, 1, 10, 2, 0, 2, 2, 0, 2, 3, - 3, 1, 3, 0, 2, 1, 3, 4, 8, 9, - 1, 1, 10, 9, 8, 7, 7, 1, 1, 1, - 3, 1, 3, 1, 3, 0, 4, 3, 4, 5, - 1, 3, 3, 2, 2, 2, 2, 2, 1, 0, - 0, 0, 2, 3, 2, 3, 11, 10, 11, 5, - 5, 16, 12, 9, 4, 15, 1, 6, 9, 8, - 0, 3, 3, 6, 3, 0, 3, 0, 2, 2, - 1, 3, 1, 1, 2, 2, 2, 0, 2, 1, - 2, 2, 2, 2, 2, 0, 1, 1, 2, 3, - 3, 5, 3, 3, 4, 5, 4, 4, 2, 2, - 2, 2, 2, 0, 2, 2, 9, 10, 9, 5, - 7, 7, 7, 7, 8, 4, 6, 2, 3, 2, - 3, 3, 3, 4, 3, 3, 2, 2, 3, 2, - 2, 2, 3, 2, 2, 3, 2, 2, 2, 3, - 3, 2, 3, 3, 2, 2, 2, 2, 2, 1, - 1, 3, 1, 1, 1, 1, 1, 1, 1, 1, + 6, 1, 3, 0, 2, 1, 3, 4, 8, 8, + 9, 1, 1, 10, 9, 8, 7, 7, 1, 1, + 1, 3, 1, 3, 1, 3, 0, 4, 3, 4, + 5, 1, 3, 3, 2, 2, 2, 2, 2, 1, + 0, 0, 0, 2, 3, 2, 3, 11, 11, 13, + 5, 5, 16, 12, 9, 4, 15, 1, 6, 9, + 8, 0, 3, 3, 6, 3, 0, 3, 4, 4, + 0, 3, 0, 2, 2, 1, 3, 1, 1, 2, + 2, 2, 0, 2, 1, 2, 2, 2, 2, 2, + 0, 1, 1, 2, 3, 3, 5, 3, 3, 4, + 5, 4, 4, 2, 2, 2, 2, 2, 0, 2, + 2, 9, 10, 9, 5, 7, 7, 7, 7, 8, + 4, 6, 2, 3, 2, 3, 3, 3, 4, 3, + 3, 2, 2, 3, 2, 2, 2, 3, 2, 2, + 3, 2, 2, 2, 3, 3, 2, 3, 3, 2, + 2, 2, 2, 2, 1, 1, 3, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 0, 3, 1, 3, + 0, 1, 1, 1, 1, 3, 1, 3, 3, 0, + 2, 5, 5, 5, 7, 5, 0, 3, 0, 3, + 4, 4, 0, 1, 1, 3, 2, 3, 3, 3, + 0, 1, 1, 2, 2, 2, 2, 1, 2, 2, + 3, 3, 3, 3, 2, 4, 5, 4, 6, 7, + 2, 3, 3, 3, 3, 0, 3, 0, 3, 3, + 1, 1, 1, 3, 2, 1, 1, 3, 3, 2, + 1, 1, 3, 1, 2, 5, 4, 6, 4, 3, + 3, 6, 5, 5, 4, 3, 5, 1, 3, 1, + 3, 3, 5, 0, 5, 0, 3, 0, 3, 0, + 3, 4, 0, 1, 1, 3, 0, 2, 1, 1, + 1, 1, 1, 1, 1, 0, 2, 2, 1, 1, + 1, 1, 1, 1, 4, 2, 5, 8, 4, 7, + 1, 2, 5, 7, 10, 8, 11, 1, 2, 5, + 5, 5, 5, 6, 5, 7, 1, 1, 1, 1, + 3, 1, 1, 1, 2, 1, 1, 2, 2, 5, + 0, 1, 2, 1, 3, 5, 7, 8, 7, 9, + 10, 7, 9, 10, 2, 2, 2, 2, 4, 2, + 4, 2, 3, 1, 3, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 0, 3, 1, 3, 0, 1, 1, 1, 1, - 3, 1, 3, 3, 0, 2, 5, 5, 5, 7, - 5, 0, 3, 0, 3, 4, 4, 0, 1, 1, - 3, 2, 3, 3, 3, 0, 1, 1, 2, 2, - 2, 2, 1, 2, 2, 3, 3, 3, 3, 2, - 4, 5, 4, 6, 7, 2, 3, 3, 3, 3, - 0, 3, 0, 3, 3, 1, 1, 1, 3, 2, - 1, 1, 3, 3, 2, 1, 1, 3, 1, 2, - 5, 4, 6, 4, 3, 3, 6, 5, 5, 4, - 3, 5, 1, 3, 1, 3, 3, 5, 0, 5, - 0, 3, 0, 3, 0, 3, 4, 0, 1, 1, - 3, 0, 2, 1, 1, 1, 1, 1, 1, 1, - 0, 2, 2, 1, 1, 1, 1, 1, 1, 4, - 5, 8, 4, 7, 1, 2, 5, 7, 10, 8, - 11, 1, 2, 5, 5, 5, 5, 6, 5, 7, - 1, 1, 1, 1, 3, 1, 1, 1, 2, 1, - 1, 2, 2, 5, 0, 1, 2, 1, 3, 5, - 7, 8, 7, 9, 10, 7, 9, 10, 2, 2, - 2, 2, 4, 2, 4, 2, 3, 1, 3, 3, + 2, 4, 3, 2, 4, 4, 0, 2, 3, 1, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 2, 4, 3, 2, 4, 4, - 0, 2, 3, 1, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 5, 5, 5, - 1, 1, 2, 3, 4, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 3, 0, 1, 1, 0, 2, - 2, 3, 2, 2, 2, 2, 2, 2, 2, 2, - 6, 8, 3, 6, 3, 1, 1, 1, 2, 1, + 1, 1, 1, 5, 5, 5, 1, 1, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, + 0, 1, 1, 0, 2, 2, 3, 2, 2, 2, + 2, 2, 2, 2, 2, 6, 8, 3, 6, 2, + 3, 1, 1, 1, 2, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 2, 2, 3, 2, 2, 2, 2, 2, 1, + 2, 2, 2, 1, 2, 3, 2, 3, 3, 2, + 3, 3, 2, 3, 4, 2, 2, 1, 1, 1, + 1, 1, 2, 1, 1, 1, 1, 1, 4, 4, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 3, + 0, 3, 0, 3, 3, 0, 5, 0, 3, 5, + 0, 1, 1, 0, 1, 2, 3, 3, 2, 2, + 4, 3, 1, 0, 1, 3, 3, 2, 2, 0, + 1, 2, 2, 2, 0, 1, 0, 1, 1, 1, + 1, 2, 2, 2, 5, 5, 5, 4, 4, 4, + 4, 4, 4, 4, 2, 1, 2, 1, 2, 2, + 3, 2, 2, 2, 2, 1, 1, 1, 1, 3, + 2, 1, 1, 3, 3, 0, 3, 0, 3, 1, + 1, 0, 1, 5, 4, 2, 2, 3, 0, 1, + 1, 3, 3, 3, 3, 3, 3, 3, 3, 1, + 3, 5, 5, 5, 4, 0, 1, 1, 2, 2, + 3, 2, 3, 3, 1, 1, 0, 1, 1, 1, + 3, 5, 3, 3, 5, 3, 2, 2, 1, 1, + 1, 1, 1, 0, 1, 0, 1, 1, 1, 3, + 3, 3, 3, 1, 11, 12, 12, 13, 13, 0, + 1, 3, 2, 1, 5, 1, 1, 0, 2, 2, + 3, 3, 1, 1, 2, 2, 2, 0, 1, 1, + 0, 2, 3, 3, 3, 3, 4, 5, 3, 3, + 4, 3, 3, 3, 4, 4, 3, 3, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 2, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 2, 2, 4, + 4, 5, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 2, 2, 3, 2, 2, - 2, 2, 2, 1, 2, 2, 2, 1, 2, 2, - 3, 3, 2, 3, 3, 2, 3, 3, 2, 3, - 4, 4, 2, 2, 1, 1, 1, 1, 1, 2, - 1, 1, 1, 1, 1, 4, 4, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 3, 0, 3, 0, - 3, 3, 0, 5, 0, 3, 5, 0, 1, 1, - 0, 1, 2, 3, 3, 2, 3, 5, 3, 5, - 3, 5, 4, 5, 4, 3, 1, 0, 1, 3, - 3, 0, 1, 2, 2, 0, 1, 0, 1, 1, - 1, 1, 2, 2, 2, 5, 5, 5, 4, 4, - 4, 4, 4, 4, 4, 2, 1, 2, 1, 2, - 2, 3, 2, 2, 2, 2, 1, 1, 1, 1, - 3, 2, 1, 1, 0, 3, 1, 1, 0, 1, - 5, 4, 2, 2, 3, 0, 1, 1, 3, 3, - 3, 3, 3, 3, 3, 1, 3, 5, 5, 5, - 4, 0, 1, 1, 2, 2, 3, 2, 3, 3, - 1, 1, 0, 1, 1, 1, 3, 5, 3, 3, - 5, 3, 2, 2, 1, 1, 1, 1, 1, 0, - 1, 0, 1, 1, 1, 3, 3, 3, 3, 3, - 1, 11, 12, 12, 13, 13, 0, 1, 3, 3, - 3, 2, 1, 5, 1, 1, 0, 2, 2, 3, - 3, 1, 1, 2, 2, 2, 0, 1, 2, 0, - 2, 3, 3, 3, 3, 3, 4, 4, 5, 3, - 3, 3, 4, 3, 3, 3, 4, 4, 3, 3, + 1, 1, 3, 1, 1, 1, 0, 6, 1, 4, + 5, 5, 6, 0, 1, 0, 3, 1, 1, 0, + 2, 0, 8, 9, 0, 2, 0, 1, 2, 0, + 2, 1, 1, 1, 1, 4, 3, 6, 5, 1, + 3, 5, 4, 8, 10, 9, 2, 2, 3, 3, + 4, 4, 4, 4, 3, 3, 3, 3, 6, 5, + 4, 4, 5, 5, 8, 4, 5, 7, 2, 2, + 2, 2, 3, 3, 3, 4, 1, 3, 3, 3, + 3, 4, 5, 5, 3, 7, 6, 5, 2, 1, + 3, 3, 3, 3, 3, 3, 3, 3, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 2, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 2, 2, 4, 4, 5, 1, 1, 1, 1, + 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, + 2, 2, 4, 4, 5, 1, 1, 1, 1, 5, + 0, 1, 2, 0, 1, 0, 1, 1, 2, 5, + 3, 4, 4, 4, 4, 4, 4, 3, 7, 6, + 8, 3, 3, 3, 3, 3, 3, 3, 3, 2, + 0, 3, 1, 3, 8, 8, 8, 11, 12, 15, + 0, 3, 3, 3, 3, 5, 3, 5, 5, 5, + 4, 4, 4, 4, 4, 4, 4, 4, 0, 1, + 1, 3, 2, 3, 8, 5, 1, 1, 1, 1, + 1, 4, 4, 4, 4, 1, 3, 1, 1, 2, + 2, 4, 4, 3, 3, 3, 3, 3, 4, 3, + 5, 5, 5, 4, 4, 4, 4, 3, 2, 2, + 6, 2, 4, 3, 4, 4, 5, 8, 6, 3, + 4, 4, 2, 4, 3, 2, 4, 5, 6, 2, + 6, 6, 3, 3, 4, 2, 4, 3, 3, 3, + 0, 1, 1, 1, 0, 2, 2, 0, 2, 3, + 2, 0, 1, 1, 2, 4, 1, 0, 1, 2, + 1, 2, 4, 4, 0, 1, 0, 3, 0, 2, + 4, 4, 2, 3, 4, 4, 5, 3, 3, 4, + 3, 1, 1, 1, 1, 0, 3, 1, 1, 1, + 3, 0, 2, 0, 2, 1, 2, 2, 1, 2, + 2, 1, 2, 2, 0, 2, 2, 2, 2, 2, + 2, 0, 1, 1, 3, 5, 1, 1, 3, 5, + 1, 2, 3, 5, 2, 2, 6, 0, 1, 0, + 3, 0, 1, 0, 2, 2, 4, 1, 2, 2, + 2, 2, 2, 0, 2, 1, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 3, 1, 1, 1, 0, 5, 8, - 1, 4, 5, 4, 5, 5, 5, 5, 8, 0, - 1, 0, 2, 0, 4, 0, 2, 0, 1, 2, - 0, 2, 1, 1, 1, 4, 3, 5, 1, 3, - 5, 4, 3, 3, 5, 5, 5, 5, 3, 8, - 10, 3, 3, 3, 3, 3, 5, 4, 5, 1, - 2, 2, 4, 3, 6, 5, 3, 9, 2, 2, - 5, 8, 4, 3, 3, 3, 3, 3, 3, 5, - 3, 3, 3, 0, 1, 2, 0, 1, 7, 1, - 3, 8, 8, 8, 11, 12, 15, 0, 3, 3, - 3, 3, 5, 3, 5, 5, 5, 4, 4, 4, - 4, 4, 4, 4, 4, 0, 1, 1, 3, 2, - 3, 8, 5, 1, 1, 1, 1, 1, 4, 4, - 4, 4, 1, 3, 1, 1, 2, 2, 4, 4, - 3, 3, 3, 3, 3, 4, 3, 5, 5, 5, - 4, 4, 4, 4, 3, 2, 2, 6, 2, 4, - 3, 4, 4, 5, 8, 6, 3, 4, 4, 2, - 4, 3, 2, 4, 5, 6, 2, 6, 6, 3, - 3, 4, 3, 0, 1, 1, 1, 0, 2, 2, - 0, 2, 3, 2, 0, 1, 1, 2, 4, 1, - 0, 1, 2, 1, 2, 4, 4, 0, 1, 0, - 3, 0, 2, 4, 4, 2, 3, 4, 4, 5, - 3, 3, 4, 3, 1, 1, 1, 1, 0, 3, - 1, 1, 1, 3, 0, 2, 0, 2, 1, 2, - 2, 1, 2, 2, 1, 2, 2, 0, 2, 2, - 2, 2, 2, 2, 0, 1, 1, 3, 5, 1, - 1, 3, 5, 1, 2, 3, 5, 2, 2, 6, - 0, 1, 0, 3, 0, 1, 0, 2, 2, 4, - 1, 2, 2, 2, 2, 2, 0, 2, 1, 3, - 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 3, 0, 1, 2, 2, 1, 1, - 1, 1, 3, 1, 1, 1, 4, 5, 1, 2, - 3, 1, 1, 2, 2, 4, 2, 6, 1, 3, - 2, 4, 1, 1, 1, 1, 1, 5, 5, 8, - 5, 5, 8, 5, 5, 8, 2, 2, 2, 3, - 4, 4, 0, 1, 3, 1, 0, 3, 1, 3, - 1, 3, 4, 6, 4, 4, 4, 3, 2, 4, - 0, 1, 0, 2, 0, 1, 1, 1, 1, 2, - 2, 1, 2, 3, 2, 3, 3, 2, 2, 2, - 12, 1, 3, 3, 3, 6, 7, 2, 3, 3, - 4, 4, 5, 5, 8, 8, 3, 3, 4, 3, - 4, 1, 3, 3, 2, 1, 1, 3, 1, 1, - 1, 1, 3, 3, 0, 5, 5, 5, 0, 2, - 1, 3, 3, 3, 2, 3, 1, 2, 0, 3, - 1, 1, 3, 4, 4, 4, 3, 4, 4, 5, - 3, 4, 5, 6, 2, 1, 2, 1, 2, 1, - 2, 1, 1, 1, 1, 1, 1, 1, 0, 2, - 1, 1, 1, 3, 1, 3, 0, 1, 1, 3, - 1, 3, 1, 1, 1, 1, 1, 1, 1, 1, + 3, 0, 1, 2, 2, 1, 1, 1, 1, 3, + 1, 1, 1, 4, 5, 1, 2, 3, 1, 1, + 2, 2, 4, 0, 1, 2, 6, 1, 3, 2, + 4, 1, 1, 1, 1, 1, 5, 5, 8, 5, + 5, 8, 5, 5, 8, 2, 2, 2, 3, 4, + 4, 0, 1, 3, 1, 0, 3, 1, 3, 1, + 3, 4, 6, 4, 4, 4, 3, 2, 4, 0, + 1, 0, 2, 1, 1, 1, 2, 2, 1, 2, + 3, 2, 3, 3, 2, 2, 2, 12, 1, 3, + 3, 3, 6, 7, 2, 3, 3, 4, 4, 5, + 5, 8, 8, 3, 3, 4, 3, 4, 1, 3, + 3, 2, 1, 1, 3, 1, 1, 1, 1, 1, + 3, 3, 0, 5, 5, 5, 0, 2, 1, 3, + 3, 3, 2, 3, 1, 2, 0, 3, 1, 1, + 3, 4, 4, 4, 3, 4, 4, 5, 3, 4, + 5, 6, 2, 1, 2, 1, 2, 1, 2, 1, + 1, 1, 1, 1, 1, 1, 0, 2, 1, 1, + 1, 3, 1, 3, 0, 1, 1, 3, 1, 3, + 1, 1, 1, 1, 1, 1, 1, 1, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 3, 2, 2, 2, 2, 2, - 2, 3, 1, 1, 1, 1, 1, 1, 5, 6, - 6, 6, 5, 5, 5, 6, 5, 5, 6, 5, - 5, 5, 5, 6, 5, 5, 5, 4, 4, 5, - 5, 5, 5, 5, 4, 4, 4, 4, 4, 4, - 4, 4, 3, 6, 6, 4, 6, 6, 4, 8, - 8, 8, 8, 4, 6, 7, 7, 7, 9, 4, - 7, 5, 4, 4, 4, 3, 4, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 8, 8, 6, 0, 2, 3, 4, 4, - 4, 4, 4, 4, 0, 3, 4, 7, 3, 1, + 3, 3, 3, 2, 2, 2, 2, 2, 2, 3, + 1, 1, 1, 1, 1, 1, 5, 6, 6, 6, + 5, 5, 5, 6, 5, 5, 6, 5, 5, 5, + 5, 6, 5, 5, 5, 4, 4, 5, 5, 5, + 5, 5, 4, 4, 4, 4, 4, 4, 4, 4, + 3, 6, 6, 4, 6, 6, 6, 4, 8, 8, + 8, 8, 4, 6, 7, 7, 7, 9, 4, 7, + 5, 4, 4, 4, 4, 2, 2, 2, 1, 2, + 2, 2, 8, 8, 6, 3, 4, 2, 2, 2, + 0, 2, 1, 3, 4, 4, 4, 4, 4, 4, + 0, 3, 4, 7, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 2, 3, 3, 1, 2, 2, 1, - 2, 1, 2, 2, 1, 2, 1, 1, 0, 1, - 0, 2, 1, 2, 4, 0, 2, 1, 1, 3, - 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 5, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 2, 2, 0, 3, 1, 3, 1, 0, 2, 1, - 0, 3, 1, 3, 2, 0, 1, 1, 0, 2, - 4, 4, 1, 1, 0, 2, 4, 4, 2, 4, - 1, 3, 5, 4, 6, 1, 1, 0, 3, 1, - 3, 3, 1, 1, 1, 1, 1, 0, 5, 1, - 3, 1, 2, 3, 1, 1, 3, 3, 3, 3, - 3, 1, 3, 1, 2, 2, 3, 1, 1, 1, - 1, 1, 3, 3, 4, 3, 1, 2, 1, 1, - 1, 1, 1, 1, 0, 1, 0, 2, 0, 3, - 0, 1, 0, 3, 3, 1, 1, 0, 1, 1, - 1, 1, 1, 0, 1, 0, 2, 1, 1, 1, - 3, 1, 1, 1, 1, 1, 1, 0, 2, 0, - 1, 1, 0, 1, 0, 4, 0, 1, 0, 3, - 0, 3, 0, 4, 0, 3, 0, 3, 3, 1, - 3, 2, 4, 1, 2, 1, 2, 2, 2, 3, - 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 2, 3, 3, 3, 3, 1, 2, 2, 1, 2, + 1, 1, 1, 2, 1, 2, 2, 1, 2, 1, + 1, 1, 0, 1, 0, 2, 1, 2, 4, 0, + 2, 1, 1, 3, 3, 3, 3, 3, 3, 3, + 3, 3, 3, 3, 1, 5, 1, 2, 2, 2, + 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, + 0, 3, 1, 3, 1, 0, 2, 1, 0, 3, + 1, 3, 2, 0, 1, 1, 0, 2, 4, 4, + 1, 1, 1, 0, 2, 4, 4, 1, 4, 1, + 3, 4, 1, 4, 3, 6, 2, 3, 1, 1, + 0, 3, 1, 3, 3, 1, 1, 1, 1, 1, + 0, 5, 1, 3, 2, 3, 3, 1, 1, 3, + 3, 3, 3, 3, 1, 3, 1, 2, 2, 3, + 1, 1, 1, 1, 1, 3, 3, 4, 3, 1, + 2, 1, 1, 1, 1, 1, 1, 0, 1, 0, + 2, 0, 3, 0, 1, 0, 3, 3, 0, 1, + 1, 1, 0, 1, 1, 1, 1, 0, 1, 0, + 2, 1, 1, 1, 3, 1, 1, 1, 1, 1, + 1, 1, 1, 0, 2, 0, 1, 1, 0, 1, + 0, 4, 0, 1, 0, 3, 0, 3, 0, 4, + 0, 3, 0, 3, 3, 1, 3, 2, 4, 1, + 2, 1, 2, 2, 2, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, @@ -10438,891 +11222,941 @@ var yyR2 = [...]int{ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, } var yyChk = [...]int{ - -1000, -435, -1, -4, -14, -15, -16, -17, -18, -20, - -67, -21, -22, -23, -75, -79, -80, -81, -77, -78, - -85, -86, -87, -83, -82, -29, -32, -24, -89, -42, + -1000, -453, -1, -4, -14, -15, -16, -17, -18, -20, + -69, -21, -22, -23, -79, -83, -84, -85, -81, -82, + -89, -90, -91, -87, -86, -29, -32, -24, -93, -42, -43, -44, -45, -46, -47, -48, -49, -51, -50, -5, - 10, 11, -118, 35, -71, 191, -426, -69, -68, -70, - 194, 193, 230, 195, 609, 352, 610, 223, 73, 422, - -88, 425, 426, -441, 290, 291, 24, 43, 427, 429, - 36, 37, 245, 318, 320, 198, 423, 411, 412, 343, - -6, 615, 192, 225, 224, 32, -8, -10, 200, -11, - -12, -7, -436, 77, 724, -195, 19, -95, -442, -95, - -101, 13, 14, 12, 531, -95, -333, 29, -3, 118, - 77, -8, 10, -251, -261, 98, 522, 199, -259, 314, - 316, 209, -248, -250, -258, 255, 265, 50, 210, 266, - 200, 314, 200, 201, 203, 522, 199, 238, 237, 314, - 316, 270, 609, 200, -138, -277, -265, -266, 332, 82, - -264, 549, 553, 270, 556, 557, 562, 322, 91, 53, - 352, 544, 344, 353, 220, 500, 315, 321, 324, 345, - 697, 354, 356, 357, 542, 543, 54, 55, 203, 213, - 712, 337, 221, 612, 266, 719, 714, 716, 326, 490, - 580, 422, 439, 431, 458, 613, 669, 285, 430, 369, - 507, 581, 329, 278, 350, 670, 305, 496, 502, 288, - 425, 603, 601, 583, 516, 246, 276, 671, 282, 284, - 283, 260, 548, 289, 42, 226, 455, 622, 610, 255, - 672, 585, 665, 584, 249, 598, 312, 41, 33, 600, - 248, 519, 109, 275, 673, 360, 504, 586, 476, 361, - 244, 271, 273, 674, 617, 333, 232, 503, 413, 451, - 343, 128, 253, 300, 362, 675, 477, 481, 676, 508, - 319, 299, 605, 677, 678, 363, 621, 679, 202, 325, - 587, 680, 256, 510, 330, 475, 211, 614, 222, 57, - 235, 511, 479, 604, 485, 488, 359, 681, 682, 683, - 684, 341, 339, 588, 340, 342, 267, 280, 618, 589, - 620, 62, 197, 624, 483, 482, 484, 281, 638, 506, - 463, 461, 685, 686, 334, 217, 521, 687, 688, 462, - 22, 689, 690, 514, 304, 336, 691, 692, 693, 590, - 606, 579, 694, 695, 505, 478, 480, 254, 127, 609, - 277, 696, 338, 501, 347, 625, 616, 323, 602, 698, - 365, 234, 228, 515, 409, 420, 421, 355, 699, 412, - 700, 701, 702, 703, 317, 316, 426, 348, 591, 427, - 272, 286, 619, 704, 592, 593, 705, 706, 264, 247, - 518, 509, 61, 492, 487, 351, 366, 410, 418, 414, - 416, 417, 419, 415, 495, 423, 274, 241, 594, 595, - 596, 411, 597, 11, 279, 331, 607, 608, 582, 499, - 349, 287, 265, 268, 466, 236, 707, 708, 453, 454, - 424, 239, 230, 122, 517, 310, 664, 314, 367, 60, - 242, 709, 710, 269, 243, 623, 428, 328, 626, 200, - 82, -268, -264, -266, -267, -265, 332, 231, 59, 96, - 64, 63, 82, -264, 609, 144, 459, 507, 191, 497, - 498, 504, -326, 505, 237, 409, 240, -282, 200, -244, - 239, 496, 319, 338, 553, 243, 244, 271, 201, 202, - 38, 509, 508, 500, -277, -90, 428, -90, -90, 204, - 428, -103, 232, 195, -138, 231, -64, 82, 292, -64, - 35, 82, -150, -269, -277, 82, -264, 42, 82, 427, - 499, 499, 85, 616, 246, 25, -415, -390, 347, -414, - -388, 192, 191, 14, 193, 270, 352, 353, 318, 201, - 12, 36, 697, 218, 354, 355, 10, 223, 356, 357, - 238, 13, 358, -416, -393, 370, 371, 372, 373, 374, - 375, 376, 377, 378, 379, 380, 381, 382, 383, 384, - 385, 386, 387, 388, 389, 390, 391, 392, 393, 394, - 395, 396, 397, 398, 399, 400, 401, 402, 403, 404, - 405, 406, 407, 408, 84, 82, -264, 25, -415, -390, - 347, 355, 409, 424, 409, 409, -253, -252, 368, 485, - -117, 668, -115, -123, -279, -277, -265, 522, -240, -259, - 205, -119, -121, -122, -142, -125, 666, -436, -120, -428, - -138, -126, 82, 578, -99, 9, -98, -100, 8, 7, - -99, -9, -4, 615, -213, 21, 20, -249, -96, -109, - 135, -111, -277, -155, 101, -162, 34, 30, -161, 332, - 231, -156, -187, -265, -186, -126, 144, -281, 133, 134, - 141, 102, 187, -172, -170, -171, -173, -175, -176, 84, - 83, 92, 85, 86, 87, 88, 93, 94, 95, -269, - -266, -263, 549, 553, 556, 557, 562, -184, -436, 145, - 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, - 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, - 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, - 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, - 186, 67, 68, 547, 199, 532, 533, 456, 12, 534, - 535, 536, 611, 220, 540, 104, 56, 54, 309, 520, - 530, 529, 528, 526, 527, 523, 525, 524, 542, 543, - 544, 206, 522, 139, 531, 566, 567, 568, 569, 570, - 571, 572, 573, 575, 576, 574, 550, 551, 552, 554, - 555, 558, 559, 560, 561, 563, 564, 565, 640, 196, - 192, 195, 100, 29, 31, 641, 252, 103, 437, 471, - 539, 20, 24, 214, 198, 459, 212, 143, 208, 215, - 294, 296, 191, 71, 642, 295, 497, 636, 633, 635, - 634, 450, 448, 293, 643, 14, 32, 224, 259, 644, - 446, 193, 250, 107, 108, 645, 47, 46, 7, 297, - 225, 303, 447, 646, 647, 23, 74, 216, 15, 210, - 240, 718, 648, 318, 17, 126, 18, 649, 630, 632, - 631, 205, 120, 201, 711, 69, 257, 650, 435, 440, - 441, 442, 443, 444, 436, 97, 651, 652, 117, 308, - 65, 578, 38, 245, 666, 537, 307, 653, 44, 43, - 470, 474, 469, 306, 486, 118, 21, 36, 654, 655, - 233, 473, 434, 468, 667, 656, 628, 262, 72, 368, - 449, 722, 39, 75, 229, 364, 335, 48, 98, 19, - 258, 70, 40, 545, 123, 723, 452, 207, 237, 657, - 512, 261, 658, 124, 445, 668, 218, 119, 429, 194, - 346, 291, 219, 313, 320, 659, 251, 125, 498, 627, - 660, 541, 35, 223, 290, 433, 209, 661, 263, 302, - 292, 301, 662, 663, 327, 49, 720, 639, 200, 45, - 106, 472, 432, 467, 204, 538, 238, 298, 8, 50, - 37, 493, 13, 358, 73, 76, 460, 457, 465, 464, - 721, 16, 311, 546, 615, 513, 99, 637, 494, -95, - -95, -95, -229, 424, -236, -233, 508, 509, -234, -237, - -231, -187, 485, 694, 695, 507, 459, 506, -269, -277, - -265, 332, 231, 144, 550, 551, 552, 104, 456, 532, - 566, 523, 525, 520, 524, 522, 34, 567, 30, 95, - 568, 547, 206, 12, 187, 554, 555, 569, 570, 571, - 67, 526, 527, 611, 139, 101, 572, 573, 93, 575, - 576, 309, 531, 68, 574, 199, 560, 559, 558, 561, - 534, 535, 94, 528, 529, 530, 56, 564, 563, 565, - -2, -6, -138, -334, -321, -324, -269, -265, -266, -267, - 227, 215, -359, 82, -264, 212, -195, -95, 201, 203, - 531, -247, 206, -247, 238, 237, 270, -260, 263, -247, - -247, 698, 200, -259, 110, 110, -72, -138, -392, -387, - -393, -246, 206, -269, -246, -246, -246, -246, -246, -246, - -246, -246, 82, -268, -138, 188, -76, -138, -130, 15, - 15, 76, 76, 82, -268, 82, 35, -245, 118, 16, - 522, 199, 200, 237, 238, 203, 270, -245, -328, 15, - 120, 241, 241, 241, 241, 242, 241, -243, 499, 501, - 502, 503, -242, 15, 120, 16, -112, 118, 23, -436, - -213, -213, -242, 136, -92, 100, -92, 82, 427, 204, - -84, -4, -17, -15, -16, -103, -9, -164, -145, 29, - 5, 6, 110, 35, 35, 84, 60, 35, -59, -58, - -60, 278, 279, 280, 281, 282, 283, 284, 285, 286, - 287, 288, 289, 35, -371, 77, 188, -316, 485, 82, - -384, -385, -138, 85, 85, 75, 338, 75, 78, 204, - 78, 75, -417, 348, 77, -417, 316, 348, 349, 265, - 314, 203, -417, -417, 316, -417, -417, -417, 335, -417, - -417, 499, -417, -417, -417, 350, 351, -417, 497, 203, - -417, -417, -417, -417, -417, 80, 75, 78, 338, 75, - 15, 75, 410, 413, 512, -157, 25, -352, 144, 360, - 361, 362, 363, 359, 338, 364, 365, 366, 241, 367, - -6, -115, 78, -217, -436, 82, -309, -308, -305, -306, - -307, -304, 34, 200, 270, -133, -135, -134, -136, 65, - 69, 71, 66, 67, 68, 500, 72, -256, 29, -125, - -436, -114, -9, -124, -119, 56, -436, -143, 123, -153, - -256, -144, 73, 205, 74, 29, -145, -146, -147, -148, - -149, 5, 6, 55, -436, -436, -7, -8, 25, 28, - -13, -7, -11, -13, 25, 28, 25, 28, -7, -437, - 79, -117, -214, 23, 36, -165, 85, 88, -196, -199, - -111, -277, 59, -106, 25, 28, 66, 58, 64, 63, - -210, 90, 15, -272, 100, 98, 99, 117, -271, 29, - 82, 84, -268, 188, -111, -159, 120, 101, 118, 119, - 103, 130, 129, 140, 133, 134, 135, 136, 137, 138, - 139, 131, 132, 143, 110, 111, 112, 113, 114, 115, - 116, -241, -436, -126, -436, 188, -436, 188, 189, 190, - 188, -162, -162, -162, -162, -162, -162, -162, -436, 188, - 188, -436, -436, -436, -436, -436, -179, -111, 615, -436, - 200, -436, -436, -436, -436, -436, -436, -436, -436, -436, - -436, -436, -436, -436, -436, -190, -111, -436, -436, -436, - -440, -174, -436, -440, -174, -440, -174, -440, -436, -440, - -174, -440, -174, -440, -440, -174, -440, -436, -436, -436, - -436, -436, -436, -436, -436, -436, -436, -436, -436, -436, - -436, -436, -436, -436, -436, -436, -436, -436, -436, -436, - -436, -436, -436, -436, -436, -436, -436, -240, -240, 15, - -130, -131, -138, -141, -277, 78, -230, -235, 510, 512, - 424, -234, -234, -276, -269, 84, 34, -332, 110, 121, - 35, 188, -195, 79, 78, -324, -284, -288, -290, -289, - -291, -286, -287, 456, 459, 463, 461, 457, 462, 144, - 460, 466, 467, 468, 469, 470, 471, 472, 473, 474, - 475, 476, 35, 226, 453, 454, 455, 626, 477, 478, - 479, 480, 481, 482, 483, 484, 431, 458, 613, 432, - 433, 434, 435, 436, 437, 439, 440, 441, 442, 443, - 444, 445, 446, 447, 448, 449, 450, 451, -284, -284, - -284, -284, 82, 241, -265, -359, 77, -213, -249, -269, - -138, -261, 209, -259, 82, 101, 82, -137, -269, -277, - -150, -247, 264, -396, -395, -387, -390, 639, -247, -260, - -387, 269, 267, 268, 78, 204, 78, 204, 80, -130, - 30, 75, -132, -138, 82, 82, -137, -150, -389, -387, - -390, -151, -269, -277, -278, -277, -262, 640, 196, 192, - 195, 100, 29, 31, 641, 252, 103, 437, 144, 550, - 551, 552, 471, 539, 20, 24, 214, 104, 198, 456, - 459, 212, 143, 208, 215, 294, 296, 532, 566, 191, - 71, 642, 523, 525, 520, 524, 295, 522, 497, 636, - 633, 635, 634, 450, 448, 293, 34, 643, 14, 567, - 32, 224, 259, 28, 644, 137, 446, 193, 577, 250, - 107, 108, 645, 47, 46, 7, 30, 297, 225, 95, - 303, 568, 447, 646, 647, 23, 74, 216, 15, 210, - 240, 718, 648, 318, 17, 547, 126, 18, 649, 630, - 632, 631, 206, 205, 120, 201, 711, 69, 257, 12, - 650, 435, 440, 441, 442, 443, 444, 436, 187, 97, - 651, 652, 117, 308, 65, 554, 555, 578, 51, 38, - 245, 569, 570, 666, 571, 537, 307, 653, 44, 43, - 470, 474, 469, 306, 486, 67, 118, 21, 526, 527, - 36, 654, 655, 611, 233, 473, 434, 468, 667, 656, - 628, 139, 262, 72, 101, 368, 572, 573, 93, 449, - 722, 39, 75, 229, 364, 335, 48, 98, 19, 258, - 70, 40, 545, 123, 723, 575, 452, 207, 237, 657, - 512, 261, 658, 124, 576, 445, 668, 218, 119, 429, - 194, 309, 531, 346, 291, 219, 313, 320, 68, 659, - 251, 125, 574, 199, 498, 627, 10, 660, 541, 35, - 223, 290, 433, 209, 661, 263, 302, 292, 301, 662, - 58, 663, 327, 49, 560, 559, 558, 561, 720, 66, - 534, 535, 639, 200, 45, 106, 472, 432, 467, 204, - 538, 238, 94, 298, 8, 50, 37, 493, 13, 358, - 73, 76, 528, 529, 530, 56, 460, 457, 465, 564, - 464, 563, 565, 721, 105, 16, 311, 546, 615, 513, - 99, 637, 494, 13, 193, 78, 84, -225, 82, -268, - 84, -225, -224, -225, -224, -245, 84, -281, -111, -247, - -247, -138, -138, -138, -138, -138, -138, -245, -245, -245, - -245, -242, 15, -242, -245, -277, -277, -111, -162, -387, - 524, 135, -245, -277, -93, -91, 217, -91, -93, 82, - 82, 427, -84, 39, 29, 29, 82, -59, -59, 84, - -59, 78, 110, -59, -164, 79, -179, -269, -369, 711, - 78, -386, 29, 512, 513, 486, -419, 200, 240, 237, - 75, -419, -414, 355, -389, -388, -387, -417, -418, -269, - -417, -417, -417, 499, -417, -417, -417, -417, -417, -417, - -417, -417, -417, -393, -419, 318, 78, -419, -389, -387, - 204, -354, -356, 420, 421, 513, 514, 359, 359, 359, - 359, 359, 359, -123, 29, -216, -215, -270, -265, -266, - -267, 227, -269, -262, -309, -306, -305, -307, 459, 507, - 143, 519, -138, -151, -121, -121, -119, -121, 65, 65, - 65, 70, 65, 70, 70, 65, 65, -134, -279, -256, - 78, -437, -437, -437, -183, 251, -9, -436, -279, -153, - -256, 201, 201, 201, 103, 15, 53, 25, 103, 15, - 53, 25, 103, 15, 53, 25, -108, -107, -110, 135, - -111, -277, -162, -226, 97, 13, 120, 78, 22, 78, - -212, 31, 32, 188, -163, 60, 85, 88, -226, 78, - -109, -138, -111, -111, -111, -177, 93, 101, 94, 95, - -271, 227, 135, -278, -270, -266, -265, 332, 231, -262, - -162, 25, 26, 27, -178, -184, -126, 89, 120, 118, - 119, 103, -162, -162, -162, -162, -162, -162, -162, -162, - -162, -162, -162, -162, -162, -162, -162, -280, 82, 84, - 82, -270, -107, -270, -161, 93, -161, -269, -269, -97, - 25, 28, -270, 500, -270, -97, -97, -97, -97, -97, - 78, -437, -107, -107, -107, -437, -111, -111, -107, -107, - -187, 84, -107, -187, 84, -107, -162, 537, 538, 539, - -107, -107, -97, -188, -189, 105, -187, -265, -267, 332, - 231, -437, -107, -437, -162, -168, -169, 618, 627, 628, - 630, 633, 626, 625, 624, 622, 621, 620, 623, 619, - 637, 636, 635, 634, 632, 631, 629, -168, -168, -107, - -108, -107, -107, -437, -437, -110, -107, -110, -107, -107, - -437, -437, -437, -437, -107, -107, -107, -107, -107, -107, - -107, -107, -107, -107, -107, -107, -140, 97, -138, -114, - -138, -130, -438, 15, 76, -438, 78, 188, -233, -236, - 78, 511, 513, 514, -230, -301, -302, 143, 75, 96, - 84, -111, -270, -278, -213, -335, -321, -322, -323, -324, - -346, 215, -358, 207, 209, 210, 50, -325, 216, 201, - 51, -285, -311, 492, 493, -293, 77, -292, 464, 77, - -292, 464, 456, 459, 457, -292, 457, 464, -292, -292, - -292, -292, 457, 77, 77, -293, -293, -293, -313, 77, - -313, 452, -314, 77, -314, -314, -314, -314, -285, -285, - -285, -285, -359, -359, -359, -111, -214, -273, 76, -217, - 203, 698, -309, 30, -309, -65, 252, 221, 188, 77, - -151, 255, 256, -391, 78, 34, -397, 315, 85, 206, - -138, 231, -138, -138, -387, -387, -393, -366, 219, 214, - -138, 78, 78, 188, 677, 677, -138, 78, 84, 82, - 82, -164, -329, 15, 120, -245, -138, -164, -105, 227, - 76, -440, -437, 429, 430, 82, -162, 39, 39, -58, - -161, -269, 79, -370, 205, 531, 84, -385, -279, 485, - 513, -420, 135, -269, -419, -420, -423, 615, 204, 79, - 78, -417, -420, 335, 318, -420, 15, -353, -355, 414, - 415, 416, 417, 418, 419, 78, 110, 110, -357, 23, - -125, -437, 78, 188, 35, -331, -332, -331, -331, -74, - -73, 196, 193, 194, 197, 198, -362, 490, 192, 249, - 248, -304, 592, 593, 581, 582, 8, 587, 234, -403, - 75, -128, -127, 75, 76, -129, 75, -127, 65, 65, - 65, -220, 77, -279, -119, 78, -184, -436, -437, -222, - -269, -153, -279, -436, -436, -436, -162, -162, 120, -162, - -162, 120, -162, -162, 120, -437, 78, 188, 78, -223, - 40, 41, -269, 487, 61, -165, -165, -199, -239, 23, - 15, 56, 56, -116, 15, -210, -210, 93, 94, 95, - 188, -436, -126, -126, -126, -178, -162, -162, -162, -105, - 100, -437, -437, -108, -107, -107, -107, -107, -107, -111, - -437, -437, -437, 78, 76, 29, -437, 76, -437, 15, - 15, -437, 15, 15, -437, -437, 15, -162, -162, -162, - -437, -437, -107, -191, -189, 107, -111, -437, -437, -437, - -437, -437, 78, 78, 15, -437, -437, -437, -437, -200, - 545, -200, -437, -437, -437, -437, -437, -200, -200, -200, - -200, -437, -437, -437, -437, -437, -437, -437, -437, -437, - -437, -437, -437, -221, 123, -138, 35, -221, 76, -114, - -114, -141, -277, 135, -235, -238, 515, 512, 518, 82, - 84, 84, 188, -214, -339, -336, 78, 123, 717, 490, - 580, 507, 34, 459, 581, 582, 143, 91, 583, 246, - 42, 201, 585, 519, 360, 586, 587, 211, 588, 589, - 590, 324, 591, 423, 592, 593, 594, 595, 596, 349, - 8, -324, 77, 82, -330, -265, 241, -264, 51, -325, - -327, -325, -325, -330, 82, -330, 51, 680, 93, 101, - -300, -302, 144, -297, -298, -315, -318, -294, 29, 718, - 495, 218, 459, 34, 75, 490, 207, 51, 50, 210, - 91, -312, 494, 85, -292, 85, 556, -292, -292, 464, - -292, 464, -292, -292, -292, -319, 84, -319, 85, -313, - 85, 79, 75, -269, 29, -138, 639, -66, 12, 13, - 14, -269, -372, -373, -374, -269, 120, 257, 258, 75, - -406, 346, -395, 316, 325, 100, 20, 615, -427, 101, - 204, 204, -138, -387, -269, 75, 75, -225, -154, 16, - 82, 82, -242, -245, -162, -390, 243, 244, -162, -162, - -139, 97, -386, 204, 188, 188, -420, 204, 337, -389, - -269, 15, 15, 335, 15, -389, 78, 110, 110, 110, - 110, 110, 110, -356, 77, 77, 369, -215, -270, -331, - 82, 84, 144, 82, 84, 144, 84, 78, -257, -325, - -368, -323, -324, -367, 208, 215, -257, 215, 212, -325, - 216, 207, 208, -254, -325, 204, 29, -257, -257, -331, - -257, 38, 38, 459, 143, -331, -331, -331, -331, -331, - -331, 123, -152, 194, 276, 272, -111, 77, -111, -218, - -269, -220, 251, -437, 78, -153, -218, -218, -218, 100, - 204, -436, 100, 204, -436, 100, 204, -436, -256, -110, - 135, -278, 84, 78, 84, 84, 488, 62, -138, -154, - 577, -114, -109, 135, -270, -108, -105, 100, -162, -437, - -437, -437, -437, -437, -437, -283, 144, 456, 226, 455, - 448, 475, 461, 492, 453, 493, 446, 447, -280, -283, - -280, -162, -162, -162, -162, -162, 15, 15, 15, 612, - -195, 109, -111, 106, -162, -162, -162, -269, -205, -436, - -200, -200, -200, -200, -200, -201, -200, -201, -201, -201, - -201, -201, -201, -201, -201, -201, -201, -201, -160, 35, - -443, -436, -9, 56, 60, -436, -228, -232, -187, -265, - -267, 227, -154, -114, -154, -154, 188, 512, 516, 517, - -336, 20, -331, -331, -331, -331, 507, 459, 143, 35, - -331, -331, -331, -331, -331, -331, 584, 584, -331, -331, - -331, -331, -331, -331, -331, -331, -331, -331, -331, 424, - -331, -331, -331, -331, -331, -337, -424, 84, -434, 91, - 270, 324, 82, -264, -262, 85, 87, 86, -331, -348, - -347, 82, -268, 207, -358, 50, -358, -330, -330, -330, - -330, -94, 82, 93, -436, 719, 85, -138, 35, -161, - 134, -281, -156, 520, 526, 527, 521, -436, 94, 95, - 13, 51, 51, 51, 84, 79, 79, 79, -292, -292, - 79, 78, 79, 78, 79, 78, -158, 673, 101, -138, - -209, 29, 85, 75, 79, 78, -284, -269, -269, -269, - 272, -409, 615, 321, -407, -405, 327, 328, 329, 330, - 331, -390, 326, -397, 323, 84, 82, 638, 672, 692, - 665, 30, -138, -387, -219, 77, -218, -219, -111, -164, - -221, 200, -389, 135, 135, -269, 204, -389, 335, -422, - 615, -389, -389, 15, -389, -355, 84, 84, 84, 85, - 85, 85, -130, -130, 84, 82, 84, 144, -73, 77, - -320, 82, -268, -330, -250, 209, 207, 82, 82, -268, - 82, -268, 82, -268, -269, 51, 51, 82, -268, -138, - -269, -320, 82, -111, -269, 35, -331, 82, 84, 93, - 84, -434, -434, -436, 217, 220, 222, -269, -402, 248, - 249, 204, 277, 101, -399, 716, 273, -218, 79, 78, - -184, -143, -269, -437, -437, -437, -162, -162, -162, -162, - -162, -162, -162, -162, -162, -279, 188, 502, -269, -192, - 17, -210, -437, -162, -201, -201, -201, -201, -201, -437, - -293, -293, -293, -314, -293, 436, -293, 436, -437, -437, - -437, 23, 23, 23, 23, -437, -162, -162, -162, -436, - -104, 541, -111, 78, 78, -437, -274, 82, -227, 75, - -228, -182, -185, -184, -436, -9, -437, -216, 10, 615, - 200, -222, -154, 78, -332, -332, -332, -332, -195, -154, - -340, -341, 124, 604, -342, 653, -337, -337, -337, -280, - -331, 35, -331, -331, -434, -434, -303, -424, 84, 84, - 84, 84, -331, -331, -434, 84, -424, 84, 217, 220, - 222, -337, -337, -337, -434, 84, -338, 34, 600, 451, - 601, 602, 603, 82, 93, 84, 84, 34, 85, 34, - -434, -337, 597, -436, 79, 78, -293, -293, 51, -327, - 77, -162, 29, 77, 82, 144, -161, 84, -440, -436, - -440, -436, -440, -436, -436, -162, -171, 520, 530, 529, - 528, 526, 527, 523, 525, 524, 542, 543, 544, 84, - 85, 85, 673, 77, -211, -209, -427, -138, -375, -376, - -377, 91, 614, 101, 259, 260, 217, 261, 262, 263, - -374, -284, -284, -284, -399, -412, -413, -411, 324, 344, - 345, 332, -410, -408, 339, 340, 341, 342, 100, 84, - 84, 84, -398, 315, 100, 324, 20, 29, 84, 84, - 84, 84, 85, 76, -218, -245, -299, -300, -138, -422, - -389, -422, 318, -389, 79, 79, -320, -197, 220, 221, - -284, -284, -273, -327, 51, 82, -255, 204, 29, -255, - 204, -197, -320, 35, 193, -331, -280, -425, -424, 97, - -296, 91, 75, -151, 277, -403, 75, -167, -161, -171, - -161, 79, -269, 78, 78, 78, 135, -436, -193, 18, - 20, -299, 82, -162, -162, -162, -162, -437, -437, -437, - -162, -437, 84, -162, -162, -181, 123, 33, -227, 78, - -437, -437, -443, -437, -437, -195, -232, -111, -111, -111, - -111, -213, -343, 606, -436, 502, -436, 502, 605, 51, - -280, -331, -303, -280, 84, 84, 598, 599, -425, -350, - -349, 76, 211, 91, 586, 593, 710, 680, -347, -212, - -212, -330, -330, -218, -437, -436, -218, -107, -107, -107, - -437, -107, -437, 79, 79, -348, -9, -211, 23, -210, - -377, 84, 263, 259, 263, 263, 263, 263, 264, -403, - -394, 91, 322, -411, 333, 678, 317, 346, 85, 85, - 122, 36, 37, -408, 85, 85, 85, 85, -405, 20, - 615, -397, 323, 84, 84, 315, -427, 42, 79, -378, - -243, -421, 29, -422, -421, 335, 79, 82, -285, -285, - 77, -330, -330, 82, -268, 82, -268, -269, -197, 34, - 34, -280, 78, -437, -436, 312, 84, 351, -152, -404, - -169, -162, -162, -162, -429, -430, -270, 685, -203, 546, - -194, -111, -180, -113, -111, -437, -437, -437, -437, -102, - 120, 615, -437, -437, -195, 20, 51, -185, -182, -443, - -9, -436, -213, -344, 607, 85, -424, -436, -424, -436, - -436, -436, 266, -280, -437, -349, -424, -331, 84, -331, - -331, 79, -310, 721, 720, -162, 79, -437, -437, -437, - -437, 79, -209, -9, 250, -211, 42, 42, 255, 256, - -402, 84, 84, 34, 334, 187, 34, 85, 187, 548, - 323, 84, 82, 324, 20, -162, -379, 44, -381, 45, - -387, -421, -348, -273, 77, -162, 143, -424, -360, -361, - 123, -209, -402, 133, -400, 274, -437, -437, -437, -437, - 78, -284, 23, 84, 579, -202, -204, -269, 78, -437, - 613, 72, 616, -206, 125, 124, -179, 13, -182, -9, - -436, 20, -437, -218, -437, -218, -161, 82, -218, 110, - 85, 84, 84, 218, -437, -351, -350, -209, 251, -26, - -4, -15, -16, -17, -18, -20, -67, -21, -22, -27, - -28, -23, -75, -79, -80, -81, -77, -88, -86, -87, - -83, -82, -31, -33, -34, -36, -39, -40, -37, -38, - -35, -29, -32, -41, -24, -42, -43, -44, -48, -49, - -30, -50, 104, 206, 423, 293, 304, 305, 306, 82, - 309, 311, 307, 308, 303, 313, 422, -296, 85, 34, - 85, 34, 336, 324, 29, 85, -295, 205, -382, 49, - -380, -317, 48, 20, 615, 79, 77, -348, -331, -437, - 78, -269, -26, -296, 187, -401, 275, -167, -437, -430, - -431, 579, 30, 691, 502, 84, 78, 29, -113, 62, - 614, 617, -437, -207, 103, -208, 122, 548, -166, 85, - 187, -207, -228, -437, -360, -341, -437, -437, -437, -437, - -437, 85, -138, -310, -198, 253, 254, -209, -111, -53, - -54, 105, -111, 82, -63, -275, 296, 297, 298, -270, - 82, 82, -52, -26, 81, -52, -111, 82, 82, -439, - 15, 59, -162, 109, -52, 312, 622, 622, 84, -220, - 85, -381, 20, -383, 46, 47, 84, 316, -351, -348, - 79, -280, -361, 56, -209, 312, -161, -167, -404, -256, - 84, 579, -436, 502, -204, -205, 62, -208, 127, 128, - 251, 127, 128, -161, -437, -345, 608, -436, 77, -209, - 82, 82, -53, 109, 107, -54, -111, 106, 294, 295, - 299, -284, 78, 724, 422, 306, 309, 311, 724, 312, - 82, 15, 724, -209, 44, 125, 84, 20, 20, 34, - 321, 25, -390, 79, -351, 235, -209, -169, -404, -279, - -432, -433, 361, 93, 34, 84, -429, -436, 615, 100, - -168, 85, -218, -218, -211, 109, 107, 104, -52, 106, - -52, 23, 23, 23, -299, -270, 109, -26, 109, -52, - -52, -52, -111, 310, -52, 97, 109, -26, 84, 84, - 7, -351, 236, -26, -433, 93, 34, -432, 93, 34, - 75, 75, -161, -437, -429, 616, -208, -437, 79, -19, - -25, -18, -24, -15, -16, -17, 422, 615, 104, -52, - 724, -52, 724, -64, 85, -9, -62, -61, 85, -64, - 301, 101, 302, 82, -301, 306, 82, 724, 724, 724, - 312, -111, 724, -57, 82, -209, -390, -436, -209, 75, - -161, 75, -161, 645, 361, 645, 361, 75, -437, 617, - -364, -365, 75, -209, -52, -117, 724, 109, 724, 109, - 107, -55, -56, 108, -26, 78, 300, 34, 109, 109, - 310, -52, 109, 109, 78, -162, 233, 75, 75, 361, - 361, 645, 361, -365, 75, -364, 75, 14, 13, 724, - 109, 104, 206, -52, 109, 107, -56, -111, -61, -162, - 82, 306, -111, 724, 309, 311, 82, -437, -437, 75, - 75, -363, 219, 214, 217, 35, -363, 109, 104, 724, - 206, -52, 106, 82, 109, 109, 361, 645, 213, 34, - 93, 109, 724, -52, 309, 311, 206, 109, 724, 82, - 82, 206, + 11, 12, -123, 36, -74, 192, -444, -71, -70, -72, + -73, 195, 194, 231, 196, 630, 368, 631, 224, 74, + 442, -92, 445, 446, -459, 306, 307, 25, 44, 447, + 449, 37, 38, 246, 334, 336, 199, 443, 428, 429, + 359, -6, 636, 193, 226, 225, 33, -8, -10, 201, + -11, -12, -7, -454, 78, 746, -204, 20, -100, -460, + -100, -106, 14, 15, 13, 551, -100, -346, 30, -3, + 119, 78, -8, 11, -260, -271, 99, 542, 200, -269, + 330, 332, 210, -257, -259, -267, 256, 266, 51, 211, + 267, 201, 330, 201, 202, 204, 542, 200, 239, 238, + 330, 332, 271, 630, 201, -143, -290, -276, -278, -277, + 348, 84, -275, 570, 574, 271, 577, 578, 583, 338, + 92, 54, 368, 565, 360, 369, 221, 520, 331, 337, + 340, 361, 719, 370, 372, 373, 563, 564, 56, 204, + 553, 554, 557, 214, 734, 353, 222, 633, 267, 741, + 736, 738, 342, 739, 510, 601, 442, 459, 451, 478, + 634, 690, 279, 301, 450, 385, 527, 602, 345, 294, + 366, 691, 321, 289, 516, 522, 304, 445, 624, 622, + 604, 536, 247, 277, 692, 298, 300, 299, 261, 569, + 305, 43, 227, 475, 643, 631, 256, 693, 606, 686, + 605, 250, 283, 619, 328, 42, 34, 621, 249, 539, + 110, 276, 694, 376, 524, 607, 496, 377, 245, 272, + 274, 290, 696, 638, 349, 233, 523, 430, 471, 359, + 129, 254, 316, 378, 697, 497, 501, 698, 528, 335, + 315, 626, 699, 700, 379, 642, 284, 701, 203, 341, + 608, 702, 257, 530, 346, 495, 212, 635, 223, 58, + 236, 531, 499, 625, 505, 508, 431, 375, 432, 703, + 704, 705, 706, 357, 355, 609, 356, 358, 620, 268, + 296, 639, 610, 641, 63, 198, 645, 503, 502, 504, + 297, 659, 526, 483, 481, 707, 708, 350, 218, 709, + 710, 482, 23, 711, 712, 534, 320, 352, 713, 714, + 715, 611, 293, 627, 600, 716, 717, 525, 498, 500, + 255, 128, 630, 278, 718, 354, 521, 363, 646, 637, + 339, 291, 623, 720, 381, 292, 235, 229, 535, 425, + 426, 440, 441, 371, 721, 429, 722, 723, 724, 725, + 333, 332, 446, 364, 612, 447, 273, 302, 640, 726, + 613, 614, 727, 728, 265, 248, 538, 529, 62, 512, + 507, 367, 382, 427, 437, 433, 435, 436, 439, 438, + 434, 515, 443, 275, 242, 615, 616, 617, 428, 618, + 12, 295, 347, 628, 629, 603, 519, 365, 303, 266, + 269, 486, 237, 729, 730, 473, 474, 444, 240, 231, + 123, 537, 326, 685, 330, 383, 288, 61, 243, 55, + 731, 732, 270, 244, 644, 287, 448, 344, 647, 201, + 84, -280, -275, -278, -279, -276, 348, 232, 60, 97, + 65, 64, 84, -275, 630, 145, 479, 527, 192, 517, + 518, 524, -339, 525, 238, 425, 241, -295, 201, -253, + 240, 516, 335, 354, 574, 244, 245, 272, 426, 432, + 202, 203, 39, 529, 528, 520, -290, -94, 448, -94, + -94, 205, 448, -108, 233, 196, -143, 232, -64, 84, + 308, -64, 36, 84, -155, -282, -290, 84, -275, 43, + 84, 447, 519, 519, 86, 637, 247, 26, -433, -408, + 363, -432, -406, 193, 192, 15, 194, 271, 368, 369, + 334, 202, 13, 37, 719, 219, 370, 371, 11, 224, + 372, 373, 239, 14, 374, -434, -411, 386, 387, 388, + 389, 390, 391, 392, 393, 394, 395, 396, 397, 398, + 399, 400, 401, 402, 403, 404, 405, 406, 407, 408, + 409, 410, 411, 412, 413, 414, 415, 416, 417, 418, + 419, 420, 421, 422, 423, 424, 83, 84, -275, 26, + -433, -408, 363, 371, 425, 444, 425, 425, -262, -261, + 384, 505, -122, 689, -120, -128, -292, -290, -276, 542, + -249, 330, -269, 206, -124, -126, -127, -147, -130, 687, + -454, -125, -446, -143, -131, 84, 599, -104, 10, -103, + -105, 9, 8, -104, -9, -4, 636, -222, 22, 21, + -258, -101, -114, 136, -116, -290, -160, 102, -170, 35, + 31, -169, 348, 232, -161, -196, -276, -195, -131, 145, + -294, 134, 135, 142, 103, 188, -180, -178, -179, -181, + -183, -184, 227, 473, 474, 83, 85, 93, 86, 87, + 88, 89, 94, 95, 96, -282, -278, -274, -277, 570, + 574, 577, 578, 583, -193, -454, 146, 147, 148, 149, + 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, + 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, + 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, + 180, 181, 182, 183, 184, 185, 186, 187, 68, 69, + 568, 200, 552, 553, 476, 554, 13, 555, 556, 557, + 632, 221, 561, 105, 57, 325, 543, 544, 548, -185, + 545, 549, 550, 563, 564, 565, 207, 542, 140, 551, + 587, 588, 589, 590, 591, 592, 593, 594, 596, 597, + 595, 571, 572, 573, 575, 576, 579, 580, 581, 582, + 584, 585, 586, 661, 197, 193, 196, 101, 30, 32, + 662, 253, 104, 457, 491, 560, 21, 25, 215, 199, + 479, 213, 144, 209, 216, 310, 312, 192, 72, 663, + 540, 311, 517, 657, 654, 656, 655, 470, 468, 309, + 664, 15, 33, 225, 260, 665, 466, 194, 251, 108, + 109, 666, 48, 47, 8, 313, 226, 319, 467, 667, + 668, 24, 75, 217, 16, 211, 241, 740, 669, 334, + 18, 127, 19, 670, 651, 653, 652, 206, 121, 202, + 733, 70, 258, 671, 455, 460, 461, 462, 463, 464, + 456, 98, 672, 673, 118, 324, 66, 599, 39, 246, + 687, 558, 323, 674, 45, 44, 490, 494, 489, 322, + 506, 119, 22, 546, 547, 37, 675, 676, 234, 493, + 454, 488, 688, 677, 649, 263, 73, 384, 469, 744, + 40, 76, 230, 380, 351, 49, 99, 20, 259, 71, + 41, 566, 124, 745, 472, 208, 238, 678, 532, 262, + 679, 125, 465, 689, 219, 120, 449, 195, 362, 307, + 220, 329, 336, 680, 252, 126, 518, 648, 681, 562, + 36, 224, 306, 453, 210, 682, 264, 318, 308, 317, + 683, 684, 343, 50, 742, 660, 201, 46, 107, 492, + 452, 487, 205, 559, 239, 314, 9, 51, 38, 513, + 14, 374, 74, 77, 480, 477, 485, 484, 743, 17, + 327, 567, 636, 533, 100, 658, 514, 541, -100, -100, + -100, -238, 444, -245, -242, 528, 529, -243, -246, -240, + -196, 505, 716, 717, 527, 479, 526, -282, -290, -276, + 348, 232, 145, 571, 572, 573, 105, 476, 552, 587, + 543, 545, 540, 544, 542, 35, 588, 31, 96, 589, + 568, 207, 13, 188, 575, 576, 590, 591, 592, 68, + 546, 547, 632, 140, 102, 593, 594, 94, 596, 597, + 325, 551, 69, 595, 200, 581, 580, 579, 582, 555, + 556, 95, 548, 549, 550, 57, 585, 584, 586, -2, + -6, -143, -347, -334, -337, -282, -276, -278, -279, 228, + -277, 216, -374, 84, -275, 213, -204, -100, 202, 204, + 551, -256, 207, -256, 239, 238, 271, -270, 264, -256, + -256, 720, 201, -269, 111, 111, -75, -143, -410, -405, + -411, -255, 207, -282, -255, -255, -255, -255, -255, -255, + -255, -255, 84, -280, -143, 189, -80, -143, -135, 16, + 16, 77, 77, 84, -280, 84, 431, 375, 36, -254, + 119, 17, 542, 200, 201, 238, 239, 204, 271, -254, + -341, 16, 121, 242, 242, 242, 242, 243, 242, -252, + 519, 521, 522, 523, -251, 16, 121, 17, -117, 119, + 24, -454, -222, -222, -251, 242, 137, -96, 101, -96, + 84, 447, 205, -88, -4, -17, -15, -16, -108, -9, + -172, -150, 30, 6, 7, 111, 36, 36, 83, 61, + 36, -59, -58, -60, 294, 295, 296, 297, 298, 299, + 300, 301, 302, 303, 304, 305, 36, -389, 78, 189, + -329, 505, 84, -402, -403, -143, 86, 86, 76, 354, + 76, 79, 205, 79, 76, -435, 364, 78, -435, 332, + 364, 365, 266, 330, 204, -435, -435, 332, -435, -435, + -435, 351, -435, -435, 519, -435, -435, -435, 366, 367, + -435, 517, 204, -435, -435, -435, -435, -435, 81, 76, + 79, 354, 76, 16, 76, 427, 430, 532, -162, 26, + -366, 145, 376, 377, 378, 379, 375, 354, 380, 381, + 382, 242, 383, 201, 519, -6, -120, 79, -226, -454, + 84, -322, -321, -318, -319, -320, -317, 35, 201, -255, + 271, -138, -140, -139, -141, 66, 70, 72, 67, 68, + 69, 520, 73, -265, 30, -130, -454, -119, -9, -129, + -124, 57, -454, -148, 124, -158, -265, -149, 74, 206, + 75, 30, -150, -151, -152, -153, -154, 6, 7, 56, + -454, -454, -7, -8, 26, 29, -13, -7, -11, -13, + 26, 29, 26, 29, -7, -455, 80, -122, -223, 24, + 37, -173, 86, 89, -196, -205, -208, -116, -290, 60, + -111, 26, 29, 67, 59, 65, 64, -219, 91, 16, + -285, 101, 99, 100, 118, -284, 30, 84, 83, -280, + 189, -116, -164, 121, 102, 119, 120, 104, 131, 130, + 141, 134, 135, 136, 137, 138, 139, 140, 132, 133, + 144, 111, 112, 113, 114, 115, 116, 117, -250, -454, + -131, -454, 189, -454, 189, 190, 191, 189, -170, -170, + -170, -170, -170, -170, -170, 83, 83, 83, -454, 189, + 189, -454, -454, -454, -454, -454, -188, -116, 636, -454, + 201, -454, -454, -454, -454, -454, -454, -454, -454, -454, + -454, -454, -454, -454, -454, -454, -199, -116, -454, -454, + -458, -454, -458, -458, -182, -458, -454, -182, -182, -454, + -454, -454, -454, -454, -454, -454, -454, -454, -454, -454, + -454, -454, -454, -454, -454, -454, -454, -454, -454, -454, + -454, -454, -454, -454, -454, -454, -454, -454, -454, -182, + -182, -182, -454, -249, -249, 16, -135, -136, -143, -146, + -290, 79, -239, -244, 530, 532, 444, -243, -243, -289, + -282, 83, 35, -345, 111, 122, 36, 189, -204, 80, + 79, -297, -301, -303, -302, -304, -299, -300, -65, 483, + 481, 477, 476, 479, 482, 145, 480, 486, 487, 488, + 489, 490, 491, 492, 493, 494, 495, 496, 36, 227, + 473, 474, 475, 647, 497, 498, 499, 500, 501, 502, + 503, 504, 451, 478, 634, 452, 453, 454, 455, 456, + 457, 459, 460, 461, 462, 463, 464, 465, 466, 467, + 468, 469, 470, 471, -297, -297, -297, -297, -297, -281, + -374, 84, -280, 78, -222, -258, -282, -143, -271, 210, + -269, 84, 102, 84, -142, -282, -290, -155, -256, 265, + -414, -413, -405, -408, 660, -256, -270, -405, 270, 268, + 269, 79, 205, 79, 205, 81, -135, 31, 76, -137, + -143, 84, 84, -142, -155, -407, -405, -408, -156, -282, + -290, -291, -290, -273, -278, -279, 661, 197, 193, 196, + 101, 30, 32, 662, 253, 104, 457, 145, 571, 572, + 573, 491, 560, 21, 25, 215, 105, 199, 476, 479, + 213, 144, 209, 216, 310, 312, 552, 587, 192, 72, + 663, 543, 545, 540, 544, 311, 542, 517, 657, 654, + 656, 655, 470, 468, 309, 35, 664, 15, 588, 33, + 225, 260, 29, 665, 138, 466, 194, 598, 251, 108, + 109, 666, 48, 47, 8, 31, 313, 226, 96, 319, + 589, 467, 667, 668, 24, 75, 217, 16, 211, 241, + 740, 669, 334, 18, 568, 127, 19, 670, 651, 653, + 652, 207, 206, 121, 202, 733, 70, 258, 13, 671, + 455, 460, 461, 462, 463, 464, 456, 188, 98, 672, + 673, 118, 324, 66, 575, 576, 599, 52, 39, 246, + 590, 591, 687, 592, 558, 323, 674, 45, 44, 490, + 494, 489, 322, 506, 68, 119, 22, 546, 547, 37, + 675, 676, 632, 234, 493, 454, 488, 688, 677, 649, + 140, 263, 73, 102, 384, 593, 594, 94, 469, 744, + 40, 76, 230, 380, 351, 49, 99, 20, 259, 71, + 41, 566, 124, 745, 596, 472, 208, 238, 678, 532, + 262, 679, 125, 597, 465, 689, 219, 120, 449, 195, + 325, 551, 362, 307, 220, 329, 336, 69, 680, 252, + 126, 595, 200, 518, 648, 11, 681, 562, 36, 224, + 306, 453, 210, 682, 264, 318, 308, 317, 683, 59, + 684, 343, 50, 581, 580, 579, 582, 742, 67, 555, + 556, 660, 201, 46, 107, 492, 452, 487, 205, 559, + 239, 95, 314, 9, 51, 38, 513, 14, 374, 74, + 77, 548, 549, 550, 57, 480, 477, 485, 585, 484, + 584, 586, 743, 106, 17, 327, 567, 636, 533, 100, + 658, 514, 14, 194, 79, 83, -234, 84, -280, 83, + -234, -233, -234, -233, 242, -254, 83, -294, -116, -256, + -256, -143, -143, -143, -143, -143, -143, -254, -254, -254, + -254, -251, 16, -251, -254, -290, -290, -116, -170, -405, + 544, 136, -254, -290, -97, -95, 218, -95, -97, 84, + 84, 447, -88, 40, 30, 30, 84, -59, -59, 83, + -59, 79, 111, -59, -172, 80, -188, -282, -387, 733, + 79, -404, 30, 532, 533, 506, -437, 201, 241, 238, + 76, -437, -432, 371, -407, -406, -405, -435, -436, -282, + -435, -435, -435, 519, -435, -435, -435, -435, -435, -435, + -435, -435, -435, -411, -437, 334, 79, -437, -407, -405, + 205, -369, -371, 440, 441, 533, 534, 375, 375, 375, + 375, 375, 375, -135, -135, -128, 30, -225, -224, -283, + -276, -278, -279, 228, -282, -273, -322, -319, -318, -320, + 479, 527, 144, 539, -143, -405, -156, -126, -126, -124, + -126, 66, 66, 66, 71, 66, 71, 71, 66, 66, + -139, -292, -265, 79, -455, -455, -455, -192, -461, 252, + -9, -454, -292, -158, -265, 202, 202, 202, 104, 16, + 54, 26, 104, 16, 54, 26, 104, 16, 54, 26, + -113, -112, -115, 136, -116, -290, -170, -235, 98, 14, + 121, 79, 23, 79, -221, 32, 33, 189, -171, 61, + 86, 89, -235, 79, -114, -143, -116, -116, -116, -186, + 94, 102, 95, 96, -284, 228, 136, -291, -283, -278, + -276, 348, 232, -273, -170, 26, 27, 28, -187, -193, + -131, 90, 121, 119, 120, 104, -170, -170, -170, -170, + -170, -170, -170, -170, -170, -170, -170, -170, -170, -170, + -170, -293, 84, 83, 145, 84, -283, -112, -283, -169, + 227, 473, 474, 94, -169, -282, -282, -102, 26, 29, + -283, 520, -283, -102, -102, -102, -102, -102, 79, -455, + -112, -112, -112, -455, -116, -116, -112, -170, -112, -196, + 83, -112, -196, 83, -112, -170, 558, 559, 560, -112, + -112, -102, -197, -198, 106, -196, -276, -279, 348, 232, + -112, -455, 86, -176, -177, 639, 648, 649, 651, 654, + 647, 646, 645, 643, 642, 641, 644, 640, 658, 657, + 656, 655, 653, 652, 650, -176, -176, -112, -113, -112, + -112, -455, -455, -115, -112, -115, -112, -112, -455, -455, + -455, -455, -112, -112, -112, -112, -112, -112, -112, -112, + -112, -112, -112, -112, -455, 86, -145, 98, -143, -119, + -143, -135, -456, 16, 77, -456, 79, 189, -242, -245, + 79, 531, 533, 534, -239, -314, -315, 144, 76, 97, + 83, -116, -283, -291, -222, -365, -334, -335, -336, -337, + -358, 216, -373, 208, 210, 211, 51, -338, 217, 202, + 52, -298, -324, 512, 513, -306, 78, -305, 78, -65, + 477, 476, 479, -305, 477, 484, -305, 484, 484, -305, + -305, -305, 477, 78, 78, -306, -306, -306, -326, 78, + -326, 472, -327, 78, -327, -327, -327, -327, -298, -298, + -298, -298, -298, -374, -116, -223, -286, 77, -226, 204, + 720, -322, 31, -322, -66, 253, 222, 189, 78, -156, + 256, 257, -409, 79, 35, -415, 331, 86, 207, -143, + 232, -143, -143, -405, -405, -411, -384, 220, 215, -143, + 79, 79, 189, 699, 699, -143, 79, 83, 84, 84, + -172, -342, 16, 121, -254, -143, -172, -110, 228, 77, + -458, -455, 449, 450, 84, -170, 40, 40, -58, -169, + -282, 80, -388, 206, 551, 83, -403, -292, 505, 533, + -438, 136, -282, -437, -438, -441, 636, 205, 80, 79, + -435, -438, 351, 334, -438, 16, -368, -370, 433, 434, + 435, 436, 437, 438, 439, 79, 111, 111, -372, 24, + -367, 636, -367, -130, -455, 79, 189, 36, -344, -345, + -344, -344, -78, -380, -76, -378, 197, 194, 193, 267, + 199, -317, 552, 250, 249, 283, 284, 75, 37, 198, + 195, -68, -77, 231, 289, 235, 290, 196, 230, 291, + 229, 292, 636, 287, 739, 510, 601, 602, 603, 92, + 604, 247, 43, 202, 606, 539, 376, 607, 608, 212, + 609, 610, 611, 340, 612, 613, 614, 615, 616, 617, + 365, 9, -415, -421, 76, -133, -132, 76, 77, -134, + 76, -132, 66, 66, 66, -229, 78, -292, -124, 79, + -193, -454, -455, -231, -282, -158, -292, -454, -454, -454, + -170, -170, 121, -170, -170, 121, -170, -170, 121, -455, + 79, 189, 79, -232, 42, 41, -282, 507, 62, -173, + -173, -208, -248, 24, 16, 57, 57, -121, 16, -219, + -219, 94, 95, 96, 189, -454, -131, -131, -131, -187, + -170, -170, -170, -110, 101, -455, -455, -113, -112, -112, + -112, -112, -112, -116, -455, -455, -455, 79, 77, 30, + -455, 77, 121, -455, 16, 16, -455, 16, 16, -455, + -455, 16, -170, -170, -170, -455, -455, -112, -200, -198, + 108, -116, -455, -455, -455, -455, -455, 79, 79, 16, + -455, -455, -455, -455, -209, 566, -209, -455, -455, -455, + -455, -455, -209, -209, -209, -209, -455, -455, -455, -455, + -455, -455, -455, -455, -455, -455, -455, -455, -455, -230, + 124, -143, 36, -230, 77, -119, -119, -146, -290, 136, + -244, -247, 535, 532, 538, 84, 83, 145, 83, 189, + -223, -350, -364, 79, 124, 739, 510, 601, -317, 602, + 603, 92, 604, 247, 43, 202, 606, 539, 376, 607, + 608, 212, 609, 610, 611, 340, 612, 443, 613, 614, + 615, 616, 617, 365, 9, 78, -343, -281, 84, -275, + 52, -338, -340, -338, -338, -343, 84, -275, -343, 52, + 702, 94, 102, -313, -315, 145, -310, -311, -328, -331, + -307, 30, 740, 515, 219, -337, 479, 527, 35, 76, + 510, 208, 52, 51, 211, 92, -325, 514, 86, 86, + 577, -305, 484, -305, -305, -305, -305, -305, -332, 83, + -332, 86, -326, 86, 80, 76, -282, 30, -143, 660, + -67, 13, 14, 15, -282, -390, -391, -392, -282, 121, + 258, 259, 76, -424, 362, -413, 332, 341, 101, 21, + 636, -445, 102, 205, 205, -143, -405, -282, 76, 76, + -234, -159, 17, 84, 84, -251, -254, -170, -408, 244, + 245, -170, -170, -144, 98, -404, 205, 189, 189, -438, + 205, 353, -407, -282, 16, 16, 351, 16, -407, 79, + 111, 111, 111, 111, 111, 111, 111, -371, 78, 78, + 385, 532, -224, -283, -344, 84, 83, 145, 84, 83, + 145, 83, -379, 79, -380, 197, 194, 283, 284, -378, + -266, -338, -386, -385, -336, -337, 124, 209, 216, 216, + 213, -266, -338, 208, 217, 124, 216, 213, -266, 202, + -344, -266, 479, 144, 205, 39, 39, 365, 124, 365, + 124, -344, -266, 209, -338, -263, 216, -264, 205, 30, + 288, 124, 124, 124, 124, 124, 124, 124, 124, 293, + -344, -344, -344, -344, -344, -344, -344, -344, 605, 605, + -344, -344, -344, -344, -344, -344, -344, -344, -344, -344, + -344, -344, -344, -344, -344, -344, -348, -442, 83, -452, + 92, 271, 340, 84, -275, -273, 86, 88, 87, -344, + -157, 195, 277, 273, -116, 78, -116, -227, -282, -229, + -461, -455, 79, -158, -227, -227, -227, 101, 205, -454, + 101, 205, -454, 101, 205, -454, -265, -115, 136, -291, + 83, 79, 83, 83, 508, 63, -143, -159, 598, -119, + -114, 136, -283, -113, -110, 101, -170, -455, -455, -455, + -455, -455, -455, -296, 145, 476, 479, 227, 475, 468, + 466, 465, 467, 495, 481, 512, 473, 513, 647, -293, + -296, -293, -170, -170, -170, -170, -170, -170, 16, 16, + 16, 633, -204, 110, -116, 107, -170, -170, -170, -282, + -214, -454, -209, -209, -209, -209, -209, -210, -209, -210, + -210, -210, -210, -210, -210, -210, -210, -210, -210, -210, + -166, -167, 36, -165, -9, -454, -168, -462, 57, 61, + -454, -237, -241, -196, -276, -279, 228, -159, -119, -159, + -159, 189, 532, 536, 537, -364, 21, -344, -344, -344, + 527, 479, 144, -344, -344, -344, -344, -344, 605, 605, + -344, -344, -344, -344, -344, -344, -344, -344, -344, -344, + -344, 444, -344, -344, -344, -344, -344, -348, -442, -344, + -360, -359, 84, -280, 208, 51, -373, -343, -343, -343, + -343, -98, -281, 94, -454, 741, 86, -143, 36, 84, + 145, -169, 135, -294, -161, -179, -454, 95, 96, 543, + 544, 548, 545, 549, 550, 563, 564, 565, 540, 546, + 547, 14, 52, 52, 52, 83, 80, 80, 80, -305, + 80, 79, 80, 79, 80, 79, -163, 694, 695, -143, + -218, -226, 86, 76, 80, 79, -297, -282, -282, -282, + 273, -427, 636, 337, -425, -423, 343, 344, 345, 346, + 347, -408, 342, -415, 339, 83, 84, 659, 693, 714, + 686, 31, -143, -405, -228, 78, -227, -228, -116, -172, + -230, 201, -407, 136, 136, -282, 205, -407, 351, -440, + 636, -407, -407, 16, -407, -370, 83, 83, 83, 86, + 86, 86, 86, -135, -135, 83, 37, 84, 83, 145, + -76, 197, 194, 283, 284, 78, -333, 84, -280, -343, + -259, 210, 208, -454, 84, -281, -281, -281, -282, 52, + 52, -231, -281, -281, -282, -281, 35, 280, 281, 282, + 84, 36, -344, 479, -231, 26, -231, 26, 35, 337, + 285, 286, -333, -281, -282, -143, 217, 213, -281, -231, + 26, 86, -231, -282, -231, 26, -231, 26, -231, 26, + -231, 26, -348, -116, -348, -452, -452, 83, 83, 83, + -344, -344, -452, 83, -442, 83, -99, 218, 221, 223, + -348, -348, -348, -452, 83, -349, 35, 621, 471, 622, + 623, 624, 84, 94, 83, 83, 35, -452, 35, -452, + -348, 618, -454, -420, 249, 250, 205, 278, 102, -417, + 738, 274, -227, 80, 79, -193, -148, -282, -455, -455, + -455, -170, -170, -170, -170, -170, -170, -170, -170, -170, + -292, 189, 522, -282, -312, -313, -201, 18, -219, -455, + -170, -210, -210, -210, -210, -210, -455, -306, -306, -306, + -306, -327, 472, -306, 456, -306, 456, -455, -455, -455, + -455, 24, 24, 24, 24, -455, -170, -170, -170, -454, + -109, 562, -116, 79, 79, -455, -287, 84, -236, 76, + -236, -237, -265, -9, -455, -225, -168, -454, 11, 57, + 61, 636, 201, -191, -194, -461, -231, -159, 79, -345, + -345, -345, -345, -204, -159, -351, -352, -355, -354, 125, + 625, 674, -348, -348, -348, -344, 36, -344, -452, -452, + 83, 83, 83, -344, -344, -452, 83, -442, 83, -99, + -348, -348, -348, -452, 83, -349, 84, 94, 83, 83, + 35, -452, 35, -452, -348, 618, -454, 80, 79, -306, + -306, 52, -340, 78, -170, 30, 78, 84, 145, -169, + 83, -170, -185, 83, 86, 86, 78, -220, 30, -445, + -143, -393, -394, -395, 92, 635, 102, 260, 261, 218, + 262, 263, 264, -392, -297, -297, -297, -417, -430, -431, + -429, 340, 360, 361, 348, -428, -426, 355, 356, 357, + 358, 101, 83, 83, 83, -416, 331, 101, 340, 21, + 30, 83, 83, 83, 83, 86, 77, -227, -254, -312, + -143, -440, -407, -440, 334, -407, 80, 80, -333, -206, + 221, 222, -297, -297, -286, -340, 52, -375, -377, 124, + -281, 694, 695, 694, 695, 36, 194, 732, 702, -333, + -344, -293, 36, 365, 365, 365, 365, -206, -264, 205, + 52, -281, 205, 365, 365, 98, 636, 83, 83, 619, + 620, -443, -442, -309, 92, 76, -156, 278, -421, 76, + -175, -169, -179, -169, 80, -282, 79, 79, 79, 136, + -454, -396, -252, -202, 19, 21, -312, 84, -312, 84, + -170, -170, -170, -170, -455, -455, -455, -170, -455, 83, + -170, -170, -190, 124, 34, -236, -292, -455, -168, -454, + -455, -455, 79, -193, -454, -455, -204, -241, -116, -116, + -116, -116, -222, -356, 627, -454, 522, 626, 52, -293, + -344, -316, -442, 83, 83, 83, 619, 620, -443, -362, + -361, 77, 212, 92, 607, 614, 732, 702, -359, -221, + -221, -343, -343, -227, -455, -454, -227, -455, 80, 80, + -360, -9, -218, 24, -219, -395, 83, 264, 260, 264, + 264, 264, 264, 265, -421, -412, 92, 338, -429, 349, + 700, 333, 362, 86, 86, 123, 37, 38, -426, 86, + 86, 86, 86, -423, 21, 636, -415, 339, 83, 83, + 331, -445, 43, 80, -396, -439, 30, -440, -439, 351, + 80, 84, -298, -298, 78, -343, -343, -455, 79, -282, + 35, 35, -206, -293, -293, -281, -282, -281, 205, -281, + -454, 201, 79, -455, 328, 83, 367, -157, -422, -177, + -170, -170, -170, -447, -448, -283, 707, -397, 45, -399, + 46, -212, 567, -203, -116, -189, -118, -116, -455, -455, + -455, -455, -107, 121, 636, -455, -455, -204, 21, 52, + -229, -168, -9, -454, -194, -455, -222, -353, 628, 86, + -170, -454, -454, -268, 267, -293, -455, -361, -442, -344, + 83, -344, -344, 80, -323, 743, 742, -170, 80, 80, + -218, -220, 251, -220, 43, 43, 256, 257, -420, 83, + 83, 35, 350, 188, 35, 86, 188, 569, 339, 83, + 84, 340, 21, -170, -397, -405, -439, -360, -286, 78, + -377, 57, -170, 144, 144, 205, -281, -375, -143, -442, + -218, -420, 134, -418, 275, -455, -455, -455, -455, 79, + -297, 24, 83, 600, -400, 50, -398, -330, 49, 21, + -211, -213, -282, 79, -455, 634, 73, 637, -215, 126, + 125, -188, 14, -9, -376, -454, 21, -455, -227, -170, + -454, 111, 86, 83, 83, 219, -455, -363, -362, -272, + 636, -9, 252, -26, -4, -15, -16, -17, -18, -20, + -69, -21, -22, -27, -28, -23, -79, -83, -84, -85, + -81, -92, -90, -91, -87, -86, -31, -33, -34, -36, + -39, -40, -37, -38, -35, -29, -32, -41, -24, -42, + -43, -44, -48, -49, -30, -50, 105, 207, 443, 309, + 320, 321, 322, 84, 325, 327, 323, 324, 319, 329, + 442, -309, 86, 35, 86, 35, 352, 340, 30, 86, + -308, 206, 636, 80, 78, -360, 236, -344, -293, -281, + -455, -68, -26, -309, 188, -419, 276, -175, -455, -448, + -449, 600, 31, 713, 522, 83, -399, 21, -401, 47, + 48, 83, 79, 30, -118, 63, 635, 638, -455, -216, + 104, -217, 123, 569, -174, 86, 188, -216, -237, -455, + -375, -354, -455, -455, -227, 86, -143, -323, 213, 279, + 505, -218, -207, 254, 255, -218, -116, -53, -54, 106, + -116, 84, -63, -288, 312, 313, 314, -283, 84, 84, + -52, -26, 82, -52, -116, 84, 84, -457, 16, 60, + -170, 110, -52, 328, 643, 643, 83, -229, 86, 332, + -363, -360, 80, 237, -293, 288, -218, 328, -169, -175, + -422, -265, 83, 600, -454, 522, 83, 21, 21, -213, + -214, 63, -217, 128, 129, 252, 128, 129, -169, -455, + 626, 52, -455, 78, 351, 213, 213, -272, -218, 84, + 84, -53, 110, 108, -54, -116, 107, 310, 311, 315, + -297, 79, 746, 442, 322, 325, 327, 746, 328, 84, + 16, 746, -218, 45, 126, 35, 337, 26, -408, 80, + -363, -454, -218, -177, -422, -292, -450, -451, 377, 94, + 35, 83, -447, -454, 83, 83, 636, 101, -176, -454, + -268, -227, 351, 351, -220, 110, 108, 105, -52, 107, + -52, 24, 24, 24, -312, -283, 110, -26, 110, -52, + -52, -52, -116, 326, -52, 98, 110, -26, 8, -363, + -170, 234, -26, -451, 94, 35, -450, 94, 35, 76, + 76, -169, -455, -447, 637, -217, -170, -454, 80, -19, + -25, -18, -24, -15, -16, -17, 442, 636, 105, -52, + 746, -52, 746, -64, 86, -9, -62, -61, 86, -64, + 317, 102, 318, 84, -314, 322, 84, 746, 746, 746, + 328, -116, 746, -57, 84, -218, -408, -455, -455, -218, + 76, -169, 76, -169, 666, 377, 666, 377, 76, -455, + 638, -455, -170, -382, -383, 76, -218, -52, 110, -122, + 746, 110, 746, 110, 108, -55, -56, 109, -26, 79, + 316, 35, 110, 110, 326, -52, 110, 110, 79, 76, + 76, 377, 377, 666, 377, -357, 629, -455, -383, 76, + -382, 76, 15, 14, 746, 110, 105, 207, -52, 110, + 108, -56, -116, -61, -170, 84, 322, -116, 746, 325, + 327, 84, 76, 76, 86, -357, -381, 220, 215, 218, + 36, -381, 110, 105, 746, 207, -52, 107, 84, 110, + 110, 377, 666, 214, 35, 94, 110, 746, -52, 325, + 327, 207, 110, 746, 84, 84, 207, } var yyDef = [...]int{ -2, -2, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 32, 33, 34, 35, 36, 37, 38, 1580, - 1094, 1094, 0, 1094, 0, -2, 126, 892, 893, 894, - 0, 0, 0, 0, 0, 0, 0, -2, 1059, 1060, - 1063, 1060, 1060, 1088, 0, 463, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 708, - 58, 0, -2, 1090, 1091, 1092, -2, -2, 0, 47, - 0, 54, 0, 2569, 2, 1588, 0, 1107, 1096, 0, - 1094, 1094, 1094, 80, 81, 0, 112, 0, 114, 0, - 0, 1580, 1094, 0, 0, 0, 1658, 1658, 322, 1658, - 1658, 1672, 0, 1674, 320, 0, 1655, 1670, 1671, 0, - 0, 0, 1656, 0, 1656, 1656, 1656, 1656, 1656, 1656, - 1656, 1656, 0, 0, 979, 1286, 1288, 1289, 1290, 1683, - 1684, 2563, 2564, 2565, 2566, 2567, 2568, 2535, 2536, 2537, + 30, 31, 32, 33, 34, 35, 36, 37, 38, 1668, + 1171, 1171, 0, 1171, 0, -2, 127, 891, 892, 893, + 894, 0, 0, 0, 0, 0, 0, 0, -2, 1136, + 1137, 1140, 1137, 1137, 1165, 0, 469, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 711, 58, 0, -2, 1167, 1168, 1169, -2, -2, 0, + 47, 0, 54, 0, 2683, 2, 1676, 0, 1184, 1173, + 0, 1171, 1171, 1171, 81, 82, 0, 113, 0, 115, + 0, 0, 1668, 1171, 0, 0, 0, 1751, 1751, 327, + 1751, 1751, 1766, 0, 1768, 325, 0, 1748, 1764, 1765, + 0, 0, 0, 1749, 0, 1749, 1749, 1749, 1749, 1749, + 1749, 1749, 1749, 0, 0, 1052, 1363, 1365, 1366, 1367, + 1368, 1777, 1778, 2674, 2675, 2676, 2677, 2678, 2679, 2647, + 2648, 2649, 2650, 2651, 2652, 2653, 2654, 2655, 2656, 2657, + 2658, 2659, 2660, 2661, 2662, 2663, 2664, 2665, 2666, 2667, + 2680, 2681, 2682, 2361, 2362, 2363, 2364, 2365, 2366, 2367, + 2368, 2369, 2370, 2371, 2372, 2373, 2374, 2375, 2376, 2377, + 2378, 2379, 2380, 2381, 2382, 2383, 2384, 2385, 2386, 2387, + 2388, 2389, 2390, 2391, 2392, 2393, 2394, 2395, 2396, 2397, + 2398, 2399, 2400, 2401, 2402, 2403, 2404, 2405, 2406, 2407, + 2408, 2409, 2410, 2411, 2412, 2413, 2414, 2415, 2416, 2417, + 2418, 2419, 2420, 2421, 2422, 2423, 2424, 2425, 2426, 2427, + 2428, 2429, 2430, 2431, 2432, 2433, 2434, 2435, 2436, 2437, + 2438, 2439, 2440, 2441, 2442, 2443, 2444, 2445, 2446, 2447, + 2448, 2449, 2450, 2451, 2452, 2453, 2454, 2455, 2456, 2457, + 2458, 2459, 2460, 2461, 2462, 2463, 2464, 2465, 2466, 2467, + 2468, 2469, 2470, 2471, 2472, 2473, 2474, 2475, 2476, 2477, + 2478, 2479, 2480, 2481, 2482, 2483, 2484, 2485, 2486, 2487, + 2488, 2489, 2490, 2491, 2492, 2493, 2494, 2495, 2496, 2497, + 2498, 2499, 2500, 2501, 2502, 2503, 2504, 2505, 2506, 2507, + 2508, 2509, 2510, 2511, 2512, 2513, 2514, 2515, 2516, 2517, + 2518, 2519, 2520, 2521, 2522, 2523, 2524, 2525, 2526, 2527, + 2528, 2529, 2530, 2531, 2532, 2533, 2534, 2535, 2536, 2537, 2538, 2539, 2540, 2541, 2542, 2543, 2544, 2545, 2546, 2547, - 2548, 2549, 2550, 2551, 2552, 2553, 2554, 2555, 2556, 2265, - 2266, 2267, 2268, 2269, 2270, 2271, 2272, 2273, 2274, 2275, - 2276, 2277, 2278, 2279, 2280, 2281, 2282, 2283, 2284, 2285, - 2286, 2287, 2288, 2289, 2290, 2291, 2292, 2293, 2294, 2295, - 2296, 2297, 2298, 2299, 2300, 2301, 2302, 2303, 2304, 2305, - 2306, 2307, 2308, 2309, 2310, 2311, 2312, 2313, 2314, 2315, - 2316, 2317, 2318, 2319, 2320, 2321, 2322, 2323, 2324, 2325, - 2326, 2327, 2328, 2329, 2330, 2331, 2332, 2333, 2334, 2335, - 2336, 2337, 2338, 2339, 2340, 2341, 2342, 2343, 2344, 2345, - 2346, 2347, 2348, 2349, 2350, 2351, 2352, 2353, 2354, 2355, - 2356, 2357, 2358, 2359, 2360, 2361, 2362, 2363, 2364, 2365, - 2366, 2367, 2368, 2369, 2370, 2371, 2372, 2373, 2374, 2375, - 2376, 2377, 2378, 2379, 2380, 2381, 2382, 2383, 2384, 2385, - 2386, 2387, 2388, 2389, 2390, 2391, 2392, 2393, 2394, 2395, - 2396, 2397, 2398, 2399, 2400, 2401, 2402, 2403, 2404, 2405, - 2406, 2407, 2408, 2409, 2410, 2411, 2412, 2413, 2414, 2415, - 2416, 2417, 2418, 2419, 2420, 2421, 2422, 2423, 2424, 2425, - 2426, 2427, 2428, 2429, 2430, 2431, 2432, 2433, 2434, 2435, - 2436, 2437, 2438, 2439, 2440, 2441, 2442, 2443, 2444, 2445, - 2446, 2447, 2448, 2449, 2450, 2451, 2452, 2453, 2454, 2455, - 2456, 2457, 2458, 2459, 2460, 2461, 2462, 2463, 2464, 2465, - 2466, 2467, 2468, 2469, 2470, 2471, 2472, 2473, 2474, 2475, - 2476, 2477, 2478, 2479, 2480, 2481, 2482, 2483, 2484, 2485, - 2486, 2487, 2488, 2489, 2490, 2491, 2492, 2493, 2494, 2495, - 2496, 2497, 2498, 2499, 2500, 2501, 2502, 2503, 2504, 2505, - 2506, 2507, 2508, 2509, 2510, 2511, 2512, 2513, 2514, 2515, - 2516, 2517, 2518, 2519, 2520, 2521, 2522, 2523, 2524, 2525, - 2526, 2527, 2528, 2529, 2530, 2531, 2532, 2533, 2534, 0, - 0, 0, 984, 985, 986, 987, 2557, 2558, 2559, 2560, - 2561, 2562, 996, 997, 0, 0, 0, 1050, 0, 1050, - 1015, 1016, 0, 1018, 0, 0, 0, 0, 0, 0, - 1047, 1029, 1032, 1036, 0, 1588, 1588, 1047, 754, 755, - 756, 1055, 1056, 1044, 1057, 1062, 1061, 1069, 1069, 0, - 1061, 73, -2, 0, 1222, 0, 441, 443, 0, 464, - 0, 467, 470, 1291, 0, -2, -2, 1692, 1075, 0, - 0, 1717, 1718, 0, 0, 0, 0, 0, 2440, 220, - 336, 261, 261, 261, 261, 261, 261, 261, 0, 261, - 261, 0, 261, 261, 261, 2453, 261, 0, 261, 261, - 261, 261, 261, 219, 335, 222, 223, 224, 225, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, - 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, - 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, - 257, 258, 259, 260, 325, 326, 327, 0, 0, 0, - 2440, 0, 712, 1064, 713, 715, 0, 709, 706, 707, - 74, 0, 61, 75, 1607, 1246, 1247, -2, 0, 0, - 1661, 63, 1183, 1184, 1185, -2, 0, 0, 1191, 1192, - -2, 1344, 1683, 0, 0, 1101, 0, 0, 1098, 1104, - 0, 0, 43, 0, 1594, 0, 0, 110, 1095, 0, - 1123, 1174, 0, 1300, 2150, 1306, -2, 2063, 1352, 1353, - 1354, 1355, 1356, 1357, 1358, 1359, 2008, 0, 0, 0, - 0, 0, 2105, 1382, 1383, 1384, 1385, 1386, 1387, 1561, - 1562, 1563, 1564, 1565, 1566, 1567, -2, -2, -2, 1547, - 1548, 0, 2563, 2564, 2566, 2567, 2568, 1624, 0, 1481, - 1482, 1483, 1484, 1485, 1486, 1487, 1488, 1489, 1490, 1491, - 1492, 1493, 1494, 1495, 1496, 1497, 1498, 1499, 1500, 1501, - 1502, 1503, 1504, 1505, 1506, 1507, 1508, 1509, 1510, 1511, - 1512, 1513, 1514, 1515, 1516, 1517, 1518, 1519, 1520, 1521, - 1522, 2131, 2194, 2082, 2199, 2027, 0, 2019, 2096, 2223, - 2224, 0, 2139, 2542, 0, -2, 2248, 2554, 2187, -2, - -2, -2, -2, -2, -2, -2, -2, -2, 2552, 2553, - 2539, 2089, 2037, 2147, 2188, 2028, 2049, 2068, 2117, 2118, - 2120, 2152, 2153, 2171, 2180, 2198, 2009, 2010, 2011, 2112, - 2113, 2220, 2219, 2218, 2221, 2254, 2252, 2255, 1997, 1998, - 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2012, - 2013, 2014, 2015, 2016, 2018, 2020, 2021, 2022, 2023, 2024, - 2025, 2026, 2029, 2030, 2031, 2036, 2038, 2039, 2040, 2041, - 2042, 2043, 2044, 2045, 2047, 2048, 2050, 2051, 2052, 2053, - 2054, 2055, 2056, 2057, 2058, 2059, 2060, 2061, 2062, 2064, - 2065, 2067, 2069, 2070, 2071, 2072, 2073, 2074, 2075, 2076, - 2077, 2078, 2079, 2080, 2081, 2083, 2084, 2085, 2086, 2087, - 2088, 2090, 2091, 2092, 2093, 2094, 2095, 2097, 2098, 2099, - 2100, 2101, 2102, 2103, 2104, 2106, 2107, 2108, 2109, 2110, - 2111, 2114, 2115, 2116, 2119, 2121, 2122, 2123, 2124, 2125, - 2126, 2127, 2128, 2129, 2130, 2132, 2133, 2136, 2137, 2138, - 2140, 2141, 2142, 2143, 2144, 2145, 2146, 2148, 2149, 2151, - 2155, 2156, 2157, 2158, 2159, 2160, 2161, 2162, 2163, 2164, - 2165, 2166, 2167, 2168, 2169, 2170, 2172, 2173, 2174, 2175, - 2176, 2177, 2178, 2179, 2181, 2182, 2183, 2184, 2185, 2186, - 2189, 2190, 2191, 2192, 2193, 2195, 2196, 2197, 2200, 2201, - 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, 2211, - 2212, 2213, 2214, 2215, 2216, 2217, 2222, 2225, 2226, 2227, - 2228, 2229, 2230, 2231, 2232, 2233, 2234, 2236, 2237, 2238, - 2239, 2240, 2241, 2242, 2243, 2244, 2249, 2250, 2251, 2253, - 2256, 2257, 2258, 2259, 2260, 2261, 2262, 2263, 2264, 1660, - 1660, 0, 97, 2516, 0, 1631, -2, -2, 1633, 0, - 0, 0, -2, -2, -2, -2, 2020, -2, 1547, 0, - 0, 0, 0, 2008, 2009, 2010, 2011, 2017, 2019, 2027, - 2028, 2032, 2033, 2034, 2035, 2037, 2046, 2049, 2063, 2066, - 2068, 2082, 2089, 2096, 2105, 2112, 2113, 2117, 2118, 2120, - 2131, 2134, 2135, 2139, 2147, 2150, 2152, 2153, 2154, 2171, - 2180, 2187, 2188, 2194, 2198, 2199, 2218, 2219, 2220, 2221, - 2223, 2224, 2235, 2245, 2246, 2247, 2248, 2252, 2254, 2255, - 113, 1580, 115, 0, 520, 521, 0, 0, 0, 0, - 0, 0, 782, 1677, 1678, 0, 1588, 1107, 0, 0, - 320, 0, 0, 0, 0, 0, 1658, 315, 0, 0, - 0, 0, 1658, 322, 0, 0, 959, 0, 960, 0, - 330, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1002, 1003, 978, 0, 980, 91, 983, 0, - 0, 0, 0, 1000, 1001, 1004, 1050, 1006, 0, 0, - 1658, 1658, 0, 0, 0, 0, 0, 1014, 0, 784, - 785, 1050, 1020, 1050, 1050, 1050, 1047, 0, 1047, 1026, - 1045, 1046, 1050, 0, 0, 0, 1031, 0, 0, 0, - 1039, 1040, 1050, 0, -2, 1067, -2, 1076, 0, 0, - 1081, 1084, 1085, 1086, 1087, 73, 1083, 1093, 1223, 0, - 0, 0, 0, 0, 0, 445, 0, 0, 466, 447, - 0, 451, 452, 453, 454, 455, 456, 457, 458, 459, - 460, 461, 462, 0, 1222, 0, 0, 1687, 1693, 1080, - 1708, 1709, 0, 1719, 1720, 265, 0, 265, 0, 0, - 0, 0, 187, 261, 0, 189, 261, 261, 261, 0, - 261, 261, 196, 197, 261, 199, 200, 201, 261, 203, - 204, 261, 206, 207, 208, 261, 261, 211, 261, 261, - 214, 215, 216, 217, 218, 334, 265, 0, 0, 265, - 0, 0, 0, 0, 0, 714, 716, 691, 0, 0, - 0, 0, 696, 697, 698, 699, 0, 0, 702, 703, - 59, 60, 0, 0, 0, -2, 896, -2, 669, 670, - 671, 0, 666, 0, 0, 0, 0, 0, 0, 1248, - 0, 0, 1251, 0, 0, 0, 0, 0, 1245, -2, - 0, 0, 0, 0, 1181, 0, 0, 1196, 0, 1198, - 0, -2, 0, 0, 0, 1245, 1202, 1203, 1204, 1205, - 1206, 0, 0, 0, 1346, 0, 51, 52, 1102, 1103, - 48, 56, 57, 49, 1099, 1100, 1105, 1106, 50, 53, - 2570, 0, 67, 0, 0, 1589, 1592, 1593, 1581, 1582, - 1585, 0, 0, 67, 1108, 1109, 1110, 1111, 1112, 1113, - 0, 1097, 0, 1124, 0, 0, 0, 0, 1175, 0, - 1178, 1179, 1180, 0, 1304, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1331, 1332, 1333, 1334, 1335, 1336, - 1337, 1307, 0, 1324, 0, 0, 0, 0, 0, 0, - 0, 1375, 1376, 1377, 1378, 1379, 1380, 0, 1114, 0, - 0, 1114, 1114, 1114, 1114, 1114, 0, 1350, 2260, 0, - 2226, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1114, 0, 1539, 0, 0, 0, - 1447, 1456, 0, 1448, 1457, 1449, 1458, 1450, 0, 1451, - 1459, 1452, 1460, 1453, 1454, 1461, 1455, 0, 0, 0, - 0, 1346, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 91, 93, 1286, 0, 98, 100, 0, 0, - 2516, 1634, 1635, 661, 1649, 1650, 1651, 0, 744, 745, - 1647, 0, 1588, 799, 0, 522, 538, 637, 555, 556, - 557, 627, 559, 629, 629, 0, 629, 629, 629, 629, - 629, 604, 605, 606, 607, 608, 610, 611, 612, 613, - 614, 0, 0, 583, 627, 627, 627, 587, 617, 618, - 619, 620, 621, 622, 623, 624, 560, 561, 562, 563, - 564, 565, 566, 567, 568, 569, 570, 571, 572, 573, - 574, 632, 632, 634, 634, 634, 634, 634, 538, 538, - 538, 538, 0, 0, 0, 781, 0, 1594, 110, 1675, - 1607, 0, 0, 322, -2, 0, -2, 0, 1281, 0, - 0, 0, 0, 135, 352, 338, 124, 0, 0, 316, - 321, 317, 318, 319, 0, 0, 0, 0, 329, 975, - 1657, 0, 967, 89, 968, 969, 970, 971, 972, 331, - 973, 974, 354, 0, 1287, 1685, 1686, 1721, 1722, 1723, - 1724, 1725, 1726, 1727, 1728, 1729, 1730, 1731, 1732, 1733, - 1734, 1735, 1736, 1737, 1738, 1739, 1740, 1741, 1742, 1743, - 1744, 1745, 1746, 1747, 1748, 1749, 1750, 1751, 1752, 1753, - 1754, 1755, 1756, 1757, 1758, 1759, 1760, 1761, 1762, 1763, - 1764, 1765, 1766, 1767, 1768, 1769, 1770, 1771, 1772, 1773, - 1774, 1775, 1776, 1777, 1778, 1779, 1780, 1781, 1782, 1783, - 1784, 1785, 1786, 1787, 1788, 1789, 1790, 1791, 1792, 1793, - 1794, 1795, 1796, 1797, 1798, 1799, 1800, 1801, 1802, 1803, - 1804, 1805, 1806, 1807, 1808, 1809, 1810, 1811, 1812, 1813, - 1814, 1815, 1816, 1817, 1818, 1819, 1820, 1821, 1822, 1823, - 1824, 1825, 1826, 1827, 1828, 1829, 1830, 1831, 1832, 1833, - 1834, 1835, 1836, 1837, 1838, 1839, 1840, 1841, 1842, 1843, - 1844, 1845, 1846, 1847, 1848, 1849, 1850, 1851, 1852, 1853, - 1854, 1855, 1856, 1857, 1858, 1859, 1860, 1861, 1862, 1863, - 1864, 1865, 1866, 1867, 1868, 1869, 1870, 1871, 1872, 1873, - 1874, 1875, 1876, 1877, 1878, 1879, 1880, 1881, 1882, 1883, - 1884, 1885, 1886, 1887, 1888, 1889, 1890, 1891, 1892, 1893, - 1894, 1895, 1896, 1897, 1898, 1899, 1900, 1901, 1902, 1903, - 1904, 1905, 1906, 1907, 1908, 1909, 1910, 1911, 1912, 1913, - 1914, 1915, 1916, 1917, 1918, 1919, 1920, 1921, 1922, 1923, - 1924, 1925, 1926, 1927, 1928, 1929, 1930, 1931, 1932, 1933, - 1934, 1935, 1936, 1937, 1938, 1939, 1940, 1941, 1942, 1943, - 1944, 1945, 1946, 1947, 1948, 1949, 1950, 1951, 1952, 1953, - 1954, 1955, 1956, 1957, 1958, 1959, 1960, 1961, 1962, 1963, - 1964, 1965, 1966, 1967, 1968, 1969, 1970, 1971, 1972, 1973, - 1974, 1975, 1976, 1977, 1978, 1979, 1980, 1981, 1982, 1983, - 1984, 1985, 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, - 1994, 1995, 1996, 0, 0, 0, 988, 990, 994, 995, - 989, 991, 998, 992, 999, 1005, 1051, 0, 1053, 0, - 0, 1222, 1010, 1011, 1012, 1013, 786, 1019, 1021, 1022, - 1028, 1050, 0, 1222, 1027, 1048, 1049, 1030, 1338, 1033, - 1465, 0, 1041, 1058, 1073, 0, 1068, 0, 1074, 1078, - 1077, 0, 1082, 0, 0, 0, 1089, 442, 444, 446, - 465, 0, 0, 468, 469, 471, 0, 1292, 1689, 0, - 0, 1711, 0, 1713, 1715, 0, 0, 266, 267, 268, - 265, 0, 221, 0, 283, 337, 0, 188, 0, 263, - 190, 191, 192, 261, 194, 195, 198, 202, 205, 209, - 210, 212, 213, 333, 0, 0, 0, 0, 185, 0, - 0, 711, 725, 0, 0, 1065, 1066, 692, 693, 694, - 695, 704, 701, 76, 0, 0, 1609, 1612, 1613, 1614, - 1615, 1616, 1681, 1682, 895, 672, 673, 674, 0, 742, - 742, 742, 665, 364, 1240, 1242, 0, 1237, 1249, 1250, - 1252, 0, 1254, 0, 0, 1257, 1258, 1259, 1226, 0, - 0, 1190, 1343, 1345, 1193, 0, 0, 0, 1294, 1200, - 0, 0, 0, 0, 0, 0, 0, 1216, 0, 0, - 0, 1217, 0, 0, 0, 1218, 0, 1347, 1348, 1119, - 1120, 0, 0, 41, 0, 1595, 0, 0, 0, 0, - 1584, 1586, 1587, 0, 0, 1569, 0, 0, 64, 110, - 110, 44, 1301, 1302, 1303, 1305, 1325, 0, 1327, 1329, - 1176, 1177, 1125, 0, 1549, 1550, 1551, 1552, 1553, -2, - 1312, 0, 0, 0, 1316, 1340, 1341, 1342, 0, 0, - 0, 0, 1338, 1320, 0, 1360, 1361, 1362, 1363, 1364, - 1365, 1366, 1367, 1368, 1369, 1370, 1371, 1374, 1479, 1480, - 0, 1558, 0, 1559, 1372, 1568, 1373, 1554, 1381, 1346, - 1115, 1116, 1556, 1557, 1555, 0, 0, 0, 0, 0, - 0, 1623, 0, 0, 0, 1422, 0, 0, 0, 0, - 1356, 1561, 0, 1356, 1561, 0, 0, 2121, 2233, 2013, - 0, 0, 0, 1545, 1542, 0, 0, 0, 0, 2557, - 2558, 1445, 0, 1466, 0, 0, 1151, 1152, 1153, 1154, - 1155, 1156, 1157, 1158, 1159, 1160, 1161, 1162, 1163, 1164, - 1165, 1166, 1167, 1168, 1169, 1170, 1171, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 95, 0, 1285, 0, - -2, 0, 0, 87, 88, 0, 0, 0, 1632, 0, - 0, 0, 103, 104, 99, 1636, 662, 0, -2, 1643, - 1561, 1645, 1549, 0, 1594, 867, 523, 525, 526, 527, - 0, 761, 770, 0, 0, 759, 761, 761, 0, 757, - 758, 530, 640, 638, 639, 558, 0, 588, 629, 0, - 589, 629, 629, 629, 629, 592, 629, 629, 595, 598, - 602, 603, 609, 0, 0, 584, 585, 586, 575, 0, - 576, 632, 578, 0, 579, 580, 581, 582, 531, 532, - 533, 534, 778, 779, 780, 0, 285, 0, 0, 0, - 0, 0, 119, 1659, 120, 0, 375, 376, 0, 287, - 0, 323, 324, 137, 0, 0, 339, 0, 130, 0, - 517, 518, 0, 961, 0, 963, 328, 965, 976, 977, - 966, 0, 0, 0, 0, 0, 92, 0, 1052, 1007, - 1008, 1009, 1298, 0, 0, 1023, 1047, 1050, 1042, 0, - 0, 1034, 0, 1072, 1070, 1079, 1219, 0, 0, 448, - 449, 450, 472, 0, 1690, 1691, 1688, 1710, 0, 1714, - 1716, 0, 269, 271, 0, 0, 179, 0, 0, 262, - 0, 193, 0, 0, 0, 0, 0, 710, 717, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 700, 0, - 77, 1608, 0, 0, 742, 0, 743, 0, 0, 897, - 898, -2, 946, 1667, 946, 946, 919, 742, 946, 0, - 0, 0, 742, 742, 742, 742, 742, 742, 0, 957, - 0, 1234, 1241, 0, 0, 1235, 0, 1236, 1253, 1255, - 1256, 1186, 0, 1226, 1182, 0, 1194, 0, -2, 0, - 1230, 1199, 1294, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, -2, 0, 0, 0, 68, - 0, 2323, 71, 0, 0, 1590, 1591, 1583, 0, 1652, - 1653, 1570, 1571, 1298, 0, 0, 1117, 1326, 1328, 1330, - 0, 1346, 1313, 1314, 1315, 1317, 1338, 1321, 0, 1318, - 0, 1309, 1420, 0, 0, 0, 0, 0, 0, 1351, - 1418, 1419, 1421, 0, 0, 0, 1425, 0, 1428, 0, - 0, 1472, 0, 0, 1473, 1433, 0, 0, 0, 0, - 0, 1439, 1580, 0, 1543, 0, 0, 1442, 1443, 1444, - 1446, 1467, 0, 0, 0, 1468, 1469, 1470, 1471, 1407, - 0, 1408, 0, 0, 0, 0, 0, 1414, 1415, 1416, - 1417, 1134, 1134, 1134, 1134, 1134, 1134, 1134, 1134, 1134, - 1134, 1134, 1134, 0, 0, 1284, 0, 1298, 0, 1298, - 1298, 94, 0, 1293, 101, 102, 0, 0, 108, 663, - 664, 1644, 0, 286, 519, 800, 0, 0, 742, 742, - 742, 742, 0, 0, 742, 742, 742, 742, 742, 742, - 0, 0, 742, 742, 742, 742, 742, 742, 742, 742, - 742, 742, 742, 0, 742, 742, 742, 742, 742, 0, - 742, 524, 0, 762, 0, 0, 2493, 763, 761, 761, - 761, 760, 761, 752, 762, 753, 776, 539, 540, 0, - 542, 543, 544, 545, 546, 547, 548, 549, 0, 0, - 0, 0, 0, 0, 0, 656, 0, 686, 688, 0, - 0, 554, 641, 0, 596, 0, 0, 597, 590, 629, - 591, 629, 599, 593, 594, 0, 625, 0, 0, 577, - 0, 796, 0, 1676, 109, 0, 0, 0, 377, 378, - 379, 1282, 0, 288, 289, 0, 0, 0, 0, 0, - 147, 0, 353, 0, 0, 0, 0, 0, 127, 0, - 0, 0, 90, 332, 355, 0, 0, 993, 1017, 0, - 787, 788, 1222, 1025, 1339, 1035, 1037, 1038, 1220, 1221, - 95, 0, 1712, 0, 0, 0, 0, 0, 0, 281, - 264, 0, 0, 0, 0, 186, 0, 0, 0, 0, - 0, 0, 0, 726, 0, 0, 0, 1610, 1611, 0, - 678, 679, 680, 681, 682, 683, 684, 665, 0, 761, - 0, 920, 921, 0, 947, 888, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1668, 1669, 0, 0, 0, - 0, 928, 929, 0, 742, 0, 0, 0, 0, 0, - 0, 0, 367, 0, 0, 0, 1238, 0, 1243, 0, - 1228, 1187, 0, -2, 0, 1201, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1349, - 1121, 0, 0, 0, 69, 70, 1596, 1597, 42, 1572, - 65, 66, 110, 1126, 1560, 0, 1319, 0, 1322, 1388, - 1134, 1134, 1134, 1134, 1134, 0, 627, 627, 1526, 627, - 634, 1529, 627, 1531, 627, 1534, 1536, 1537, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1540, 1441, 1546, 0, 0, 0, 0, 1127, 1128, 1130, - 1409, 1410, 1411, 1412, 1413, 1392, 1135, 1393, 1394, 1396, - 1397, 1399, 1400, 1401, 1402, 1404, 1405, 1406, 1617, 0, - 0, 0, 1600, 1605, 1606, 0, 1298, 1625, 0, 0, - 0, 0, 1580, 1298, 85, 86, 0, 105, 106, 107, - 801, 879, 0, 0, 0, 0, 742, 0, 742, 742, - 0, 0, 0, 0, 0, 0, 742, 742, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 831, - 0, 0, 0, 0, 0, 841, 842, 848, 849, 850, - 851, 852, 864, 865, 866, 853, 854, 855, 0, 0, - 764, 627, 627, 0, 768, 759, 769, 746, 748, 749, - 751, 0, 777, 541, 0, 0, 552, 0, 0, 642, - 0, 0, 645, 1465, 1465, 1465, 0, 0, 1310, 1311, - 0, 685, 687, 689, 690, 628, 630, 631, 600, 601, - 615, 0, 616, 0, 635, 0, 783, 797, 0, 0, - 111, 109, 130, 0, 295, 0, 291, 0, 0, 0, - 0, 155, 0, 138, 139, 140, 142, 143, 0, 0, - 0, 136, 0, 341, 0, 344, 345, 0, 0, 0, - 0, 0, 962, 964, 0, 0, 1225, 982, 1299, 1050, - 657, 0, 281, 270, 272, 273, 0, 281, 284, 180, - 0, 181, 183, 0, 182, 718, 719, 720, 721, 722, - 723, 724, 0, 0, 705, 675, 676, 677, 899, 0, - 943, 0, 0, 1675, 759, 1672, 0, -2, 902, 903, - 911, 912, 913, 914, 915, 0, 926, 0, 0, 908, - 0, 943, 0, 923, 0, 742, 0, 933, 934, 935, - 936, 937, 938, 0, 940, 941, 942, 0, 371, 368, - 369, 0, 365, 0, 364, 0, 0, 0, 1227, 0, - 1195, 1197, 1231, 1295, 1296, 1297, 1207, 1208, 0, 1210, - 1211, 0, 1213, 1214, 0, 1233, 0, 0, 72, 1577, - 0, 1118, 1389, 1323, 1391, 1395, 1390, 1398, 1403, 1423, - 1523, 657, 1527, 1528, 1530, 1532, 1533, 1535, 1427, 1424, - 1426, 0, 0, 0, 0, 1434, 0, 0, 0, 0, - 0, 0, 1544, 0, 0, 1464, 1132, 1131, 78, 0, - 1617, 1598, 1619, 1621, 0, 0, 0, 0, -2, 1992, - 1957, 0, 1580, 0, 0, 0, 0, 0, 1588, 84, - 881, 870, 0, 0, 0, 880, 802, 803, 804, 805, - 0, 742, 0, 0, 809, 810, 811, 846, 847, 813, - 814, 815, 0, 0, 818, 819, 820, 821, 822, 823, - 824, 825, 826, 827, 828, 829, 830, 856, 857, 858, - 859, 860, 861, 832, 833, 834, 835, 836, 837, 838, - 839, 840, 0, 0, 730, 0, 1585, 1585, 761, 761, - 0, 0, 0, 0, 659, 660, 643, 644, 646, 0, - 648, 0, 650, 0, 0, 0, 655, 1465, 1465, 1465, - 1465, 1465, 1465, 1465, 1465, 1465, 0, 0, 0, 626, - 0, 0, 798, 0, 0, 111, 129, 0, 110, 296, - 297, 0, 0, 0, 302, 0, 0, 0, 0, 0, - 290, 292, 293, 294, 364, 173, 156, 157, 0, 0, - 0, 0, 148, 149, 0, 0, 0, 0, 0, 144, - 145, 146, 340, 0, 0, 343, 0, 0, 131, 132, - 0, 134, 130, 0, 0, 1024, 1702, 658, 1283, 274, - 281, 274, 0, 184, 727, 728, 0, 901, 944, 0, - 538, 538, 0, 761, 761, 922, 0, 1665, 1666, 0, - 0, 917, 943, 0, 0, 0, 932, 0, 862, 0, - 953, 0, 0, 958, 366, 957, 0, 358, 373, 374, - 0, 1239, 1229, 0, 0, 0, 1122, 0, 1146, 0, - 0, 1524, 1525, 0, 0, 0, 0, 1435, 1436, 1437, - 1474, 1440, 1541, 0, 0, 1580, 0, 0, 79, 0, - 1622, -2, 0, 0, 96, 1588, 1626, 1627, 1628, 1629, - 1630, 83, 883, 0, 0, 0, 0, 0, 0, 0, - 806, 0, 812, 807, 816, 817, 843, 844, 0, 729, - 733, 0, 742, 0, 742, 742, 740, 741, 765, 766, - 767, 747, 750, 0, 535, 0, 0, 0, 0, 0, - 652, 0, 654, 633, 636, 0, 109, 0, 0, 111, - 298, 299, 300, 301, 303, 304, 0, 0, 0, 367, - 123, 0, 0, 158, 0, 0, 0, 0, 168, 169, - 170, 171, 172, 150, 151, 152, 153, 154, 141, 0, - 0, 342, 0, 347, 348, 0, 128, 0, 1224, 1704, - 1698, 176, 0, 274, 178, 282, 900, 945, 528, 529, - 0, 1675, 0, 904, 906, 905, 907, 916, 918, 0, - 925, 930, 0, 939, 0, 109, 372, 370, 367, 356, - 360, 0, 0, 0, 0, 1261, 0, 2408, 62, 0, - 1578, 1579, 1573, 1574, 1576, 1429, 1431, 1430, 1432, 0, - 0, 0, 1462, 1463, 1136, 0, 0, 1620, 1599, 0, - 1603, 0, 82, 868, 0, 882, 0, 0, 0, 0, - 0, 0, 0, 808, 845, 734, 735, 0, 737, 0, - 0, 0, 550, 536, 537, 0, 553, 647, 649, 651, - 653, 731, 117, 109, 0, 73, 305, 306, 307, 308, - 371, 174, 175, 159, 160, 0, 162, 163, 0, 0, - 0, 350, 0, 346, 0, 981, 1662, 1706, -2, 0, - 275, 177, 0, 0, 0, 924, 742, 863, 0, 949, - 0, 73, 371, 0, 362, 0, 1209, 1212, 1215, 0, - 0, 0, 0, 0, 0, 1147, 1148, 0, 0, 1438, - 0, 0, 0, 0, 0, 0, 1133, 0, 1602, 0, - 0, 879, 871, 0, 873, 0, 0, 0, 0, 0, - 736, 738, 739, 0, 535, 116, 732, 118, 380, 109, - 475, 476, 477, 478, 479, 480, 481, 482, 483, 484, - 485, 486, 487, 488, 489, 490, 491, 492, 493, 494, - 495, 496, 497, 498, 499, 500, 501, 502, 503, 504, - 505, 506, 507, 508, 509, 510, 511, 512, 513, 514, - 515, 516, 0, 0, 0, 0, 0, 0, 73, 0, - 73, 0, 0, 0, 424, 0, 73, 0, 0, 164, - 0, 166, 167, 349, 0, 133, 1226, 0, 1698, 0, - 1700, 0, 1697, 0, 0, 731, 0, 0, 0, 948, - 0, 0, 109, 954, 0, 357, 0, 358, 1244, 1262, - 1263, 0, 0, 1264, 0, 0, 0, 0, 1575, 1475, - 0, 1478, 1129, 1137, 0, 1140, 0, 0, 0, 1172, - 0, 1138, 1618, -2, 0, 885, 872, 874, 875, 876, - 877, 0, 0, 551, 109, 0, 0, 122, 0, 0, - 394, 0, 0, 1677, 0, 0, -2, -2, -2, 1679, - 421, 422, 0, 473, 0, 0, 0, 438, 439, 0, - 425, 0, 440, 309, 0, 109, 161, 165, 351, 40, - 0, 1705, 0, 1703, 0, 0, 1699, 0, 909, 0, - 731, 931, 950, 0, 955, 109, 0, 358, 361, 0, - 1267, 0, 0, 0, 1149, 1150, 1476, 0, 1141, 1142, - 1143, 1144, 1145, 0, 869, 884, 0, 0, 0, 111, - 381, 382, 0, 0, 73, 395, 0, 73, 0, 0, - 0, 657, 0, 73, 73, 73, 73, 0, 73, 73, - 0, 426, 73, 73, 1663, 1664, 1707, 0, 0, 276, - 277, 278, 280, 731, 927, 0, 73, 359, 363, 1260, - 1268, 1269, 0, 0, 0, 1276, 0, 0, 0, 0, - 1173, 886, 0, 0, 73, 0, 73, 392, 0, 73, - 0, 0, 0, 0, 661, 1680, 0, 474, 310, 0, - 0, 0, 0, 0, 0, 0, 312, 109, 1701, 1695, - 0, 910, 0, 109, 1270, 0, 0, 1271, 0, 0, - 0, 0, 0, 1265, 0, 0, 1139, 878, 771, 109, - 383, 384, 385, 386, 387, 388, 73, 0, 390, 0, - 73, 0, 73, 404, 405, 406, 73, 413, 415, 416, - 417, 0, 419, 420, 408, 429, 311, 73, 73, 73, - 73, 0, 73, 423, 427, 125, 279, 0, 956, 0, - 0, 0, 0, 1272, 1273, 1277, 1279, 0, 1266, 1477, - 772, 773, 0, 121, 0, 74, 73, 0, -2, 0, - 73, 0, 401, 0, 407, 0, 418, 0, 313, 0, - 0, 0, 0, 0, 0, 0, 2140, 0, 0, 0, - 0, 1278, 1280, 774, 0, 775, 0, 0, 0, 73, - 0, 393, 397, 0, 0, 73, 402, 0, 414, 409, - 314, 430, 0, 73, 432, 435, 428, 951, 952, 0, - 0, 789, 791, 792, 0, 0, 790, 389, 391, 73, - 399, 0, 73, 431, 0, 0, 1274, 1275, 793, 794, - 795, 0, 73, 0, 433, 436, 398, 0, -2, 434, - 437, 400, + 2548, 2549, 2550, 2551, 2552, 2553, 2554, 2555, 2556, 2557, + 2558, 2559, 2560, 2561, 2562, 2563, 2564, 2565, 2566, 2567, + 2568, 2569, 2570, 2571, 2572, 2573, 2574, 2575, 2576, 2577, + 2578, 2579, 2580, 2581, 2582, 2583, 2584, 2585, 2586, 2587, + 2588, 2589, 2590, 2591, 2592, 2593, 2594, 2595, 2596, 2597, + 2598, 2599, 2600, 2601, 2602, 2603, 2604, 2605, 2606, 2607, + 2608, 2609, 2610, 2611, 2612, 2613, 2614, 2615, 2616, 2617, + 2618, 2619, 2620, 2621, 2622, 2623, 2624, 2625, 2626, 2627, + 2628, 2629, 2630, 2631, 2632, 2633, 2634, 2635, 2636, 2637, + 2638, 2639, 2640, 2641, 2642, 2643, 2644, 2645, 2646, 0, + 0, 0, 1057, 1058, 1059, 1060, 2668, 2669, 2670, 2671, + 2672, 2673, 1069, 1070, 0, 0, 0, 1127, 0, 1127, + 1088, 1089, 0, 1091, 0, 0, 0, 0, 0, 0, + 1124, 1102, 1105, 1109, 0, 1676, 1676, 1124, 1115, 0, + 758, 759, 760, 1132, 1133, 1121, 1134, 1139, 1138, 1146, + 1146, 0, 1138, 73, -2, 0, 1301, 0, 447, 449, + 0, 470, 0, 473, 476, 1369, 0, -2, -2, 1788, + 1152, 0, 0, 1813, 1814, 0, 0, 0, 0, 0, + 2545, 225, 341, 266, 266, 266, 266, 266, 266, 266, + 0, 266, 266, 0, 266, 266, 266, 2561, 266, 0, + 266, 266, 266, 266, 266, 224, 340, 227, 228, 229, + 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, + 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, + 250, 251, 252, 253, 254, 255, 256, 257, 258, 259, + 260, 261, 262, 263, 264, 265, 330, 331, 332, 0, + 0, 0, 2545, 0, 715, 1141, 716, 718, 0, 712, + 709, 710, 74, 0, 61, 75, 1700, 1323, 1324, -2, + 0, 1749, 0, 1754, 63, 1260, 1261, 1262, -2, 0, + 0, 1268, 1269, -2, 1422, 1777, 0, 0, 1178, 0, + 0, 1175, 1181, 0, 0, 43, 0, 1683, 0, 0, + 111, 1172, 0, 1200, 1251, 0, 1378, 2246, 1384, -2, + 2159, 1430, 1431, 1432, 1433, 1434, 1435, 1436, 1437, 2104, + 0, 0, 0, 0, 0, 2201, 1460, 1461, 1462, 1463, + 1464, 1465, 2410, 2623, 2624, 1646, 1650, 1651, 1652, 1653, + 1654, 1655, -2, -2, -2, 1631, 1632, 0, 1644, 2674, + 2675, 2677, 2678, 2679, 1717, 0, 1558, 1559, 1560, 1561, + 1562, 1563, 1564, 1565, 1566, 1567, 1568, 1569, 1570, 1571, + 1572, 1573, 1574, 1575, 1576, 1577, 1578, 1579, 1580, 1581, + 1582, 1583, 1584, 1585, 1586, 1587, 1588, 1589, 1590, 1591, + 1592, 1593, 1594, 1595, 1596, 1597, 1598, 1599, 2227, 2290, + 2178, 2295, 2123, 2680, 2115, 2681, 2192, 2319, 2320, 2682, + 2235, 2654, 0, -2, 2344, 2283, -2, -2, -2, 1528, + -2, -2, -2, 2664, 2665, 2651, 2185, 2133, 2243, 2284, + 2124, 2145, 2164, 2213, 2214, 2216, 2248, 2249, 2267, 2276, + 2294, 2105, 2106, 2107, 2208, 2209, 2316, 2315, 2314, 2317, + 2350, 2348, 2351, 2093, 2094, 2095, 2096, 2097, 2098, 2099, + 2100, 2101, 2102, 2103, 2108, 2109, 2110, 2111, 2112, 2114, + 2116, 2117, 2118, 2119, 2120, 2121, 2122, 2125, 2126, 2127, + -2, 2132, 2134, 2135, 2136, 2137, 2138, 2139, 2140, 2141, + 2143, 2144, 2146, 2147, 2148, 2149, 2150, 2151, 2152, 2153, + 2154, 2155, 2156, 2157, 2158, 2160, 2161, 2163, 2165, 2166, + 2167, 2168, 2169, 2170, 2171, 2172, 2173, 2174, 2175, 2176, + 2177, 2179, 2180, 2181, 2182, 2183, 2184, 2186, 2187, 2188, + 2189, 2190, 2191, 2193, 2194, 2195, 2196, 2197, 2198, 2199, + 2200, 2202, 2203, 2204, 2205, 2206, 2207, 2210, 2211, 2212, + 2215, 2217, 2218, 2219, 2220, 2221, 2222, 2223, 2224, 2225, + 2226, 2228, 2229, -2, -2, 2232, 2233, 2234, 2236, 2237, + 2238, 2239, 2240, 2241, 2242, 2244, 2245, 2247, 2251, 2252, + 2253, 2254, 2255, 2256, 2257, 2258, 2259, 2260, 2261, 2262, + 2263, 2264, 2265, 2266, 2268, 2269, 2270, 2271, 2272, 2273, + 2274, 2275, 2277, 2278, 2279, 2280, 2281, 2282, 2285, 2286, + 2287, 2288, 2289, 2291, 2292, 2293, 2296, 2297, 2298, 2299, + 2300, 2301, 2302, 2303, 2304, 2305, 2306, 2307, 2308, 2309, + 2310, 2311, 2312, 2313, 2318, 2321, 2322, 2323, 2324, 2325, + 2326, 2327, 2328, 2329, 2330, 2332, 2333, 2334, 2335, 2336, + 2337, 2338, 2339, 2340, 2345, 2346, 2347, 2349, 2352, 2353, + 2354, 2355, 2356, 2357, 2358, 2359, 2360, 0, 1753, 1753, + 0, 98, 2625, 0, 1724, -2, -2, 1726, 0, 0, + 0, -2, -2, -2, -2, 2116, -2, 1631, 0, 0, + 0, 0, 2104, 2105, 2106, 2107, 2113, 2115, 2123, 2124, + 2128, 2129, 2130, 2131, 2133, 2142, 2145, 2159, 2162, 2164, + 2178, 2185, 2192, 2201, 2208, 2209, 2213, 2214, 2216, 2227, + 2230, 2231, 2235, 2243, 2246, 2248, 2249, 2250, 2267, 2276, + 2283, 2284, 2290, 2294, 2295, 2314, 2315, 2316, 2317, 2319, + 2320, 2331, 2341, 2342, 2343, 2344, 2348, 2350, 2351, 114, + 1668, 116, 0, 526, 527, 0, 0, 0, 0, 0, + 0, 0, 783, 1771, 1772, 0, 1676, 1184, 0, 0, + 325, 0, 0, 0, 0, 0, 1751, 320, 0, 0, + 0, 0, 1751, 327, 0, 0, 1032, 0, 1033, 0, + 335, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1075, 1076, 1051, 0, 1053, 92, 1056, 0, + 0, 0, 0, 1073, 1074, 1077, 0, 1118, 1127, 1079, + 0, 0, 1751, 1751, 0, 0, 0, 0, 0, 1087, + 0, 785, 786, 1127, 1093, 1127, 1127, 1127, 1124, 0, + 1124, 1099, 1122, 1123, 1127, 0, 0, 0, 1104, 0, + 0, 0, 1112, 1113, 1127, 1117, 0, -2, 1144, -2, + 1153, 0, 0, 1158, 1161, 1162, 1163, 1164, 73, 1160, + 1170, 1302, 0, 0, 0, 0, 0, 0, 451, 0, + 0, 472, 453, 0, 457, 458, 459, 460, 461, 462, + 463, 464, 465, 466, 467, 468, 0, 1301, 0, 0, + 1783, 1789, 1157, 1804, 1805, 0, 1815, 1816, 270, 0, + 270, 0, 0, 0, 0, 192, 266, 0, 194, 266, + 266, 266, 0, 266, 266, 201, 202, 266, 204, 205, + 206, 266, 208, 209, 266, 211, 212, 213, 266, 266, + 216, 266, 266, 219, 220, 221, 222, 223, 339, 270, + 0, 0, 270, 0, 0, 0, 0, 0, 717, 719, + 690, 0, 0, 0, 0, 695, 696, 697, 698, 0, + 0, 701, 702, 0, 0, 59, 60, 0, 0, 0, + -2, 896, -2, 668, 669, 670, 0, 665, 0, 0, + 0, 0, 0, 0, 0, 1325, 0, 0, 1328, 0, + 0, 0, 0, 0, 1763, -2, 0, 0, 0, 0, + 1258, 1273, 0, 1275, 0, 1277, 0, -2, 0, 0, + 0, 1763, 1281, 1282, 1283, 1284, 1285, 0, 0, 0, + 1424, 0, 51, 52, 1179, 1180, 48, 56, 57, 49, + 1176, 1177, 1182, 1183, 50, 53, 2684, 0, 67, 0, + 0, 1677, 1680, 1681, 1682, 1669, 1670, 1673, 0, 0, + 67, 1185, 1186, 1187, 1188, 1189, 1190, 0, 1174, 0, + 1201, 0, 0, 0, 0, 1252, 0, 1255, 1256, 1257, + 0, 1382, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1409, 1410, 1411, 1412, 1413, 1414, 1415, 1385, 0, + 1402, 0, 0, 0, 0, 0, 0, 0, 1453, 1454, + 1455, 1456, 1457, 1458, 0, 1647, 1648, 1649, 1191, 0, + 0, 1191, 1191, 1191, 1191, 1191, 0, 1428, 2356, 0, + 2322, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1191, 0, 1623, 0, 0, + 1525, 0, 1526, 1527, 1529, 1542, 0, 1530, 1531, 0, + 0, 0, 0, 1424, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1537, + 1538, 1539, 0, 0, 0, 0, 0, 0, 92, 94, + 1363, 0, 99, 101, 0, 0, 2625, 1727, 1728, 659, + 1742, 1743, 1744, 0, 748, 749, 1740, 0, 1676, 800, + 0, 543, 640, 561, 562, 563, 630, 565, 632, 0, + 632, 632, 1620, 1621, 632, 632, 632, 607, 608, 609, + 610, 611, 613, 614, 615, 616, 617, 0, 0, 589, + 630, 630, 630, 593, 620, 621, 622, 623, 624, 625, + 626, 627, 566, 567, 568, 569, 570, 571, 572, 573, + 574, 575, 576, 577, 578, 579, 580, 635, 635, 637, + 637, 637, 637, 637, 543, 543, 543, 543, 543, 0, + 782, 987, 988, 0, 1683, 111, 1769, 1700, 0, 0, + 327, -2, 0, -2, 0, 1358, 0, 0, 0, 0, + 140, 357, 343, 125, 0, 0, 321, 326, 322, 323, + 324, 0, 0, 0, 0, 334, 1048, 1750, 0, 1040, + 90, 1041, 1042, 1043, 1044, 1045, 336, 1046, 1047, 359, + 0, 1364, 1779, 1780, 1781, 1782, 1817, 1818, 1819, 1820, + 1821, 1822, 1823, 1824, 1825, 1826, 1827, 1828, 1829, 1830, + 1831, 1832, 1833, 1834, 1835, 1836, 1837, 1838, 1839, 1840, + 1841, 1842, 1843, 1844, 1845, 1846, 1847, 1848, 1849, 1850, + 1851, 1852, 1853, 1854, 1855, 1856, 1857, 1858, 1859, 1860, + 1861, 1862, 1863, 1864, 1865, 1866, 1867, 1868, 1869, 1870, + 1871, 1872, 1873, 1874, 1875, 1876, 1877, 1878, 1879, 1880, + 1881, 1882, 1883, 1884, 1885, 1886, 1887, 1888, 1889, 1890, + 1891, 1892, 1893, 1894, 1895, 1896, 1897, 1898, 1899, 1900, + 1901, 1902, 1903, 1904, 1905, 1906, 1907, 1908, 1909, 1910, + 1911, 1912, 1913, 1914, 1915, 1916, 1917, 1918, 1919, 1920, + 1921, 1922, 1923, 1924, 1925, 1926, 1927, 1928, 1929, 1930, + 1931, 1932, 1933, 1934, 1935, 1936, 1937, 1938, 1939, 1940, + 1941, 1942, 1943, 1944, 1945, 1946, 1947, 1948, 1949, 1950, + 1951, 1952, 1953, 1954, 1955, 1956, 1957, 1958, 1959, 1960, + 1961, 1962, 1963, 1964, 1965, 1966, 1967, 1968, 1969, 1970, + 1971, 1972, 1973, 1974, 1975, 1976, 1977, 1978, 1979, 1980, + 1981, 1982, 1983, 1984, 1985, 1986, 1987, 1988, 1989, 1990, + 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, + 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, + 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019, 2020, + 2021, 2022, 2023, 2024, 2025, 2026, 2027, 2028, 2029, 2030, + 2031, 2032, 2033, 2034, 2035, 2036, 2037, 2038, 2039, 2040, + 2041, 2042, 2043, 2044, 2045, 2046, 2047, 2048, 2049, 2050, + 2051, 2052, 2053, 2054, 2055, 2056, 2057, 2058, 2059, 2060, + 2061, 2062, 2063, 2064, 2065, 2066, 2067, 2068, 2069, 2070, + 2071, 2072, 2073, 2074, 2075, 2076, 2077, 2078, 2079, 2080, + 2081, 2082, 2083, 2084, 2085, 2086, 2087, 2088, 2089, 2090, + 2091, 2092, 0, 0, 0, 1061, 1063, 1067, 1068, 1062, + 1064, 1071, 1065, 1072, 1116, 1078, 1128, 0, 1130, 0, + 0, 1301, 1083, 1084, 1085, 1086, 787, 1092, 1094, 1095, + 1101, 1127, 0, 1301, 1100, 1125, 1126, 1103, 1416, 1106, + 1540, 0, 1114, 1135, 1150, 0, 1145, 0, 1151, 1155, + 1154, 0, 1159, 0, 0, 0, 1166, 448, 450, 452, + 471, 0, 0, 474, 475, 477, 0, 1370, 1785, 0, + 0, 1807, 0, 1809, 1811, 0, 0, 271, 272, 273, + 270, 0, 226, 0, 288, 342, 0, 193, 0, 268, + 195, 196, 197, 266, 199, 200, 203, 207, 210, 214, + 215, 217, 218, 338, 0, 0, 0, 0, 190, 0, + 0, 714, 729, 0, 0, 1142, 1143, 691, 692, 693, + 694, 707, 700, 705, 705, 76, 0, 0, 1702, 1705, + 1706, 1707, 1708, 1709, 1775, 1776, 895, 671, 672, 673, + 0, 746, 746, 746, 664, 0, 369, 1319, 1321, 0, + 1316, 1326, 1327, 1329, 0, 1331, 0, 0, 1334, 1335, + 1336, 1305, 0, 0, 1267, 1421, 1423, 1270, 0, 1274, + 0, 0, 1372, 1279, 0, 0, 0, 0, 0, 0, + 0, 1295, 0, 0, 0, 1296, 0, 0, 0, 1297, + 0, 1425, 1426, 1196, 1197, 0, 0, 41, 0, 1684, + 0, 0, 0, 0, 1672, 1674, 1675, 0, 0, 1657, + 0, 0, 64, 111, 111, 44, 1379, 1380, 1381, 1383, + 1403, 0, 1405, 1407, 1253, 1254, 1202, 0, 1633, -2, + 1635, -2, -2, -2, 1390, 0, 0, 0, 1394, 1418, + 1419, 1420, 0, 0, 0, 0, 1416, 1398, 0, 1438, + 1439, 1440, 1441, 1442, 1443, 1444, 1445, 1446, 1447, 1448, + 1449, 1452, 1555, 1556, 1557, 0, 1642, 0, 1643, 1450, + 0, 0, 0, 1656, 1451, 1638, 1459, 1424, 1192, 1193, + 1640, 1641, 1639, 0, 0, 0, 0, 0, 0, 1716, + 0, 0, 0, 1500, 0, 0, 0, 0, 0, 1434, + 1646, 0, 1434, 1646, 0, 0, 2217, 2329, 2109, 0, + 0, 0, 1629, 1626, 0, 0, 0, 0, 2668, 2669, + 0, 1541, 0, 0, 1228, 1229, 1230, 1231, 1232, 1233, + 1234, 1235, 1236, 1237, 1238, 1239, 1240, 1241, 1242, 1243, + 1244, 1245, 1246, 1247, 1248, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1535, 0, 96, 0, 1362, 0, + -2, 0, 0, 88, 89, 0, 0, 0, 1725, 0, + 0, 0, 104, 105, 100, 1729, 660, 0, -2, 1736, + 1646, 1738, 1633, 0, 1683, -2, 528, 529, 530, 531, + 0, 765, 773, 0, 0, 763, 765, 765, 0, 761, + 762, 534, 643, 641, 642, 564, 0, 594, 0, 632, + 632, 1620, 1621, 596, 632, 632, 599, 632, 632, 602, + 605, 606, 612, 0, 0, 590, 591, 592, 581, 0, + 582, 635, 584, 0, 585, 586, 587, 588, 535, 536, + 537, 538, 539, 781, 0, 290, 0, 0, 0, 0, + 0, 120, 1752, 121, 0, 380, 381, 0, 292, 0, + 328, 329, 142, 0, 0, 344, 0, 131, 0, 523, + 524, 0, 1034, 0, 1036, 333, 1038, 1049, 1050, 1039, + 0, 0, 0, 0, 0, 93, 0, 1129, 1080, 1081, + 1082, 1376, 0, 0, 1096, 1124, 1127, 1119, 0, 0, + 1107, 0, 1149, 1147, 1156, 1298, 0, 0, 454, 455, + 456, 478, 0, 1786, 1787, 1784, 1806, 0, 1810, 1812, + 0, 274, 276, 0, 0, 184, 0, 0, 267, 0, + 198, 0, 0, 0, 0, 0, 713, 720, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 699, 0, + 703, 0, 704, 77, 1701, 0, 0, 746, 0, 747, + 0, 0, 995, 898, 899, 997, -2, 993, 993, 746, + 993, 0, 0, 0, 0, 0, 0, 936, 746, 993, + 1758, 0, 949, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 985, 986, 746, 746, 746, 746, 746, 746, + 746, 746, 0, 0, 746, 746, 746, 746, 746, 746, + 746, 746, 746, 746, 746, 746, 746, 746, 746, 746, + 0, 746, 989, 1030, 0, 1313, 1320, 0, 0, 1314, + 0, 1315, 1330, 1332, 1333, 1263, 0, 1305, 1259, 1273, + 1271, 0, -2, 0, 1309, 1278, 1372, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, -2, + 0, 0, 0, 68, 2423, 0, 71, 0, 0, 1678, + 1679, 1671, 0, 1745, 1746, 1658, 1659, 1376, 0, 0, + 1194, 1404, 1406, 1408, 0, 1424, 1391, 1392, 1393, 1395, + 1416, 1399, 0, 1396, 0, 1387, 1498, 0, 0, 0, + 0, 0, 0, 1429, 1496, 1497, 1499, 0, 0, 0, + 1503, 0, 0, 1507, 0, 0, 1548, 0, 0, 1549, + 1512, 0, 0, 0, 0, 0, 1518, 1668, 0, 1627, + 0, 0, 1521, 1522, 1523, 1524, 1543, 0, 0, 0, + 1544, 1545, 1546, 1547, 1485, 0, 1486, 0, 0, 0, + 0, 0, 1492, 1493, 1494, 1495, 1211, 1211, 1211, 1211, + 1211, 1211, 1211, 1211, 1211, 1211, 1211, 1211, 1536, 0, + 0, 1361, 0, 1376, 0, 1376, 1376, 95, 0, 1371, + 102, 103, 0, 0, 109, 661, 662, 663, 1737, 0, + 291, 525, 801, 664, 0, 746, 746, 746, 0, 746, + 746, 746, 746, 746, 0, 0, 746, 746, 746, 746, + 746, 746, 746, 746, 746, 746, 746, 0, 746, 746, + 746, 746, 746, 0, 746, 0, 0, 0, -2, -2, + 765, 765, 765, 764, 765, 756, 766, 767, 757, 779, + 544, 545, 0, 547, 548, 549, 550, 551, 552, 553, + 554, 0, 0, 0, 0, 559, 0, 0, 0, 0, + 652, 0, 685, 687, 0, 0, 560, 644, 0, 0, + 0, 595, 632, 603, 597, 598, 600, 601, 0, 628, + 0, 0, 583, 0, 797, 0, 1770, 110, 1700, 0, + 0, 382, 383, 384, 1359, 0, 293, 294, 0, 0, + 0, 0, 0, 152, 0, 358, 0, 0, 0, 0, + 0, 128, 0, 0, 0, 91, 337, 360, 0, 0, + 1066, 1090, 0, 788, 789, 1301, 1098, 1417, 1108, 1110, + 1111, 1299, 1300, 96, 0, 1808, 0, 0, 0, 0, + 0, 0, 286, 269, 0, 0, 0, 0, 191, 0, + 0, 0, 0, 0, 0, 0, 0, 730, 0, 0, + 0, 0, 1703, 1704, 0, 677, 678, 679, 680, 681, + 682, 683, 897, 664, 996, 0, 0, 0, 0, 998, + 0, 765, 0, 0, 906, 907, 0, 994, 887, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 746, 0, 928, 929, 930, 0, 931, + 0, 0, 0, 0, 0, 0, 0, 1759, 1760, 1761, + 948, 0, 0, 0, 0, 0, 0, 0, 0, 1019, + 0, 0, 0, 0, 0, 0, 0, 0, 746, 746, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 980, 981, 847, 848, + 849, 850, 851, 863, 864, 865, 852, 853, 854, 0, + 372, 0, 0, 0, 1317, 0, 1322, 0, 1307, 1264, + 0, -2, 0, 1280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 1427, 1198, 0, + 0, 0, 69, 653, 1685, 1686, 42, 1660, 65, 66, + 111, 1203, 1645, 0, 1397, 0, 1400, 1466, 1211, 1211, + 1211, 1211, 1211, 0, 630, 630, 630, 1605, 630, 637, + 1608, 1610, 1611, 1612, 630, 1614, 630, 1617, 1619, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1624, 1520, 1630, 0, 0, 0, 0, 1204, + 1205, 1207, 1487, 1488, 1489, 1490, 1491, 1470, 1212, 1471, + 1472, 1474, 1475, 1477, 1478, 1479, 1480, 1482, 1483, 1484, + 1710, 1710, 0, -2, 1692, 0, 1689, 1273, 1698, 1699, + 0, 1376, 1718, 0, 0, 0, 0, 1668, 1376, 86, + 87, 0, 106, 107, 108, 802, 873, 0, 0, 0, + 746, 0, 746, 0, 0, 0, 0, 0, 746, 746, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 827, 0, 0, 0, 0, 0, 837, 838, 0, + 0, 768, 630, 630, 0, 763, 772, 750, 752, 753, + 755, 0, 780, 546, 0, 0, 557, 0, 0, 657, + 658, 645, 0, 0, 648, 649, 0, 1388, 1389, 1540, + 1540, 1540, 1540, 1540, 1540, 0, 0, 0, 1540, 1540, + 1540, 0, 684, 686, 688, 689, 631, 633, 634, 604, + 618, 0, 619, 0, 638, 0, 784, 798, 799, 0, + 112, 0, 131, 0, 300, 0, 296, 0, 0, 0, + 0, 160, 0, 143, 144, 145, 147, 148, 0, 0, + 0, 141, 0, 346, 0, 349, 350, 0, 0, 0, + 0, 0, 1035, 1037, 0, 0, 1304, 1055, 1377, 1127, + 653, 0, 286, 275, 277, 278, 0, 286, 289, 185, + 0, 186, 188, 0, 187, 721, 722, 723, 724, 725, + 726, 727, 728, 0, 0, 708, 706, 674, 675, 676, + 900, -2, 993, 0, 0, 0, 990, 0, 0, 1769, + 763, 1766, 0, 0, -2, 908, 909, 932, 933, 934, + 0, 1000, 0, 0, 0, 0, 914, 915, 916, 917, + 0, 746, 0, 0, 0, 0, 0, 0, 937, 938, + 939, 940, 990, 0, 0, 944, 0, 0, 0, 0, + 0, 1007, 0, 0, 1011, 1012, 1013, 1014, 1015, 1016, + 1017, 1018, 950, 951, 952, 953, 954, 955, 956, 957, + 0, 0, 960, 961, 962, 963, 964, 842, 843, 844, + 965, 966, 967, 968, 969, 970, 855, 856, 857, 858, + 859, 860, 971, 972, 973, 974, 975, 976, 977, 978, + 979, 0, 0, 376, 373, 374, 0, 370, 0, 369, + 0, 0, 0, 1306, 0, 1272, 1276, 1310, 1373, 1374, + 1375, 1286, 1287, 0, 1289, 1290, 0, 1292, 1293, 0, + 1312, 0, 0, 72, 1798, 654, 1665, 0, 1195, 1467, + 1401, 1469, 1473, 1468, 1476, 1481, 1501, 1600, 653, 653, + 1606, 1607, 1609, 1613, 1615, 1616, 1618, 1505, 1502, 1504, + 1506, 0, 0, 0, 0, 1513, 0, 0, 0, 0, + 0, 0, 1628, 0, 0, 1534, 1209, 1208, 78, 0, + 79, 1710, 0, 0, 0, 0, 0, 0, -2, -2, + -2, 2088, 2053, 1696, 1712, 0, 0, 1668, 0, 0, + 0, 0, 0, 1676, 85, 879, 868, 0, 0, 877, + 878, 874, 803, 804, 805, 0, 746, 0, 808, 809, + 811, 812, 813, 0, 0, 816, 817, 818, 819, 820, + 821, 822, 823, 824, 825, 826, 828, 829, 830, 831, + 832, 833, 834, 835, 836, 0, 0, 734, 0, 1673, + 1673, 765, 765, 0, 0, 0, 0, 655, 656, 646, + 647, 0, 651, 629, 0, 0, 0, 0, 110, 130, + 0, 111, 301, 302, 0, 0, 0, 307, 0, 0, + 0, 0, 0, 295, 297, 298, 299, 369, 178, 161, + 162, 0, 0, 0, 0, 153, 154, 0, 0, 0, + 0, 0, 149, 150, 151, 345, 0, 0, 348, 0, + 0, 132, 133, 0, 135, 131, 0, 0, 1097, 1798, + 1360, 279, 286, 279, 0, 189, 731, 732, 0, 902, + 991, 0, 543, 543, 0, 765, 765, 0, 1022, 0, + 935, 910, 912, 911, 913, 0, 0, 920, 921, 990, + 0, 925, 0, 1001, 1002, 1003, 1004, 941, 0, 0, + 0, 0, 0, 1005, 1006, 0, 0, 958, 959, 982, + 983, 0, 861, 1026, 0, 0, 1031, 371, 1030, 0, + 363, 378, 379, 0, 1318, 1308, 0, 0, 0, 1199, + 0, 1800, 1794, 1223, 0, 0, 1601, 1602, 1603, 1604, + 0, 0, 0, 0, 1514, 1515, 1516, 1550, 1519, 1625, + 0, 0, 1668, 0, 0, 80, 1305, -2, 1690, 0, + 0, 1697, 1273, 1714, 0, 97, 1676, 1719, 1720, 1721, + 1722, 1723, 84, 881, 0, 0, 0, 0, 875, 806, + 0, 810, 845, 846, 814, 815, 839, 840, 0, 733, + 737, 0, 746, 0, 746, 746, 744, 745, 769, 770, + 771, 751, 754, 0, 540, 0, 0, 650, 636, 639, + 0, 110, 112, 0, 112, 303, 304, 305, 306, 308, + 309, 0, 0, 0, 372, 124, 0, 0, 163, 0, + 0, 0, 0, 173, 174, 175, 176, 177, 155, 156, + 157, 158, 159, 146, 0, 0, 347, 0, 352, 353, + 0, 129, 0, 1303, 1800, 181, 0, 279, 183, 287, + 901, 992, 532, 533, 0, 1769, 0, 999, 0, 0, + 0, 919, 922, 923, 926, 942, 943, 0, 0, 947, + 0, 0, 0, 984, 110, 377, 375, 372, 361, 365, + 0, 0, 0, 0, 1338, 0, 2513, 70, 1802, -2, + 0, 62, 0, 1666, 1667, 1661, 1662, 1664, 1508, 1510, + 1509, 1511, 0, 0, 0, 1532, 1533, 1213, 0, 0, + 1688, 1691, 1693, 0, 1713, 1715, 83, 1020, 0, 880, + 0, 0, 0, 0, 0, 807, 841, 738, 739, 0, + 741, 0, 0, 0, 555, 541, 542, 0, 558, 735, + 136, 0, 0, 73, 310, 311, 312, 313, 376, 179, + 180, 164, 165, 0, 167, 168, 0, 0, 0, 355, + 0, 351, 0, 1054, 1755, 280, 182, 0, 0, 0, + 1023, 0, 918, 746, 0, 0, 946, 0, 1009, 862, + 73, 376, 0, 367, 0, 1288, 1291, 1294, 0, 0, + 0, 0, 0, 0, 1794, 0, 1796, 0, 1793, 0, + 1224, 1225, 0, 0, 1517, 0, 0, 0, 0, 0, + 0, 1210, 0, 0, 867, 0, 873, 869, 0, 0, + 0, 0, 740, 742, 743, 0, 540, 117, 736, 118, + 0, 110, 385, 110, 481, 482, 483, 484, 485, 486, + 487, 488, 489, 490, 491, 492, 493, 494, 495, 496, + 497, 498, 499, 500, 501, 502, 503, 504, 505, 506, + 507, 508, 509, 510, 511, 512, 513, 514, 515, 516, + 517, 518, 519, 520, 521, 522, 0, 0, 0, 0, + 0, 0, 73, 0, 73, 0, 0, 0, 430, 0, + 73, 0, 0, 169, 0, 171, 172, 354, 0, 134, + 1305, 0, 0, 735, 0, 0, 0, 0, 927, 945, + 1008, 0, 110, 1027, 0, 362, 0, 363, 1762, 1339, + 1340, 0, 0, 1341, 0, 0, 1801, 0, 1799, 0, + 0, 1795, 0, 0, 1663, 1551, 0, 1554, 1206, 1214, + 0, 1217, 0, 0, 0, 1249, 0, 1215, 1711, -2, + 0, 0, 870, 871, 0, 876, 0, 556, 0, 0, + 0, 136, 110, 0, 0, 123, 0, 0, 400, 0, + 0, 1771, 0, 0, -2, -2, -2, 1773, 427, 428, + 0, 479, 0, 0, 0, 444, 445, 0, 431, 0, + 446, 314, 0, 110, 166, 170, 356, 40, 0, 0, + 903, 0, 735, 0, 924, 1010, 1028, 110, 0, 363, + 366, 0, 1344, 0, 0, 0, 1803, 0, 0, 1226, + 1227, 1552, 0, 1218, 1219, 1220, 1221, 1222, 0, 1021, + 0, 875, 872, 0, 137, 0, 0, 119, 112, 386, + 387, 0, 0, 73, 401, 0, 73, 0, 0, 0, + 653, 0, 73, 73, 73, 73, 0, 73, 73, 0, + 432, 73, 73, 1756, 1757, 281, 282, 283, 285, 735, + 905, 0, 73, 364, 368, 1337, 1345, 1346, 0, 0, + 0, 1353, 0, 0, 1797, 1791, 0, 0, 1250, 0, + 0, 0, 138, 139, 73, 0, 73, 398, 0, 73, + 0, 0, 0, 0, 659, 1774, 0, 480, 315, 0, + 0, 0, 0, 0, 0, 0, 317, 110, 0, 904, + 0, 2236, 110, 1347, 0, 0, 1348, 0, 0, 0, + 0, 0, 1342, 0, 0, 1216, 0, 0, 774, 110, + 388, 389, 390, 391, 392, 393, 73, 0, 396, 0, + 73, 0, 73, 410, 411, 412, 73, 419, 421, 422, + 423, 0, 425, 426, 414, 435, 316, 73, 73, 73, + 73, 0, 73, 429, 433, 126, 284, 1024, 1025, 1029, + 0, 0, 0, 0, 1349, 1350, 1354, 1356, 0, 1343, + 1553, 884, 0, 775, 776, 0, 122, 0, 395, 74, + 73, 0, -2, 0, 73, 0, 407, 0, 413, 0, + 424, 0, 318, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1355, 1357, 882, 0, 884, 777, 0, + 778, 0, 0, 0, 73, 0, 399, 403, 0, 0, + 73, 408, 0, 420, 415, 319, 436, 0, 73, 438, + 441, 434, 0, 0, 885, 883, 790, 792, 793, 0, + 0, 791, 394, 397, 73, 405, 0, 73, 437, 0, + 0, 1351, 1352, 794, 795, 796, 0, 73, 0, 439, + 442, 404, 0, -2, 440, 443, 406, } var yyTok1 = [...]int{ 1, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 102, 3, 3, 3, 138, 130, 3, - 77, 79, 135, 133, 78, 134, 188, 136, 3, 3, - 3, 3, 3, 3, 3, 3, 3, 3, 81, 724, - 111, 110, 112, 3, 80, 3, 3, 3, 3, 3, + 3, 3, 3, 103, 3, 3, 3, 139, 131, 3, + 78, 80, 136, 134, 79, 135, 189, 137, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 3, 82, 746, + 112, 111, 113, 3, 81, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 140, 3, 3, 3, 3, 3, + 3, 3, 3, 3, 141, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 129, 3, 141, + 3, 3, 3, 3, 130, 3, 142, } var yyTok2 = [...]int{ @@ -11333,16 +12167,16 @@ var yyTok2 = [...]int{ 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 82, 83, 84, 85, 86, + 72, 73, 74, 75, 76, 77, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, - 97, 98, 99, 100, 101, 103, 104, 105, 106, 107, - 108, 109, 113, 114, 115, 116, 117, 118, 119, 120, - 121, 122, 123, 124, 125, 126, 127, 128, 131, 132, - 137, 139, 142, 143, 144, 145, 146, 147, 148, 149, + 97, 98, 99, 100, 101, 102, 104, 105, 106, 107, + 108, 109, 110, 114, 115, 116, 117, 118, 119, 120, + 121, 122, 123, 124, 125, 126, 127, 128, 129, 132, + 133, 138, 140, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, - 180, 181, 182, 183, 184, 185, 186, 187, 189, 190, + 180, 181, 182, 183, 184, 185, 186, 187, 188, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, @@ -11444,7 +12278,11 @@ var yyTok3 = [...]int{ 58030, 707, 58031, 708, 58032, 709, 58033, 710, 58034, 711, 58035, 712, 58036, 713, 58037, 714, 58038, 715, 58039, 716, 58040, 717, 58041, 718, 58042, 719, 58043, 720, 58044, 721, - 58045, 722, 58046, 723, 0, + 58045, 722, 58046, 723, 58047, 724, 58048, 725, 58049, 726, + 58050, 727, 58051, 728, 58052, 729, 58053, 730, 58054, 731, + 58055, 732, 58056, 733, 58057, 734, 58058, 735, 58059, 736, + 58060, 737, 58061, 738, 58062, 739, 58063, 740, 58064, 741, + 58065, 742, 58066, 743, 58067, 744, 58068, 745, 0, } var yyErrorMessages = [...]struct { @@ -11786,38 +12624,38 @@ yydefault: case 1: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:628 +//line sql.y:667 { setParseTree(yylex, yyDollar[1].statement) } case 2: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:632 +//line sql.y:671 { setParseTree(yylex, yyDollar[1].statement) statementSeen(yylex) } case 3: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:639 +//line sql.y:678 { yyVAL.statement = yyDollar[1].selStmt } case 39: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:678 +//line sql.y:717 { setParseTree(yylex, nil) } case 40: yyDollar = yyS[yypt-12 : yypt+1] -//line sql.y:684 +//line sql.y:723 { yyVAL.statement = &Load{Local: yyDollar[3].boolVal, Infile: yyDollar[4].str, IgnoreOrReplace: yyDollar[5].str, Table: yyDollar[6].tableName, Partition: yyDollar[7].partitions, Charset: yyDollar[8].str, Fields: yyDollar[9].Fields, Lines: yyDollar[10].Lines, IgnoreNum: yyDollar[11].sqlVal, Columns: yyDollar[12].columns} } case 41: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:690 +//line sql.y:729 { yyDollar[1].selStmt.SetOrderBy(yyDollar[2].orderBy) yyDollar[1].selStmt.SetLimit(yyDollar[3].limit) @@ -11830,7 +12668,7 @@ yydefault: } case 42: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:701 +//line sql.y:740 { yyVAL.selStmt = &Select{ Comments: Comments(yyDollar[2].bytes2), @@ -11841,7 +12679,7 @@ yydefault: } case 43: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:712 +//line sql.y:751 { if yyDollar[1].selStmt.GetInto() != nil { yylex.Error(fmt.Errorf("INTO clause is not allowed").Error()) @@ -11851,55 +12689,55 @@ yydefault: } case 44: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:722 +//line sql.y:761 { yyVAL.statement = &Stream{Comments: Comments(yyDollar[2].bytes2), SelectExpr: yyDollar[3].selectExpr, Table: yyDollar[5].tableName} } case 45: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:730 +//line sql.y:769 { yyVAL.selStmt = yyDollar[1].selStmt } case 46: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:734 +//line sql.y:773 { yyVAL.selStmt = yyDollar[1].selStmt } case 47: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:741 +//line sql.y:780 { yyVAL.selStmt = yyDollar[1].selStmt } case 48: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:745 +//line sql.y:784 { yyVAL.selStmt = &SetOp{Type: yyDollar[2].str, Left: yyDollar[1].selStmt, Right: yyDollar[3].selStmt} } case 49: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:749 +//line sql.y:788 { yyVAL.selStmt = &SetOp{Type: yyDollar[2].str, Left: yyDollar[1].selStmt, Right: yyDollar[3].selStmt} } case 50: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:758 +//line sql.y:797 { yyVAL.selStmt = &SetOp{Type: yyDollar[2].str, Left: yyDollar[1].selStmt, Right: yyDollar[3].selStmt} } case 51: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:762 +//line sql.y:801 { yyVAL.selStmt = &SetOp{Type: yyDollar[2].str, Left: yyDollar[1].selStmt, Right: yyDollar[3].selStmt} } case 52: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:770 +//line sql.y:808 { if yyDollar[1].selStmt.GetInto() != nil { yylex.Error(fmt.Errorf("INTO clause is not allowed").Error()) @@ -11909,62 +12747,62 @@ yydefault: } case 53: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:778 +//line sql.y:816 { yyVAL.selStmt = &ParenSelect{Select: yyDollar[2].selStmt} } case 54: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:786 +//line sql.y:824 { yyVAL.selStmt = yyDollar[1].selStmt } case 55: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:790 +//line sql.y:828 { yyVAL.selStmt = yyDollar[1].selStmt } case 56: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:798 +//line sql.y:836 { yyVAL.selStmt = yyDollar[1].selStmt } case 57: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:802 +//line sql.y:840 { yyVAL.selStmt = yyDollar[1].selStmt } case 58: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:808 +//line sql.y:846 { yyVAL.selStmt = yyDollar[1].selStmt } case 59: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:812 +//line sql.y:850 { yyDollar[3].selStmt.SetWith(yyDollar[2].with) yyVAL.selStmt = yyDollar[3].selStmt } case 60: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:819 +//line sql.y:857 { yyVAL.with = &With{Ctes: yyDollar[2].tableExprs, Recursive: true} } case 61: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:822 +//line sql.y:860 { yyVAL.with = &With{Ctes: yyDollar[1].tableExprs, Recursive: false} } case 62: yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:828 +//line sql.y:866 { yyVAL.selStmt = &Select{ Comments: Comments(yyDollar[2].bytes2), @@ -11980,97 +12818,97 @@ yydefault: } case 63: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:842 +//line sql.y:880 { yyVAL.selStmt = &Select{SelectExprs: SelectExprs{&StarExpr{}}, From: TableExprs{yyDollar[2].tableExpr}} } case 64: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:847 +//line sql.y:885 { yyVAL.tableExprs = nil } case 65: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:851 +//line sql.y:889 { yyVAL.tableExprs = nil } case 66: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:855 +//line sql.y:893 { yyVAL.tableExprs = yyDollar[2].tableExprs } case 67: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:864 +//line sql.y:902 { yyVAL.into = nil } case 68: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:868 +//line sql.y:906 { yyVAL.into = &Into{Variables: yyDollar[2].variables} } case 69: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:872 +//line sql.y:910 { - yyVAL.into = &Into{Outfile: string(yyDollar[3].bytes)} + yyVAL.into = &Into{Dumpfile: string(yyDollar[3].bytes)} } case 70: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:876 + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:914 { - yyVAL.into = &Into{Dumpfile: string(yyDollar[3].bytes)} + yyVAL.into = &Into{Outfile: string(yyDollar[3].bytes), Charset: yyDollar[4].str, Fields: yyDollar[5].Fields, Lines: yyDollar[6].Lines} } case 71: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:882 +//line sql.y:920 { yyVAL.variables = Variables{yyDollar[1].colIdent} } case 72: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:886 +//line sql.y:924 { yyVAL.variables = append(yyVAL.variables, yyDollar[3].colIdent) } case 73: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:891 +//line sql.y:929 { yyVAL.with = nil } case 74: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:895 +//line sql.y:933 { yyVAL.with = yyDollar[2].with } case 75: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:901 +//line sql.y:939 { yyVAL.tableExprs = TableExprs{yyDollar[1].tableExpr} } case 76: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:905 +//line sql.y:943 { yyVAL.tableExprs = append(yyDollar[1].tableExprs, yyDollar[3].tableExpr) } case 77: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:911 +//line sql.y:949 { yyVAL.tableExpr = &CommonTableExpr{&AliasedTableExpr{Expr: yyDollar[4].simpleTableExpr, As: yyDollar[1].tableIdent}, yyDollar[2].columns} } case 78: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:917 +//line sql.y:955 { // insert_data returns a *Insert pre-filled with Columns & Values ins := yyDollar[7].ins @@ -12084,8 +12922,23 @@ yydefault: yyVAL.statement = ins } case 79: + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:968 + { + // insert_data returns a *Insert pre-filled with Columns & Values + ins := yyDollar[7].ins + ins.Action = yyDollar[2].str + ins.Comments = yyDollar[3].bytes2 + ins.Ignore = yyDollar[4].str + ins.Table = yyDollar[5].tableName + ins.Partitions = yyDollar[6].partitions + ins.OnDup = OnDup(yyDollar[8].assignExprs) + ins.With = yyDollar[1].with + yyVAL.statement = ins + } + case 80: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:930 +//line sql.y:981 { cols := make(Columns, 0, len(yyDollar[8].assignExprs)) vals := make(ValTuple, 0, len(yyDollar[9].assignExprs)) @@ -12093,207 +12946,207 @@ yydefault: cols = append(cols, updateList.Name.Name) vals = append(vals, updateList.Expr) } - yyVAL.statement = &Insert{Action: yyDollar[2].str, Comments: Comments(yyDollar[3].bytes2), Ignore: yyDollar[4].str, Table: yyDollar[5].tableName, Partitions: yyDollar[6].partitions, Columns: cols, Rows: Values{vals}, OnDup: OnDup(yyDollar[9].assignExprs), With: yyDollar[1].with} + yyVAL.statement = &Insert{Action: yyDollar[2].str, Comments: Comments(yyDollar[3].bytes2), Ignore: yyDollar[4].str, Table: yyDollar[5].tableName, Partitions: yyDollar[6].partitions, Columns: cols, Rows: &AliasedValues{Values: Values{vals}}, OnDup: OnDup(yyDollar[9].assignExprs), With: yyDollar[1].with} } - case 80: + case 81: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:942 +//line sql.y:993 { yyVAL.str = InsertStr } - case 81: + case 82: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:946 +//line sql.y:997 { yyVAL.str = ReplaceStr } - case 82: + case 83: yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:952 +//line sql.y:1003 { yyVAL.statement = &Update{Comments: Comments(yyDollar[3].bytes2), Ignore: yyDollar[4].str, TableExprs: yyDollar[5].tableExprs, Exprs: yyDollar[7].assignExprs, Where: NewWhere(WhereStr, yyDollar[8].expr), OrderBy: yyDollar[9].orderBy, Limit: yyDollar[10].limit, With: yyDollar[1].with} } - case 83: + case 84: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:958 +//line sql.y:1009 { yyVAL.statement = &Delete{Comments: Comments(yyDollar[3].bytes2), TableExprs: TableExprs{&AliasedTableExpr{Expr: yyDollar[5].tableName}}, Partitions: yyDollar[6].partitions, Where: NewWhere(WhereStr, yyDollar[7].expr), OrderBy: yyDollar[8].orderBy, Limit: yyDollar[9].limit, With: yyDollar[1].with} } - case 84: + case 85: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:962 +//line sql.y:1013 { yyVAL.statement = &Delete{Comments: Comments(yyDollar[3].bytes2), Targets: yyDollar[5].tableNames, TableExprs: yyDollar[7].tableExprs, Where: NewWhere(WhereStr, yyDollar[8].expr), With: yyDollar[1].with} } - case 85: + case 86: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:966 +//line sql.y:1017 { yyVAL.statement = &Delete{Comments: Comments(yyDollar[3].bytes2), Targets: yyDollar[4].tableNames, TableExprs: yyDollar[6].tableExprs, Where: NewWhere(WhereStr, yyDollar[7].expr), With: yyDollar[1].with} } - case 86: + case 87: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:970 +//line sql.y:1021 { yyVAL.statement = &Delete{Comments: Comments(yyDollar[3].bytes2), Targets: yyDollar[4].tableNames, TableExprs: yyDollar[6].tableExprs, Where: NewWhere(WhereStr, yyDollar[7].expr), With: yyDollar[1].with} } - case 87: + case 88: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:975 +//line sql.y:1026 { } - case 88: + case 89: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:976 +//line sql.y:1027 { } - case 89: + case 90: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:980 +//line sql.y:1031 { yyVAL.tableNames = TableNames{yyDollar[1].tableName.ToViewName()} } - case 90: + case 91: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:984 +//line sql.y:1035 { yyVAL.tableNames = append(yyVAL.tableNames, yyDollar[3].tableName.ToViewName()) } - case 91: + case 92: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:990 +//line sql.y:1041 { yyVAL.tableNames = TableNames{yyDollar[1].tableName} } - case 92: + case 93: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:994 +//line sql.y:1045 { yyVAL.tableNames = append(yyVAL.tableNames, yyDollar[3].tableName) } - case 93: + case 94: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1000 +//line sql.y:1051 { yyVAL.tableNames = TableNames{yyDollar[1].tableName} } - case 94: + case 95: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1004 +//line sql.y:1055 { yyVAL.tableNames = append(yyVAL.tableNames, yyDollar[3].tableName) } - case 95: + case 96: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1009 +//line sql.y:1060 { yyVAL.partitions = nil } - case 96: + case 97: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1013 +//line sql.y:1064 { yyVAL.partitions = yyDollar[3].partitions } - case 97: + case 98: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1019 +//line sql.y:1070 { yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Exprs: yyDollar[3].setVarExprs} } - case 98: + case 99: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1023 +//line sql.y:1074 { for i := 0; i < len(yyDollar[4].setVarExprs); i++ { yyDollar[4].setVarExprs[i].Scope = SetScope_None } yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Exprs: yyDollar[4].setVarExprs} } - case 99: + case 100: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1030 +//line sql.y:1081 { for i := 0; i < len(yyDollar[5].setVarExprs); i++ { yyDollar[5].setVarExprs[i].Scope = yyDollar[3].setScope } yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Exprs: yyDollar[5].setVarExprs} } - case 100: + case 101: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1039 +//line sql.y:1090 { yyVAL.setVarExprs = SetVarExprs{yyDollar[1].setVarExpr} } - case 101: + case 102: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1043 +//line sql.y:1094 { yyVAL.setVarExprs = append(yyVAL.setVarExprs, yyDollar[3].setVarExpr) } - case 102: + case 103: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1049 +//line sql.y:1100 { yyVAL.setVarExpr = &SetVarExpr{Name: NewColName(TransactionStr), Expr: NewStrVal([]byte(yyDollar[3].str))} } - case 103: + case 104: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1053 +//line sql.y:1104 { yyVAL.setVarExpr = &SetVarExpr{Name: NewColName(TransactionStr), Expr: NewStrVal([]byte(TxReadWrite))} } - case 104: + case 105: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1057 +//line sql.y:1108 { yyVAL.setVarExpr = &SetVarExpr{Name: NewColName(TransactionStr), Expr: NewStrVal([]byte(TxReadOnly))} } - case 105: + case 106: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1063 +//line sql.y:1114 { yyVAL.str = IsolationLevelRepeatableRead } - case 106: + case 107: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1067 +//line sql.y:1118 { yyVAL.str = IsolationLevelReadCommitted } - case 107: + case 108: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1071 +//line sql.y:1122 { yyVAL.str = IsolationLevelReadUncommitted } - case 108: + case 109: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1075 +//line sql.y:1126 { yyVAL.str = IsolationLevelSerializable } - case 109: + case 110: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1080 +//line sql.y:1131 { yyVAL.int = yyPosition(yylex) } - case 110: + case 111: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1085 +//line sql.y:1136 { yyVAL.int = yyOldPosition(yylex) } - case 111: + case 112: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1090 +//line sql.y:1141 { yyVAL.boolean = yySpecialCommentMode(yylex) } - case 112: + case 113: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1096 +//line sql.y:1147 { yyDollar[1].ddl.TableSpec = yyDollar[2].TableSpec if len(yyDollar[1].ddl.TableSpec.Constraints) > 0 { @@ -12301,87 +13154,90 @@ yydefault: } yyVAL.statement = yyDollar[1].ddl } - case 113: + case 114: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1105 +//line sql.y:1156 { yyDollar[1].ddl.OptSelect = &OptSelect{Select: yyDollar[3].selStmt} yyVAL.statement = yyDollar[1].ddl } - case 114: + case 115: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1114 +//line sql.y:1165 { yyDollar[1].ddl.OptSelect = &OptSelect{Select: yyDollar[2].selStmt} yyVAL.statement = yyDollar[1].ddl } - case 115: + case 116: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1119 +//line sql.y:1170 { yyDollar[1].ddl.OptLike = &OptLike{LikeTable: yyDollar[3].tableName} yyVAL.statement = yyDollar[1].ddl } - case 116: + case 117: yyDollar = yyS[yypt-11 : yypt+1] -//line sql.y:1124 +//line sql.y:1175 { // For consistency, we always return AlterTable for any ALTER TABLE-equivalent statements ddl := &DDL{Action: AlterStr, Table: yyDollar[7].tableName, IndexSpec: &IndexSpec{Action: CreateStr, ToName: yyDollar[4].colIdent, Using: yyDollar[5].colIdent, Type: yyDollar[2].str, Columns: yyDollar[9].indexColumns, Options: yyDollar[11].indexOptions}} yyVAL.statement = &AlterTable{Table: yyDollar[7].tableName, Statements: []*DDL{ddl}} } - case 117: - yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:1130 + case 118: + yyDollar = yyS[yypt-11 : yypt+1] +//line sql.y:1181 { yyDollar[2].viewSpec.ViewName = yyDollar[4].tableName.ToViewName() yyDollar[2].viewSpec.ViewExpr = yyDollar[9].selStmt yyDollar[2].viewSpec.Columns = yyDollar[5].columns + yyDollar[2].viewSpec.CheckOption = yyDollar[11].viewCheckOption yyVAL.statement = &DDL{Action: CreateStr, ViewSpec: yyDollar[2].viewSpec, SpecialCommentMode: yyDollar[8].boolean, SubStatementPositionStart: yyDollar[7].int, SubStatementPositionEnd: yyDollar[10].int - 1} } - case 118: - yyDollar = yyS[yypt-11 : yypt+1] -//line sql.y:1137 + case 119: + yyDollar = yyS[yypt-13 : yypt+1] +//line sql.y:1189 { yyDollar[4].viewSpec.ViewName = yyDollar[6].tableName.ToViewName() - yyDollar[4].viewSpec.ViewExpr = yyDollar[10].selStmt - yyVAL.statement = &DDL{Action: CreateStr, ViewSpec: yyDollar[4].viewSpec, SpecialCommentMode: yyDollar[9].boolean, SubStatementPositionStart: yyDollar[8].int, SubStatementPositionEnd: yyDollar[11].int - 1, OrReplace: true} + yyDollar[4].viewSpec.ViewExpr = yyDollar[11].selStmt + yyDollar[4].viewSpec.Columns = yyDollar[7].columns + yyDollar[4].viewSpec.CheckOption = yyDollar[13].viewCheckOption + yyVAL.statement = &DDL{Action: CreateStr, ViewSpec: yyDollar[4].viewSpec, SpecialCommentMode: yyDollar[10].boolean, SubStatementPositionStart: yyDollar[9].int, SubStatementPositionEnd: yyDollar[12].int - 1, OrReplace: true} } - case 119: + case 120: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1143 +//line sql.y:1197 { var ne bool if yyDollar[3].byt != 0 { ne = true } - yyVAL.statement = &DBDDL{Action: CreateStr, DBName: string(yyDollar[4].bytes), IfNotExists: ne, CharsetCollate: yyDollar[5].charsetCollates} + yyVAL.statement = &DBDDL{Action: CreateStr, SchemaOrDatabase: "database", DBName: string(yyDollar[4].bytes), IfNotExists: ne, CharsetCollate: yyDollar[5].charsetCollates} } - case 120: + case 121: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1151 +//line sql.y:1205 { var ne bool if yyDollar[3].byt != 0 { ne = true } - yyVAL.statement = &DBDDL{Action: CreateStr, DBName: string(yyDollar[4].bytes), IfNotExists: ne, CharsetCollate: yyDollar[5].charsetCollates} + yyVAL.statement = &DBDDL{Action: CreateStr, SchemaOrDatabase: "schema", DBName: string(yyDollar[4].bytes), IfNotExists: ne, CharsetCollate: yyDollar[5].charsetCollates} } - case 121: + case 122: yyDollar = yyS[yypt-16 : yypt+1] -//line sql.y:1159 +//line sql.y:1213 { yyVAL.statement = &DDL{Action: CreateStr, Table: yyDollar[8].tableName, TriggerSpec: &TriggerSpec{TrigName: yyDollar[4].triggerName, Definer: yyDollar[2].str, Time: yyDollar[5].str, Event: yyDollar[6].str, Order: yyDollar[12].triggerOrder, Body: yyDollar[15].statement}, SpecialCommentMode: yyDollar[14].boolean, SubStatementPositionStart: yyDollar[13].int, SubStatementPositionEnd: yyDollar[16].int - 1} } - case 122: + case 123: yyDollar = yyS[yypt-12 : yypt+1] -//line sql.y:1163 +//line sql.y:1217 { yyVAL.statement = &DDL{Action: CreateStr, ProcedureSpec: &ProcedureSpec{ProcName: yyDollar[4].procedureName, Definer: yyDollar[2].str, Params: yyDollar[6].procedureParams, Characteristics: yyDollar[8].characteristics, Body: yyDollar[11].statement}, SpecialCommentMode: yyDollar[10].boolean, SubStatementPositionStart: yyDollar[9].int, SubStatementPositionEnd: yyDollar[12].int - 1} } - case 123: + case 124: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:1167 +//line sql.y:1221 { var notExists bool if yyDollar[3].byt != 0 { @@ -12400,9 +13256,9 @@ yydefault: passwordOptions, locked := NewPasswordOptionsWithLock(yyDollar[8].passLockItems) yyVAL.statement = &CreateUser{IfNotExists: notExists, Users: yyDollar[4].accountsWithAuth, DefaultRoles: yyDollar[5].accountNames, TLSOptions: tlsOptions, AccountLimits: accountLimits, PasswordOptions: passwordOptions, Locked: locked, Attribute: yyDollar[9].str} } - case 124: + case 125: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1186 +//line sql.y:1240 { var notExists bool if yyDollar[3].byt != 0 { @@ -12410,9 +13266,9 @@ yydefault: } yyVAL.statement = &CreateRole{IfNotExists: notExists, Roles: yyDollar[4].accountNames} } - case 125: + case 126: yyDollar = yyS[yypt-15 : yypt+1] -//line sql.y:1194 +//line sql.y:1248 { var notExists bool if yyDollar[4].byt != 0 { @@ -12420,39 +13276,39 @@ yydefault: } yyVAL.statement = &DDL{Action: CreateStr, EventSpec: &EventSpec{EventName: yyDollar[5].eventName, Definer: yyDollar[2].str, IfNotExists: notExists, OnSchedule: yyDollar[8].eventScheduleSpec, OnCompletionPreserve: yyDollar[9].eventOnCompletion, Status: yyDollar[10].eventStatus, Comment: yyDollar[11].sqlVal, Body: yyDollar[14].statement}, SubStatementPositionStart: yyDollar[13].int, SubStatementPositionEnd: yyDollar[15].int - 1} } - case 126: + case 127: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1202 +//line sql.y:1256 { yyVAL.statement = yyDollar[1].statement } - case 127: + case 128: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:1208 +//line sql.y:1262 { yyVAL.statement = &CreateSpatialRefSys{SRID: NewIntVal(yyDollar[5].bytes), SrsAttr: yyDollar[6].srsAttr} } - case 128: + case 129: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:1212 +//line sql.y:1266 { yyVAL.statement = &CreateSpatialRefSys{SRID: NewIntVal(yyDollar[8].bytes), IfNotExists: true, SrsAttr: yyDollar[9].srsAttr} } - case 129: + case 130: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:1216 +//line sql.y:1270 { yyVAL.statement = &CreateSpatialRefSys{SRID: NewIntVal(yyDollar[7].bytes), OrReplace: true, SrsAttr: yyDollar[8].srsAttr} } - case 130: + case 131: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1221 +//line sql.y:1275 { yyVAL.srsAttr = &SrsAttribute{} } - case 131: + case 132: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1225 +//line sql.y:1279 { if yyDollar[1].srsAttr.Name != "" { yylex.Error("multiple definitions of attribute name") @@ -12461,9 +13317,9 @@ yydefault: yyDollar[1].srsAttr.Name = string(yyDollar[3].bytes) yyVAL.srsAttr = yyDollar[1].srsAttr } - case 132: + case 133: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1234 +//line sql.y:1288 { if yyDollar[1].srsAttr.Definition != "" { yylex.Error("multiple definitions of attribute definition") @@ -12472,9 +13328,9 @@ yydefault: yyDollar[1].srsAttr.Definition = string(yyDollar[3].bytes) yyVAL.srsAttr = yyDollar[1].srsAttr } - case 133: + case 134: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:1243 +//line sql.y:1297 { if yyDollar[1].srsAttr.Organization != "" { yylex.Error("multiple definitions of attribute organization") @@ -12484,9 +13340,9 @@ yydefault: yyDollar[1].srsAttr.OrgID = NewIntVal(yyDollar[6].bytes) yyVAL.srsAttr = yyDollar[1].srsAttr } - case 134: + case 135: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1253 +//line sql.y:1307 { if yyDollar[1].srsAttr.Description != "" { yylex.Error("multiple definitions of attribute description") @@ -12495,679 +13351,703 @@ yydefault: yyDollar[1].srsAttr.Description = string(yyDollar[3].bytes) yyVAL.srsAttr = yyDollar[1].srsAttr } - case 135: + case 136: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1263 +//line sql.y:1318 + { + yyVAL.viewCheckOption = ViewCheckOptionUnspecified + } + case 137: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:1322 + { + yyVAL.viewCheckOption = ViewCheckOptionCascaded + } + case 138: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:1326 + { + yyVAL.viewCheckOption = ViewCheckOptionCascaded + } + case 139: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:1330 + { + yyVAL.viewCheckOption = ViewCheckOptionLocal + } + case 140: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:1335 { yyVAL.accountNames = nil } - case 136: + case 141: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1267 +//line sql.y:1339 { yyVAL.accountNames = yyDollar[3].accountNames } - case 137: + case 142: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1272 +//line sql.y:1344 { yyVAL.tlsOptionItems = nil } - case 138: + case 143: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1276 +//line sql.y:1348 { yyVAL.tlsOptionItems = nil } - case 139: + case 144: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1280 +//line sql.y:1352 { yyVAL.tlsOptionItems = yyDollar[2].tlsOptionItems } - case 140: + case 145: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1286 +//line sql.y:1358 { yyVAL.tlsOptionItems = []TLSOptionItem{yyDollar[1].tlsOptionItem} } - case 141: + case 146: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1290 +//line sql.y:1362 { yyVAL.tlsOptionItems = append(yyDollar[1].tlsOptionItems, yyDollar[3].tlsOptionItem) } - case 142: + case 147: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1296 +//line sql.y:1368 { yyVAL.tlsOptionItem = TLSOptionItem{TLSOptionItemType: TLSOptionItemType_SSL, ItemData: ""} } - case 143: + case 148: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1300 +//line sql.y:1372 { yyVAL.tlsOptionItem = TLSOptionItem{TLSOptionItemType: TLSOptionItemType_X509, ItemData: ""} } - case 144: + case 149: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1304 +//line sql.y:1376 { yyVAL.tlsOptionItem = TLSOptionItem{TLSOptionItemType: TLSOptionItemType_Cipher, ItemData: string(yyDollar[2].bytes)} } - case 145: + case 150: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1308 +//line sql.y:1380 { yyVAL.tlsOptionItem = TLSOptionItem{TLSOptionItemType: TLSOptionItemType_Issuer, ItemData: string(yyDollar[2].bytes)} } - case 146: + case 151: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1312 +//line sql.y:1384 { yyVAL.tlsOptionItem = TLSOptionItem{TLSOptionItemType: TLSOptionItemType_Subject, ItemData: string(yyDollar[2].bytes)} } - case 147: + case 152: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1317 +//line sql.y:1389 { yyVAL.accountLimitItems = nil } - case 148: + case 153: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1321 +//line sql.y:1393 { yyVAL.accountLimitItems = yyDollar[2].accountLimitItems } - case 149: + case 154: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1327 +//line sql.y:1399 { yyVAL.accountLimitItems = []AccountLimitItem{yyDollar[1].accountLimitItem} } - case 150: + case 155: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1331 +//line sql.y:1403 { yyVAL.accountLimitItems = append(yyDollar[1].accountLimitItems, yyDollar[2].accountLimitItem) } - case 151: + case 156: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1337 +//line sql.y:1409 { yyVAL.accountLimitItem = AccountLimitItem{AccountLimitItemType: AccountLimitItemType_Queries_PH, Count: NewIntVal(yyDollar[2].bytes)} } - case 152: + case 157: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1341 +//line sql.y:1413 { yyVAL.accountLimitItem = AccountLimitItem{AccountLimitItemType: AccountLimitItemType_Updates_PH, Count: NewIntVal(yyDollar[2].bytes)} } - case 153: + case 158: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1345 +//line sql.y:1417 { yyVAL.accountLimitItem = AccountLimitItem{AccountLimitItemType: AccountLimitItemType_Connections_PH, Count: NewIntVal(yyDollar[2].bytes)} } - case 154: + case 159: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1349 +//line sql.y:1421 { yyVAL.accountLimitItem = AccountLimitItem{AccountLimitItemType: AccountLimitItemType_Connections, Count: NewIntVal(yyDollar[2].bytes)} } - case 155: + case 160: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1354 +//line sql.y:1426 { yyVAL.passLockItems = nil } - case 156: + case 161: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1358 +//line sql.y:1430 { yyVAL.passLockItems = yyDollar[1].passLockItems } - case 157: + case 162: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1364 +//line sql.y:1436 { yyVAL.passLockItems = []PassLockItem{yyDollar[1].passLockItem} } - case 158: + case 163: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1368 +//line sql.y:1440 { yyVAL.passLockItems = append(yyDollar[1].passLockItems, yyDollar[2].passLockItem) } - case 159: + case 164: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1374 +//line sql.y:1446 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassExpireDefault, Value: nil} } - case 160: + case 165: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1378 +//line sql.y:1450 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassExpireNever, Value: nil} } - case 161: + case 166: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1382 +//line sql.y:1454 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassExpireInterval, Value: NewIntVal(yyDollar[4].bytes)} } - case 162: + case 167: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1386 +//line sql.y:1458 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassHistory, Value: nil} } - case 163: + case 168: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1390 +//line sql.y:1462 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassHistory, Value: NewIntVal(yyDollar[3].bytes)} } - case 164: + case 169: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1394 +//line sql.y:1466 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassReuseInterval, Value: nil} } - case 165: + case 170: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1398 +//line sql.y:1470 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassReuseInterval, Value: NewIntVal(yyDollar[4].bytes)} } - case 166: + case 171: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1402 +//line sql.y:1474 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassReqCurrentDefault, Value: nil} } - case 167: + case 172: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1406 +//line sql.y:1478 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassReqCurrentOptional, Value: nil} } - case 168: + case 173: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1410 +//line sql.y:1482 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassFailedLogins, Value: NewIntVal(yyDollar[2].bytes)} } - case 169: + case 174: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1414 +//line sql.y:1486 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassLockTime, Value: NewIntVal(yyDollar[2].bytes)} } - case 170: + case 175: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1418 +//line sql.y:1490 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_PassLockTime, Value: nil} } - case 171: + case 176: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1422 +//line sql.y:1494 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_AccountLock, Value: nil} } - case 172: + case 177: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1426 +//line sql.y:1498 { yyVAL.passLockItem = PassLockItem{PassLockItemType: PassLockItemType_AccountUnlock, Value: nil} } - case 173: + case 178: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1431 +//line sql.y:1503 { yyVAL.str = "" } - case 174: + case 179: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1435 +//line sql.y:1507 { comment := string(yyDollar[2].bytes) yyVAL.str = `{"comment": "` + escapeDoubleQuotes(comment) + `"}` } - case 175: + case 180: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1440 +//line sql.y:1512 { yyVAL.str = string(yyDollar[2].bytes) } - case 176: + case 181: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:1446 +//line sql.y:1518 { allPriv := []Privilege{Privilege{Type: PrivilegeType_All, Columns: nil}} yyVAL.statement = &GrantPrivilege{Privileges: allPriv, ObjectType: yyDollar[4].grantObjectType, PrivilegeLevel: yyDollar[5].privilegeLevel, To: yyDollar[7].accountNames, WithGrantOption: yyDollar[8].boolean, As: yyDollar[9].grantAssumption} } - case 177: + case 182: yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:1451 +//line sql.y:1523 { allPriv := []Privilege{Privilege{Type: PrivilegeType_All, Columns: nil}} yyVAL.statement = &GrantPrivilege{Privileges: allPriv, ObjectType: yyDollar[5].grantObjectType, PrivilegeLevel: yyDollar[6].privilegeLevel, To: yyDollar[8].accountNames, WithGrantOption: yyDollar[9].boolean, As: yyDollar[10].grantAssumption} } - case 178: + case 183: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:1456 +//line sql.y:1528 { yyVAL.statement = &GrantPrivilege{Privileges: yyDollar[2].grantPrivileges, ObjectType: yyDollar[4].grantObjectType, PrivilegeLevel: yyDollar[5].privilegeLevel, To: yyDollar[7].accountNames, WithGrantOption: yyDollar[8].boolean, As: yyDollar[9].grantAssumption} } - case 179: + case 184: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1460 +//line sql.y:1532 { yyVAL.statement = &GrantRole{Roles: yyDollar[2].accountNames, To: yyDollar[4].accountNames, WithAdminOption: yyDollar[5].boolean} } - case 180: + case 185: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:1464 +//line sql.y:1536 { yyVAL.statement = &GrantProxy{On: yyDollar[4].accountName, To: yyDollar[6].accountNames, WithGrantOption: yyDollar[7].boolean} } - case 181: + case 186: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:1470 +//line sql.y:1542 { allPriv := []Privilege{Privilege{Type: PrivilegeType_All, Columns: nil}} yyVAL.statement = &RevokePrivilege{Privileges: allPriv, ObjectType: yyDollar[4].grantObjectType, PrivilegeLevel: yyDollar[5].privilegeLevel, From: yyDollar[7].accountNames} } - case 182: + case 187: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:1475 +//line sql.y:1547 { yyVAL.statement = &RevokePrivilege{Privileges: yyDollar[2].grantPrivileges, ObjectType: yyDollar[4].grantObjectType, PrivilegeLevel: yyDollar[5].privilegeLevel, From: yyDollar[7].accountNames} } - case 183: + case 188: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:1479 +//line sql.y:1551 { yyVAL.statement = &RevokeAllPrivileges{From: yyDollar[7].accountNames} } - case 184: + case 189: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:1483 +//line sql.y:1555 { yyVAL.statement = &RevokeAllPrivileges{From: yyDollar[8].accountNames} } - case 185: + case 190: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1487 +//line sql.y:1559 { yyVAL.statement = &RevokeRole{Roles: yyDollar[2].accountNames, From: yyDollar[4].accountNames} } - case 186: + case 191: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:1491 +//line sql.y:1563 { yyVAL.statement = &RevokeProxy{On: yyDollar[4].accountName, From: yyDollar[6].accountNames} } - case 187: + case 192: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1497 +//line sql.y:1569 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Alter, Columns: yyDollar[2].strs} } - case 188: + case 193: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1501 +//line sql.y:1573 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_AlterRoutine, Columns: yyDollar[3].strs} } - case 189: + case 194: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1505 +//line sql.y:1577 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Create, Columns: yyDollar[2].strs} } - case 190: + case 195: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1509 +//line sql.y:1581 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_CreateRole, Columns: yyDollar[3].strs} } - case 191: + case 196: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1513 +//line sql.y:1585 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_CreateRoutine, Columns: yyDollar[3].strs} } - case 192: + case 197: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1517 +//line sql.y:1589 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_CreateTablespace, Columns: yyDollar[3].strs} } - case 193: + case 198: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1521 +//line sql.y:1593 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_CreateTemporaryTables, Columns: yyDollar[4].strs} } - case 194: + case 199: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1525 +//line sql.y:1597 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_CreateUser, Columns: yyDollar[3].strs} } - case 195: + case 200: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1529 +//line sql.y:1601 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_CreateView, Columns: yyDollar[3].strs} } - case 196: + case 201: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1533 +//line sql.y:1605 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Delete, Columns: yyDollar[2].strs} } - case 197: + case 202: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1537 +//line sql.y:1609 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Drop, Columns: yyDollar[2].strs} } - case 198: + case 203: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1541 +//line sql.y:1613 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_DropRole, Columns: yyDollar[3].strs} } - case 199: + case 204: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1545 +//line sql.y:1617 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Event, Columns: yyDollar[2].strs} } - case 200: + case 205: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1549 +//line sql.y:1621 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Execute, Columns: yyDollar[2].strs} } - case 201: + case 206: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1553 +//line sql.y:1625 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_File, Columns: yyDollar[2].strs} } - case 202: + case 207: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1557 +//line sql.y:1629 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_GrantOption, Columns: yyDollar[3].strs} } - case 203: + case 208: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1561 +//line sql.y:1633 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Index, Columns: yyDollar[2].strs} } - case 204: + case 209: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1565 +//line sql.y:1637 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Insert, Columns: yyDollar[2].strs} } - case 205: + case 210: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1569 +//line sql.y:1641 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_LockTables, Columns: yyDollar[3].strs} } - case 206: + case 211: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1573 +//line sql.y:1645 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Process, Columns: yyDollar[2].strs} } - case 207: + case 212: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1577 +//line sql.y:1649 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_References, Columns: yyDollar[2].strs} } - case 208: + case 213: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1581 +//line sql.y:1653 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Reload, Columns: yyDollar[2].strs} } - case 209: + case 214: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1585 +//line sql.y:1657 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_ReplicationClient, Columns: yyDollar[3].strs} } - case 210: + case 215: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1589 +//line sql.y:1661 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_ReplicationSlave, Columns: yyDollar[3].strs} } - case 211: + case 216: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1593 +//line sql.y:1665 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Select, Columns: yyDollar[2].strs} } - case 212: + case 217: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1597 +//line sql.y:1669 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_ShowDatabases, Columns: yyDollar[3].strs} } - case 213: + case 218: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1601 +//line sql.y:1673 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_ShowView, Columns: yyDollar[3].strs} } - case 214: + case 219: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1605 +//line sql.y:1677 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Shutdown, Columns: yyDollar[2].strs} } - case 215: + case 220: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1609 +//line sql.y:1681 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Super, Columns: yyDollar[2].strs} } - case 216: + case 221: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1613 +//line sql.y:1685 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Trigger, Columns: yyDollar[2].strs} } - case 217: + case 222: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1617 +//line sql.y:1689 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Update, Columns: yyDollar[2].strs} } - case 218: + case 223: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1621 +//line sql.y:1693 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Usage, Columns: yyDollar[2].strs} } - case 219: + case 224: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1625 +//line sql.y:1697 { yyVAL.grantPrivilege = Privilege{Type: PrivilegeType_Dynamic, DynamicName: strings.ToLower(string(yyDollar[1].bytes))} } - case 220: + case 225: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1631 +//line sql.y:1703 { yyVAL.grantPrivileges = []Privilege{yyDollar[1].grantPrivilege} } - case 221: + case 226: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1635 +//line sql.y:1707 { yyVAL.grantPrivileges = append(yyDollar[1].grantPrivileges, yyDollar[3].grantPrivilege) } - case 261: + case 266: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1681 +//line sql.y:1753 { yyVAL.strs = nil } - case 262: + case 267: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1685 +//line sql.y:1757 { yyVAL.strs = yyDollar[2].strs } - case 263: + case 268: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1691 +//line sql.y:1763 { yyVAL.strs = []string{yyDollar[1].colIdent.String()} } - case 264: + case 269: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1695 +//line sql.y:1767 { yyVAL.strs = append(yyDollar[1].strs, yyDollar[3].colIdent.String()) } - case 265: + case 270: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1700 +//line sql.y:1772 { yyVAL.grantObjectType = GrantObjectType_Any } - case 266: + case 271: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1704 +//line sql.y:1776 { yyVAL.grantObjectType = GrantObjectType_Table } - case 267: + case 272: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1708 +//line sql.y:1780 { yyVAL.grantObjectType = GrantObjectType_Function } - case 268: + case 273: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1712 +//line sql.y:1784 { yyVAL.grantObjectType = GrantObjectType_Procedure } - case 269: + case 274: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1718 +//line sql.y:1790 { yyVAL.privilegeLevel = PrivilegeLevel{Database: "", TableRoutine: "*"} } - case 270: + case 275: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1722 +//line sql.y:1794 { yyVAL.privilegeLevel = PrivilegeLevel{Database: "*", TableRoutine: "*"} } - case 271: + case 276: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1726 +//line sql.y:1798 { yyVAL.privilegeLevel = PrivilegeLevel{Database: "", TableRoutine: yyDollar[1].colIdent.String()} } - case 272: + case 277: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1730 +//line sql.y:1802 { yyVAL.privilegeLevel = PrivilegeLevel{Database: yyDollar[1].colIdent.String(), TableRoutine: "*"} } - case 273: + case 278: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1734 +//line sql.y:1806 { yyVAL.privilegeLevel = PrivilegeLevel{Database: yyDollar[1].colIdent.String(), TableRoutine: yyDollar[3].colIdent.String()} } - case 274: + case 279: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1739 +//line sql.y:1811 { yyVAL.grantAssumption = nil } - case 275: + case 280: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1743 +//line sql.y:1815 { yyVAL.grantAssumption = &GrantUserAssumption{Type: GrantUserAssumptionType_Default, User: yyDollar[2].accountName, Roles: nil} } - case 276: + case 281: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1747 +//line sql.y:1819 { yyVAL.grantAssumption = &GrantUserAssumption{Type: GrantUserAssumptionType_Default, User: yyDollar[2].accountName, Roles: nil} } - case 277: + case 282: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1751 +//line sql.y:1823 { yyVAL.grantAssumption = &GrantUserAssumption{Type: GrantUserAssumptionType_None, User: yyDollar[2].accountName, Roles: nil} } - case 278: + case 283: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1755 +//line sql.y:1827 { yyVAL.grantAssumption = &GrantUserAssumption{Type: GrantUserAssumptionType_All, User: yyDollar[2].accountName, Roles: nil} } - case 279: + case 284: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:1759 +//line sql.y:1831 { yyVAL.grantAssumption = &GrantUserAssumption{Type: GrantUserAssumptionType_AllExcept, User: yyDollar[2].accountName, Roles: yyDollar[7].accountNames} } - case 280: + case 285: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1763 +//line sql.y:1835 { yyVAL.grantAssumption = &GrantUserAssumption{Type: GrantUserAssumptionType_Roles, User: yyDollar[2].accountName, Roles: yyDollar[5].accountNames} } - case 281: + case 286: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1768 +//line sql.y:1840 { yyVAL.boolean = false } - case 282: + case 287: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1772 +//line sql.y:1844 { yyVAL.boolean = true } - case 283: + case 288: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1777 +//line sql.y:1849 { yyVAL.boolean = false } - case 284: + case 289: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1781 +//line sql.y:1853 { yyVAL.boolean = true } - case 285: + case 290: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1788 +//line sql.y:1860 { if yyDollar[1].selStmt.GetInto() != nil { yylex.Error(fmt.Errorf("INTO clause is not allowed").Error()) @@ -13178,9 +14058,9 @@ yydefault: yyDollar[1].selStmt.SetLock(yyDollar[4].str) yyVAL.selStmt = yyDollar[1].selStmt } - case 286: + case 291: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1801 +//line sql.y:1873 { if yyDollar[1].selStmt.GetInto() != nil { yylex.Error(fmt.Errorf("INTO clause is not allowed").Error()) @@ -13191,153 +14071,153 @@ yydefault: yyDollar[1].selStmt.SetLock(yyDollar[4].str) yyVAL.selStmt = yyDollar[1].selStmt } - case 287: + case 292: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1813 +//line sql.y:1885 { yyVAL.procedureParams = nil } - case 288: + case 293: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1817 +//line sql.y:1889 { yyVAL.procedureParams = yyDollar[1].procedureParams } - case 289: + case 294: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1823 +//line sql.y:1895 { yyVAL.procedureParams = []ProcedureParam{yyDollar[1].procedureParam} } - case 290: + case 295: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1827 +//line sql.y:1899 { yyVAL.procedureParams = append(yyVAL.procedureParams, yyDollar[3].procedureParam) } - case 291: + case 296: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1833 +//line sql.y:1905 { yyVAL.procedureParam = ProcedureParam{Direction: ProcedureParamDirection_In, Name: yyDollar[1].colIdent.String(), Type: yyDollar[2].columnType} } - case 292: + case 297: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1837 +//line sql.y:1909 { yyVAL.procedureParam = ProcedureParam{Direction: ProcedureParamDirection_In, Name: yyDollar[2].colIdent.String(), Type: yyDollar[3].columnType} } - case 293: + case 298: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1841 +//line sql.y:1913 { yyVAL.procedureParam = ProcedureParam{Direction: ProcedureParamDirection_Inout, Name: yyDollar[2].colIdent.String(), Type: yyDollar[3].columnType} } - case 294: + case 299: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1845 +//line sql.y:1917 { yyVAL.procedureParam = ProcedureParam{Direction: ProcedureParamDirection_Out, Name: yyDollar[2].colIdent.String(), Type: yyDollar[3].columnType} } - case 295: + case 300: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1850 +//line sql.y:1922 { yyVAL.characteristics = nil } - case 296: + case 301: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1854 +//line sql.y:1926 { yyVAL.characteristics = yyDollar[1].characteristics } - case 297: + case 302: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1860 +//line sql.y:1932 { yyVAL.characteristics = []Characteristic{yyDollar[1].characteristic} } - case 298: + case 303: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1864 +//line sql.y:1936 { yyVAL.characteristics = append(yyVAL.characteristics, yyDollar[2].characteristic) } - case 299: + case 304: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1870 +//line sql.y:1942 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_Comment, Comment: string(yyDollar[2].bytes)} } - case 300: + case 305: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1874 +//line sql.y:1946 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_LanguageSql} } - case 301: + case 306: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1878 +//line sql.y:1950 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_NotDeterministic} } - case 302: + case 307: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1882 +//line sql.y:1954 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_Deterministic} } - case 303: + case 308: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1886 +//line sql.y:1958 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_ContainsSql} } - case 304: + case 309: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1890 +//line sql.y:1962 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_NoSql} } - case 305: + case 310: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1894 +//line sql.y:1966 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_ReadsSqlData} } - case 306: + case 311: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1898 +//line sql.y:1970 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_ModifiesSqlData} } - case 307: + case 312: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1902 +//line sql.y:1974 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_SqlSecurityDefiner} } - case 308: + case 313: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1906 +//line sql.y:1978 { yyVAL.characteristic = Characteristic{Type: CharacteristicValue_SqlSecurityInvoker} } - case 309: + case 314: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1912 +//line sql.y:1984 { yyVAL.statement = &BeginEndBlock{Label: ""} } - case 310: + case 315: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1916 +//line sql.y:1988 { yyVAL.statement = &BeginEndBlock{Label: string(yyDollar[1].bytes)} } - case 311: + case 316: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:1920 +//line sql.y:1992 { label := string(yyDollar[1].bytes) if label != string(yyDollar[5].bytes) { @@ -13346,21 +14226,21 @@ yydefault: } yyVAL.statement = &BeginEndBlock{Label: label} } - case 312: + case 317: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:1929 +//line sql.y:2001 { yyVAL.statement = &BeginEndBlock{Label: "", Statements: yyDollar[2].statements} } - case 313: + case 318: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:1933 +//line sql.y:2005 { yyVAL.statement = &BeginEndBlock{Label: string(yyDollar[1].bytes), Statements: yyDollar[4].statements} } - case 314: + case 319: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:1937 +//line sql.y:2009 { label := string(yyDollar[1].bytes) if label != string(yyDollar[7].bytes) { @@ -13369,87 +14249,87 @@ yydefault: } yyVAL.statement = &BeginEndBlock{Label: label, Statements: yyDollar[4].statements} } - case 315: + case 320: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:1948 +//line sql.y:2020 { yyVAL.viewSpec = &ViewSpec{Algorithm: "", Definer: yyDollar[1].str, Security: yyDollar[2].str} } - case 316: + case 321: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1952 +//line sql.y:2024 { yyVAL.viewSpec = &ViewSpec{Algorithm: yyDollar[1].str, Definer: yyDollar[2].str, Security: yyDollar[3].str} } - case 317: + case 322: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1958 +//line sql.y:2030 { yyVAL.str = string(yyDollar[3].bytes) } - case 318: + case 323: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1962 +//line sql.y:2034 { yyVAL.str = string(yyDollar[3].bytes) } - case 319: + case 324: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1966 +//line sql.y:2038 { yyVAL.str = string(yyDollar[3].bytes) } - case 320: + case 325: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1971 +//line sql.y:2043 { yyVAL.str = "" } - case 321: + case 326: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1975 +//line sql.y:2047 { yyVAL.str = yyDollar[3].accountName.String() } - case 322: + case 327: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:1980 +//line sql.y:2052 { yyVAL.str = "" } - case 323: + case 328: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1984 +//line sql.y:2056 { yyVAL.str = string(yyDollar[3].bytes) } - case 324: + case 329: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:1988 +//line sql.y:2060 { yyVAL.str = string(yyDollar[3].bytes) } - case 325: + case 330: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1994 +//line sql.y:2066 { yyVAL.str = string(yyDollar[1].bytes) } - case 326: + case 331: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:1998 +//line sql.y:2070 { yyVAL.str = string(yyDollar[1].bytes) } - case 327: + case 332: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2002 +//line sql.y:2074 { yyVAL.str = string(yyDollar[1].bytes) } - case 328: + case 333: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2008 +//line sql.y:2080 { anyHost := false if yyDollar[3].str == "%" { @@ -13457,33 +14337,33 @@ yydefault: } yyVAL.accountName = AccountName{Name: yyDollar[1].str, Host: yyDollar[3].str, AnyHost: anyHost} } - case 329: + case 334: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2016 +//line sql.y:2088 { yyVAL.accountName = AccountName{Name: yyDollar[1].str, Host: "", AnyHost: false} } - case 330: + case 335: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2020 +//line sql.y:2092 { yyVAL.accountName = AccountName{Name: yyDollar[1].str, Host: "", AnyHost: true} } - case 331: + case 336: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2026 +//line sql.y:2098 { yyVAL.accountNames = []AccountName{yyDollar[1].accountName} } - case 332: + case 337: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2030 +//line sql.y:2102 { yyVAL.accountNames = append(yyDollar[1].accountNames, yyDollar[3].accountName) } - case 333: + case 338: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2036 +//line sql.y:2108 { if len(yyDollar[1].str) == 0 { yylex.Error("the anonymous user is not a valid role name") @@ -13491,9 +14371,9 @@ yydefault: } yyVAL.accountName = AccountName{Name: yyDollar[1].str, Host: yyDollar[3].str, AnyHost: false} } - case 334: + case 339: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2044 +//line sql.y:2116 { if len(yyDollar[1].str) == 0 { yylex.Error("the anonymous user is not a valid role name") @@ -13501,9 +14381,9 @@ yydefault: } yyVAL.accountName = AccountName{Name: yyDollar[1].str, Host: "", AnyHost: false} } - case 335: + case 340: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2052 +//line sql.y:2124 { if len(yyDollar[1].str) == 0 { yylex.Error("the anonymous user is not a valid role name") @@ -13511,552 +14391,558 @@ yydefault: } yyVAL.accountName = AccountName{Name: yyDollar[1].str, Host: "", AnyHost: true} } - case 336: + case 341: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2062 +//line sql.y:2134 { yyVAL.accountNames = []AccountName{yyDollar[1].accountName} } - case 337: + case 342: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2066 +//line sql.y:2138 { yyVAL.accountNames = append(yyDollar[1].accountNames, yyDollar[3].accountName) } - case 338: + case 343: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2072 +//line sql.y:2144 { yyVAL.accountWithAuth = AccountWithAuth{AccountName: yyDollar[1].accountName} } - case 339: + case 344: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2076 +//line sql.y:2148 { yyVAL.accountWithAuth = AccountWithAuth{AccountName: yyDollar[1].accountName, Auth1: yyDollar[2].authentication} } - case 340: + case 345: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2080 +//line sql.y:2152 { yyVAL.accountWithAuth = AccountWithAuth{AccountName: yyDollar[1].accountName, Auth1: yyDollar[2].authentication, AuthInitial: yyDollar[5].authentication} } - case 341: + case 346: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2084 +//line sql.y:2156 { yyVAL.accountWithAuth = AccountWithAuth{AccountName: yyDollar[1].accountName, Auth1: yyDollar[2].authentication, Auth2: yyDollar[4].authentication} } - case 342: + case 347: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:2088 +//line sql.y:2160 { yyVAL.accountWithAuth = AccountWithAuth{AccountName: yyDollar[1].accountName, Auth1: yyDollar[2].authentication, Auth2: yyDollar[4].authentication, Auth3: yyDollar[6].authentication} } - case 343: + case 348: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2094 +//line sql.y:2166 { yyVAL.authentication = &Authentication{RandomPassword: true} } - case 344: + case 349: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2098 +//line sql.y:2170 { yyVAL.authentication = &Authentication{Password: string(yyDollar[3].bytes)} } - case 345: + case 350: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2102 +//line sql.y:2174 { yyVAL.authentication = &Authentication{Plugin: string(yyDollar[3].bytes)} } - case 346: + case 351: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:2106 +//line sql.y:2178 { yyVAL.authentication = &Authentication{Plugin: string(yyDollar[3].bytes), RandomPassword: true} } - case 347: + case 352: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2110 +//line sql.y:2182 { yyVAL.authentication = &Authentication{Plugin: string(yyDollar[3].bytes), Password: string(yyDollar[5].bytes)} } - case 348: + case 353: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2114 +//line sql.y:2186 { yyVAL.authentication = &Authentication{Plugin: string(yyDollar[3].bytes), Identity: string(yyDollar[5].bytes)} } - case 349: + case 354: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2120 +//line sql.y:2192 { yyVAL.authentication = &Authentication{RandomPassword: true} } - case 350: + case 355: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2124 +//line sql.y:2196 { yyVAL.authentication = &Authentication{Password: string(yyDollar[3].bytes)} } - case 351: + case 356: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2128 +//line sql.y:2200 { yyVAL.authentication = &Authentication{Plugin: string(yyDollar[3].bytes), Identity: string(yyDollar[5].bytes)} } - case 352: + case 357: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2134 +//line sql.y:2206 { yyVAL.accountsWithAuth = []AccountWithAuth{yyDollar[1].accountWithAuth} } - case 353: + case 358: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2138 +//line sql.y:2210 { yyVAL.accountsWithAuth = append(yyDollar[1].accountsWithAuth, yyDollar[3].accountWithAuth) } - case 354: + case 359: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2144 +//line sql.y:2216 { yyVAL.eventName = EventName{Name: yyDollar[1].colIdent} } - case 355: + case 360: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2148 +//line sql.y:2220 { yyVAL.eventName = EventName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].colIdent} } - case 356: + case 361: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2154 +//line sql.y:2226 { yyVAL.eventScheduleSpec = &EventScheduleSpec{At: &EventScheduleTimeSpec{EventTimestamp: yyDollar[2].expr, EventIntervals: yyDollar[3].intervalExprs}} } - case 357: + case 362: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2158 +//line sql.y:2230 { yyVAL.eventScheduleSpec = &EventScheduleSpec{EveryInterval: IntervalExpr{Expr: yyDollar[2].expr, Unit: string(yyDollar[3].bytes)}, Starts: yyDollar[4].eventScheduleTimeSpec, Ends: yyDollar[5].eventScheduleTimeSpec} } - case 358: + case 363: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2163 +//line sql.y:2235 { yyVAL.intervalExprs = []IntervalExpr{} } - case 359: + case 364: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2167 +//line sql.y:2239 { yyVAL.intervalExprs = append(yyDollar[1].intervalExprs, IntervalExpr{Expr: yyDollar[4].expr, Unit: string(yyDollar[5].bytes)}) } - case 360: + case 365: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2172 +//line sql.y:2244 { yyVAL.eventScheduleTimeSpec = nil } - case 361: + case 366: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2176 +//line sql.y:2248 { yyVAL.eventScheduleTimeSpec = &EventScheduleTimeSpec{EventTimestamp: yyDollar[2].expr, EventIntervals: yyDollar[3].intervalExprs} } - case 362: + case 367: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2181 +//line sql.y:2253 { yyVAL.eventScheduleTimeSpec = nil } - case 363: + case 368: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2185 +//line sql.y:2257 { yyVAL.eventScheduleTimeSpec = &EventScheduleTimeSpec{EventTimestamp: yyDollar[2].expr, EventIntervals: yyDollar[3].intervalExprs} } - case 364: + case 369: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2190 +//line sql.y:2262 { yyVAL.eventOnCompletion = EventOnCompletion_Undefined } - case 365: + case 370: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2194 +//line sql.y:2266 { yyVAL.eventOnCompletion = EventOnCompletion_Preserve } - case 366: + case 371: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2198 +//line sql.y:2270 { yyVAL.eventOnCompletion = EventOnCompletion_NotPreserve } - case 367: + case 372: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2203 +//line sql.y:2275 { yyVAL.eventStatus = EventStatus_Undefined } - case 368: + case 373: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2207 +//line sql.y:2279 { yyVAL.eventStatus = EventStatus_Enable } - case 369: + case 374: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2211 +//line sql.y:2283 { yyVAL.eventStatus = EventStatus_Disable } - case 370: + case 375: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2215 +//line sql.y:2287 { yyVAL.eventStatus = EventStatus_DisableOnSlave } - case 371: + case 376: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2220 +//line sql.y:2292 { yyVAL.sqlVal = nil } - case 372: + case 377: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2224 +//line sql.y:2296 { yyVAL.sqlVal = NewStrVal(yyDollar[2].bytes) } - case 373: + case 378: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2230 +//line sql.y:2302 { yyVAL.expr = yyDollar[1].expr } - case 374: + case 379: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2234 +//line sql.y:2306 { yyVAL.expr = yyDollar[1].expr } - case 375: + case 380: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2240 +//line sql.y:2312 { yyVAL.str = BeforeStr } - case 376: + case 381: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2244 +//line sql.y:2316 { yyVAL.str = AfterStr } - case 377: + case 382: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2250 +//line sql.y:2322 { yyVAL.str = InsertStr } - case 378: + case 383: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2254 +//line sql.y:2326 { yyVAL.str = UpdateStr } - case 379: + case 384: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2258 +//line sql.y:2330 { yyVAL.str = DeleteStr } - case 380: + case 385: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2263 +//line sql.y:2335 { yyVAL.triggerOrder = nil } - case 381: + case 386: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2267 +//line sql.y:2339 { yyVAL.triggerOrder = &TriggerOrder{PrecedesOrFollows: FollowsStr, OtherTriggerName: string(yyDollar[2].bytes)} } - case 382: + case 387: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2271 +//line sql.y:2343 { yyVAL.triggerOrder = &TriggerOrder{PrecedesOrFollows: PrecedesStr, OtherTriggerName: string(yyDollar[2].bytes)} } - case 383: + case 388: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2277 +//line sql.y:2349 { yyVAL.statement = yyDollar[1].statement } - case 389: + case 394: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2288 +//line sql.y:2360 { yyVAL.statement = &BeginEndBlock{Statements: yyDollar[2].statements} } - case 390: + case 395: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:2364 + { + yyVAL.statement = &BeginEndBlock{} + } + case 396: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2294 +//line sql.y:2370 { yyVAL.statement = &CaseStatement{Expr: yyDollar[2].expr, Cases: yyDollar[3].caseStatementCases} } - case 391: + case 397: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:2298 +//line sql.y:2374 { yyVAL.statement = &CaseStatement{Expr: yyDollar[2].expr, Cases: yyDollar[3].caseStatementCases, Else: yyDollar[5].statements} } - case 392: + case 398: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2302 +//line sql.y:2378 { yyVAL.statement = &CaseStatement{Expr: nil, Cases: yyDollar[2].caseStatementCases} } - case 393: + case 399: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:2306 +//line sql.y:2382 { yyVAL.statement = &CaseStatement{Expr: nil, Cases: yyDollar[2].caseStatementCases, Else: yyDollar[4].statements} } - case 394: + case 400: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2312 +//line sql.y:2388 { yyVAL.caseStatementCases = []CaseStatementCase{yyDollar[1].caseStatementCase} } - case 395: + case 401: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2316 +//line sql.y:2392 { yyVAL.caseStatementCases = append(yyVAL.caseStatementCases, yyDollar[2].caseStatementCase) } - case 396: + case 402: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2322 +//line sql.y:2398 { yyVAL.caseStatementCase = CaseStatementCase{Case: yyDollar[2].expr, Statements: yyDollar[4].statements} } - case 397: + case 403: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:2328 +//line sql.y:2404 { conds := []IfStatementCondition{IfStatementCondition{Expr: yyDollar[2].expr, Statements: yyDollar[4].statements}} yyVAL.statement = &IfStatement{Conditions: conds} } - case 398: + case 404: yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:2333 +//line sql.y:2409 { conds := []IfStatementCondition{IfStatementCondition{Expr: yyDollar[2].expr, Statements: yyDollar[4].statements}} yyVAL.statement = &IfStatement{Conditions: conds, Else: yyDollar[7].statements} } - case 399: + case 405: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:2338 +//line sql.y:2414 { conds := yyDollar[6].ifStatementConditions conds = append([]IfStatementCondition{IfStatementCondition{Expr: yyDollar[2].expr, Statements: yyDollar[4].statements}}, conds...) yyVAL.statement = &IfStatement{Conditions: conds} } - case 400: + case 406: yyDollar = yyS[yypt-11 : yypt+1] -//line sql.y:2344 +//line sql.y:2420 { conds := yyDollar[6].ifStatementConditions conds = append([]IfStatementCondition{IfStatementCondition{Expr: yyDollar[2].expr, Statements: yyDollar[4].statements}}, conds...) yyVAL.statement = &IfStatement{Conditions: conds, Else: yyDollar[8].statements} } - case 401: + case 407: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2352 +//line sql.y:2428 { yyVAL.ifStatementConditions = []IfStatementCondition{yyDollar[1].ifStatementCondition} } - case 402: + case 408: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2356 +//line sql.y:2432 { yyVAL.ifStatementConditions = append(yyVAL.ifStatementConditions, yyDollar[2].ifStatementCondition) } - case 403: + case 409: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2362 +//line sql.y:2438 { yyVAL.ifStatementCondition = IfStatementCondition{Expr: yyDollar[2].expr, Statements: yyDollar[4].statements} } - case 404: + case 410: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2368 +//line sql.y:2444 { yyVAL.statement = &Declare{Condition: &DeclareCondition{Name: string(yyDollar[2].bytes), SqlStateValue: string(yyDollar[5].bytes)}} } - case 405: + case 411: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2372 +//line sql.y:2448 { yyVAL.statement = &Declare{Condition: &DeclareCondition{Name: string(yyDollar[2].bytes), MysqlErrorCode: NewIntVal(yyDollar[5].bytes)}} } - case 406: + case 412: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2376 +//line sql.y:2452 { yyVAL.statement = &Declare{Cursor: &DeclareCursor{Name: string(yyDollar[2].bytes), SelectStmt: yyDollar[5].selStmt}} } - case 407: + case 413: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:2380 +//line sql.y:2456 { yyVAL.statement = &Declare{Handler: &DeclareHandler{Action: yyDollar[2].declareHandlerAction, ConditionValues: yyDollar[5].declareHandlerConditions, Statement: yyDollar[6].statement}} } - case 408: + case 414: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2384 +//line sql.y:2460 { yyDollar[3].columnType.Charset = yyDollar[4].str yyDollar[3].columnType.Collate = yyDollar[5].str yyVAL.statement = &Declare{Variables: &DeclareVariables{Names: yyDollar[2].colIdents, VarType: yyDollar[3].columnType}} } - case 409: + case 415: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:2390 +//line sql.y:2466 { yyDollar[3].columnType.Charset = yyDollar[4].str yyDollar[3].columnType.Collate = yyDollar[5].str yyDollar[3].columnType.Default = yyDollar[7].expr yyVAL.statement = &Declare{Variables: &DeclareVariables{Names: yyDollar[2].colIdents, VarType: yyDollar[3].columnType}} } - case 410: + case 416: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2399 +//line sql.y:2475 { yyVAL.declareHandlerAction = DeclareHandlerAction_Continue } - case 411: + case 417: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2403 +//line sql.y:2479 { yyVAL.declareHandlerAction = DeclareHandlerAction_Exit } - case 412: + case 418: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2407 +//line sql.y:2483 { yyVAL.declareHandlerAction = DeclareHandlerAction_Undo } - case 413: + case 419: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2413 +//line sql.y:2489 { yyVAL.declareHandlerConditions = []DeclareHandlerCondition{yyDollar[1].declareHandlerCondition} } - case 414: + case 420: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2417 +//line sql.y:2493 { yyVAL.declareHandlerConditions = append(yyVAL.declareHandlerConditions, yyDollar[3].declareHandlerCondition) } - case 415: + case 421: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2423 +//line sql.y:2499 { yyVAL.declareHandlerCondition = DeclareHandlerCondition{ValueType: DeclareHandlerCondition_MysqlErrorCode, MysqlErrorCode: NewIntVal(yyDollar[1].bytes)} } - case 416: + case 422: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2427 +//line sql.y:2503 { yyVAL.declareHandlerCondition = DeclareHandlerCondition{ValueType: DeclareHandlerCondition_SqlState, String: string(yyDollar[1].bytes)} } - case 417: + case 423: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2431 +//line sql.y:2507 { yyVAL.declareHandlerCondition = DeclareHandlerCondition{ValueType: DeclareHandlerCondition_SqlWarning} } - case 418: + case 424: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2435 +//line sql.y:2511 { yyVAL.declareHandlerCondition = DeclareHandlerCondition{ValueType: DeclareHandlerCondition_NotFound} } - case 419: + case 425: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2439 +//line sql.y:2515 { yyVAL.declareHandlerCondition = DeclareHandlerCondition{ValueType: DeclareHandlerCondition_SqlException} } - case 420: + case 426: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2443 +//line sql.y:2519 { yyVAL.declareHandlerCondition = DeclareHandlerCondition{ValueType: DeclareHandlerCondition_ConditionName, String: string(yyDollar[1].bytes)} } - case 421: + case 427: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2449 +//line sql.y:2525 { yyVAL.statement = &OpenCursor{Name: string(yyDollar[2].bytes)} } - case 422: + case 428: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2455 +//line sql.y:2531 { yyVAL.statement = &CloseCursor{Name: string(yyDollar[2].bytes)} } - case 423: + case 429: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2461 +//line sql.y:2537 { yyVAL.statement = &FetchCursor{Name: string(yyDollar[3].bytes), Variables: yyDollar[5].strs} } - case 424: + case 430: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2466 +//line sql.y:2542 { } - case 426: + case 432: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2469 +//line sql.y:2545 { } - case 427: + case 433: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2473 +//line sql.y:2549 { yyVAL.strs = []string{string(yyDollar[1].bytes)} } - case 428: + case 434: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2477 +//line sql.y:2553 { yyVAL.strs = append(yyVAL.strs, string(yyDollar[3].bytes)) } - case 429: + case 435: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2483 +//line sql.y:2559 { yyVAL.statement = &Loop{Label: "", Statements: yyDollar[2].statements} } - case 430: + case 436: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:2487 +//line sql.y:2563 { yyVAL.statement = &Loop{Label: string(yyDollar[1].bytes), Statements: yyDollar[4].statements} } - case 431: + case 437: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:2491 +//line sql.y:2567 { label := string(yyDollar[1].bytes) if label != string(yyDollar[8].bytes) { @@ -14065,21 +14951,21 @@ yydefault: } yyVAL.statement = &Loop{Label: label, Statements: yyDollar[4].statements} } - case 432: + case 438: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:2502 +//line sql.y:2578 { yyVAL.statement = &Repeat{Label: "", Statements: yyDollar[2].statements, Condition: yyDollar[5].expr} } - case 433: + case 439: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:2506 +//line sql.y:2582 { yyVAL.statement = &Repeat{Label: string(yyDollar[1].bytes), Statements: yyDollar[4].statements, Condition: yyDollar[7].expr} } - case 434: + case 440: yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:2510 +//line sql.y:2586 { label := string(yyDollar[1].bytes) if label != string(yyDollar[10].bytes) { @@ -14088,21 +14974,21 @@ yydefault: } yyVAL.statement = &Repeat{Label: label, Statements: yyDollar[4].statements, Condition: yyDollar[7].expr} } - case 435: + case 441: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:2521 +//line sql.y:2597 { yyVAL.statement = &While{Label: "", Condition: yyDollar[2].expr, Statements: yyDollar[4].statements} } - case 436: + case 442: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:2525 +//line sql.y:2601 { yyVAL.statement = &While{Label: string(yyDollar[1].bytes), Condition: yyDollar[4].expr, Statements: yyDollar[6].statements} } - case 437: + case 443: yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:2529 +//line sql.y:2605 { label := string(yyDollar[1].bytes) if label != string(yyDollar[10].bytes) { @@ -14111,237 +14997,237 @@ yydefault: } yyVAL.statement = &While{Label: label, Condition: yyDollar[4].expr, Statements: yyDollar[6].statements} } - case 438: + case 444: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2540 +//line sql.y:2616 { yyVAL.statement = &Leave{Label: string(yyDollar[2].bytes)} } - case 439: + case 445: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2546 +//line sql.y:2622 { yyVAL.statement = &Iterate{Label: string(yyDollar[2].bytes)} } - case 440: + case 446: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2552 +//line sql.y:2628 { yyVAL.statement = &Return{Expr: yyDollar[2].expr} } - case 441: + case 447: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2558 +//line sql.y:2634 { yyVAL.statement = &Signal{SqlStateValue: string(yyDollar[2].bytes)} } - case 442: + case 448: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2562 +//line sql.y:2638 { yyVAL.statement = &Signal{SqlStateValue: string(yyDollar[2].bytes), Info: yyDollar[4].signalInfos} } - case 443: + case 449: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2566 +//line sql.y:2642 { yyVAL.statement = &Signal{ConditionName: string(yyDollar[2].bytes)} } - case 444: + case 450: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2570 +//line sql.y:2646 { yyVAL.statement = &Signal{ConditionName: string(yyDollar[2].bytes), Info: yyDollar[4].signalInfos} } - case 445: + case 451: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2576 +//line sql.y:2652 { yyVAL.bytes = yyDollar[2].bytes } - case 446: + case 452: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2580 +//line sql.y:2656 { yyVAL.bytes = yyDollar[3].bytes } - case 447: + case 453: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2586 +//line sql.y:2662 { yyVAL.signalInfos = []SignalInfo{yyDollar[1].signalInfo} } - case 448: + case 454: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2590 +//line sql.y:2666 { yyVAL.signalInfos = append(yyVAL.signalInfos, yyDollar[3].signalInfo) } - case 449: + case 455: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2596 +//line sql.y:2672 { yyVAL.signalInfo = SignalInfo{ConditionItemName: yyDollar[1].signalConditionItemName, Value: yyDollar[3].expr.(*SQLVal)} } - case 450: + case 456: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2600 +//line sql.y:2676 { yyVAL.signalInfo = SignalInfo{ConditionItemName: yyDollar[1].signalConditionItemName, Value: &ColName{Name: yyDollar[3].colIdent}} } - case 451: + case 457: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2606 +//line sql.y:2682 { yyVAL.signalConditionItemName = SignalConditionItemName_ClassOrigin } - case 452: + case 458: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2610 +//line sql.y:2686 { yyVAL.signalConditionItemName = SignalConditionItemName_SubclassOrigin } - case 453: + case 459: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2614 +//line sql.y:2690 { yyVAL.signalConditionItemName = SignalConditionItemName_MessageText } - case 454: + case 460: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2618 +//line sql.y:2694 { yyVAL.signalConditionItemName = SignalConditionItemName_MysqlErrno } - case 455: + case 461: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2622 +//line sql.y:2698 { yyVAL.signalConditionItemName = SignalConditionItemName_ConstraintCatalog } - case 456: + case 462: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2626 +//line sql.y:2702 { yyVAL.signalConditionItemName = SignalConditionItemName_ConstraintSchema } - case 457: + case 463: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2630 +//line sql.y:2706 { yyVAL.signalConditionItemName = SignalConditionItemName_ConstraintName } - case 458: + case 464: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2634 +//line sql.y:2710 { yyVAL.signalConditionItemName = SignalConditionItemName_CatalogName } - case 459: + case 465: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2638 +//line sql.y:2714 { yyVAL.signalConditionItemName = SignalConditionItemName_SchemaName } - case 460: + case 466: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2642 +//line sql.y:2718 { yyVAL.signalConditionItemName = SignalConditionItemName_TableName } - case 461: + case 467: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2646 +//line sql.y:2722 { yyVAL.signalConditionItemName = SignalConditionItemName_ColumnName } - case 462: + case 468: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2650 +//line sql.y:2726 { yyVAL.signalConditionItemName = SignalConditionItemName_CursorName } - case 463: + case 469: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2656 +//line sql.y:2732 { yyVAL.statement = &Resignal{} } - case 464: + case 470: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2660 +//line sql.y:2736 { yyVAL.statement = &Resignal{Signal{SqlStateValue: string(yyDollar[2].bytes)}} } - case 465: + case 471: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2664 +//line sql.y:2740 { yyVAL.statement = &Resignal{Signal{SqlStateValue: string(yyDollar[2].bytes), Info: yyDollar[4].signalInfos}} } - case 466: + case 472: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2668 +//line sql.y:2744 { yyVAL.statement = &Resignal{Signal{Info: yyDollar[3].signalInfos}} } - case 467: + case 473: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2672 +//line sql.y:2748 { yyVAL.statement = &Resignal{Signal{ConditionName: string(yyDollar[2].bytes)}} } - case 468: + case 474: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2676 +//line sql.y:2752 { yyVAL.statement = &Resignal{Signal{ConditionName: string(yyDollar[2].bytes), Info: yyDollar[4].signalInfos}} } - case 469: + case 475: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2682 +//line sql.y:2758 { yyVAL.statement = &Call{ProcName: yyDollar[2].procedureName, Params: yyDollar[3].exprs, AsOf: yyDollar[4].expr} } - case 470: + case 476: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2687 +//line sql.y:2763 { yyVAL.exprs = nil } - case 471: + case 477: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2691 +//line sql.y:2767 { yyVAL.exprs = nil } - case 472: + case 478: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2695 +//line sql.y:2771 { yyVAL.exprs = yyDollar[2].exprs } - case 473: + case 479: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2701 +//line sql.y:2777 { yyVAL.statements = Statements{yyDollar[1].statement} } - case 474: + case 480: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2705 +//line sql.y:2781 { yyVAL.statements = append(yyVAL.statements, yyDollar[3].statement) } - case 475: + case 481: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2711 +//line sql.y:2787 { yyVAL.statement = yyDollar[1].selStmt } - case 517: + case 523: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2758 +//line sql.y:2834 { var ne bool if yyDollar[4].byt != 0 { @@ -14355,9 +15241,9 @@ yydefault: yyVAL.ddl = &DDL{Action: CreateStr, Table: yyDollar[5].tableName, IfNotExists: ne, Temporary: neTemp} } - case 518: + case 524: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2772 +//line sql.y:2848 { var ne bool if yyDollar[4].byt != 0 { @@ -14371,69 +15257,57 @@ yydefault: yyVAL.ddl = &DDL{Action: CreateStr, Table: TableName{Name: NewTableIdent(string(yyDollar[5].bytes))}, IfNotExists: ne, Temporary: neTemp} } - case 519: + case 525: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:2788 +//line sql.y:2864 { yyVAL.TableSpec = yyDollar[2].TableSpec - yyVAL.TableSpec.Options = yyDollar[4].str + yyDollar[5].str + for _, opt := range yyDollar[4].tableOptions { + yyVAL.TableSpec.AddTableOption(opt) + } + yyVAL.TableSpec.PartitionOpt = yyDollar[5].partOption } - case 520: + case 526: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2795 +//line sql.y:2874 { yyVAL.TableSpec = &TableSpec{} yyVAL.TableSpec.AddColumn(yyDollar[1].columnDefinition) } - case 521: + case 527: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2800 +//line sql.y:2879 { yyVAL.TableSpec = &TableSpec{} yyVAL.TableSpec.AddConstraint(yyDollar[1].constraintDefinition) } - case 522: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2805 - { - yyVAL.TableSpec = &TableSpec{} - yyVAL.TableSpec.AddColumn(yyDollar[1].columnDefinition) - yyVAL.TableSpec.AddConstraint(yyDollar[2].constraintDefinition) - } - case 523: + case 528: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2811 - { - yyVAL.TableSpec.AddColumn(yyDollar[3].columnDefinition) - } - case 524: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:2815 +//line sql.y:2884 { yyVAL.TableSpec.AddColumn(yyDollar[3].columnDefinition) - yyVAL.TableSpec.AddConstraint(yyDollar[4].constraintDefinition) } - case 525: + case 529: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2820 +//line sql.y:2888 { yyVAL.TableSpec.AddIndex(yyDollar[3].indexDefinition) } - case 526: + case 530: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2824 +//line sql.y:2892 { yyVAL.TableSpec.AddConstraint(yyDollar[3].constraintDefinition) } - case 527: + case 531: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2828 +//line sql.y:2896 { yyVAL.TableSpec.AddConstraint(yyDollar[3].constraintDefinition) } - case 528: + case 532: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2834 +//line sql.y:2902 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14441,9 +15315,9 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} } - case 529: + case 533: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2842 +//line sql.y:2910 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14451,9 +15325,9 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} } - case 530: + case 534: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2852 +//line sql.y:2920 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14461,9 +15335,9 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: yyDollar[1].colIdent, Type: yyDollar[2].columnType} } - case 531: + case 535: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2860 +//line sql.y:2928 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14471,9 +15345,9 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} } - case 532: + case 536: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2868 +//line sql.y:2936 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14481,9 +15355,9 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} } - case 533: + case 537: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2876 +//line sql.y:2944 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14491,9 +15365,9 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} } - case 534: + case 538: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2884 +//line sql.y:2952 { if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { yylex.Error(err.Error()) @@ -14501,39 +15375,49 @@ yydefault: } yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} } - case 535: + case 539: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:2960 + { + if err := yyDollar[2].columnType.merge(yyDollar[3].columnType); err != nil { + yylex.Error(err.Error()) + return 1 + } + yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType} + } + case 540: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2893 +//line sql.y:2969 { yyVAL.boolVal = BoolVal(false) } - case 536: + case 541: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2897 +//line sql.y:2973 { yyVAL.boolVal = BoolVal(false) } - case 537: + case 542: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:2901 +//line sql.y:2977 { yyVAL.boolVal = BoolVal(true) } - case 538: + case 543: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:2906 +//line sql.y:2982 { yyVAL.columnType = ColumnType{} } - case 539: + case 544: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2910 +//line sql.y:2986 { yyVAL.columnType = yyDollar[1].columnType } - case 540: + case 545: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2914 +//line sql.y:2990 { opt := ColumnType{Null: BoolVal(true), NotNull: BoolVal(false), sawnull: true} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14542,9 +15426,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 541: + case 546: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:2923 +//line sql.y:2999 { opt := ColumnType{Null: BoolVal(false), NotNull: BoolVal(true), sawnull: true} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14553,9 +15437,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 542: + case 547: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2932 +//line sql.y:3008 { opt := ColumnType{Charset: yyDollar[2].str} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14564,9 +15448,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 543: + case 548: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2941 +//line sql.y:3017 { opt := ColumnType{Collate: yyDollar[2].str} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14575,9 +15459,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 544: + case 549: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2950 +//line sql.y:3026 { opt := ColumnType{BinaryCollate: true} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14586,9 +15470,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 545: + case 550: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2959 +//line sql.y:3035 { opt := ColumnType{Default: yyDollar[2].optVal} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14597,9 +15481,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 546: + case 551: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2968 +//line sql.y:3044 { opt := ColumnType{OnUpdate: yyDollar[2].optVal} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14608,9 +15492,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 547: + case 552: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2977 +//line sql.y:3053 { opt := ColumnType{Autoincrement: yyDollar[2].boolVal, sawai: true} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14619,9 +15503,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 548: + case 553: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2986 +//line sql.y:3062 { opt := ColumnType{KeyOpt: yyDollar[2].colKeyOpt} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14630,9 +15514,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 549: + case 554: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:2995 +//line sql.y:3071 { opt := ColumnType{Comment: yyDollar[2].sqlVal} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14641,9 +15525,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 550: + case 555: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:3004 +//line sql.y:3080 { opt := ColumnType{GeneratedExpr: &ParenExpr{yyDollar[4].expr}, Stored: yyDollar[6].boolVal} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14652,9 +15536,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 551: + case 556: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:3013 +//line sql.y:3089 { opt := ColumnType{GeneratedExpr: &ParenExpr{yyDollar[6].expr}, Stored: yyDollar[8].boolVal} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14663,9 +15547,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 552: + case 557: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3022 +//line sql.y:3098 { opt := ColumnType{SRID: NewIntVal(yyDollar[3].bytes)} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14674,9 +15558,9 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 553: + case 558: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:3032 +//line sql.y:3108 { opt := ColumnType{ForeignKeyDef: &ForeignKeyDefinition{ReferencedTable: yyDollar[3].tableName, ReferencedColumns: yyDollar[5].columns}} if err := yyDollar[1].columnType.merge(opt); err != nil { @@ -14685,553 +15569,546 @@ yydefault: } yyVAL.columnType = yyDollar[1].columnType } - case 554: + case 559: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3117 + { + opt := ColumnType{Constraint: yyDollar[2].constraintDefinition} + if err := yyDollar[1].columnType.merge(opt); err != nil { + yylex.Error(err.Error()) + return 1 + } + yyVAL.columnType = yyDollar[1].columnType + } + case 560: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3043 +//line sql.y:3128 { yyVAL.columnType = yyDollar[1].columnType yyVAL.columnType.Unsigned = yyDollar[2].boolVal yyVAL.columnType.Zerofill = yyDollar[3].boolVal } - case 558: + case 564: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3054 +//line sql.y:3139 { yyVAL.columnType = yyDollar[1].columnType yyVAL.columnType.Length = yyDollar[2].sqlVal } - case 559: + case 565: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3059 +//line sql.y:3144 { yyVAL.columnType = yyDollar[1].columnType } - case 560: + case 566: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3065 +//line sql.y:3150 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 561: + case 567: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3069 +//line sql.y:3154 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 562: + case 568: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3073 +//line sql.y:3158 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 563: + case 569: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3077 +//line sql.y:3162 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 564: + case 570: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3081 +//line sql.y:3166 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 565: + case 571: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3085 +//line sql.y:3170 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 566: + case 572: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3089 +//line sql.y:3174 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 567: + case 573: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3093 +//line sql.y:3178 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 568: + case 574: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3097 +//line sql.y:3182 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 569: + case 575: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3101 +//line sql.y:3186 { yyVAL.columnType = ColumnType{Type: "bigint", Unsigned: true, NotNull: true, Autoincrement: true, KeyOpt: colKeyUnique} } - case 570: + case 576: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3105 +//line sql.y:3190 { yyVAL.columnType = ColumnType{Type: "tinyint"} } - case 571: + case 577: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3109 +//line sql.y:3194 { yyVAL.columnType = ColumnType{Type: "smallint"} } - case 572: + case 578: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3113 +//line sql.y:3198 { yyVAL.columnType = ColumnType{Type: "mediumint"} } - case 573: + case 579: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3117 +//line sql.y:3202 { yyVAL.columnType = ColumnType{Type: "int"} } - case 574: + case 580: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3121 +//line sql.y:3206 { yyVAL.columnType = ColumnType{Type: "bigint"} } - case 575: + case 581: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3127 +//line sql.y:3212 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 576: + case 582: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3133 +//line sql.y:3218 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 577: + case 583: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3139 +//line sql.y:3224 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} yyVAL.columnType.Length = yyDollar[3].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[3].LengthScaleOption.Scale } - case 578: + case 584: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3145 +//line sql.y:3230 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 579: + case 585: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3151 +//line sql.y:3236 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 580: + case 586: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3157 +//line sql.y:3242 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 581: + case 587: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3163 +//line sql.y:3248 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 582: + case 588: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3169 +//line sql.y:3254 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 583: + case 589: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3177 +//line sql.y:3262 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 584: + case 590: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3181 +//line sql.y:3266 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 585: + case 591: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3185 +//line sql.y:3270 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 586: + case 592: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3189 +//line sql.y:3274 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 587: + case 593: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3193 +//line sql.y:3278 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 588: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3199 - { - yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} - } - case 589: + case 594: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3203 +//line sql.y:3284 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 590: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3207 - { - yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} - } - case 591: + case 595: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3211 +//line sql.y:3288 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} } - case 592: + case 596: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3215 +//line sql.y:3292 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 593: + case 597: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3219 +//line sql.y:3296 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} } - case 594: + case 598: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3223 +//line sql.y:3300 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} } - case 595: + case 599: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3227 +//line sql.y:3304 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 596: + case 600: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3231 +//line sql.y:3308 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} } - case 597: + case 601: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3235 +//line sql.y:3312 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} } - case 598: + case 602: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3239 +//line sql.y:3316 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 599: + case 603: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3243 +//line sql.y:3320 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Length: yyDollar[3].sqlVal} } - case 600: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3247 - { - yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Length: yyDollar[4].sqlVal} - } - case 601: + case 604: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3251 +//line sql.y:3324 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Length: yyDollar[4].sqlVal} } - case 602: + case 605: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3255 +//line sql.y:3328 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 603: + case 606: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3259 +//line sql.y:3332 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 604: + case 607: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3263 +//line sql.y:3336 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 605: + case 608: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3267 +//line sql.y:3340 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 606: + case 609: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3271 +//line sql.y:3344 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 607: + case 610: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3275 +//line sql.y:3348 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 608: + case 611: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3279 +//line sql.y:3352 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 609: + case 612: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3283 +//line sql.y:3356 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} } - case 610: + case 613: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3287 +//line sql.y:3360 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 611: + case 614: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3291 +//line sql.y:3364 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 612: + case 615: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3295 +//line sql.y:3368 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 613: + case 616: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3299 +//line sql.y:3372 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 614: + case 617: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3303 +//line sql.y:3376 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 615: + case 618: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3307 +//line sql.y:3380 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), EnumValues: yyDollar[3].strs} } - case 616: + case 619: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3312 +//line sql.y:3385 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), EnumValues: yyDollar[3].strs} } - case 617: + case 620: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3318 +//line sql.y:3391 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 618: + case 621: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3322 +//line sql.y:3395 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 619: + case 622: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3326 +//line sql.y:3399 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 620: + case 623: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3330 +//line sql.y:3403 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 621: + case 624: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3334 +//line sql.y:3407 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 622: + case 625: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3338 +//line sql.y:3411 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 623: + case 626: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3342 +//line sql.y:3415 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 624: + case 627: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3346 +//line sql.y:3419 { yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)} } - case 625: + case 628: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3352 +//line sql.y:3425 { yyVAL.strs = make([]string, 0, 4) yyVAL.strs = append(yyVAL.strs, string(yyDollar[1].bytes)) } - case 626: + case 629: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3357 +//line sql.y:3430 { yyVAL.strs = append(yyDollar[1].strs, string(yyDollar[3].bytes)) } - case 627: + case 630: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3362 +//line sql.y:3435 { yyVAL.sqlVal = nil } - case 628: + case 631: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3366 +//line sql.y:3439 { yyVAL.sqlVal = NewIntVal(yyDollar[2].bytes) } - case 629: + case 632: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3371 +//line sql.y:3444 { yyVAL.sqlVal = nil } - case 630: + case 633: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3375 +//line sql.y:3448 { yyVAL.sqlVal = NewIntVal(yyDollar[2].bytes) } - case 631: + case 634: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3379 +//line sql.y:3452 { yyVAL.sqlVal = NewValArg(yyDollar[2].bytes) } - case 632: + case 635: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3384 +//line sql.y:3457 { yyVAL.LengthScaleOption = LengthScaleOption{} } - case 633: + case 636: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3388 +//line sql.y:3461 { yyVAL.LengthScaleOption = LengthScaleOption{ Length: NewIntVal(yyDollar[2].bytes), Scale: NewIntVal(yyDollar[4].bytes), } } - case 634: + case 637: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3396 +//line sql.y:3469 { yyVAL.LengthScaleOption = LengthScaleOption{} } - case 635: + case 638: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3400 +//line sql.y:3473 { yyVAL.LengthScaleOption = LengthScaleOption{ Length: NewIntVal(yyDollar[2].bytes), } } - case 636: + case 639: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3406 +//line sql.y:3479 { yyVAL.LengthScaleOption = LengthScaleOption{ Length: NewIntVal(yyDollar[2].bytes), Scale: NewIntVal(yyDollar[4].bytes), } } - case 637: + case 640: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3414 +//line sql.y:3487 { yyVAL.boolVal = BoolVal(false) } - case 638: + case 641: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3418 +//line sql.y:3491 { yyVAL.boolVal = BoolVal(false) } - case 639: + case 642: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3422 +//line sql.y:3495 { yyVAL.boolVal = BoolVal(true) } - case 640: + case 643: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3427 +//line sql.y:3500 { yyVAL.boolVal = BoolVal(false) } - case 641: + case 644: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3431 +//line sql.y:3504 { yyVAL.boolVal = BoolVal(true) } - case 642: + case 645: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3437 +//line sql.y:3510 { yyVAL.optVal = yyDollar[2].expr } - case 643: + case 646: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3441 +//line sql.y:3514 { if num, ok := yyDollar[3].expr.(*SQLVal); ok && num.Type == IntVal { // Handle double negative @@ -15245,646 +16122,652 @@ yydefault: yyVAL.optVal = &UnaryExpr{Operator: UMinusStr, Expr: yyDollar[3].expr} } } - case 644: + case 647: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3455 +//line sql.y:3528 { yyVAL.optVal = &UnaryExpr{Operator: yyDollar[2].str, Expr: NewStrVal(yyDollar[3].bytes)} } - case 645: + case 648: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3459 +//line sql.y:3532 { yyVAL.optVal = yyDollar[2].boolVal } - case 646: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3463 - { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes))} - } - case 647: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3467 - { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes)), Exprs: yyDollar[4].selectExprs} - } - case 648: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3471 - { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes))} - } case 649: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3475 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3536 { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes)), Exprs: yyDollar[4].selectExprs} + yyVAL.optVal = yyDollar[2].expr } case 650: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3479 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:3540 { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes))} + yyVAL.optVal = &ParenExpr{yyDollar[3].expr} } case 651: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3483 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3546 { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes)), Exprs: yyDollar[4].selectExprs} + yyVAL.optVal = yyDollar[3].expr } case 652: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3487 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3552 { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes))} + yyVAL.boolVal = BoolVal(true) } case 653: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3491 + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:3557 { - yyVAL.optVal = &FuncExpr{Name: NewColIdent(string(yyDollar[2].bytes)), Exprs: yyDollar[4].selectExprs} + yyVAL.str = "" } case 654: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3495 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3561 { - yyVAL.optVal = &ParenExpr{yyDollar[3].expr} + yyVAL.str = yyDollar[1].str } case 655: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3501 +//line sql.y:3567 { - yyVAL.optVal = yyDollar[3].expr + yyVAL.str = string(yyDollar[3].bytes) } case 656: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3507 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3571 { - yyVAL.boolVal = BoolVal(true) + yyVAL.str = string(yyDollar[3].bytes) } case 657: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3512 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3575 { - yyVAL.str = "" + yyVAL.str = string(yyDollar[2].bytes) } case 658: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3516 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3579 { - yyVAL.str = yyDollar[1].str + yyVAL.str = string(yyDollar[2].bytes) } case 659: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3522 + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:3585 { - yyVAL.str = string(yyDollar[3].bytes) + yyVAL.str = "" } case 660: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3526 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3589 { - yyVAL.str = string(yyDollar[3].bytes) + yyVAL.str = yyDollar[1].str } case 661: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3531 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3595 { - yyVAL.str = "" + yyVAL.str = string(yyDollar[2].bytes) } case 662: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3535 - { - yyVAL.str = yyDollar[1].str - } - case 663: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3541 +//line sql.y:3599 { yyVAL.str = string(yyDollar[2].bytes) } - case 664: + case 663: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3545 +//line sql.y:3603 { yyVAL.str = string(yyDollar[2].bytes) } - case 665: + case 664: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3550 +//line sql.y:3608 { yyVAL.boolean = false } - case 666: + case 665: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3554 +//line sql.y:3612 { yyVAL.boolean = true } - case 667: + case 666: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3559 +//line sql.y:3617 { yyVAL.charsetCollates = nil } - case 668: + case 667: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3563 +//line sql.y:3621 { yyVAL.charsetCollates = yyDollar[1].charsetCollates } + case 668: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3627 + { + yyVAL.charsetCollates = []*CharsetAndCollate{yyDollar[1].charsetCollate} + } case 669: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3569 +//line sql.y:3631 { yyVAL.charsetCollates = []*CharsetAndCollate{yyDollar[1].charsetCollate} } case 670: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3573 +//line sql.y:3635 { yyVAL.charsetCollates = []*CharsetAndCollate{yyDollar[1].charsetCollate} } case 671: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3577 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3639 { - yyVAL.charsetCollates = []*CharsetAndCollate{yyDollar[1].charsetCollate} + yyVAL.charsetCollates = append(yyDollar[1].charsetCollates, yyDollar[2].charsetCollate) } case 672: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3581 +//line sql.y:3643 { yyVAL.charsetCollates = append(yyDollar[1].charsetCollates, yyDollar[2].charsetCollate) } case 673: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3585 +//line sql.y:3647 { yyVAL.charsetCollates = append(yyDollar[1].charsetCollates, yyDollar[2].charsetCollate) } case 674: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3589 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:3653 { - yyVAL.charsetCollates = append(yyDollar[1].charsetCollates, yyDollar[2].charsetCollate) + yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Value: string(yyDollar[5].bytes), IsDefault: yyDollar[1].boolean} } case 675: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3595 +//line sql.y:3657 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Value: string(yyDollar[5].bytes), IsDefault: yyDollar[1].boolean} } case 676: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3599 +//line sql.y:3661 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Value: string(yyDollar[5].bytes), IsDefault: yyDollar[1].boolean} } case 677: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3603 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:3665 { - yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Value: string(yyDollar[5].bytes), IsDefault: yyDollar[1].boolean} + yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 678: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3607 +//line sql.y:3669 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 679: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3611 +//line sql.y:3673 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 680: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3615 +//line sql.y:3679 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 681: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3621 +//line sql.y:3683 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 682: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3625 +//line sql.y:3687 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 683: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3629 +//line sql.y:3693 { yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} } case 684: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3635 - { - yyVAL.charsetCollate = &CharsetAndCollate{Type: string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes), IsDefault: yyDollar[1].boolean} - } - case 685: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3641 +//line sql.y:3699 { yyVAL.colKeyOpt = colKeyPrimary } - case 686: + case 685: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3645 +//line sql.y:3703 { yyVAL.colKeyOpt = colKey } - case 687: + case 686: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3649 +//line sql.y:3707 { yyVAL.colKeyOpt = colKeyUniqueKey } - case 688: + case 687: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3653 +//line sql.y:3711 { yyVAL.colKeyOpt = colKeyUnique } - case 689: + case 688: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3657 +//line sql.y:3715 { yyVAL.colKeyOpt = colKeyFulltextKey } - case 690: + case 689: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3663 +//line sql.y:3721 { yyVAL.sqlVal = NewStrVal(yyDollar[2].bytes) } - case 691: + case 690: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3669 +//line sql.y:3727 { yyVAL.statement = &Flush{Type: yyDollar[2].str, Option: yyDollar[3].flushOption} } + case 691: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:3733 + { + yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} + } case 692: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3675 +//line sql.y:3737 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} } case 693: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3679 +//line sql.y:3741 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} } case 694: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3683 +//line sql.y:3745 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} } case 695: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3687 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3749 { - yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} + yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} } case 696: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3691 +//line sql.y:3753 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} } case 697: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3695 +//line sql.y:3757 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} } case 698: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3699 +//line sql.y:3761 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} } case 699: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3703 - { - yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} - } - case 700: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3707 +//line sql.y:3765 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Channel: yyDollar[3].str} } - case 701: + case 700: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3711 +//line sql.y:3769 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes)} } - case 702: + case 701: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3715 +//line sql.y:3773 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} } - case 703: + case 702: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3719 +//line sql.y:3777 { yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes)} } + case 703: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3781 + { + yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes), Tables: yyDollar[2].tableNames, ReadLock: yyDollar[3].boolean} + } case 704: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3724 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3785 { - yyVAL.str = "" + yyVAL.flushOption = &FlushOption{Name: string(yyDollar[1].bytes), Tables: yyDollar[2].tableNames, ReadLock: yyDollar[3].boolean} } case 705: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3726 + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:3790 { - yyVAL.str = string(yyDollar[3].bytes) + yyVAL.boolean = false } case 706: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3730 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3792 { - yyVAL.str = string(yyDollar[1].bytes) + yyVAL.boolean = true } case 707: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3732 + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:3795 { - yyVAL.str = string(yyDollar[1].bytes) + yyVAL.str = "" } case 708: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3735 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3797 { - yyVAL.str = "" + yyVAL.str = string(yyDollar[3].bytes) } case 709: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3737 +//line sql.y:3801 { - yyVAL.str = yyDollar[1].str + yyVAL.str = string(yyDollar[1].bytes) } case 710: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3803 + { + yyVAL.str = string(yyDollar[1].bytes) + } + case 711: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:3806 + { + yyVAL.str = "" + } + case 712: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:3808 + { + yyVAL.str = yyDollar[1].str + } + case 713: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3741 +//line sql.y:3812 { yyVAL.statement = &ChangeReplicationSource{Options: yyDollar[5].replicationOptions} } - case 711: + case 714: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3745 +//line sql.y:3816 { yyVAL.statement = &ChangeReplicationFilter{Options: yyDollar[4].replicationOptions} } - case 712: + case 715: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3749 +//line sql.y:3820 { yyVAL.statement = &StartReplica{} } - case 713: + case 716: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3753 +//line sql.y:3824 { yyVAL.statement = &StopReplica{} } - case 714: + case 717: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3757 +//line sql.y:3828 { yyVAL.statement = &ResetReplica{All: yyDollar[3].boolean} } - case 715: + case 718: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3762 +//line sql.y:3833 { yyVAL.boolean = false } - case 716: + case 719: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3764 +//line sql.y:3835 { yyVAL.boolean = true } - case 717: + case 720: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3769 +//line sql.y:3840 { yyVAL.replicationOptions = []*ReplicationOption{yyDollar[1].replicationOption} } - case 718: + case 721: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3773 +//line sql.y:3844 { yyVAL.replicationOptions = append(yyVAL.replicationOptions, yyDollar[3].replicationOption) } - case 719: + case 722: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3779 +//line sql.y:3850 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } - case 720: + case 723: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3783 +//line sql.y:3854 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } - case 721: + case 724: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3787 +//line sql.y:3858 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } - case 722: + case 725: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3791 +//line sql.y:3862 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: mustAtoi(yylex, string(yyDollar[3].bytes))} } - case 723: + case 726: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3795 +//line sql.y:3866 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: mustAtoi(yylex, string(yyDollar[3].bytes))} } - case 724: + case 727: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3799 +//line sql.y:3870 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: mustAtoi(yylex, string(yyDollar[3].bytes))} } - case 725: + case 728: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:3874 + { + yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: mustAtoi(yylex, string(yyDollar[3].bytes))} + } + case 729: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3805 +//line sql.y:3880 { yyVAL.replicationOptions = []*ReplicationOption{yyDollar[1].replicationOption} } - case 726: + case 730: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3809 +//line sql.y:3884 { yyVAL.replicationOptions = append(yyVAL.replicationOptions, yyDollar[3].replicationOption) } - case 727: + case 731: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3815 +//line sql.y:3890 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: yyDollar[4].tableNames} } - case 728: + case 732: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3819 +//line sql.y:3894 { yyVAL.replicationOption = &ReplicationOption{Name: string(yyDollar[1].bytes), Value: yyDollar[4].tableNames} } - case 729: + case 733: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3825 +//line sql.y:3900 { yyVAL.indexDefinition = &IndexDefinition{Info: yyDollar[1].indexInfo, Columns: yyDollar[3].indexColumns, Options: yyDollar[5].indexOptions} } - case 730: + case 734: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:3829 +//line sql.y:3904 { yyVAL.indexDefinition = &IndexDefinition{Info: yyDollar[1].indexInfo, Columns: yyDollar[3].indexColumns} } - case 731: + case 735: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3834 +//line sql.y:3909 { yyVAL.indexOptions = nil } - case 732: + case 736: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3838 +//line sql.y:3913 { yyVAL.indexOptions = yyDollar[1].indexOptions } - case 733: + case 737: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3844 +//line sql.y:3919 { yyVAL.indexOptions = []*IndexOption{yyDollar[1].indexOption} } - case 734: + case 738: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3848 +//line sql.y:3923 { yyVAL.indexOptions = append(yyVAL.indexOptions, yyDollar[2].indexOption) } - case 735: + case 739: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3854 +//line sql.y:3929 { yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Using: string(yyDollar[2].bytes)} } - case 736: + case 740: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3858 +//line sql.y:3933 { // should not be string yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: NewIntVal(yyDollar[3].bytes)} } - case 737: + case 741: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3863 +//line sql.y:3938 { yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: NewStrVal(yyDollar[2].bytes)} } - case 738: + case 742: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3867 +//line sql.y:3942 { yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: NewStrVal(yyDollar[3].bytes)} } - case 739: + case 743: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3871 +//line sql.y:3946 { yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: NewStrVal(yyDollar[3].bytes)} } - case 740: + case 744: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3875 +//line sql.y:3950 { yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: nil} } - case 741: + case 745: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3879 +//line sql.y:3954 { yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: nil} } - case 742: + case 746: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3885 +//line sql.y:3960 { yyVAL.str = "" } - case 743: + case 747: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3889 +//line sql.y:3964 { yyVAL.str = string(yyDollar[1].str) } - case 744: + case 748: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3895 +//line sql.y:3970 { yyVAL.str = string(yyDollar[1].bytes) } - case 745: + case 749: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3899 +//line sql.y:3974 { yyVAL.str = ":=" } - case 746: + case 750: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3907 +//line sql.y:3982 { yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Name: NewColIdent("PRIMARY"), Primary: true, Unique: true} } - case 747: + case 751: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3911 +//line sql.y:3986 { - yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes), Name: NewColIdent(string(yyDollar[2].bytes)), Primary: true, Unique: true} + yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes), Name: NewColIdent("PRIMARY"), Primary: true, Unique: true} } - case 748: + case 752: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3915 +//line sql.y:3990 { yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].str), Name: NewColIdent(yyDollar[3].str), Spatial: true, Unique: false} } - case 749: + case 753: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3919 +//line sql.y:3994 { yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].str), Name: NewColIdent(yyDollar[3].str), Fulltext: true} } - case 750: + case 754: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:3923 +//line sql.y:3998 { var name string name = yyDollar[2].str @@ -15893,849 +16776,848 @@ yydefault: } yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[3].bytes) + " " + string(yyDollar[4].str), Name: NewColIdent(name), Unique: true} } - case 751: + case 755: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3932 +//line sql.y:4007 { yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].str), Name: NewColIdent(yyDollar[3].str), Unique: true} } - case 752: + case 756: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3936 +//line sql.y:4011 { yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes), Name: NewColIdent(yyDollar[2].str), Unique: true} } - case 753: + case 757: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:3940 +//line sql.y:4015 { yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].str), Name: NewColIdent(yyDollar[2].str), Unique: false} } - case 754: + case 758: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3946 +//line sql.y:4021 { yyVAL.str = string(yyDollar[1].bytes) } - case 755: + case 759: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3950 +//line sql.y:4025 { yyVAL.str = string(yyDollar[1].bytes) } - case 756: + case 760: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3954 +//line sql.y:4029 { yyVAL.str = string(yyDollar[1].bytes) } - case 757: + case 761: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3960 +//line sql.y:4035 { yyVAL.str = string(yyDollar[1].bytes) } - case 758: + case 762: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3964 +//line sql.y:4039 { yyVAL.str = string(yyDollar[1].bytes) } - case 759: + case 763: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3969 +//line sql.y:4044 { yyVAL.str = "" } - case 760: + case 764: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3973 +//line sql.y:4048 { yyVAL.str = yyDollar[1].str } - case 761: + case 765: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:3978 +//line sql.y:4053 { yyVAL.str = "" } - case 762: + case 766: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3982 +//line sql.y:4057 { yyVAL.str = string(yyDollar[1].bytes) } - case 763: + case 767: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3986 +//line sql.y:4061 { yyVAL.str = string(yyDollar[1].bytes) } - case 764: + case 768: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:3992 +//line sql.y:4067 { yyVAL.indexColumns = []*IndexColumn{yyDollar[1].indexColumn} } - case 765: + case 769: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:3996 +//line sql.y:4071 { yyVAL.indexColumns = append(yyVAL.indexColumns, yyDollar[3].indexColumn) } - case 766: + case 770: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4002 +//line sql.y:4077 { yyVAL.indexColumn = &IndexColumn{Column: NewColIdent(string(yyDollar[1].bytes)), Length: yyDollar[2].sqlVal, Order: yyDollar[3].str} } - case 767: + case 771: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4006 +//line sql.y:4081 { yyVAL.indexColumn = &IndexColumn{Column: NewColIdent(string(yyDollar[1].bytes)), Length: yyDollar[2].sqlVal, Order: yyDollar[3].str} } - case 768: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4012 - { - yyVAL.constraintDefinition = &ConstraintDefinition{Name: string(yyDollar[2].bytes), Details: yyDollar[3].constraintInfo} - } - case 769: + case 772: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4016 +//line sql.y:4087 { yyVAL.constraintDefinition = &ConstraintDefinition{Name: string(yyDollar[2].bytes), Details: yyDollar[3].constraintInfo} } - case 770: + case 773: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4020 +//line sql.y:4091 { yyVAL.constraintDefinition = &ConstraintDefinition{Details: yyDollar[1].constraintInfo} } - case 771: + case 774: yyDollar = yyS[yypt-11 : yypt+1] -//line sql.y:4026 +//line sql.y:4097 { yyVAL.constraintInfo = &ForeignKeyDefinition{Source: yyDollar[5].columns, ReferencedTable: yyDollar[8].tableName, ReferencedColumns: yyDollar[10].columns, Index: string(yyDollar[3].bytes)} } - case 772: + case 775: yyDollar = yyS[yypt-12 : yypt+1] -//line sql.y:4030 +//line sql.y:4101 { yyVAL.constraintInfo = &ForeignKeyDefinition{Source: yyDollar[5].columns, ReferencedTable: yyDollar[8].tableName, ReferencedColumns: yyDollar[10].columns, OnDelete: yyDollar[12].ReferenceAction, Index: string(yyDollar[3].bytes)} } - case 773: + case 776: yyDollar = yyS[yypt-12 : yypt+1] -//line sql.y:4034 +//line sql.y:4105 { yyVAL.constraintInfo = &ForeignKeyDefinition{Source: yyDollar[5].columns, ReferencedTable: yyDollar[8].tableName, ReferencedColumns: yyDollar[10].columns, OnUpdate: yyDollar[12].ReferenceAction, Index: string(yyDollar[3].bytes)} } - case 774: + case 777: yyDollar = yyS[yypt-13 : yypt+1] -//line sql.y:4038 +//line sql.y:4109 { yyVAL.constraintInfo = &ForeignKeyDefinition{Source: yyDollar[5].columns, ReferencedTable: yyDollar[8].tableName, ReferencedColumns: yyDollar[10].columns, OnDelete: yyDollar[12].ReferenceAction, OnUpdate: yyDollar[13].ReferenceAction, Index: string(yyDollar[3].bytes)} } - case 775: + case 778: yyDollar = yyS[yypt-13 : yypt+1] -//line sql.y:4042 +//line sql.y:4113 { yyVAL.constraintInfo = &ForeignKeyDefinition{Source: yyDollar[5].columns, ReferencedTable: yyDollar[8].tableName, ReferencedColumns: yyDollar[10].columns, OnDelete: yyDollar[13].ReferenceAction, OnUpdate: yyDollar[12].ReferenceAction, Index: string(yyDollar[3].bytes)} } - case 776: + case 779: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4047 +//line sql.y:4118 { yyVAL.bytes = nil } - case 777: + case 780: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4051 +//line sql.y:4122 { yyVAL.bytes = yyDollar[1].bytes } - case 778: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4057 - { - yyVAL.constraintDefinition = &ConstraintDefinition{Name: string(yyDollar[2].bytes), Details: yyDollar[3].constraintInfo} - } - case 779: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4062 - { - yyVAL.constraintDefinition = &ConstraintDefinition{Name: string(yyDollar[2].bytes), Details: yyDollar[3].constraintInfo} - } - case 780: + case 781: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4066 +//line sql.y:4128 { yyVAL.constraintDefinition = &ConstraintDefinition{Name: string(yyDollar[2].bytes), Details: yyDollar[3].constraintInfo} } - case 781: + case 782: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4070 +//line sql.y:4132 { yyVAL.constraintDefinition = &ConstraintDefinition{Details: yyDollar[2].constraintInfo} } - case 782: + case 783: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4074 +//line sql.y:4136 { yyVAL.constraintDefinition = &ConstraintDefinition{Details: yyDollar[1].constraintInfo} } - case 783: + case 784: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4080 +//line sql.y:4142 { yyVAL.constraintInfo = &CheckConstraintDefinition{Expr: yyDollar[3].expr, Enforced: yyDollar[5].boolean} } - case 784: + case 785: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4086 +//line sql.y:4148 { yyVAL.str = string(yyDollar[1].bytes) } - case 785: + case 786: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4090 +//line sql.y:4152 { yyVAL.str = string(yyDollar[1].bytes) } - case 786: + case 787: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4095 +//line sql.y:4157 { yyVAL.str = "" } - case 787: + case 788: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4099 +//line sql.y:4161 { yyVAL.str = string(yyDollar[2].bytes) } - case 788: + case 789: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4103 +//line sql.y:4165 { yyVAL.str = string(yyDollar[2].bytes) } - case 789: + case 790: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4109 +//line sql.y:4171 { yyVAL.ReferenceAction = yyDollar[3].ReferenceAction } - case 790: + case 791: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4115 +//line sql.y:4177 { yyVAL.ReferenceAction = yyDollar[3].ReferenceAction } - case 791: + case 792: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4121 +//line sql.y:4183 { yyVAL.ReferenceAction = Restrict } - case 792: + case 793: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4125 +//line sql.y:4187 { yyVAL.ReferenceAction = Cascade } - case 793: + case 794: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4129 +//line sql.y:4191 { yyVAL.ReferenceAction = NoAction } - case 794: + case 795: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4133 +//line sql.y:4195 { yyVAL.ReferenceAction = SetDefault } - case 795: + case 796: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4137 +//line sql.y:4199 { yyVAL.ReferenceAction = SetNull } - case 796: + case 797: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4142 +//line sql.y:4204 { yyVAL.boolean = true } - case 797: + case 798: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4146 +//line sql.y:4208 { yyVAL.boolean = true } - case 798: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4150 + case 799: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4212 { yyVAL.boolean = false } - case 799: + case 800: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4155 +//line sql.y:4217 { - yyVAL.str = "" + yyVAL.tableOptions = nil } - case 800: + case 801: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4159 +//line sql.y:4221 { - yyVAL.str = yyDollar[1].str + " " + string(yyDollar[2].str) - } - case 801: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4163 - { - yyVAL.str = string(yyDollar[1].str) + ", " + string(yyDollar[3].str) + yyVAL.tableOptions = append(yyDollar[1].tableOptions, yyDollar[2].tableOption) } case 802: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4169 +//line sql.y:4225 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOptions = append(yyDollar[1].tableOptions, yyDollar[3].tableOption) } case 803: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4173 +//line sql.y:4231 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 804: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4177 +//line sql.y:4235 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 805: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4181 +//line sql.y:4239 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].str) + " " + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 806: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4185 +//line sql.y:4243 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyDollar[4].str + yyVAL.tableOption = &TableOption{Name: "CHARACTER SET", Value: yyDollar[4].str} } case 807: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4189 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4247 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyDollar[4].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Value: yyDollar[5].str} } case 808: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4193 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4251 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + yyDollar[5].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 809: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4197 +//line sql.y:4255 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: "CHECKSUM", Value: string(yyDollar[3].bytes)} } case 810: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4201 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4259 { - yyVAL.str = "CHECKSUM" + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[2].bytes), Value: yyDollar[4].str} } case 811: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4205 +//line sql.y:4263 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 812: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4209 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4267 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyDollar[4].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 813: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4213 +//line sql.y:4271 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 814: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4217 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4275 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes)} } case 815: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4221 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4279 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Value: string(yyDollar[4].bytes)} } case 816: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4225 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4283 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + "'" + string(yyDollar[4].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 817: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4229 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4287 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + "'" + string(yyDollar[4].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 818: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4233 +//line sql.y:4291 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 819: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4237 +//line sql.y:4295 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 820: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4241 +//line sql.y:4299 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 821: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4245 +//line sql.y:4303 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 822: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4249 +//line sql.y:4307 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 823: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4253 +//line sql.y:4311 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 824: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4257 +//line sql.y:4315 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 825: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4261 +//line sql.y:4319 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 826: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4265 +//line sql.y:4323 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 827: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4269 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4327 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes) + string(yyDollar[2].bytes)} } case 828: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4273 +//line sql.y:4331 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 829: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4277 +//line sql.y:4335 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 830: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4281 +//line sql.y:4339 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 831: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4285 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4343 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 832: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4289 +//line sql.y:4347 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 833: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4293 +//line sql.y:4351 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 834: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4297 +//line sql.y:4355 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 835: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4301 +//line sql.y:4359 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "'" + string(yyDollar[3].bytes) + "'" + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[3].bytes)} } case 836: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4305 +//line sql.y:4363 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[3].str} } case 837: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4309 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4367 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: yyDollar[2].str} } case 838: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4313 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4371 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[2].bytes)} } case 839: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4317 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4375 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[3].bytes) + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes)} } case 840: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4321 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4379 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyDollar[3].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes)} } case 841: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4325 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4383 { - yyVAL.str = string(yyDollar[1].bytes) + yyDollar[2].str + yyVAL.tableOption = &TableOption{Name: string(yyDollar[1].bytes), Value: "(" + yyDollar[4].str + ")"} } case 842: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4329 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4389 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + yyVAL.bytes = yyDollar[1].bytes } case 843: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4333 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4393 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes) + yyVAL.bytes = yyDollar[1].bytes } case 844: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4337 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4397 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes) + yyVAL.bytes = yyDollar[1].bytes } case 845: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4341 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4403 { - yyVAL.str = string(yyDollar[1].bytes) + " " + "(" + yyDollar[4].str + ")" + yyVAL.str = string(yyDollar[1].bytes) } case 846: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4347 +//line sql.y:4407 { yyVAL.str = string(yyDollar[1].bytes) } case 847: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4351 +//line sql.y:4413 { - yyVAL.str = string(yyDollar[1].bytes) + yyVAL.str = "'" + string(yyDollar[1].bytes) + "'" } case 848: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4357 +//line sql.y:4417 { - yyVAL.str = "'" + string(yyDollar[1].bytes) + "'" + yyVAL.str = string(yyDollar[1].bytes) } case 849: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4361 +//line sql.y:4422 { yyVAL.str = string(yyDollar[1].bytes) } case 850: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4366 +//line sql.y:4426 { yyVAL.str = string(yyDollar[1].bytes) } case 851: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4370 +//line sql.y:4430 { yyVAL.str = string(yyDollar[1].bytes) } case 852: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4374 +//line sql.y:4436 { - yyVAL.str = string(yyDollar[1].bytes) + yyVAL.bytes = yyDollar[1].bytes } case 853: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4380 +//line sql.y:4440 { yyVAL.bytes = yyDollar[1].bytes } case 854: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4384 +//line sql.y:4444 { yyVAL.bytes = yyDollar[1].bytes } case 855: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4388 +//line sql.y:4450 { - yyVAL.bytes = yyDollar[1].bytes + yyVAL.str = string(yyDollar[1].bytes) } case 856: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4394 +//line sql.y:4454 { yyVAL.str = string(yyDollar[1].bytes) } case 857: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4398 +//line sql.y:4458 { yyVAL.str = string(yyDollar[1].bytes) } case 858: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4402 +//line sql.y:4462 { yyVAL.str = string(yyDollar[1].bytes) } case 859: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4406 +//line sql.y:4466 { yyVAL.str = string(yyDollar[1].bytes) } case 860: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4410 +//line sql.y:4470 { yyVAL.str = string(yyDollar[1].bytes) } case 861: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4414 +//line sql.y:4476 { yyVAL.str = string(yyDollar[1].bytes) } case 862: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4420 - { - yyVAL.str = string(yyDollar[1].bytes) - } - case 863: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4424 +//line sql.y:4480 { yyVAL.str = yyDollar[1].str + "," + string(yyDollar[3].bytes) } - case 867: + case 866: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4435 +//line sql.y:4491 { - yyVAL.str = "" + yyVAL.partOption = nil + } + case 867: + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:4495 + { + yyDollar[3].partOption.Partitions = yyDollar[4].sqlVal + yyDollar[3].partOption.SubPartition = yyDollar[5].subpart + yyDollar[3].partOption.Definitions = yyDollar[6].partDefs + yyVAL.partOption = yyDollar[3].partOption } case 868: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4439 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4504 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyDollar[3].str + yyDollar[4].str + yyDollar[5].str + yyVAL.partOption = yyDollar[1].partOption } case 869: - yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4443 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4508 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyDollar[3].str + yyDollar[4].str + yyDollar[5].str + "(partition_definitions)" + yyVAL.partOption = &PartitionOption{ + PartitionType: string(yyDollar[1].str), + Expr: yyDollar[3].expr, + } } case 870: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4449 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4515 { - yyVAL.str = yyDollar[1].str + yyVAL.partOption = &PartitionOption{ + PartitionType: string(yyDollar[1].str), + ColList: yyDollar[4].columns, + } } case 871: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4453 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4524 { - yyVAL.str = string(yyDollar[1].bytes) + " (" + string(yyDollar[3].bytes) + ")" + yyVAL.partOption = &PartitionOption{ + IsLinear: yyDollar[1].boolean, + PartitionType: string(yyDollar[2].bytes), + Expr: yyDollar[4].expr, + } } case 872: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4457 + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:4532 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " (column_list)" + yyVAL.partOption = &PartitionOption{ + IsLinear: yyDollar[1].boolean, + PartitionType: string(yyDollar[2].bytes), + KeyAlgorithm: yyDollar[3].str, + ColList: yyDollar[5].columns, + } } case 873: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4461 + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:4542 { - yyVAL.str = string(yyDollar[1].bytes) + " (" + string(yyDollar[3].bytes) + ")" + yyVAL.boolean = false } case 874: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4465 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4546 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " (column_list)" + yyVAL.boolean = true } case 875: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4471 + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:4551 { - yyVAL.str = yyDollar[1].str + string(yyDollar[2].bytes) + " (value)" + yyVAL.str = "" } case 876: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4475 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4555 { - yyVAL.str = yyDollar[1].str + string(yyDollar[2].bytes) + " (" + string(yyDollar[4].bytes) + ")" + yyVAL.str = string(yyDollar[1].bytes) + " = " + string(yyDollar[3].bytes) } case 877: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4479 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4561 { - yyVAL.str = yyDollar[1].str + string(yyDollar[2].bytes) + " (column_list)" + yyVAL.str = string(yyDollar[1].bytes) } case 878: - yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4483 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4565 { - yyVAL.str = yyDollar[1].str + string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + string(yyDollar[5].bytes) + " (column_list)" + yyVAL.str = string(yyDollar[1].bytes) } case 879: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4488 +//line sql.y:4570 { - yyVAL.str = "" + yyVAL.sqlVal = nil } case 880: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4492 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4574 { - yyVAL.str = string(yyDollar[1].bytes) + " " + yyVAL.sqlVal = NewIntVal(yyDollar[2].bytes) } case 881: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4497 +//line sql.y:4579 { - yyVAL.str = "" + yyVAL.subpart = nil } case 882: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4501 + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:4583 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyVAL.subpart = &SubPartition{ + IsLinear: yyDollar[3].boolean, + PartitionType: string(yyDollar[4].bytes), + Expr: yyDollar[6].expr, + SubPartitions: yyDollar[8].sqlVal, + } } case 883: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4506 + yyDollar = yyS[yypt-9 : yypt+1] +//line sql.y:4592 { - yyVAL.str = "" + yyVAL.subpart = &SubPartition{ + IsLinear: yyDollar[3].boolean, + PartitionType: string(yyDollar[4].bytes), + KeyAlgorithm: yyDollar[5].str, + Expr: yyDollar[7].expr, + SubPartitions: yyDollar[9].sqlVal, + } } case 884: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4510 - { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyDollar[3].str + " " + yyDollar[4].str - } - case 885: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4515 +//line sql.y:4603 { - yyVAL.str = "" + yyVAL.sqlVal = nil } - case 886: + case 885: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4519 +//line sql.y:4607 { - yyVAL.str = string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes) + " " + yyVAL.sqlVal = NewIntVal(yyDollar[2].bytes) } - case 887: + case 886: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4524 +//line sql.y:4612 { yyVAL.str = "" } - case 888: + case 887: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4528 +//line sql.y:4616 { yyVAL.str = "" } - case 889: + case 888: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4532 +//line sql.y:4620 { yyVAL.str = string(yyDollar[2].bytes) } - case 890: + case 889: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4537 +//line sql.y:4625 { yyVAL.str = string("") } - case 891: + case 890: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4541 +//line sql.y:4629 { yyVAL.str = string(yyDollar[2].bytes) } case 895: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4552 +//line sql.y:4641 { - yyVAL.statement = &DBDDL{Action: AlterStr, DBName: string(yyDollar[3].bytes), CharsetCollate: yyDollar[4].charsetCollates} + yyVAL.statement = &DBDDL{Action: AlterStr, SchemaOrDatabase: "database", DBName: string(yyDollar[3].bytes), CharsetCollate: yyDollar[4].charsetCollates} } case 896: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4556 +//line sql.y:4645 { - yyVAL.statement = &DBDDL{Action: AlterStr, CharsetCollate: yyDollar[3].charsetCollates} + yyVAL.statement = &DBDDL{Action: AlterStr, SchemaOrDatabase: "database", CharsetCollate: yyDollar[3].charsetCollates} } case 897: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4562 + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:4651 { for i := 0; i < len(yyDollar[5].ddls); i++ { if yyDollar[5].ddls[i].Action == RenameStr { @@ -16744,361 +17626,1003 @@ yydefault: yyDollar[5].ddls[i].Table = yyDollar[4].tableName } } - yyVAL.statement = &AlterTable{Table: yyDollar[4].tableName, Statements: yyDollar[5].ddls} + yyVAL.statement = &AlterTable{Table: yyDollar[4].tableName, Statements: yyDollar[5].ddls, PartitionSpecs: yyDollar[6].partSpecs} } case 898: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4662 + { + yyVAL.statement = &AlterTable{Table: yyDollar[4].tableName, PartitionSpecs: yyDollar[5].partSpecs} + } + case 899: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4575 +//line sql.y:4668 { yyVAL.ddls = []*DDL{yyDollar[1].ddl} } - case 899: + case 900: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4579 +//line sql.y:4672 { yyVAL.ddls = append(yyVAL.ddls, yyDollar[3].ddl) } - case 900: + case 901: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4585 +//line sql.y:4678 { - ddl := &DDL{Action: AlterStr, ColumnAction: AddStr, TableSpec: &TableSpec{}} + ddl := &DDL{ + Action: AlterStr, + ColumnAction: AddStr, + TableSpec: &TableSpec{}, + } ddl.TableSpec.AddColumn(yyDollar[4].columnDefinition) ddl.Column = yyDollar[4].columnDefinition.Name yyVAL.ddl = ddl } - case 901: + case 902: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4592 +//line sql.y:4689 { - ddl := &DDL{Action: AlterStr, ColumnAction: AddStr, TableSpec: &TableSpec{}, ColumnOrder: yyDollar[4].columnOrder} + ddl := &DDL{ + Action: AlterStr, + ColumnAction: AddStr, + TableSpec: &TableSpec{}, + ColumnOrder: yyDollar[4].columnOrder, + } ddl.TableSpec.AddColumn(yyDollar[3].columnDefinition) ddl.Column = yyDollar[3].columnDefinition.Name yyVAL.ddl = ddl } - case 902: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4599 - { - yyVAL.ddl = &DDL{Action: AlterStr, ColumnAction: DropStr, Column: NewColIdent(string(yyDollar[3].bytes))} - } case 903: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4603 - { - yyVAL.ddl = &DDL{Action: AlterStr, ColumnAction: DropStr, Column: NewColIdent(string(yyDollar[3].bytes))} + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:4701 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: CreateStr, + ToName: NewColIdent(yyDollar[3].str), + Using: yyDollar[4].colIdent, + Columns: yyDollar[6].indexColumns, + Options: yyDollar[8].indexOptions, + }, + } } case 904: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4607 + yyDollar = yyS[yypt-10 : yypt+1] +//line sql.y:4714 { - yyVAL.ddl = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string(yyDollar[3].bytes)), ToColumn: NewColIdent(string(yyDollar[5].bytes))} + idxName := yyDollar[5].str + if len(idxName) == 0 { + idxName = yyDollar[2].str + } + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: CreateStr, + ToName: NewColIdent(idxName), + Type: yyDollar[3].str, + Using: yyDollar[6].colIdent, + Columns: yyDollar[8].indexColumns, + Options: yyDollar[10].indexOptions, + }, + } } case 905: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4611 + yyDollar = yyS[yypt-9 : yypt+1] +//line sql.y:4734 { - yyVAL.ddl = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string(yyDollar[3].bytes)), ToColumn: NewColIdent(string(yyDollar[5].bytes))} + ddl := &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: CreateStr, + }, + } + ddl.IndexSpec = &IndexSpec{ + Action: CreateStr, + Using: NewColIdent(""), + ToName: NewColIdent(yyDollar[2].str), + Type: PrimaryStr, + Columns: yyDollar[7].indexColumns, + Options: yyDollar[9].indexOptions, + } + yyVAL.ddl = ddl } case 906: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4615 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4752 { - yyVAL.ddl = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string(yyDollar[3].bytes)), ToColumn: NewColIdent(string(yyDollar[5].bytes))} + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: AddStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(yyDollar[2].constraintDefinition) + yyVAL.ddl = ddl } case 907: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4619 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4762 { - yyVAL.ddl = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string(yyDollar[3].bytes)), ToColumn: NewColIdent(string(yyDollar[5].bytes))} + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: AddStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(yyDollar[2].constraintDefinition) + yyVAL.ddl = ddl } case 908: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4623 - { - // Change this to a rename statement - yyVAL.ddl = &DDL{Action: RenameStr, ToTables: TableNames{yyDollar[3].tableName}} +//line sql.y:4772 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + ConstraintAction: DropStr, + TableSpec: &TableSpec{ + Constraints: []*ConstraintDefinition{ + &ConstraintDefinition{ + Name: string(yyDollar[3].bytes), + }, + }, + }, + } } case 909: - yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4628 - { - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: CreateStr, ToName: NewColIdent(yyDollar[3].str), Using: yyDollar[4].colIdent, Columns: yyDollar[6].indexColumns, Options: yyDollar[8].indexOptions}} + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4786 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + ConstraintAction: DropStr, + TableSpec: &TableSpec{ + Constraints: []*ConstraintDefinition{ + &ConstraintDefinition{ + Name: string(yyDollar[3].bytes), + Details: &CheckConstraintDefinition{}, + }, + }, + }, + } } case 910: - yyDollar = yyS[yypt-10 : yypt+1] -//line sql.y:4632 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4801 { - idxName := yyDollar[5].str - if len(idxName) == 0 { - idxName = yyDollar[2].str - } - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: CreateStr, ToName: NewColIdent(idxName), Type: yyDollar[3].str, Using: yyDollar[6].colIdent, Columns: yyDollar[8].indexColumns, Options: yyDollar[10].indexOptions}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 911: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4640 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4805 { - yyVAL.ddl = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: []*ConstraintDefinition{&ConstraintDefinition{Name: string(yyDollar[3].bytes)}}}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 912: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4645 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4809 { - yyVAL.ddl = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: []*ConstraintDefinition{&ConstraintDefinition{Name: string(yyDollar[3].bytes)}}}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 913: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4650 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4813 { - yyVAL.ddl = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: []*ConstraintDefinition{&ConstraintDefinition{Name: string(yyDollar[3].bytes), Details: &CheckConstraintDefinition{}}}}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 914: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4655 +//line sql.y:4817 { - yyVAL.ddl = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: []*ConstraintDefinition{&ConstraintDefinition{Name: string(yyDollar[3].bytes), Details: &CheckConstraintDefinition{}}}}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 915: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4660 +//line sql.y:4821 { - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: DropStr, ToName: yyDollar[3].colIdent}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 916: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4664 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4825 { - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: RenameStr, FromName: yyDollar[3].colIdent, ToName: yyDollar[5].colIdent}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 917: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4668 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4829 { - ddl := &DDL{Action: AlterStr, ColumnAction: ModifyStr, TableSpec: &TableSpec{}, ColumnOrder: yyDollar[4].columnOrder} - ddl.TableSpec.AddColumn(yyDollar[3].columnDefinition) - ddl.Column = yyDollar[3].columnDefinition.Name - yyVAL.ddl = ddl + yyVAL.ddl = &DDL{Action: AlterStr} } case 918: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4675 - { - ddl := &DDL{Action: AlterStr, ColumnAction: ChangeStr, TableSpec: &TableSpec{}, Column: NewColIdent(string(yyDollar[3].bytes)), ColumnOrder: yyDollar[5].columnOrder} - ddl.TableSpec.AddColumn(yyDollar[4].columnDefinition) - yyVAL.ddl = ddl + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:4833 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + DefaultSpec: &DefaultSpec{ + Action: SetStr, + Column: yyDollar[3].colIdent, + Value: yyDollar[6].expr, + }, + } } case 919: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4681 - { - yyVAL.ddl = &DDL{Action: AlterStr, PartitionSpec: yyDollar[1].partSpec} + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4844 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + DefaultSpec: &DefaultSpec{ + Action: DropStr, + Column: yyDollar[3].colIdent, + }, + } } case 920: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4685 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4854 { - ddl := &DDL{Action: AlterStr, ConstraintAction: AddStr, TableSpec: &TableSpec{}} - ddl.TableSpec.AddConstraint(yyDollar[2].constraintDefinition) - yyVAL.ddl = ddl + yyVAL.ddl = &DDL{Action: AlterStr} } case 921: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4691 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4858 { - ddl := &DDL{Action: AlterStr, ConstraintAction: AddStr, TableSpec: &TableSpec{}} - ddl.TableSpec.AddConstraint(yyDollar[2].constraintDefinition) - yyVAL.ddl = ddl + yyVAL.ddl = &DDL{Action: AlterStr} } case 922: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4697 - { - yyVAL.ddl = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: []*ConstraintDefinition{&ConstraintDefinition{Name: string(yyDollar[4].bytes), Details: &ForeignKeyDefinition{}}}}} + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4862 + { + ddl := &DDL{ + Action: AlterStr, + ColumnAction: ChangeStr, + TableSpec: &TableSpec{}, + Column: NewColIdent(string(yyDollar[3].bytes)), + ColumnOrder: yyDollar[5].columnOrder, + } + ddl.TableSpec.AddColumn(yyDollar[4].columnDefinition) + yyVAL.ddl = ddl } case 923: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4702 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4874 { - yyVAL.ddl = &DDL{Action: AlterStr, AutoIncSpec: &AutoIncSpec{Value: yyDollar[3].expr}} + yyVAL.ddl = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: yyDollar[5].str, + Collation: "", + }, + } } case 924: - yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:4706 - { - yyVAL.ddl = &DDL{Action: AlterStr, DefaultSpec: &DefaultSpec{Action: SetStr, Column: yyDollar[3].colIdent, Value: yyDollar[6].expr}} + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:4884 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: yyDollar[5].str, + Collation: yyDollar[8].str, + }, + } } case 925: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4710 - { - yyVAL.ddl = &DDL{Action: AlterStr, DefaultSpec: &DefaultSpec{Action: DropStr, Column: yyDollar[3].colIdent}} + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4894 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: "", + Collation: yyDollar[4].str, + }, + } } case 926: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4714 + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:4904 { - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: DropStr, Type: PrimaryStr}} + yyVAL.ddl = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: yyDollar[5].str, + Collation: "", + }, + } } case 927: - yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:4720 - { - ddl := &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: CreateStr}} - ddl.IndexSpec = &IndexSpec{Action: CreateStr, Using: NewColIdent(""), ToName: NewColIdent(yyDollar[2].str), Type: PrimaryStr, Columns: yyDollar[7].indexColumns, Options: yyDollar[9].indexOptions} - yyVAL.ddl = ddl + yyDollar = yyS[yypt-7 : yypt+1] +//line sql.y:4914 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: yyDollar[5].str, + Collation: yyDollar[7].str, + }, + } } case 928: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4726 +//line sql.y:4924 { - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: string(yyDollar[1].bytes)}} + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: string(yyDollar[1].bytes), + }, + } } case 929: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4730 +//line sql.y:4933 { - yyVAL.ddl = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: string(yyDollar[1].bytes)}} + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: string(yyDollar[1].bytes), + }, + } } case 930: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4734 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4942 { - yyVAL.ddl = &DDL{Action: AlterStr, AlterCollationSpec: &AlterCollationSpec{CharacterSet: yyDollar[5].str, Collation: ""}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 931: - yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4738 + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:4946 { - yyVAL.ddl = &DDL{Action: AlterStr, AlterCollationSpec: &AlterCollationSpec{CharacterSet: yyDollar[5].str, Collation: yyDollar[8].str}} + yyVAL.ddl = &DDL{Action: AlterStr} } case 932: - yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4742 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:4950 { - yyVAL.ddl = &DDL{Action: AlterStr, AlterCollationSpec: &AlterCollationSpec{CharacterSet: "", Collation: yyDollar[4].str}} + yyVAL.ddl = &DDL{ + Action: AlterStr, + ColumnAction: DropStr, + Column: NewColIdent(string(yyDollar[3].bytes)), + } } case 933: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4746 +//line sql.y:4958 { - yyVAL.ddl = &DDL{Action: AlterStr} + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: DropStr, + ToName: yyDollar[3].colIdent, + }, + } } case 934: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4750 +//line sql.y:4968 { - yyVAL.ddl = &DDL{Action: AlterStr} + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: DropStr, + Type: PrimaryStr, + }, + } } case 935: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4754 + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:4978 { - yyVAL.ddl = &DDL{Action: AlterStr} + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: DropStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[4].bytes), + Details: &ForeignKeyDefinition{}, + }) + yyVAL.ddl = ddl } case 936: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4758 + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:4991 { yyVAL.ddl = &DDL{Action: AlterStr} } case 937: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4762 +//line sql.y:4995 { yyVAL.ddl = &DDL{Action: AlterStr} } case 938: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4766 +//line sql.y:4999 { yyVAL.ddl = &DDL{Action: AlterStr} } case 939: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4770 + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5003 { yyVAL.ddl = &DDL{Action: AlterStr} } case 940: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4774 +//line sql.y:5007 { yyVAL.ddl = &DDL{Action: AlterStr} } case 941: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5011 + { + ddl := &DDL{ + Action: AlterStr, + ColumnAction: ModifyStr, + TableSpec: &TableSpec{}, + ColumnOrder: yyDollar[4].columnOrder, + } + ddl.TableSpec.AddColumn(yyDollar[3].columnDefinition) + ddl.Column = yyDollar[3].columnDefinition.Name + yyVAL.ddl = ddl + } + case 942: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:5024 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + ColumnAction: RenameStr, + Column: NewColIdent(string(yyDollar[3].bytes)), + ToColumn: NewColIdent(string(yyDollar[5].bytes)), + } + } + case 943: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:5033 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: RenameStr, + FromName: yyDollar[3].colIdent, + ToName: yyDollar[5].colIdent, + }, + } + } + case 944: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4778 +//line sql.y:5044 + { + // Change this to a rename statement + yyVAL.ddl = &DDL{ + Action: RenameStr, + ToTables: TableNames{yyDollar[3].tableName}, + } + } + case 945: + yyDollar = yyS[yypt-7 : yypt+1] +//line sql.y:5052 + { + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: RenameStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[5].bytes), + Details: &ForeignKeyDefinition{}, + }) + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[7].bytes), + Details: &ForeignKeyDefinition{}, + }) + yyVAL.ddl = ddl + } + case 946: + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:5069 + { + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: RenameStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[4].bytes), + Details: &CheckConstraintDefinition{}, + }) + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[6].bytes), + Details: &CheckConstraintDefinition{}, + }) + yyVAL.ddl = ddl + } + case 947: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:5086 + { + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: RenameStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[3].bytes), + }) + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string(yyDollar[5].bytes), + }) + yyVAL.ddl = ddl + } + case 948: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:5101 + { + yyVAL.ddl = &DDL{ + Action: AlterStr, + } + } + case 949: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:5107 + { + yyVAL.ddl = yyDollar[1].ddl + } + case 950: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5114 { yyVAL.ddl = &DDL{Action: AlterStr} } - case 942: + case 951: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4782 +//line sql.y:5118 + { + yyVAL.ddl = &DDL{Action: AlterStr, AutoIncSpec: &AutoIncSpec{Value: yyDollar[3].expr}} + } + case 952: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5122 { yyVAL.ddl = &DDL{Action: AlterStr} } - case 943: + case 953: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5126 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 954: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5130 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 955: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5134 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 956: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5138 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 957: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5142 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 958: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5146 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 959: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5150 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 960: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5154 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 961: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5158 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 962: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5162 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 963: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5166 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 964: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5170 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 965: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5174 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 966: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5178 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 967: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5182 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 968: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5186 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 969: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5190 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 970: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5194 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 971: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5198 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 972: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5202 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 973: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5206 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 974: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5210 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 975: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5214 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 976: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5218 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 977: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5222 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 978: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5226 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 979: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5230 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 980: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:5234 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 981: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:5238 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 982: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5242 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 983: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5246 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 984: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:5250 + { + yyVAL.ddl = &DDL{Action: AlterStr} + } + case 985: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:5256 + { + yyVAL.boolean = true + } + case 986: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:5260 + { + yyVAL.boolean = false + } + case 989: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:5270 + { + var ifExists bool + if yyDollar[3].byt != 0 { + ifExists = true + } + yyVAL.statement = &DDL{Action: AlterStr, User: yyDollar[4].accountName, Authentication: yyDollar[5].authentication, IfExists: ifExists} + } + case 990: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4787 +//line sql.y:5279 { yyVAL.columnOrder = nil } - case 944: + case 991: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4791 +//line sql.y:5283 { yyVAL.columnOrder = &ColumnOrder{First: true} } - case 945: + case 992: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4795 +//line sql.y:5287 { yyVAL.columnOrder = &ColumnOrder{AfterColumn: NewColIdent(string(yyDollar[2].bytes))} } - case 946: + case 993: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4800 +//line sql.y:5292 { } - case 947: + case 994: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4802 +//line sql.y:5294 { } - case 948: + case 995: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:5297 + { + yyVAL.partSpecs = nil + } + case 996: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:5301 + { + yyVAL.partSpecs = yyDollar[1].partSpecs + } + case 997: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:5307 + { + yyVAL.partSpecs = []*PartitionSpec{yyDollar[1].partSpec} + } + case 998: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:5311 + { + yyVAL.partSpecs = append(yyDollar[1].partSpecs, yyDollar[2].partSpec) + } + case 999: + yyDollar = yyS[yypt-5 : yypt+1] +//line sql.y:5317 + { + yyVAL.partSpec = &PartitionSpec{Action: AddStr, Definitions: yyDollar[4].partDefs} + } + case 1000: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5321 + { + yyVAL.partSpec = &PartitionSpec{Action: DropStr, Names: yyDollar[3].partitions} + } + case 1001: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5325 + { + yyVAL.partSpec = &PartitionSpec{Action: DiscardStr, Names: yyDollar[3].partitions} + } + case 1002: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5329 + { + yyVAL.partSpec = &PartitionSpec{Action: DiscardStr, IsAll: true} + } + case 1003: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5333 + { + yyVAL.partSpec = &PartitionSpec{Action: ImportStr, Names: yyDollar[3].partitions} + } + case 1004: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5337 + { + yyVAL.partSpec = &PartitionSpec{Action: ImportStr, IsAll: true} + } + case 1005: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5341 + { + yyVAL.partSpec = &PartitionSpec{Action: TruncateStr, Names: yyDollar[3].partitions} + } + case 1006: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5345 + { + yyVAL.partSpec = &PartitionSpec{Action: TruncateStr, IsAll: true} + } + case 1007: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5349 + { + yyVAL.partSpec = &PartitionSpec{Action: CoalesceStr, Number: NewIntVal(yyDollar[3].bytes)} + } + case 1008: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:4806 +//line sql.y:5353 { - yyVAL.partSpec = &PartitionSpec{Action: ReorganizeStr, Name: yyDollar[3].colIdent, Definitions: yyDollar[6].partDefs} + yyVAL.partSpec = &PartitionSpec{Action: ReorganizeStr, Names: yyDollar[3].partitions, Definitions: yyDollar[6].partDefs} } - case 949: + case 1009: + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:5357 + { + yyVAL.partSpec = &PartitionSpec{Action: ExchangeStr, Names: Partitions{yyDollar[3].colIdent}, TableName: yyDollar[6].tableName} + } + case 1010: + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:5361 + { + yyVAL.partSpec = &PartitionSpec{Action: ExchangeStr, Names: Partitions{yyDollar[3].colIdent}, TableName: yyDollar[6].tableName, WithValidation: yyDollar[7].boolean} + } + case 1011: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5365 + { + yyVAL.partSpec = &PartitionSpec{Action: AnalyzeStr, Names: yyDollar[3].partitions} + } + case 1012: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5369 + { + yyVAL.partSpec = &PartitionSpec{Action: AnalyzeStr, IsAll: true} + } + case 1013: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5382 + { + yyVAL.partSpec = &PartitionSpec{Action: OptimizeStr, Names: yyDollar[3].partitions} + } + case 1014: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5386 + { + yyVAL.partSpec = &PartitionSpec{Action: OptimizeStr, IsAll: true} + } + case 1015: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5390 + { + yyVAL.partSpec = &PartitionSpec{Action: RebuildStr, Names: yyDollar[3].partitions} + } + case 1016: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5394 + { + yyVAL.partSpec = &PartitionSpec{Action: RebuildStr, IsAll: true} + } + case 1017: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5398 + { + yyVAL.partSpec = &PartitionSpec{Action: RepairStr, Names: yyDollar[3].partitions} + } + case 1018: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5402 + { + yyVAL.partSpec = &PartitionSpec{Action: RepairStr, IsAll: true} + } + case 1019: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:5406 + { + yyVAL.partSpec = &PartitionSpec{Action: RemoveStr} + } + case 1020: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:5411 + { + yyVAL.partDefs = nil + } + case 1021: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5415 + { + yyVAL.partDefs = yyDollar[2].partDefs + } + case 1022: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4812 +//line sql.y:5421 { yyVAL.partDefs = []*PartitionDefinition{yyDollar[1].partDef} } - case 950: + case 1023: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4816 +//line sql.y:5425 { yyVAL.partDefs = append(yyDollar[1].partDefs, yyDollar[3].partDef) } - case 951: + case 1024: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4822 +//line sql.y:5431 { yyVAL.partDef = &PartitionDefinition{Name: yyDollar[2].colIdent, Limit: yyDollar[7].expr} } - case 952: + case 1025: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4826 +//line sql.y:5435 { yyVAL.partDef = &PartitionDefinition{Name: yyDollar[2].colIdent, Maxvalue: true} } - case 953: + case 1026: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:4832 +//line sql.y:5441 { es := &EventSpec{EventName: yyDollar[4].eventName, Definer: yyDollar[2].str, OnCompletionPreserve: yyDollar[5].eventOnCompletion, RenameName: yyDollar[6].eventName, Status: yyDollar[7].eventStatus, Comment: yyDollar[8].sqlVal} if err := es.ValidateAlterEvent(); err != nil { @@ -17107,77 +18631,77 @@ yydefault: } yyVAL.statement = &DDL{Action: AlterStr, EventSpec: es} } - case 954: + case 1027: yyDollar = yyS[yypt-11 : yypt+1] -//line sql.y:4841 +//line sql.y:5450 { yyVAL.statement = &DDL{Action: AlterStr, EventSpec: &EventSpec{EventName: yyDollar[4].eventName, Definer: yyDollar[2].str, OnSchedule: yyDollar[7].eventScheduleSpec, OnCompletionPreserve: yyDollar[8].eventOnCompletion, RenameName: yyDollar[9].eventName, Status: yyDollar[10].eventStatus, Comment: yyDollar[11].sqlVal}} } - case 955: + case 1028: yyDollar = yyS[yypt-12 : yypt+1] -//line sql.y:4845 +//line sql.y:5454 { yyVAL.statement = &DDL{Action: AlterStr, EventSpec: &EventSpec{EventName: yyDollar[4].eventName, Definer: yyDollar[2].str, OnCompletionPreserve: yyDollar[5].eventOnCompletion, RenameName: yyDollar[6].eventName, Status: yyDollar[7].eventStatus, Comment: yyDollar[8].sqlVal, Body: yyDollar[11].statement}, SubStatementPositionStart: yyDollar[10].int, SubStatementPositionEnd: yyDollar[12].int - 1} } - case 956: + case 1029: yyDollar = yyS[yypt-15 : yypt+1] -//line sql.y:4849 +//line sql.y:5458 { yyVAL.statement = &DDL{Action: AlterStr, EventSpec: &EventSpec{EventName: yyDollar[4].eventName, Definer: yyDollar[2].str, OnSchedule: yyDollar[7].eventScheduleSpec, OnCompletionPreserve: yyDollar[8].eventOnCompletion, RenameName: yyDollar[9].eventName, Status: yyDollar[10].eventStatus, Comment: yyDollar[11].sqlVal, Body: yyDollar[14].statement}, SubStatementPositionStart: yyDollar[13].int, SubStatementPositionEnd: yyDollar[15].int - 1} } - case 957: + case 1030: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4854 +//line sql.y:5463 { yyVAL.eventName = EventName{} } - case 958: + case 1031: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4858 +//line sql.y:5467 { yyVAL.eventName = yyDollar[3].eventName } - case 959: + case 1032: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4864 +//line sql.y:5473 { yyVAL.statement = yyDollar[3].ddl } - case 960: + case 1033: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4868 +//line sql.y:5477 { yyVAL.statement = &RenameUser{Accounts: yyDollar[3].accountRenames} } - case 961: + case 1034: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4874 +//line sql.y:5483 { yyVAL.ddl = &DDL{Action: RenameStr, FromTables: TableNames{yyDollar[1].tableName}, ToTables: TableNames{yyDollar[3].tableName}} } - case 962: + case 1035: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4878 +//line sql.y:5487 { yyVAL.ddl = yyDollar[1].ddl yyVAL.ddl.FromTables = append(yyVAL.ddl.FromTables, yyDollar[3].tableName) yyVAL.ddl.ToTables = append(yyVAL.ddl.ToTables, yyDollar[5].tableName) } - case 963: + case 1036: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4886 +//line sql.y:5495 { yyVAL.accountRenames = []AccountRename{{From: yyDollar[1].accountName, To: yyDollar[3].accountName}} } - case 964: + case 1037: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4890 +//line sql.y:5499 { yyVAL.accountRenames = append(yyDollar[1].accountRenames, AccountRename{From: yyDollar[3].accountName, To: yyDollar[5].accountName}) } - case 965: + case 1038: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4896 +//line sql.y:5505 { var exists bool if yyDollar[3].byt != 0 { @@ -17185,17 +18709,17 @@ yydefault: } yyVAL.statement = &DDL{Action: DropStr, FromTables: yyDollar[4].tableNames, IfExists: exists} } - case 966: + case 1039: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:4904 +//line sql.y:5513 { // For consistency, we always use a AlterTable for ALTER TABLE equivalent statements ddl := &DDL{Action: AlterStr, Table: yyDollar[5].tableName, IndexSpec: &IndexSpec{Action: DropStr, ToName: yyDollar[3].colIdent}} yyVAL.statement = &AlterTable{Table: yyDollar[5].tableName, Statements: []*DDL{ddl}} } - case 967: + case 1040: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4910 +//line sql.y:5519 { var exists bool if yyDollar[3].byt != 0 { @@ -17203,29 +18727,29 @@ yydefault: } yyVAL.statement = &DDL{Action: DropStr, FromViews: yyDollar[4].tableNames, IfExists: exists} } - case 968: + case 1041: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4918 +//line sql.y:5527 { var exists bool if yyDollar[3].byt != 0 { exists = true } - yyVAL.statement = &DBDDL{Action: DropStr, DBName: string(yyDollar[4].bytes), IfExists: exists} + yyVAL.statement = &DBDDL{Action: DropStr, SchemaOrDatabase: "database", DBName: string(yyDollar[4].bytes), IfExists: exists} } - case 969: + case 1042: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4926 +//line sql.y:5535 { var exists bool if yyDollar[3].byt != 0 { exists = true } - yyVAL.statement = &DBDDL{Action: DropStr, DBName: string(yyDollar[4].bytes), IfExists: exists} + yyVAL.statement = &DBDDL{Action: DropStr, SchemaOrDatabase: "schema", DBName: string(yyDollar[4].bytes), IfExists: exists} } - case 970: + case 1043: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4934 +//line sql.y:5543 { var exists bool if yyDollar[3].byt != 0 { @@ -17233,9 +18757,9 @@ yydefault: } yyVAL.statement = &DDL{Action: DropStr, TriggerSpec: &TriggerSpec{TrigName: yyDollar[4].triggerName}, IfExists: exists} } - case 971: + case 1044: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4942 +//line sql.y:5551 { var exists bool if yyDollar[3].byt != 0 { @@ -17243,9 +18767,9 @@ yydefault: } yyVAL.statement = &DDL{Action: DropStr, ProcedureSpec: &ProcedureSpec{ProcName: yyDollar[4].procedureName}, IfExists: exists} } - case 972: + case 1045: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4950 +//line sql.y:5559 { var exists bool if yyDollar[3].byt != 0 { @@ -17253,9 +18777,9 @@ yydefault: } yyVAL.statement = &DropUser{IfExists: exists, AccountNames: yyDollar[4].accountNames} } - case 973: + case 1046: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4958 +//line sql.y:5567 { var exists bool if yyDollar[3].byt != 0 { @@ -17263,9 +18787,9 @@ yydefault: } yyVAL.statement = &DropRole{IfExists: exists, Roles: yyDollar[4].accountNames} } - case 974: + case 1047: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:4966 +//line sql.y:5575 { var exists bool if yyDollar[3].byt != 0 { @@ -17273,756 +18797,780 @@ yydefault: } yyVAL.statement = &DDL{Action: DropStr, EventSpec: &EventSpec{EventName: yyDollar[4].eventName}, IfExists: exists} } - case 975: + case 1048: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:4975 +//line sql.y:5584 { } - case 976: + case 1049: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4979 +//line sql.y:5588 { yyVAL.ReferenceAction = Restrict } - case 977: + case 1050: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:4983 +//line sql.y:5592 { yyVAL.ReferenceAction = Cascade } - case 978: + case 1051: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4989 +//line sql.y:5598 { yyVAL.statement = &DDL{Action: TruncateStr, Table: yyDollar[3].tableName} } - case 979: + case 1052: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:4993 +//line sql.y:5602 { yyVAL.statement = &DDL{Action: TruncateStr, Table: yyDollar[2].tableName} } - case 980: + case 1053: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:4999 +//line sql.y:5608 { yyVAL.statement = yyDollar[3].statement } - case 981: + case 1054: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:5005 +//line sql.y:5614 { yyVAL.statement = &Analyze{Tables: []TableName{yyDollar[1].tableName}, Action: UpdateStr, Columns: yyDollar[5].columns, Using: yyDollar[8].expr} } - case 982: + case 1055: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5009 +//line sql.y:5618 { yyVAL.statement = &Analyze{Tables: []TableName{yyDollar[1].tableName}, Action: DropStr, Columns: yyDollar[5].columns} } - case 983: + case 1056: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5013 +//line sql.y:5622 { yyVAL.statement = &Analyze{Tables: yyDollar[1].tableNames} } - case 988: + case 1061: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5025 +//line sql.y:5634 { yyVAL.statement = &Prepare{Name: string(yyDollar[2].bytes), Expr: string(yyDollar[4].bytes)} } - case 989: + case 1062: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5029 +//line sql.y:5638 { yyVAL.statement = &Prepare{Name: string(yyDollar[2].bytes), Expr: string(yyDollar[4].bytes)} } - case 990: + case 1063: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5033 +//line sql.y:5642 { yyVAL.statement = &Prepare{Name: string(yyDollar[2].bytes), Expr: string(yyDollar[4].str)} } - case 991: + case 1064: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5037 +//line sql.y:5646 { yyVAL.statement = &Prepare{Name: string(yyDollar[2].bytes), Expr: string(yyDollar[4].str)} } - case 992: + case 1065: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5043 +//line sql.y:5652 { yyVAL.strs = []string{yyDollar[1].str} } - case 993: + case 1066: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5047 +//line sql.y:5656 { yyVAL.strs = append(yyDollar[1].strs, yyDollar[3].str) } - case 994: + case 1067: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5054 +//line sql.y:5663 { yyVAL.str = string(yyDollar[1].bytes) } - case 995: + case 1068: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5058 +//line sql.y:5667 { yyVAL.str = string(yyDollar[1].bytes) } - case 996: + case 1069: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5064 +//line sql.y:5673 { yyVAL.statement = &Execute{Name: string(yyDollar[2].bytes)} } - case 997: + case 1070: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5068 +//line sql.y:5677 { yyVAL.statement = &Execute{Name: string(yyDollar[2].bytes)} } - case 998: + case 1071: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5072 +//line sql.y:5681 { yyVAL.statement = &Execute{Name: string(yyDollar[2].bytes), VarList: yyDollar[4].strs} } - case 999: + case 1072: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5076 +//line sql.y:5685 { yyVAL.statement = &Execute{Name: string(yyDollar[2].bytes), VarList: yyDollar[4].strs} } - case 1000: + case 1073: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5082 +//line sql.y:5691 { yyVAL.statement = &Deallocate{Name: string(yyDollar[3].bytes)} } - case 1001: + case 1074: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5086 +//line sql.y:5695 { yyVAL.statement = &Deallocate{Name: string(yyDollar[3].bytes)} } - case 1002: + case 1075: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5090 +//line sql.y:5699 { yyVAL.statement = &Deallocate{Name: string(yyDollar[3].bytes)} } - case 1003: + case 1076: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5094 +//line sql.y:5703 { yyVAL.statement = &Deallocate{Name: string(yyDollar[3].bytes)} } - case 1004: + case 1077: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5100 +//line sql.y:5709 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)} } - case 1005: + case 1078: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5105 +//line sql.y:5714 { yyVAL.statement = &Show{Type: CharsetStr, Filter: yyDollar[4].showFilter} } - case 1006: + case 1079: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5109 +//line sql.y:5718 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), Filter: yyDollar[3].showFilter} } - case 1007: + case 1080: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5113 +//line sql.y:5722 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), IfNotExists: yyDollar[4].byt == 1, Database: string(yyDollar[5].bytes)} } - case 1008: + case 1081: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5117 +//line sql.y:5726 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), IfNotExists: yyDollar[4].byt == 1, Database: string(yyDollar[5].bytes)} } - case 1009: + case 1082: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5121 +//line sql.y:5730 { showTablesOpt := &ShowTablesOpt{AsOf: yyDollar[5].expr} yyVAL.statement = &Show{Type: CreateTableStr, Table: yyDollar[4].tableName, ShowTablesOpt: showTablesOpt} } - case 1010: + case 1083: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5126 +//line sql.y:5735 { yyVAL.statement = &Show{Type: CreateProcedureStr, Table: yyDollar[4].tableName} } - case 1011: + case 1084: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5130 +//line sql.y:5739 { yyVAL.statement = &Show{Type: CreateTriggerStr, Table: yyDollar[4].tableName} } - case 1012: + case 1085: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5134 +//line sql.y:5743 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Table: yyDollar[4].tableName} } - case 1013: + case 1086: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5138 +//line sql.y:5747 { yyVAL.statement = &Show{Type: CreateEventStr, Table: yyDollar[4].tableName} } - case 1014: + case 1087: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5142 +//line sql.y:5751 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), Filter: yyDollar[3].showFilter} } - case 1015: + case 1088: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5146 +//line sql.y:5755 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)} } - case 1016: + case 1089: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5150 +//line sql.y:5759 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)} } - case 1017: + case 1090: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5154 +//line sql.y:5763 { yyVAL.statement = &Show{Type: IndexStr, Table: yyDollar[4].tableName, Database: yyDollar[5].str, ShowIndexFilterOpt: yyDollar[6].expr} } - case 1018: + case 1091: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5158 +//line sql.y:5767 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)} } - case 1019: + case 1092: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5162 +//line sql.y:5771 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Filter: yyDollar[4].showFilter} } - case 1020: + case 1093: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5166 +//line sql.y:5775 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)} } - case 1021: + case 1094: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5170 +//line sql.y:5779 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Filter: yyDollar[4].showFilter} } - case 1022: + case 1095: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5174 +//line sql.y:5783 { yyVAL.statement = &Show{Scope: yyDollar[2].str, Type: string(yyDollar[3].bytes), Filter: yyDollar[4].showFilter} } - case 1023: + case 1096: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5178 +//line sql.y:5787 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes), Database: yyDollar[4].str, Filter: yyDollar[5].showFilter} } - case 1024: + case 1097: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:5182 +//line sql.y:5791 { showTablesOpt := &ShowTablesOpt{DbName: yyDollar[6].str, AsOf: yyDollar[7].expr, Filter: yyDollar[8].showFilter} yyVAL.statement = &Show{Type: string(yyDollar[3].str), ShowTablesOpt: showTablesOpt, Table: yyDollar[5].tableName, Full: yyDollar[2].boolean} } - case 1025: + case 1098: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5187 +//line sql.y:5796 { showTablesOpt := &ShowTablesOpt{DbName: yyDollar[4].str, Filter: yyDollar[6].showFilter, AsOf: yyDollar[5].expr} yyVAL.statement = &Show{Type: string(yyDollar[3].bytes), ShowTablesOpt: showTablesOpt, Full: yyDollar[2].boolean} } - case 1026: + case 1099: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5192 +//line sql.y:5801 { yyVAL.statement = &Show{Type: string(yyDollar[3].bytes), Full: yyDollar[2].boolean} } - case 1027: + case 1100: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5196 +//line sql.y:5805 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), ShowTablesOpt: &ShowTablesOpt{DbName: yyDollar[3].str, Filter: yyDollar[4].showFilter}} } - case 1028: + case 1101: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5200 +//line sql.y:5809 { yyVAL.statement = &Show{Scope: yyDollar[2].str, Type: string(yyDollar[3].bytes), Filter: yyDollar[4].showFilter} } - case 1029: + case 1102: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5204 +//line sql.y:5813 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)} } - case 1030: + case 1103: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5208 +//line sql.y:5817 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), ShowCollationFilterOpt: yyDollar[4].expr} } - case 1031: + case 1104: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5212 +//line sql.y:5821 { cmp := yyDollar[3].expr.(*ComparisonExpr) cmp.Left = &ColName{Name: NewColIdent("collation")} yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), ShowCollationFilterOpt: cmp} } - case 1032: + case 1105: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5218 +//line sql.y:5827 { yyVAL.statement = &ShowGrants{} } - case 1033: + case 1106: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5222 +//line sql.y:5831 { an := yyDollar[4].accountName yyVAL.statement = &ShowGrants{For: &an} } - case 1034: + case 1107: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5227 +//line sql.y:5836 { yyVAL.statement = &ShowGrants{CurrentUser: true} } - case 1035: + case 1108: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5231 +//line sql.y:5840 { an := yyDollar[4].accountName yyVAL.statement = &ShowGrants{For: &an, Using: yyDollar[6].accountNames} } - case 1036: + case 1109: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5236 +//line sql.y:5845 { yyVAL.statement = &ShowPrivileges{} } - case 1037: + case 1110: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5240 +//line sql.y:5849 { yyVAL.statement = &Show{Type: string(yyDollar[6].bytes), CountStar: true} } - case 1038: + case 1111: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5244 +//line sql.y:5853 { yyVAL.statement = &Show{Type: string(yyDollar[6].bytes), CountStar: true} } - case 1039: + case 1112: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5248 +//line sql.y:5857 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), Limit: yyDollar[3].limit} } - case 1040: + case 1113: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5252 +//line sql.y:5861 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), Limit: yyDollar[3].limit} } - case 1041: + case 1114: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5256 +//line sql.y:5865 { yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), ShowTablesOpt: &ShowTablesOpt{DbName: yyDollar[3].str, Filter: yyDollar[4].showFilter}} } - case 1042: + case 1115: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:5869 + { + yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)} + } + case 1116: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:5873 + { + yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes) + " " + string(yyDollar[4].bytes)} + } + case 1117: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5877 + { + yyVAL.statement = &Show{Type: "BINARY LOG STATUS"} + } + case 1118: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:5881 + { + yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)} + } + case 1119: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5262 +//line sql.y:5887 { yyVAL.expr = &ComparisonExpr{Operator: LikeStr, Right: yyDollar[2].expr, Escape: yyDollar[3].expr} } - case 1043: + case 1120: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5268 +//line sql.y:5893 { yyVAL.boolean = false } - case 1044: + case 1121: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5272 +//line sql.y:5897 { yyVAL.boolean = true } - case 1045: + case 1122: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5278 +//line sql.y:5903 { yyVAL.str = string(yyDollar[1].bytes) } - case 1046: + case 1123: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5282 +//line sql.y:5907 { yyVAL.str = string(yyDollar[1].bytes) } - case 1047: + case 1124: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5288 +//line sql.y:5913 { yyVAL.str = "" } - case 1048: + case 1125: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5292 +//line sql.y:5917 { yyVAL.str = yyDollar[2].tableIdent.v } - case 1049: + case 1126: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5296 +//line sql.y:5921 { yyVAL.str = yyDollar[2].tableIdent.v } - case 1050: + case 1127: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5302 +//line sql.y:5927 { yyVAL.showFilter = nil } - case 1051: + case 1128: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5306 +//line sql.y:5931 { yyVAL.showFilter = &ShowFilter{Like: string(yyDollar[2].bytes)} } - case 1052: + case 1129: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5310 +//line sql.y:5935 { yyVAL.showFilter = &ShowFilter{Like: string(yyDollar[3].bytes)} } - case 1053: + case 1130: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5314 +//line sql.y:5939 { yyVAL.showFilter = &ShowFilter{Filter: yyDollar[2].expr} } - case 1054: + case 1131: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5320 +//line sql.y:5945 { yyVAL.str = "" } - case 1055: + case 1132: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5324 +//line sql.y:5949 { yyVAL.str = SessionStr } - case 1056: + case 1133: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5328 +//line sql.y:5953 { yyVAL.str = GlobalStr } - case 1057: + case 1134: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5334 +//line sql.y:5959 { yyVAL.statement = &Use{DBName: yyDollar[2].tableIdent} } - case 1058: + case 1135: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5338 +//line sql.y:5963 { yyVAL.statement = &Use{DBName: TableIdent{v: yyDollar[2].tableIdent.v + "/" + yyDollar[4].tableIdent.v}} } - case 1059: + case 1136: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5342 +//line sql.y:5967 { yyVAL.statement = &Use{DBName: TableIdent{v: ""}} } - case 1060: + case 1137: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5347 +//line sql.y:5972 { yyVAL.bytes = nil } - case 1061: + case 1138: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5351 +//line sql.y:5976 { yyVAL.bytes = yyDollar[1].bytes } - case 1062: + case 1139: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5357 +//line sql.y:5982 { yyVAL.statement = &Begin{} } - case 1063: + case 1140: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5361 +//line sql.y:5986 { yyVAL.statement = yyDollar[1].statement } - case 1064: + case 1141: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5367 +//line sql.y:5992 { yyVAL.statement = &Begin{} } - case 1065: + case 1142: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5371 +//line sql.y:5996 { yyVAL.statement = &Begin{TransactionCharacteristic: TxReadWrite} } - case 1066: + case 1143: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5375 +//line sql.y:6000 { yyVAL.statement = &Begin{TransactionCharacteristic: TxReadOnly} } - case 1067: + case 1144: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5380 +//line sql.y:6005 { yyVAL.bytes = nil } - case 1068: + case 1145: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5384 +//line sql.y:6009 { yyVAL.bytes = nil } - case 1069: + case 1146: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5389 +//line sql.y:6014 { yyVAL.bytes = nil } - case 1070: + case 1147: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5393 +//line sql.y:6018 { yyVAL.bytes = nil } - case 1071: + case 1148: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5398 +//line sql.y:6023 { yyVAL.bytes = nil } - case 1072: + case 1149: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5402 +//line sql.y:6027 { yyVAL.bytes = nil } - case 1073: + case 1150: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5408 +//line sql.y:6033 { yyVAL.statement = &Commit{} } - case 1074: + case 1151: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5414 +//line sql.y:6039 { yyVAL.statement = &Rollback{} } - case 1075: + case 1152: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5420 +//line sql.y:6045 { yyVAL.statement = &Savepoint{Identifier: string(yyDollar[2].bytes)} } - case 1076: + case 1153: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5426 +//line sql.y:6051 { yyVAL.statement = &RollbackSavepoint{Identifier: string(yyDollar[3].bytes)} } - case 1077: + case 1154: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5430 +//line sql.y:6055 { yyVAL.statement = &RollbackSavepoint{Identifier: string(yyDollar[4].bytes)} } - case 1078: + case 1155: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5434 +//line sql.y:6059 { yyVAL.statement = &RollbackSavepoint{Identifier: string(yyDollar[4].bytes)} } - case 1079: + case 1156: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5438 +//line sql.y:6063 { yyVAL.statement = &RollbackSavepoint{Identifier: string(yyDollar[5].bytes)} } - case 1080: + case 1157: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5444 +//line sql.y:6069 { yyVAL.statement = &ReleaseSavepoint{Identifier: string(yyDollar[3].bytes)} } - case 1081: + case 1158: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5450 +//line sql.y:6075 { yyVAL.statement = &Explain{ExplainFormat: yyDollar[2].str, Statement: yyDollar[3].statement} } - case 1082: + case 1159: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5454 +//line sql.y:6079 { yyVAL.statement = &Explain{ExplainFormat: yyDollar[3].str, Statement: yyDollar[4].statement} } - case 1083: + case 1160: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5458 +//line sql.y:6083 { yyVAL.statement = &Explain{Analyze: true, ExplainFormat: TreeStr, Statement: yyDollar[3].selStmt} } - case 1084: + case 1161: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5464 +//line sql.y:6089 { yyVAL.statement = yyDollar[1].selStmt } - case 1088: + case 1165: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5472 +//line sql.y:6097 { yyVAL.str = "" } - case 1089: + case 1166: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5476 +//line sql.y:6101 { yyVAL.str = string(yyDollar[3].bytes) } - case 1093: + case 1170: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5488 +//line sql.y:6113 { showTablesOpt := &ShowTablesOpt{AsOf: yyDollar[3].expr} yyVAL.statement = &Show{Type: "columns", Table: yyDollar[2].tableName, ShowTablesOpt: showTablesOpt} } - case 1094: + case 1171: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5494 +//line sql.y:6119 { setAllowComments(yylex, true) } - case 1095: + case 1172: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5498 +//line sql.y:6123 { yyVAL.bytes2 = yyDollar[2].bytes2 setAllowComments(yylex, false) } - case 1096: + case 1173: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5504 +//line sql.y:6129 { yyVAL.bytes2 = nil } - case 1097: + case 1174: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5508 +//line sql.y:6133 { yyVAL.bytes2 = append(yyDollar[1].bytes2, yyDollar[2].bytes) } - case 1098: + case 1175: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5514 +//line sql.y:6139 { yyVAL.str = UnionStr } - case 1099: + case 1176: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5518 +//line sql.y:6143 { yyVAL.str = UnionAllStr } - case 1100: + case 1177: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5522 +//line sql.y:6147 { yyVAL.str = UnionDistinctStr } - case 1101: + case 1178: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5528 +//line sql.y:6153 { yyVAL.str = IntersectStr } - case 1102: + case 1179: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5532 +//line sql.y:6157 { yyVAL.str = IntersectAllStr } - case 1103: + case 1180: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5536 +//line sql.y:6161 { yyVAL.str = IntersectDistinctStr } - case 1104: + case 1181: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5542 +//line sql.y:6167 { yyVAL.str = ExceptStr } - case 1105: + case 1182: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5546 +//line sql.y:6171 { yyVAL.str = ExceptAllStr } - case 1106: + case 1183: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5550 +//line sql.y:6175 { yyVAL.str = ExceptDistinctStr } - case 1107: + case 1184: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5555 +//line sql.y:6180 { yyVAL.queryOpts = QueryOpts{} } - case 1108: + case 1185: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5559 +//line sql.y:6184 { opt := QueryOpts{All: true} if err := yyDollar[1].queryOpts.merge(opt); err != nil { @@ -18031,9 +19579,9 @@ yydefault: } yyVAL.queryOpts = yyDollar[1].queryOpts } - case 1109: + case 1186: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5568 +//line sql.y:6193 { opt := QueryOpts{Distinct: true} if err := yyDollar[1].queryOpts.merge(opt); err != nil { @@ -18042,9 +19590,9 @@ yydefault: } yyVAL.queryOpts = yyDollar[1].queryOpts } - case 1110: + case 1187: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5577 +//line sql.y:6202 { opt := QueryOpts{StraightJoinHint: true} if err := yyDollar[1].queryOpts.merge(opt); err != nil { @@ -18053,9 +19601,9 @@ yydefault: } yyVAL.queryOpts = yyDollar[1].queryOpts } - case 1111: + case 1188: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5586 +//line sql.y:6211 { opt := QueryOpts{SQLCalcFoundRows: true} if err := yyDollar[1].queryOpts.merge(opt); err != nil { @@ -18064,9 +19612,9 @@ yydefault: } yyVAL.queryOpts = yyDollar[1].queryOpts } - case 1112: + case 1189: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5595 +//line sql.y:6220 { opt := QueryOpts{SQLCache: true} if err := yyDollar[1].queryOpts.merge(opt); err != nil { @@ -18075,9 +19623,9 @@ yydefault: } yyVAL.queryOpts = yyDollar[1].queryOpts } - case 1113: + case 1190: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5604 +//line sql.y:6229 { opt := QueryOpts{SQLNoCache: true} if err := yyDollar[1].queryOpts.merge(opt); err != nil { @@ -18086,27 +19634,27 @@ yydefault: } yyVAL.queryOpts = yyDollar[1].queryOpts } - case 1114: + case 1191: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5614 +//line sql.y:6239 { yyVAL.str = "" } - case 1115: + case 1192: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5618 +//line sql.y:6243 { yyVAL.str = AllStr } - case 1116: + case 1193: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5622 +//line sql.y:6247 { yyVAL.str = DistinctStr } - case 1117: + case 1194: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5628 +//line sql.y:6253 { if ae, ok := yyDollar[2].selectExpr.(*AliasedExpr); ok { ae.StartParsePos = yyDollar[1].int @@ -18114,9 +19662,9 @@ yydefault: } yyVAL.selectExprs = SelectExprs{yyDollar[2].selectExpr} } - case 1118: + case 1195: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5636 +//line sql.y:6261 { if ae, ok := yyDollar[4].selectExpr.(*AliasedExpr); ok { ae.StartParsePos = yyDollar[3].int @@ -18124,129 +19672,129 @@ yydefault: } yyVAL.selectExprs = append(yyVAL.selectExprs, yyDollar[4].selectExpr) } - case 1119: + case 1196: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5647 +//line sql.y:6272 { yyVAL.selectExpr = &StarExpr{} } - case 1120: + case 1197: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5651 +//line sql.y:6276 { yyVAL.selectExpr = &AliasedExpr{Expr: yyDollar[1].expr} } - case 1121: + case 1198: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5655 +//line sql.y:6280 { yyVAL.selectExpr = &StarExpr{TableName: TableName{Name: yyDollar[1].tableIdent}} } - case 1122: + case 1199: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5659 +//line sql.y:6284 { - yyVAL.selectExpr = &StarExpr{TableName: TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}} + yyVAL.selectExpr = &StarExpr{TableName: TableName{DbQualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}} } - case 1123: + case 1200: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5665 +//line sql.y:6290 { yyVAL.selectExpr = &StarExpr{} } - case 1124: + case 1201: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5669 +//line sql.y:6294 { yyVAL.selectExpr = &AliasedExpr{Expr: yyDollar[1].expr, As: yyDollar[2].colIdent} } - case 1125: + case 1202: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5673 +//line sql.y:6298 { yyVAL.selectExpr = &StarExpr{TableName: TableName{Name: yyDollar[1].tableIdent}} } - case 1126: + case 1203: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5677 +//line sql.y:6302 { - yyVAL.selectExpr = &StarExpr{TableName: TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}} + yyVAL.selectExpr = &StarExpr{TableName: TableName{DbQualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}} } - case 1127: + case 1204: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5683 +//line sql.y:6308 { yyVAL.over = &Over{NameRef: yyDollar[2].colIdent} } - case 1128: + case 1205: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5687 +//line sql.y:6312 { yyVAL.over = (*Over)(yyDollar[2].windowDef) } - case 1129: + case 1206: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5693 +//line sql.y:6318 { yyVAL.windowDef = &WindowDef{NameRef: yyDollar[2].colIdent, PartitionBy: yyDollar[3].exprs, OrderBy: yyDollar[4].orderBy, Frame: yyDollar[5].frame} } - case 1130: + case 1207: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5698 +//line sql.y:6323 { yyVAL.colIdent = ColIdent{} } - case 1131: + case 1208: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5701 +//line sql.y:6326 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1132: + case 1209: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5706 +//line sql.y:6331 { yyVAL.exprs = nil } - case 1133: + case 1210: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5710 +//line sql.y:6335 { yyVAL.exprs = yyDollar[3].exprs } - case 1134: + case 1211: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5715 +//line sql.y:6340 { yyVAL.over = nil } - case 1135: + case 1212: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5719 +//line sql.y:6344 { yyVAL.over = yyDollar[1].over } - case 1136: + case 1213: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5724 +//line sql.y:6349 { yyVAL.frame = nil } - case 1137: + case 1214: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5728 +//line sql.y:6353 { yyVAL.frame = &Frame{Unit: RowsUnit, Extent: yyDollar[2].frameExtent} } - case 1138: + case 1215: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5732 +//line sql.y:6357 { yyVAL.frame = &Frame{Unit: RangeUnit, Extent: yyDollar[2].frameExtent} } - case 1139: + case 1216: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5739 +//line sql.y:6364 { startBound := yyDollar[2].frameBound endBound := yyDollar[4].frameBound @@ -18269,9 +19817,9 @@ yydefault: } yyVAL.frameExtent = &FrameExtent{Start: startBound, End: endBound} } - case 1140: + case 1217: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5762 +//line sql.y:6387 { startBound := yyDollar[1].frameBound switch { @@ -18284,149 +19832,149 @@ yydefault: } yyVAL.frameExtent = &FrameExtent{Start: startBound} } - case 1141: + case 1218: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5777 +//line sql.y:6402 { yyVAL.frameBound = &FrameBound{Type: UnboundedPreceding} } - case 1142: + case 1219: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5781 +//line sql.y:6406 { yyVAL.frameBound = &FrameBound{Type: UnboundedFollowing} } - case 1143: + case 1220: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5785 +//line sql.y:6410 { yyVAL.frameBound = &FrameBound{Type: CurrentRow} } - case 1144: + case 1221: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5789 +//line sql.y:6414 { yyVAL.frameBound = &FrameBound{ Expr: yyDollar[1].expr, Type: ExprPreceding, } } - case 1145: + case 1222: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5796 +//line sql.y:6421 { yyVAL.frameBound = &FrameBound{ Expr: yyDollar[1].expr, Type: ExprFollowing, } } - case 1146: + case 1223: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5804 +//line sql.y:6429 { yyVAL.window = nil } - case 1147: + case 1224: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5807 +//line sql.y:6432 { yyVAL.window = yyDollar[2].window } - case 1148: + case 1225: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5813 +//line sql.y:6438 { yyVAL.window = Window{yyDollar[1].windowDef} } - case 1149: + case 1226: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5816 +//line sql.y:6441 { yyVAL.window = append(yyDollar[1].window, yyDollar[3].windowDef) } - case 1150: + case 1227: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5822 +//line sql.y:6447 { def := yyDollar[3].windowDef def.Name = yyDollar[1].colIdent yyVAL.windowDef = def } - case 1172: + case 1249: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5856 +//line sql.y:6481 { yyVAL.expr = NewIntVal(yyDollar[1].bytes) } - case 1173: + case 1250: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5860 +//line sql.y:6485 { yyVAL.expr = &IntervalExpr{Expr: yyDollar[2].expr, Unit: string(yyDollar[3].bytes)} } - case 1174: + case 1251: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:5865 +//line sql.y:6490 { yyVAL.colIdent = ColIdent{} } - case 1175: + case 1252: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5869 +//line sql.y:6494 { yyVAL.colIdent = yyDollar[1].colIdent } - case 1176: + case 1253: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5873 +//line sql.y:6498 { yyVAL.colIdent = yyDollar[2].colIdent } - case 1177: + case 1254: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5877 +//line sql.y:6502 { yyVAL.colIdent = NewColIdent(string(yyDollar[2].bytes)) } - case 1178: + case 1255: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5883 +//line sql.y:6508 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1179: + case 1256: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5887 +//line sql.y:6512 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1180: + case 1257: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5891 +//line sql.y:6516 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1181: + case 1258: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5897 +//line sql.y:6522 { yyVAL.tableExprs = TableExprs{yyDollar[1].tableExpr} } - case 1182: + case 1259: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5901 +//line sql.y:6526 { yyVAL.tableExprs = append(yyVAL.tableExprs, yyDollar[3].tableExpr) } - case 1185: + case 1262: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5911 +//line sql.y:6536 { yyVAL.tableExpr = yyDollar[1].aliasedTableName } - case 1186: + case 1263: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5915 +//line sql.y:6540 { switch n := yyDollar[1].simpleTableExpr.(type) { case *Subquery: @@ -18436,9 +19984,9 @@ yydefault: } yyVAL.tableExpr = &AliasedTableExpr{Lateral: false, Expr: yyDollar[1].simpleTableExpr, As: yyDollar[3].tableIdent} } - case 1187: + case 1264: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:5925 +//line sql.y:6550 { switch n := yyDollar[2].simpleTableExpr.(type) { case *Subquery: @@ -18448,424 +19996,422 @@ yydefault: } yyVAL.tableExpr = &AliasedTableExpr{Lateral: true, Expr: yyDollar[2].simpleTableExpr, As: yyDollar[4].tableIdent} } - case 1188: + case 1265: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5935 +//line sql.y:6560 { // missed alias for subquery yylex.Error("Every derived table must have its own alias") return 1 } - case 1189: + case 1266: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5941 +//line sql.y:6566 { // missed alias for subquery yylex.Error("Every derived table must have its own alias") return 1 } - case 1190: + case 1267: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5947 +//line sql.y:6572 { yyVAL.tableExpr = &ParenTableExpr{Exprs: yyDollar[2].tableExprs} } - case 1193: + case 1270: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5956 +//line sql.y:6580 { yyVAL.simpleTableExpr = &ValuesStatement{Rows: yyDollar[2].values} } - case 1194: + case 1271: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5962 +//line sql.y:6586 { yyVAL.values = Values{yyDollar[2].valTuple} } - case 1195: + case 1272: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5966 +//line sql.y:6590 { yyVAL.values = append(yyVAL.values, yyDollar[4].valTuple) } - case 1196: + case 1273: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:6595 + { + } + case 1274: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:6597 + { + } + case 1275: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5972 +//line sql.y:6601 { yyVAL.aliasedTableName = yyDollar[2].aliasedTableName yyVAL.aliasedTableName.Expr = yyDollar[1].tableName } - case 1197: + case 1276: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:5977 +//line sql.y:6606 { yyVAL.aliasedTableName = yyDollar[6].aliasedTableName yyVAL.aliasedTableName.Expr = yyDollar[1].tableName yyVAL.aliasedTableName.Partitions = yyDollar[4].partitions } - case 1198: + case 1277: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:5987 +//line sql.y:6616 { yyVAL.aliasedTableName = &AliasedTableExpr{Hints: yyDollar[1].indexHints} } - case 1199: + case 1278: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:5991 +//line sql.y:6620 { yyVAL.aliasedTableName = &AliasedTableExpr{As: yyDollar[2].tableIdent, Hints: yyDollar[3].indexHints} } - case 1200: + case 1279: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:5995 +//line sql.y:6624 { yyVAL.aliasedTableName = &AliasedTableExpr{AsOf: yyDollar[1].asOf, Hints: yyDollar[2].indexHints} } - case 1201: + case 1280: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:5999 +//line sql.y:6628 { yyVAL.aliasedTableName = &AliasedTableExpr{AsOf: yyDollar[1].asOf, As: yyDollar[3].tableIdent, Hints: yyDollar[4].indexHints} } - case 1202: + case 1281: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6005 +//line sql.y:6634 { yyVAL.asOf = yyDollar[1].asOf } - case 1203: + case 1282: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6009 +//line sql.y:6638 { yyVAL.asOf = yyDollar[1].asOf } - case 1204: + case 1283: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6013 +//line sql.y:6642 { yyVAL.asOf = yyDollar[1].asOf } - case 1205: + case 1284: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6017 +//line sql.y:6646 { yyVAL.asOf = yyDollar[1].asOf } - case 1206: + case 1285: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6021 +//line sql.y:6650 { yyVAL.asOf = yyDollar[1].asOf } - case 1207: + case 1286: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6027 +//line sql.y:6656 { yyVAL.asOf = &AsOf{Start: yyDollar[3].expr, End: yyDollar[5].expr, EndInclusive: true} } - case 1208: + case 1287: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6031 +//line sql.y:6660 { yyVAL.asOf = &AsOf{Start: yyDollar[3].expr, End: yyDollar[5].expr} } - case 1209: + case 1288: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:6035 +//line sql.y:6664 { yyVAL.asOf = &AsOf{Start: yyDollar[5].expr, End: yyDollar[7].expr, StartInclusive: true, EndInclusive: true} } - case 1210: + case 1289: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6041 +//line sql.y:6670 { yyVAL.asOf = &AsOf{Start: yyDollar[3].expr, End: yyDollar[5].expr, EndInclusive: true} } - case 1211: + case 1290: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6045 +//line sql.y:6674 { yyVAL.asOf = &AsOf{Start: yyDollar[3].expr, End: yyDollar[5].expr} } - case 1212: + case 1291: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:6049 +//line sql.y:6678 { yyVAL.asOf = &AsOf{Start: yyDollar[5].expr, End: yyDollar[7].expr, StartInclusive: true, EndInclusive: true} } - case 1213: + case 1292: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6053 +//line sql.y:6682 { yyVAL.asOf = &AsOf{Start: yyDollar[3].expr, End: yyDollar[5].expr, EndInclusive: true} } - case 1214: + case 1293: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6057 +//line sql.y:6686 { yyVAL.asOf = &AsOf{Start: yyDollar[3].expr, End: yyDollar[5].expr} } - case 1215: + case 1294: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:6061 +//line sql.y:6690 { yyVAL.asOf = &AsOf{Start: yyDollar[5].expr, End: yyDollar[7].expr, StartInclusive: true, EndInclusive: true} } - case 1216: + case 1295: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6067 +//line sql.y:6696 { yyVAL.asOf = &AsOf{All: true} } - case 1217: + case 1296: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6073 +//line sql.y:6702 { yyVAL.asOf = &AsOf{All: true} } - case 1218: + case 1297: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6077 +//line sql.y:6706 { yyVAL.asOf = &AsOf{All: true} } - case 1219: + case 1298: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6083 +//line sql.y:6712 { yyVAL.asOf = &AsOf{Time: yyDollar[3].expr} } - case 1220: + case 1299: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6087 +//line sql.y:6716 { yyVAL.asOf = &AsOf{Time: yyDollar[4].expr} } - case 1221: + case 1300: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6091 +//line sql.y:6720 { yyVAL.asOf = &AsOf{Time: yyDollar[4].expr} } - case 1222: + case 1301: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6096 +//line sql.y:6725 { yyVAL.expr = nil } - case 1223: + case 1302: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6100 +//line sql.y:6729 { yyVAL.expr = yyDollar[1].asOf.Time } - case 1224: + case 1303: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6106 +//line sql.y:6735 { yyVAL.columns = yyDollar[2].columns } - case 1225: + case 1304: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6110 +//line sql.y:6739 { yyVAL.columns = yyDollar[1].columns } - case 1226: + case 1305: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6115 +//line sql.y:6744 { yyVAL.columns = nil } - case 1227: + case 1306: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6119 +//line sql.y:6748 { yyVAL.columns = yyDollar[2].columns } - case 1228: + case 1307: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6125 +//line sql.y:6754 { yyVAL.columns = Columns{yyDollar[1].colIdent} } - case 1229: + case 1308: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6129 +//line sql.y:6758 { yyVAL.columns = append(yyVAL.columns, yyDollar[3].colIdent) } - case 1230: + case 1309: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6135 +//line sql.y:6764 { yyVAL.partitions = Partitions{yyDollar[1].colIdent} } - case 1231: + case 1310: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6139 +//line sql.y:6768 { yyVAL.partitions = append(yyVAL.partitions, yyDollar[3].colIdent) } - case 1232: + case 1311: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6145 +//line sql.y:6774 { yyVAL.tableExpr = &TableFuncExpr{Name: string(yyDollar[1].bytes), Exprs: yyDollar[3].selectExprs} } - case 1233: + case 1312: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6149 +//line sql.y:6778 { yyVAL.tableExpr = &TableFuncExpr{Name: string(yyDollar[1].bytes), Exprs: yyDollar[3].selectExprs, Alias: yyDollar[6].tableIdent} } - case 1234: + case 1313: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6163 +//line sql.y:6792 { yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr, Condition: yyDollar[4].joinCondition} } - case 1235: + case 1314: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6167 +//line sql.y:6796 { yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr, Condition: yyDollar[4].joinCondition} } - case 1236: + case 1315: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6171 +//line sql.y:6800 { yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr, Condition: yyDollar[4].joinCondition} } - case 1237: + case 1316: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6175 +//line sql.y:6804 { yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr} } - case 1238: + case 1317: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6181 +//line sql.y:6810 { yyVAL.joinCondition = JoinCondition{On: yyDollar[2].expr} } - case 1239: + case 1318: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6183 +//line sql.y:6812 { yyVAL.joinCondition = JoinCondition{Using: yyDollar[3].columns} } - case 1240: + case 1319: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6187 +//line sql.y:6816 { yyVAL.joinCondition = JoinCondition{} } - case 1241: + case 1320: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6189 +//line sql.y:6818 { yyVAL.joinCondition = yyDollar[1].joinCondition } - case 1242: + case 1321: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6193 +//line sql.y:6822 { yyVAL.joinCondition = JoinCondition{} } - case 1243: + case 1322: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6195 +//line sql.y:6824 { yyVAL.joinCondition = JoinCondition{On: yyDollar[2].expr} } - case 1244: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6198 - { - yyVAL.empty = struct{}{} - } - case 1245: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6200 - { - yyVAL.empty = struct{}{} - } - case 1247: + case 1324: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6205 +//line sql.y:6829 { yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes)) } - case 1248: + case 1325: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6211 +//line sql.y:6835 { yyVAL.str = JoinStr } - case 1249: + case 1326: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6215 +//line sql.y:6839 { yyVAL.str = JoinStr } - case 1250: + case 1327: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6219 +//line sql.y:6843 { yyVAL.str = JoinStr } - case 1251: + case 1328: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6225 +//line sql.y:6849 { yyVAL.str = StraightJoinStr } - case 1252: + case 1329: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6231 +//line sql.y:6855 { yyVAL.str = LeftJoinStr } - case 1253: + case 1330: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6235 +//line sql.y:6859 { yyVAL.str = LeftJoinStr } - case 1254: + case 1331: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6239 +//line sql.y:6863 { yyVAL.str = RightJoinStr } - case 1255: + case 1332: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6243 +//line sql.y:6867 { yyVAL.str = RightJoinStr } - case 1256: + case 1333: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6247 +//line sql.y:6871 { yyVAL.str = FullOuterJoinStr } - case 1257: + case 1334: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6251 +//line sql.y:6875 { yyVAL.str = FullOuterJoinStr } - case 1258: + case 1335: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6257 +//line sql.y:6881 { yyVAL.str = NaturalJoinStr } - case 1259: + case 1336: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6261 +//line sql.y:6885 { if yyDollar[2].str == LeftJoinStr { yyVAL.str = NaturalLeftJoinStr @@ -18873,709 +20419,715 @@ yydefault: yyVAL.str = NaturalRightJoinStr } } - case 1260: + case 1337: yyDollar = yyS[yypt-12 : yypt+1] -//line sql.y:6271 +//line sql.y:6895 { yyDollar[8].JSONTableSpec.Path = string(yyDollar[5].bytes) yyVAL.tableExpr = &JSONTableExpr{Data: yyDollar[3].expr, Spec: yyDollar[8].JSONTableSpec, Alias: yyDollar[12].tableIdent} } - case 1261: + case 1338: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6278 +//line sql.y:6902 { yyVAL.JSONTableSpec = &JSONTableSpec{} yyVAL.JSONTableSpec.AddColumn(yyDollar[1].JSONTableColDef) } - case 1262: + case 1339: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6283 +//line sql.y:6907 { yyVAL.JSONTableSpec.AddColumn(yyDollar[3].JSONTableColDef) } - case 1263: + case 1340: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6289 +//line sql.y:6913 { yyVAL.JSONTableColDef = &JSONTableColDef{Name: yyDollar[1].colIdent, Type: yyDollar[2].columnType, Opts: yyDollar[3].JSONTableColOpts} } - case 1264: + case 1341: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6293 +//line sql.y:6917 { yyVAL.JSONTableColDef = &JSONTableColDef{Name: yyDollar[1].colIdent, Type: ColumnType{Type: "INTEGER", Unsigned: true, Autoincrement: true}} } - case 1265: + case 1342: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6297 +//line sql.y:6921 { yyDollar[5].JSONTableSpec.Path = string(yyDollar[2].bytes) yyVAL.JSONTableColDef = &JSONTableColDef{Spec: yyDollar[5].JSONTableSpec} } - case 1266: + case 1343: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:6302 +//line sql.y:6926 { yyDollar[6].JSONTableSpec.Path = string(yyDollar[3].bytes) yyVAL.JSONTableColDef = &JSONTableColDef{Spec: yyDollar[6].JSONTableSpec} } - case 1267: + case 1344: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6309 +//line sql.y:6933 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes)} } - case 1268: + case 1345: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6313 +//line sql.y:6937 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ValOnEmpty: yyDollar[3].expr} } - case 1269: + case 1346: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6317 +//line sql.y:6941 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ValOnError: yyDollar[3].expr} } - case 1270: + case 1347: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6321 +//line sql.y:6945 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ValOnEmpty: yyDollar[3].expr, ValOnError: yyDollar[4].expr} } - case 1271: + case 1348: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6325 +//line sql.y:6949 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ValOnEmpty: yyDollar[4].expr, ValOnError: yyDollar[3].expr} } - case 1272: + case 1349: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6329 +//line sql.y:6953 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ErrorOnEmpty: true} } - case 1273: + case 1350: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6333 +//line sql.y:6957 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ErrorOnError: true} } - case 1274: + case 1351: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:6337 +//line sql.y:6961 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ErrorOnEmpty: true, ErrorOnError: true} } - case 1275: + case 1352: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:6341 +//line sql.y:6965 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[2].bytes), ErrorOnEmpty: true, ErrorOnError: true} } - case 1276: + case 1353: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6345 +//line sql.y:6969 { yyVAL.JSONTableColOpts = JSONTableColOpts{Path: string(yyDollar[3].bytes), Exists: true} } - case 1277: + case 1354: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6351 +//line sql.y:6975 { yyVAL.expr = &NullVal{} } - case 1278: + case 1355: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6355 +//line sql.y:6979 { yyVAL.expr = yyDollar[2].expr } - case 1279: + case 1356: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6361 +//line sql.y:6985 { yyVAL.expr = &NullVal{} } - case 1280: + case 1357: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6365 +//line sql.y:6989 { yyVAL.expr = yyDollar[2].expr } - case 1281: + case 1358: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6371 +//line sql.y:6995 { yyVAL.triggerName = TriggerName{Name: yyDollar[1].colIdent} } - case 1282: + case 1359: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6375 +//line sql.y:6999 { yyVAL.triggerName = TriggerName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].colIdent} } - case 1283: + case 1360: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6381 +//line sql.y:7005 { yyVAL.tableName = yyDollar[3].tableName } - case 1284: + case 1361: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6387 +//line sql.y:7011 { yyVAL.tableName = yyDollar[2].tableName } - case 1285: + case 1362: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6391 +//line sql.y:7015 { yyVAL.tableName = yyDollar[1].tableName } - case 1286: + case 1363: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6397 +//line sql.y:7021 { yyVAL.tableName = TableName{Name: yyDollar[1].tableIdent} } - case 1287: + case 1364: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6401 +//line sql.y:7025 { - yyVAL.tableName = TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent} + yyVAL.tableName = TableName{DbQualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent} } - case 1288: + case 1365: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6405 +//line sql.y:7029 { yyVAL.tableName = TableName{Name: NewTableIdent(string(yyDollar[1].bytes))} } - case 1289: + case 1366: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6409 +//line sql.y:7033 { yyVAL.tableName = TableName{Name: NewTableIdent(string(yyDollar[1].bytes))} } - case 1290: + case 1367: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6413 +//line sql.y:7037 { yyVAL.tableName = TableName{Name: NewTableIdent(string(yyDollar[1].bytes))} } - case 1291: + case 1368: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:7041 + { + yyVAL.tableName = TableName{Name: NewTableIdent(string(yyDollar[1].bytes))} + } + case 1369: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6419 +//line sql.y:7047 { yyVAL.procedureName = ProcedureName{Name: yyDollar[1].colIdent} } - case 1292: + case 1370: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6423 +//line sql.y:7051 { yyVAL.procedureName = ProcedureName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].colIdent} } - case 1293: + case 1371: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6429 +//line sql.y:7057 { yyVAL.tableName = TableName{Name: yyDollar[1].tableIdent} } - case 1294: + case 1372: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6434 +//line sql.y:7062 { yyVAL.indexHints = nil } - case 1295: + case 1373: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6438 +//line sql.y:7066 { yyVAL.indexHints = &IndexHints{Type: UseStr, Indexes: yyDollar[4].columns} } - case 1296: + case 1374: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6442 +//line sql.y:7070 { yyVAL.indexHints = &IndexHints{Type: IgnoreStr, Indexes: yyDollar[4].columns} } - case 1297: + case 1375: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6446 +//line sql.y:7074 { yyVAL.indexHints = &IndexHints{Type: ForceStr, Indexes: yyDollar[4].columns} } - case 1298: + case 1376: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6451 +//line sql.y:7079 { yyVAL.expr = nil } - case 1299: + case 1377: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6455 +//line sql.y:7083 { yyVAL.expr = yyDollar[2].expr } - case 1300: + case 1378: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6461 +//line sql.y:7089 { yyVAL.expr = yyDollar[1].expr } - case 1301: + case 1379: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6465 +//line sql.y:7093 { yyVAL.expr = &AndExpr{Left: yyDollar[1].expr, Right: yyDollar[3].expr} } - case 1302: + case 1380: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6469 +//line sql.y:7097 { yyVAL.expr = &OrExpr{Left: yyDollar[1].expr, Right: yyDollar[3].expr} } - case 1303: + case 1381: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6473 +//line sql.y:7101 { yyVAL.expr = &XorExpr{Left: yyDollar[1].expr, Right: yyDollar[3].expr} } - case 1304: + case 1382: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6477 +//line sql.y:7105 { yyVAL.expr = &NotExpr{Expr: yyDollar[2].expr} } - case 1305: + case 1383: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6481 +//line sql.y:7109 { yyVAL.expr = &IsExpr{Operator: yyDollar[3].str, Expr: yyDollar[1].expr} } - case 1306: + case 1384: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6485 +//line sql.y:7113 { yyVAL.expr = yyDollar[1].expr } - case 1307: + case 1385: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6489 +//line sql.y:7117 { yyVAL.expr = &Default{ColName: yyDollar[2].str} } - case 1308: + case 1386: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6495 +//line sql.y:7123 { yyVAL.str = "" } - case 1309: + case 1387: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6499 +//line sql.y:7127 { yyVAL.str = string(yyDollar[2].bytes) } - case 1310: + case 1388: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6505 +//line sql.y:7133 { yyVAL.boolVal = BoolVal(true) } - case 1311: + case 1389: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6509 +//line sql.y:7137 { yyVAL.boolVal = BoolVal(false) } - case 1312: + case 1390: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6515 +//line sql.y:7143 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: yyDollar[2].str, Right: yyDollar[3].expr} } - case 1313: + case 1391: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6519 +//line sql.y:7147 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: yyDollar[2].str, Right: &AllExpr{Subquery: yyDollar[4].subquery}} } - case 1314: + case 1392: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6523 +//line sql.y:7151 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: yyDollar[2].str, Right: yyDollar[4].subquery} } - case 1315: + case 1393: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6527 +//line sql.y:7155 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: yyDollar[2].str, Right: yyDollar[4].subquery} } - case 1316: + case 1394: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6531 +//line sql.y:7159 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: InStr, Right: yyDollar[3].colTuple} } - case 1317: + case 1395: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6535 +//line sql.y:7163 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: NotInStr, Right: yyDollar[4].colTuple} } - case 1318: + case 1396: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6539 +//line sql.y:7167 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: LikeStr, Right: yyDollar[3].expr, Escape: yyDollar[4].expr} } - case 1319: + case 1397: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6543 +//line sql.y:7171 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: NotLikeStr, Right: yyDollar[4].expr, Escape: yyDollar[5].expr} } - case 1320: + case 1398: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6547 +//line sql.y:7175 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: RegexpStr, Right: yyDollar[3].expr} } - case 1321: + case 1399: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6551 +//line sql.y:7179 { yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: NotRegexpStr, Right: yyDollar[4].expr} } - case 1322: + case 1400: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6555 +//line sql.y:7183 { yyVAL.expr = &RangeCond{Left: yyDollar[1].expr, Operator: BetweenStr, From: yyDollar[3].expr, To: yyDollar[5].expr} } - case 1323: + case 1401: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6559 +//line sql.y:7187 { yyVAL.expr = &RangeCond{Left: yyDollar[1].expr, Operator: NotBetweenStr, From: yyDollar[4].expr, To: yyDollar[6].expr} } - case 1324: + case 1402: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6563 +//line sql.y:7191 { yyVAL.expr = &ExistsExpr{Subquery: yyDollar[2].subquery} } - case 1325: + case 1403: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6569 +//line sql.y:7197 { yyVAL.str = IsNullStr } - case 1326: + case 1404: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6573 +//line sql.y:7201 { yyVAL.str = IsNotNullStr } - case 1327: + case 1405: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6577 +//line sql.y:7205 { yyVAL.str = IsTrueStr } - case 1328: + case 1406: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6581 +//line sql.y:7209 { yyVAL.str = IsNotTrueStr } - case 1329: + case 1407: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6585 +//line sql.y:7213 { yyVAL.str = IsFalseStr } - case 1330: + case 1408: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6589 +//line sql.y:7217 { yyVAL.str = IsNotFalseStr } - case 1331: + case 1409: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6595 +//line sql.y:7223 { yyVAL.str = EqualStr } - case 1332: + case 1410: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6599 +//line sql.y:7227 { yyVAL.str = LessThanStr } - case 1333: + case 1411: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6603 +//line sql.y:7231 { yyVAL.str = GreaterThanStr } - case 1334: + case 1412: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6607 +//line sql.y:7235 { yyVAL.str = LessEqualStr } - case 1335: + case 1413: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6611 +//line sql.y:7239 { yyVAL.str = GreaterEqualStr } - case 1336: + case 1414: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6615 +//line sql.y:7243 { yyVAL.str = NotEqualStr } - case 1337: + case 1415: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6619 +//line sql.y:7247 { yyVAL.str = NullSafeEqualStr } - case 1338: + case 1416: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6624 +//line sql.y:7252 { yyVAL.expr = nil } - case 1339: + case 1417: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6628 +//line sql.y:7256 { yyVAL.expr = yyDollar[2].expr } - case 1340: + case 1418: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6634 +//line sql.y:7262 { yyVAL.colTuple = yyDollar[1].valTuple } - case 1341: + case 1419: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6638 +//line sql.y:7266 { yyVAL.colTuple = yyDollar[1].subquery } - case 1342: + case 1420: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6642 +//line sql.y:7270 { yyVAL.colTuple = ListArg(yyDollar[1].bytes) } - case 1343: + case 1421: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6648 +//line sql.y:7276 { yyVAL.subquery = &Subquery{Select: yyDollar[2].selStmt} } - case 1344: + case 1422: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6654 +//line sql.y:7282 { yyVAL.simpleTableExpr = yyDollar[1].subquery } - case 1345: + case 1423: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6658 +//line sql.y:7286 { yyVAL.simpleTableExpr = yyDollar[2].simpleTableExpr } - case 1346: + case 1424: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:6663 +//line sql.y:7291 { yyVAL.selectExprs = nil } - case 1348: + case 1426: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6670 +//line sql.y:7298 { yyVAL.selectExprs = SelectExprs{yyDollar[1].selectExpr} } - case 1349: + case 1427: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6674 +//line sql.y:7302 { yyVAL.selectExprs = append(yyDollar[1].selectExprs, yyDollar[3].selectExpr) } - case 1350: + case 1428: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6680 +//line sql.y:7308 { yyVAL.exprs = Exprs{yyDollar[1].expr} } - case 1351: + case 1429: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6684 +//line sql.y:7312 { yyVAL.exprs = append(yyDollar[1].exprs, yyDollar[3].expr) } - case 1352: + case 1430: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6690 +//line sql.y:7318 { yyVAL.expr = yyDollar[1].expr } - case 1353: + case 1431: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6694 +//line sql.y:7322 { yyVAL.expr = &ColName{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1354: + case 1432: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6698 +//line sql.y:7326 { yyVAL.expr = &ColName{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1355: + case 1433: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6702 +//line sql.y:7330 { yyVAL.expr = yyDollar[1].boolVal } - case 1356: + case 1434: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6706 +//line sql.y:7334 { yyVAL.expr = yyDollar[1].colName } - case 1357: + case 1435: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6710 +//line sql.y:7338 { yyVAL.expr = &ColName{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1358: + case 1436: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6714 +//line sql.y:7342 { yyVAL.expr = yyDollar[1].expr } - case 1359: + case 1437: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:6718 +//line sql.y:7346 { yyVAL.expr = yyDollar[1].subquery } - case 1360: + case 1438: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6722 +//line sql.y:7350 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: BitAndStr, Right: yyDollar[3].expr} } - case 1361: + case 1439: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6726 +//line sql.y:7354 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: BitOrStr, Right: yyDollar[3].expr} } - case 1362: + case 1440: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6730 +//line sql.y:7358 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: BitXorStr, Right: yyDollar[3].expr} } - case 1363: + case 1441: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6734 +//line sql.y:7362 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: PlusStr, Right: yyDollar[3].expr} } - case 1364: + case 1442: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6738 +//line sql.y:7366 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: MinusStr, Right: yyDollar[3].expr} } - case 1365: + case 1443: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6742 +//line sql.y:7370 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: MultStr, Right: yyDollar[3].expr} } - case 1366: + case 1444: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6746 +//line sql.y:7374 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: DivStr, Right: yyDollar[3].expr} } - case 1367: + case 1445: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6750 +//line sql.y:7378 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: IntDivStr, Right: yyDollar[3].expr} } - case 1368: + case 1446: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6754 +//line sql.y:7382 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ModStr, Right: yyDollar[3].expr} } - case 1369: + case 1447: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6758 +//line sql.y:7386 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ModStr, Right: yyDollar[3].expr} } - case 1370: + case 1448: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6762 +//line sql.y:7390 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ShiftLeftStr, Right: yyDollar[3].expr} } - case 1371: + case 1449: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6766 +//line sql.y:7394 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ShiftRightStr, Right: yyDollar[3].expr} } - case 1372: + case 1450: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6770 +//line sql.y:7398 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].colName, Operator: JSONExtractOp, Right: yyDollar[3].expr} } - case 1373: + case 1451: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6774 +//line sql.y:7402 { yyVAL.expr = &BinaryExpr{Left: yyDollar[1].colName, Operator: JSONUnquoteExtractOp, Right: yyDollar[3].expr} } - case 1374: + case 1452: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6778 +//line sql.y:7406 { - yyVAL.expr = &CollateExpr{Expr: yyDollar[1].expr, Charset: yyDollar[3].str} + yyVAL.expr = &CollateExpr{Expr: yyDollar[1].expr, Collation: yyDollar[3].str} } - case 1375: + case 1453: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6782 +//line sql.y:7410 { yyVAL.expr = &UnaryExpr{Operator: BinaryStr, Expr: yyDollar[2].expr} } - case 1376: + case 1454: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6786 +//line sql.y:7414 { yyVAL.expr = &UnaryExpr{Operator: yyDollar[1].str, Expr: yyDollar[2].expr} } - case 1377: + case 1455: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6790 +//line sql.y:7418 { if num, ok := yyDollar[2].expr.(*SQLVal); ok && num.Type == IntVal { yyVAL.expr = num @@ -19583,9 +21135,9 @@ yydefault: yyVAL.expr = &UnaryExpr{Operator: UPlusStr, Expr: yyDollar[2].expr} } } - case 1378: + case 1456: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6798 +//line sql.y:7426 { if num, ok := yyDollar[2].expr.(*SQLVal); ok && num.Type == IntVal { // Handle double negative @@ -19599,21 +21151,21 @@ yydefault: yyVAL.expr = &UnaryExpr{Operator: UMinusStr, Expr: yyDollar[2].expr} } } - case 1379: + case 1457: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6812 +//line sql.y:7440 { yyVAL.expr = &UnaryExpr{Operator: TildaStr, Expr: yyDollar[2].expr} } - case 1380: + case 1458: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:6816 +//line sql.y:7444 { yyVAL.expr = &UnaryExpr{Operator: BangStr, Expr: yyDollar[2].expr} } - case 1381: + case 1459: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6820 +//line sql.y:7448 { // This rule prevents the usage of INTERVAL // as a function. If support is needed for that, @@ -19621,1405 +21173,1504 @@ yydefault: // will be non-trivial because of grammar conflicts. yyVAL.expr = &IntervalExpr{Expr: yyDollar[2].expr, Unit: yyDollar[3].colIdent.String()} } - case 1388: + case 1466: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6840 +//line sql.y:7468 { yyVAL.expr = &FuncExpr{Name: yyDollar[1].colIdent, Distinct: yyDollar[3].str == DistinctStr, Exprs: yyDollar[4].selectExprs} } - case 1389: + case 1467: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6844 +//line sql.y:7472 { yyVAL.expr = &FuncExpr{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].colIdent, Exprs: yyDollar[5].selectExprs} } - case 1390: + case 1468: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6854 +//line sql.y:7482 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[4].selectExprs, Distinct: yyDollar[3].str == DistinctStr, Over: yyDollar[6].over} } - case 1391: + case 1469: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6858 +//line sql.y:7486 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[4].selectExprs, Distinct: yyDollar[3].str == DistinctStr, Over: yyDollar[6].over} } - case 1392: + case 1470: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6862 +//line sql.y:7490 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1393: + case 1471: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6866 +//line sql.y:7494 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1394: + case 1472: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6870 +//line sql.y:7498 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1395: + case 1473: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6874 +//line sql.y:7502 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[4].selectExprs, Distinct: yyDollar[3].str == DistinctStr, Over: yyDollar[6].over} } - case 1396: + case 1474: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6878 +//line sql.y:7506 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1397: + case 1475: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6882 +//line sql.y:7510 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1398: + case 1476: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6886 +//line sql.y:7514 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[4].selectExprs, Distinct: yyDollar[3].str == DistinctStr, Over: yyDollar[6].over} } - case 1399: + case 1477: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6890 +//line sql.y:7518 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1400: + case 1478: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6894 +//line sql.y:7522 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1401: + case 1479: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6898 +//line sql.y:7526 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1402: + case 1480: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6902 +//line sql.y:7530 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1403: + case 1481: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6906 +//line sql.y:7534 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[4].selectExprs, Distinct: yyDollar[3].str == DistinctStr, Over: yyDollar[6].over} } - case 1404: + case 1482: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6910 +//line sql.y:7538 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1405: + case 1483: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6914 +//line sql.y:7542 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1406: + case 1484: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6918 +//line sql.y:7546 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1407: + case 1485: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6927 +//line sql.y:7555 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Over: yyDollar[4].over} } - case 1408: + case 1486: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6931 +//line sql.y:7559 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Over: yyDollar[4].over} } - case 1409: + case 1487: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6935 +//line sql.y:7563 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{yyDollar[3].selectExpr}, Over: yyDollar[5].over} } - case 1410: + case 1488: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6939 +//line sql.y:7567 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1411: + case 1489: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6943 +//line sql.y:7571 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{yyDollar[3].selectExpr}, Over: yyDollar[5].over} } - case 1412: + case 1490: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6947 +//line sql.y:7575 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1413: + case 1491: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:6951 +//line sql.y:7579 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs, Over: yyDollar[5].over} } - case 1414: + case 1492: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6955 +//line sql.y:7583 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Over: yyDollar[4].over} } - case 1415: + case 1493: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6959 +//line sql.y:7587 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Over: yyDollar[4].over} } - case 1416: + case 1494: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6963 +//line sql.y:7591 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Over: yyDollar[4].over} } - case 1417: + case 1495: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6967 +//line sql.y:7595 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Over: yyDollar[4].over} } - case 1418: + case 1496: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6978 +//line sql.y:7606 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1419: + case 1497: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6982 +//line sql.y:7610 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1420: + case 1498: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6986 +//line sql.y:7614 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1421: + case 1499: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:6990 +//line sql.y:7618 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1422: + case 1500: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:6994 +//line sql.y:7622 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1423: + case 1501: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:6998 +//line sql.y:7626 { yyVAL.expr = &ConvertExpr{Name: string(yyDollar[1].bytes), Expr: yyDollar[3].expr, Type: yyDollar[5].convertType} } - case 1424: + case 1502: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:7002 +//line sql.y:7630 { yyVAL.expr = &ConvertExpr{Name: string(yyDollar[1].bytes), Expr: yyDollar[3].expr, Type: yyDollar[5].convertType} } - case 1425: + case 1503: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7006 +//line sql.y:7634 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} + yyVAL.expr = &CharExpr{Exprs: yyDollar[3].selectExprs} } - case 1426: + case 1504: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:7010 +//line sql.y:7638 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} + yyVAL.expr = &CharExpr{Exprs: yyDollar[3].selectExprs, Type: yyDollar[5].str} } - case 1427: + case 1505: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:7014 +//line sql.y:7642 { yyVAL.expr = &ConvertUsingExpr{Expr: yyDollar[3].expr, Type: yyDollar[5].str} } - case 1428: + case 1506: + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:7646 + { + yyVAL.expr = &FuncExpr{Name: NewColIdent("LOCATE"), Exprs: []SelectExpr{&AliasedExpr{Expr: yyDollar[3].expr}, &AliasedExpr{Expr: yyDollar[5].expr}}} + } + case 1507: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7018 +//line sql.y:7650 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1429: + case 1508: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:7022 +//line sql.y:7654 { yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: yyDollar[7].expr} } - case 1430: + case 1509: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:7026 +//line sql.y:7658 { yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: yyDollar[7].expr} } - case 1431: + case 1510: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:7030 +//line sql.y:7662 { yyVAL.expr = &SubstrExpr{StrVal: NewStrVal(yyDollar[3].bytes), From: yyDollar[5].expr, To: yyDollar[7].expr} } - case 1432: + case 1511: yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:7034 +//line sql.y:7666 { yyVAL.expr = &SubstrExpr{StrVal: NewStrVal(yyDollar[3].bytes), From: yyDollar[5].expr, To: yyDollar[7].expr} } - case 1433: + case 1512: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7038 +//line sql.y:7670 { yyVAL.expr = &TrimExpr{Pattern: NewStrVal([]byte(" ")), Str: yyDollar[3].expr, Dir: Both} } - case 1434: + case 1513: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:7042 +//line sql.y:7674 { yyVAL.expr = &TrimExpr{Pattern: yyDollar[3].expr, Str: yyDollar[5].expr, Dir: Both} } - case 1435: + case 1514: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:7046 +//line sql.y:7678 { yyVAL.expr = &TrimExpr{Pattern: yyDollar[4].expr, Str: yyDollar[6].expr, Dir: Leading} } - case 1436: + case 1515: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:7050 +//line sql.y:7682 { yyVAL.expr = &TrimExpr{Pattern: yyDollar[4].expr, Str: yyDollar[6].expr, Dir: Trailing} } - case 1437: + case 1516: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:7054 +//line sql.y:7686 { yyVAL.expr = &TrimExpr{Pattern: yyDollar[4].expr, Str: yyDollar[6].expr, Dir: Both} } - case 1438: + case 1517: yyDollar = yyS[yypt-9 : yypt+1] -//line sql.y:7058 +//line sql.y:7690 { yyVAL.expr = &MatchExpr{Columns: yyDollar[3].selectExprs, Expr: yyDollar[7].expr, Option: yyDollar[8].str} } - case 1439: + case 1518: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7062 +//line sql.y:7694 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1440: + case 1519: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:7066 +//line sql.y:7698 { yyVAL.expr = &GroupConcatExpr{Distinct: yyDollar[3].str, Exprs: yyDollar[4].selectExprs, OrderBy: yyDollar[5].orderBy, Separator: yyDollar[6].separator} } - case 1441: + case 1520: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:7070 +//line sql.y:7702 { yyVAL.expr = &CaseExpr{Expr: yyDollar[2].expr, Whens: yyDollar[3].whens, Else: yyDollar[4].expr} } - case 1442: + case 1521: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7074 +//line sql.y:7706 { yyVAL.expr = &ValuesFuncExpr{Name: yyDollar[3].colName} } - case 1443: + case 1522: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7078 +//line sql.y:7710 { yyVAL.expr = &ValuesFuncExpr{Name: NewColName(string(yyDollar[3].bytes))} } - case 1444: + case 1523: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7083 +//line sql.y:7715 { yyVAL.expr = &ValuesFuncExpr{Name: NewColName(string(yyDollar[3].bytes))} } - case 1445: - yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7087 - { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} - } - case 1446: + case 1524: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7091 +//line sql.y:7719 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1447: + case 1525: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7101 +//line sql.y:7730 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1448: + case 1526: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7105 +//line sql.y:7734 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1449: + case 1527: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7109 +//line sql.y:7738 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1450: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7114 + case 1528: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:7743 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} + yyVAL.expr = yyDollar[1].expr } - case 1451: + case 1529: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7119 +//line sql.y:7747 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: yyDollar[2].expr}}} } - case 1452: + case 1530: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7124 +//line sql.y:7751 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: yyDollar[2].expr}}} } - case 1453: + case 1531: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7130 +//line sql.y:7755 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: yyDollar[2].expr}}} } - case 1454: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7135 + case 1532: + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:7759 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} + yyVAL.expr = &TimestampFuncExpr{Name: string("timestampadd"), Unit: string(yyDollar[3].bytes), Expr1: yyDollar[5].expr, Expr2: yyDollar[7].expr} } - case 1455: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7139 + case 1533: + yyDollar = yyS[yypt-8 : yypt+1] +//line sql.y:7763 { - yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} + yyVAL.expr = &TimestampFuncExpr{Name: string("timestampdiff"), Unit: string(yyDollar[3].bytes), Expr1: yyDollar[5].expr, Expr2: yyDollar[7].expr} } - case 1456: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7144 + case 1534: + yyDollar = yyS[yypt-6 : yypt+1] +//line sql.y:7767 { - yyVAL.expr = &CurTimeFuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Fsp: yyDollar[2].expr} + yyVAL.expr = &ExtractFuncExpr{Name: string(yyDollar[1].bytes), Unit: string(yyDollar[3].bytes), Expr: yyDollar[5].expr} } - case 1457: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7148 + case 1535: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:7775 { - yyVAL.expr = &CurTimeFuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Fsp: yyDollar[2].expr} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1458: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7152 + case 1536: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:7779 { - yyVAL.expr = &CurTimeFuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Fsp: yyDollar[2].expr} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: NewIntVal(yyDollar[3].bytes)}}} } - case 1459: + case 1537: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7157 +//line sql.y:7783 { - yyVAL.expr = &CurTimeFuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Fsp: yyDollar[2].expr} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: yyDollar[2].expr}}} } - case 1460: + case 1538: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7162 +//line sql.y:7787 { - yyVAL.expr = &CurTimeFuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Fsp: yyDollar[2].expr} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: yyDollar[2].expr}}} } - case 1461: + case 1539: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7167 - { - yyVAL.expr = &CurTimeFuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Fsp: yyDollar[2].expr} - } - case 1462: - yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:7171 - { - yyVAL.expr = &TimestampFuncExpr{Name: string("timestampadd"), Unit: string(yyDollar[3].bytes), Expr1: yyDollar[5].expr, Expr2: yyDollar[7].expr} - } - case 1463: - yyDollar = yyS[yypt-8 : yypt+1] -//line sql.y:7175 +//line sql.y:7791 { - yyVAL.expr = &TimestampFuncExpr{Name: string("timestampdiff"), Unit: string(yyDollar[3].bytes), Expr1: yyDollar[5].expr, Expr2: yyDollar[7].expr} + yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: SelectExprs{&AliasedExpr{Expr: yyDollar[2].expr}}} } - case 1464: - yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:7179 + case 1542: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:7804 { - yyVAL.expr = &ExtractFuncExpr{Name: string(yyDollar[1].bytes), Unit: string(yyDollar[3].bytes), Expr: yyDollar[5].expr} + yyVAL.expr = NewIntVal([]byte("0")) } - case 1467: + case 1543: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7190 +//line sql.y:7808 { - yyVAL.expr = yyDollar[2].expr + yyVAL.expr = NewIntVal(yyDollar[2].bytes) } - case 1468: + case 1544: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7200 +//line sql.y:7818 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1469: + case 1545: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7204 +//line sql.y:7822 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1470: + case 1546: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7208 +//line sql.y:7826 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1471: + case 1547: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7212 +//line sql.y:7830 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1472: + case 1548: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7216 +//line sql.y:7834 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1473: + case 1549: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7220 +//line sql.y:7838 { yyVAL.expr = &FuncExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Exprs: yyDollar[3].selectExprs} } - case 1474: + case 1550: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7226 +//line sql.y:7844 { yyVAL.str = "" } - case 1475: + case 1551: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7230 +//line sql.y:7848 { yyVAL.str = BooleanModeStr } - case 1476: + case 1552: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7234 +//line sql.y:7852 { yyVAL.str = NaturalLanguageModeStr } - case 1477: + case 1553: yyDollar = yyS[yypt-7 : yypt+1] -//line sql.y:7238 +//line sql.y:7856 { yyVAL.str = NaturalLanguageModeWithQueryExpansionStr } - case 1478: + case 1554: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7242 +//line sql.y:7860 { yyVAL.str = QueryExpansionStr } - case 1479: + case 1555: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7248 +//line sql.y:7866 { yyVAL.str = string(yyDollar[1].bytes) } - case 1480: + case 1556: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7252 +//line sql.y:7870 { yyVAL.str = string(yyDollar[1].bytes) } - case 1481: + case 1557: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:7874 + { + yyVAL.str = string(yyDollar[1].bytes) + } + case 1558: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7258 +//line sql.y:7880 { yyVAL.str = Armscii8Str } - case 1482: + case 1559: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7262 +//line sql.y:7884 { yyVAL.str = AsciiStr } - case 1483: + case 1560: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7266 +//line sql.y:7888 { yyVAL.str = Big5Str } - case 1484: + case 1561: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7270 +//line sql.y:7892 { yyVAL.str = UBinaryStr } - case 1485: + case 1562: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7274 +//line sql.y:7896 { yyVAL.str = Cp1250Str } - case 1486: + case 1563: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7278 +//line sql.y:7900 { yyVAL.str = Cp1251Str } - case 1487: + case 1564: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7282 +//line sql.y:7904 { yyVAL.str = Cp1256Str } - case 1488: + case 1565: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7286 +//line sql.y:7908 { yyVAL.str = Cp1257Str } - case 1489: + case 1566: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7290 +//line sql.y:7912 { yyVAL.str = Cp850Str } - case 1490: + case 1567: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7294 +//line sql.y:7916 { yyVAL.str = Cp852Str } - case 1491: + case 1568: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7298 +//line sql.y:7920 { yyVAL.str = Cp866Str } - case 1492: + case 1569: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7302 +//line sql.y:7924 { yyVAL.str = Cp932Str } - case 1493: + case 1570: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7306 +//line sql.y:7928 { yyVAL.str = Dec8Str } - case 1494: + case 1571: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7310 +//line sql.y:7932 { yyVAL.str = EucjpmsStr } - case 1495: + case 1572: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7314 +//line sql.y:7936 { yyVAL.str = EuckrStr } - case 1496: + case 1573: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7318 +//line sql.y:7940 { yyVAL.str = Gb18030Str } - case 1497: + case 1574: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7322 +//line sql.y:7944 { yyVAL.str = Gb2312Str } - case 1498: + case 1575: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7326 +//line sql.y:7948 { yyVAL.str = GbkStr } - case 1499: + case 1576: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7330 +//line sql.y:7952 { yyVAL.str = Geostd8Str } - case 1500: + case 1577: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7334 +//line sql.y:7956 { yyVAL.str = GreekStr } - case 1501: + case 1578: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7338 +//line sql.y:7960 { yyVAL.str = HebrewStr } - case 1502: + case 1579: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7342 +//line sql.y:7964 { yyVAL.str = Hp8Str } - case 1503: + case 1580: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7346 +//line sql.y:7968 { yyVAL.str = Keybcs2Str } - case 1504: + case 1581: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7350 +//line sql.y:7972 { yyVAL.str = Koi8rStr } - case 1505: + case 1582: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7354 +//line sql.y:7976 { yyVAL.str = Koi8uStr } - case 1506: + case 1583: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7358 +//line sql.y:7980 { yyVAL.str = Latin1Str } - case 1507: + case 1584: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7362 +//line sql.y:7984 { yyVAL.str = Latin2Str } - case 1508: + case 1585: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7366 +//line sql.y:7988 { yyVAL.str = Latin5Str } - case 1509: + case 1586: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7370 +//line sql.y:7992 { yyVAL.str = Latin7Str } - case 1510: + case 1587: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7374 +//line sql.y:7996 { yyVAL.str = MacceStr } - case 1511: + case 1588: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7378 +//line sql.y:8000 { yyVAL.str = MacromanStr } - case 1512: + case 1589: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7382 +//line sql.y:8004 { yyVAL.str = SjisStr } - case 1513: + case 1590: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7386 +//line sql.y:8008 { yyVAL.str = Swe7Str } - case 1514: + case 1591: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7390 +//line sql.y:8012 { yyVAL.str = Tis620Str } - case 1515: + case 1592: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7394 +//line sql.y:8016 { yyVAL.str = Ucs2Str } - case 1516: + case 1593: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7398 +//line sql.y:8020 { yyVAL.str = UjisStr } - case 1517: + case 1594: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7402 +//line sql.y:8024 { yyVAL.str = Utf16Str } - case 1518: + case 1595: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7406 +//line sql.y:8028 { yyVAL.str = Utf16leStr } - case 1519: + case 1596: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7410 +//line sql.y:8032 { yyVAL.str = Utf32Str } - case 1520: + case 1597: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7414 +//line sql.y:8036 { yyVAL.str = Utf8mb3Str } - case 1521: + case 1598: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7418 +//line sql.y:8040 { yyVAL.str = Utf8mb3Str } - case 1522: + case 1599: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7422 +//line sql.y:8044 { yyVAL.str = Utf8mb4Str } - case 1523: + case 1600: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7428 +//line sql.y:8050 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 1524: + case 1601: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7432 +//line sql.y:8054 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal, Charset: yyDollar[3].str, Operator: CharacterSetStr} } - case 1525: + case 1602: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7436 +//line sql.y:8058 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal, Charset: string(yyDollar[3].bytes)} } - case 1526: + case 1603: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:8062 + { + yyVAL.convertType = &ConvertType{Type: "CHAR", Length: yyDollar[2].sqlVal, Charset: yyDollar[3].str, Operator: CharacterSetStr} + } + case 1604: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:8066 + { + yyVAL.convertType = &ConvertType{Type: "CHAR", Length: yyDollar[2].sqlVal, Charset: string(yyDollar[3].bytes)} + } + case 1605: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7440 +//line sql.y:8070 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1527: + case 1606: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7444 +//line sql.y:8074 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 1528: + case 1607: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7448 +//line sql.y:8078 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} yyVAL.convertType.Length = yyDollar[2].LengthScaleOption.Length yyVAL.convertType.Scale = yyDollar[2].LengthScaleOption.Scale } - case 1529: + case 1608: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7454 +//line sql.y:8084 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1530: + case 1609: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:8088 + { + yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} + } + case 1610: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8092 + { + yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} + } + case 1611: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8096 + { + yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} + } + case 1612: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8100 + { + yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} + } + case 1613: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7458 +//line sql.y:8104 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 1531: + case 1614: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7462 +//line sql.y:8108 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1532: + case 1615: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7466 +//line sql.y:8112 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1533: + case 1616: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7470 +//line sql.y:8116 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].sqlVal} } - case 1534: + case 1617: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7474 +//line sql.y:8120 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1535: + case 1618: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7478 +//line sql.y:8124 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1536: + case 1619: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7482 +//line sql.y:8128 { yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} } - case 1537: + case 1620: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7486 +//line sql.y:8134 { - yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)} + yyVAL.bytes = yyDollar[1].bytes } - case 1538: + case 1621: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8138 + { + yyVAL.bytes = yyDollar[1].bytes + } + case 1622: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7491 +//line sql.y:8143 { yyVAL.expr = nil } - case 1539: + case 1623: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7495 +//line sql.y:8147 { yyVAL.expr = yyDollar[1].expr } - case 1540: + case 1624: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7500 +//line sql.y:8152 { yyVAL.separator = Separator{SeparatorString: "", DefaultSeparator: true} } - case 1541: + case 1625: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7504 +//line sql.y:8156 { yyVAL.separator = Separator{SeparatorString: string(yyDollar[2].bytes), DefaultSeparator: false} } - case 1542: + case 1626: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7510 +//line sql.y:8162 { yyVAL.whens = []*When{yyDollar[1].when} } - case 1543: + case 1627: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7514 +//line sql.y:8166 { yyVAL.whens = append(yyDollar[1].whens, yyDollar[2].when) } - case 1544: + case 1628: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7520 +//line sql.y:8172 { yyVAL.when = &When{Cond: yyDollar[2].expr, Val: yyDollar[4].expr} } - case 1545: + case 1629: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7525 +//line sql.y:8177 { yyVAL.expr = nil } - case 1546: + case 1630: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7529 +//line sql.y:8181 { yyVAL.expr = yyDollar[2].expr } - case 1547: + case 1631: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7535 +//line sql.y:8187 { yyVAL.colName = &ColName{Name: yyDollar[1].colIdent} } - case 1548: + case 1632: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7539 +//line sql.y:8191 { yyVAL.colName = &ColName{Name: NewColIdent(string(yyDollar[1].bytes))} } - case 1549: + case 1633: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7543 +//line sql.y:8195 { yyVAL.colName = &ColName{Qualifier: TableName{Name: yyDollar[1].tableIdent}, Name: yyDollar[3].colIdent} } - case 1550: + case 1634: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7547 +//line sql.y:8199 { yyVAL.colName = &ColName{Qualifier: TableName{Name: yyDollar[1].tableIdent}, Name: NewColIdent(string(yyDollar[3].bytes))} } - case 1551: + case 1635: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7551 +//line sql.y:8203 { yyVAL.colName = &ColName{Qualifier: TableName{Name: yyDollar[1].tableIdent}, Name: NewColIdent(string(yyDollar[3].bytes))} } - case 1552: + case 1636: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7555 +//line sql.y:8207 { yyVAL.colName = &ColName{Qualifier: TableName{Name: yyDollar[1].tableIdent}, Name: NewColIdent(string(yyDollar[3].bytes))} } - case 1553: + case 1637: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7559 +//line sql.y:8211 { yyVAL.colName = &ColName{Qualifier: TableName{Name: yyDollar[1].tableIdent}, Name: NewColIdent(string(yyDollar[3].bytes))} } - case 1554: + case 1638: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7563 +//line sql.y:8215 { yyVAL.colName = &ColName{Qualifier: TableName{Name: NewTableIdent(string(yyDollar[1].bytes))}, Name: yyDollar[3].colIdent} } - case 1555: + case 1639: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7567 +//line sql.y:8219 { yyVAL.colName = &ColName{Qualifier: TableName{Name: NewTableIdent(string(yyDollar[1].bytes))}, Name: yyDollar[3].colIdent} } - case 1556: + case 1640: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7571 +//line sql.y:8223 { yyVAL.colName = &ColName{Qualifier: TableName{Name: NewTableIdent(string(yyDollar[1].bytes))}, Name: yyDollar[3].colIdent} } - case 1557: + case 1641: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7575 +//line sql.y:8227 { yyVAL.colName = &ColName{Qualifier: TableName{Name: NewTableIdent(string(yyDollar[1].bytes))}, Name: NewColIdent(string(yyDollar[3].bytes))} } - case 1558: + case 1642: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7579 +//line sql.y:8231 { yyVAL.colName = &ColName{Qualifier: TableName{Name: NewTableIdent(string(yyDollar[1].bytes))}, Name: yyDollar[3].colIdent} } - case 1559: + case 1643: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7583 +//line sql.y:8235 { yyVAL.colName = &ColName{Qualifier: TableName{Name: NewTableIdent(string(yyDollar[1].bytes))}, Name: yyDollar[3].colIdent} } - case 1560: + case 1644: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8239 + { + yyVAL.colName = &ColName{Name: NewColIdent(string(yyDollar[1].bytes))} + } + case 1645: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:7587 +//line sql.y:8243 { - yyVAL.colName = &ColName{Qualifier: TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}, Name: yyDollar[5].colIdent} + yyVAL.colName = &ColName{Qualifier: TableName{DbQualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}, Name: yyDollar[5].colIdent} } - case 1561: + case 1646: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7593 +//line sql.y:8249 { yyVAL.expr = NewStrVal(yyDollar[1].bytes) } - case 1562: + case 1647: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:8253 + { + yyVAL.expr = NewStrVal(yyDollar[2].bytes) + } + case 1648: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:8257 + { + yyVAL.expr = NewStrVal(yyDollar[2].bytes) + } + case 1649: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:8261 + { + yyVAL.expr = NewStrVal(yyDollar[2].bytes) + } + case 1650: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7597 +//line sql.y:8265 { yyVAL.expr = NewHexVal(yyDollar[1].bytes) } - case 1563: + case 1651: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7601 +//line sql.y:8269 { yyVAL.expr = NewBitVal(yyDollar[1].bytes) } - case 1564: + case 1652: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7605 +//line sql.y:8273 { yyVAL.expr = NewIntVal(yyDollar[1].bytes) } - case 1565: + case 1653: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7609 +//line sql.y:8277 { yyVAL.expr = NewFloatVal(yyDollar[1].bytes) } - case 1566: + case 1654: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7613 +//line sql.y:8281 { yyVAL.expr = NewHexNum(yyDollar[1].bytes) } - case 1567: + case 1655: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7617 +//line sql.y:8285 { yyVAL.expr = NewValArg(yyDollar[1].bytes) } - case 1568: + case 1656: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7621 +//line sql.y:8289 { yyVAL.expr = &NullVal{} } - case 1569: + case 1657: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7627 +//line sql.y:8295 { yyVAL.expr = NewIntVal([]byte("1")) } - case 1570: + case 1658: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7631 +//line sql.y:8299 { yyVAL.expr = NewIntVal(yyDollar[1].bytes) } - case 1571: + case 1659: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7635 +//line sql.y:8303 { yyVAL.expr = NewValArg(yyDollar[1].bytes) } - case 1572: + case 1660: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7640 +//line sql.y:8308 { yyVAL.exprs = nil } - case 1573: + case 1661: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7644 +//line sql.y:8312 { yyVAL.exprs = yyDollar[3].exprs } - case 1574: + case 1662: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7650 +//line sql.y:8318 { yyVAL.exprs = Exprs{yyDollar[1].expr} } - case 1575: + case 1663: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7654 +//line sql.y:8322 { yyVAL.exprs = append(yyDollar[1].exprs, yyDollar[3].expr) } - case 1576: + case 1664: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7660 +//line sql.y:8328 { yyVAL.expr = yyDollar[1].expr } - case 1577: + case 1665: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7665 +//line sql.y:8333 { yyVAL.expr = nil } - case 1578: + case 1666: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7669 +//line sql.y:8337 { yyVAL.expr = yyDollar[2].expr } - case 1579: + case 1667: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7675 +//line sql.y:8343 { yyVAL.expr = yyDollar[1].expr } - case 1580: + case 1668: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7680 +//line sql.y:8348 { yyVAL.orderBy = nil } - case 1581: + case 1669: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7684 +//line sql.y:8352 { yyVAL.orderBy = yyDollar[3].orderBy } - case 1582: + case 1670: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7690 +//line sql.y:8358 { yyVAL.orderBy = OrderBy{yyDollar[1].order} } - case 1583: + case 1671: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7694 +//line sql.y:8362 { yyVAL.orderBy = append(yyDollar[1].orderBy, yyDollar[3].order) } - case 1584: + case 1672: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7700 +//line sql.y:8368 { yyVAL.order = &Order{Expr: yyDollar[1].expr, Direction: yyDollar[2].str} } - case 1585: + case 1673: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7705 +//line sql.y:8373 { yyVAL.str = AscScr } - case 1586: + case 1674: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7709 +//line sql.y:8377 { yyVAL.str = AscScr } - case 1587: + case 1675: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7713 +//line sql.y:8381 { yyVAL.str = DescScr } - case 1588: + case 1676: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7718 +//line sql.y:8386 { yyVAL.limit = nil } - case 1589: + case 1677: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7722 +//line sql.y:8390 { yyVAL.limit = &Limit{Rowcount: yyDollar[2].expr} } - case 1590: + case 1678: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7726 +//line sql.y:8394 { yyVAL.limit = &Limit{Offset: yyDollar[2].expr, Rowcount: yyDollar[4].expr} } - case 1591: + case 1679: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7730 +//line sql.y:8398 { yyVAL.limit = &Limit{Offset: yyDollar[4].expr, Rowcount: yyDollar[2].expr} } - case 1592: + case 1680: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7736 +//line sql.y:8404 { yyVAL.expr = NewIntVal(yyDollar[1].bytes) } - case 1593: + case 1681: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7740 +//line sql.y:8408 { yyVAL.expr = NewValArg(yyDollar[1].bytes) } - case 1594: + case 1682: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8412 + { + yyVAL.expr = yyDollar[1].colName + } + case 1683: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7745 +//line sql.y:8417 { yyVAL.str = "" } - case 1595: + case 1684: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7749 +//line sql.y:8421 { yyVAL.str = ForUpdateStr } - case 1596: + case 1685: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7753 +//line sql.y:8425 { yyVAL.str = ForUpdateSkipLockedStr } - case 1597: + case 1686: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7757 +//line sql.y:8429 { yyVAL.str = ShareModeStr } - case 1598: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7770 + case 1687: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8435 { - yyVAL.ins = &Insert{Rows: yyDollar[2].values} + yyVAL.ins = yyDollar[1].ins } - case 1599: + case 1688: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7774 - { - yyVAL.ins = &Insert{Columns: []ColIdent{}, Rows: yyDollar[4].values} +//line sql.y:8439 + { + yyVAL.ins = yyDollar[1].ins + // Rows is guarenteed to be an *AliasedValues here. + rows := yyVAL.ins.Rows.(*AliasedValues) + rows.As = yyDollar[3].tableIdent + if yyDollar[4].columns != nil { + rows.Columns = yyDollar[4].columns + } + yyVAL.ins.Rows = rows } - case 1600: + case 1689: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7778 +//line sql.y:8459 { - yyVAL.ins = &Insert{Rows: yyDollar[1].selStmt} + yyVAL.ins = yyDollar[1].ins } - case 1601: + case 1690: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7782 +//line sql.y:8463 { - // Drop the redundant parenthesis. - yyVAL.ins = &Insert{Rows: yyDollar[2].selStmt} + yyDollar[3].ins.Columns = []ColIdent{} + yyVAL.ins = yyDollar[3].ins } - case 1602: - yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:7787 + case 1691: + yyDollar = yyS[yypt-4 : yypt+1] +//line sql.y:8468 { - yyVAL.ins = &Insert{Columns: yyDollar[2].columns, Rows: yyDollar[5].values} + yyDollar[4].ins.Columns = yyDollar[2].columns + yyVAL.ins = yyDollar[4].ins } - case 1603: + case 1692: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8475 + { + yyVAL.ins = &Insert{Rows: yyDollar[1].selStmt} + } + case 1693: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:7791 +//line sql.y:8479 { yyVAL.ins = &Insert{Columns: yyDollar[2].columns, Rows: yyDollar[4].selStmt} } - case 1604: + case 1694: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:8483 + { + // Drop the redundant parenthesis. + yyVAL.ins = &Insert{Rows: yyDollar[2].selStmt} + } + case 1695: yyDollar = yyS[yypt-6 : yypt+1] -//line sql.y:7795 +//line sql.y:8488 { // Drop the redundant parenthesis. yyVAL.ins = &Insert{Columns: yyDollar[2].columns, Rows: yyDollar[5].selStmt} } - case 1607: + case 1696: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:8495 + { + yyVAL.ins = &Insert{Rows: &AliasedValues{Values: yyDollar[2].values}} + } + case 1697: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:8499 + { + yyVAL.ins = yyDollar[2].ins + } + case 1700: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7805 +//line sql.y:8508 { yyVAL.columns = nil } - case 1608: + case 1701: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7809 +//line sql.y:8512 { yyVAL.columns = yyDollar[2].columns } - case 1609: + case 1702: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7815 +//line sql.y:8518 { yyVAL.columns = Columns{yyDollar[1].colIdent} } - case 1610: + case 1703: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7819 +//line sql.y:8522 { yyVAL.columns = append(yyVAL.columns, yyDollar[3].colIdent) } - case 1611: + case 1704: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7825 +//line sql.y:8528 { yyVAL.colIdent = yyDollar[3].colIdent } - case 1612: + case 1705: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7829 +//line sql.y:8532 { yyVAL.colIdent = yyDollar[1].colIdent } - case 1613: + case 1706: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7833 +//line sql.y:8536 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1614: + case 1707: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7837 +//line sql.y:8540 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1615: + case 1708: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7841 +//line sql.y:8544 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1616: + case 1709: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7845 +//line sql.y:8548 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1617: + case 1710: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:7850 +//line sql.y:8553 { yyVAL.assignExprs = nil } - case 1618: + case 1711: yyDollar = yyS[yypt-5 : yypt+1] -//line sql.y:7854 +//line sql.y:8557 { yyVAL.assignExprs = yyDollar[5].assignExprs } - case 1619: + case 1712: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7860 +//line sql.y:8563 { yyVAL.values = Values{yyDollar[1].valTuple} } - case 1620: + case 1713: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7864 +//line sql.y:8567 { yyVAL.values = append(yyDollar[1].values, yyDollar[3].valTuple) } - case 1621: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7870 + case 1714: + yyDollar = yyS[yypt-2 : yypt+1] +//line sql.y:8573 { - yyVAL.valTuple = yyDollar[1].valTuple + yyVAL.valTuple = yyDollar[2].valTuple } - case 1622: - yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7874 + case 1715: + yyDollar = yyS[yypt-3 : yypt+1] +//line sql.y:8577 { yyVAL.valTuple = ValTuple{} } - case 1623: + case 1716: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7880 +//line sql.y:8583 { yyVAL.valTuple = ValTuple(yyDollar[2].exprs) } - case 1624: + case 1717: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7886 +//line sql.y:8589 { if len(yyDollar[1].valTuple) == 1 { yyVAL.expr = &ParenExpr{yyDollar[1].valTuple[0]} @@ -21027,59 +22678,59 @@ yydefault: yyVAL.expr = yyDollar[1].valTuple } } - case 1625: + case 1718: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7896 +//line sql.y:8599 { yyVAL.assignExprs = AssignmentExprs{yyDollar[1].assignExpr} } - case 1626: + case 1719: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7900 +//line sql.y:8603 { yyVAL.assignExprs = append(yyDollar[1].assignExprs, yyDollar[3].assignExpr) } - case 1627: + case 1720: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7906 +//line sql.y:8609 { yyVAL.assignExpr = &AssignmentExpr{Name: yyDollar[1].colName, Expr: yyDollar[3].expr} } - case 1628: + case 1721: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7909 +//line sql.y:8612 { yyVAL.assignExpr = &AssignmentExpr{Name: &ColName{Name: NewColIdent(string(yyDollar[1].bytes))}, Expr: yyDollar[3].expr} } - case 1629: + case 1722: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7913 +//line sql.y:8616 { yyVAL.assignExpr = &AssignmentExpr{Name: &ColName{Name: NewColIdent(string(yyDollar[1].bytes))}, Expr: yyDollar[3].expr} } - case 1630: + case 1723: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7917 +//line sql.y:8620 { yyVAL.assignExpr = &AssignmentExpr{Name: &ColName{Name: NewColIdent(string(yyDollar[1].bytes))}, Expr: yyDollar[3].expr} } - case 1631: + case 1724: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7923 +//line sql.y:8626 { yyVAL.setVarExprs = SetVarExprs{yyDollar[1].setVarExpr} } - case 1632: + case 1725: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7927 +//line sql.y:8630 { yyVAL.setVarExprs = append(yyDollar[1].setVarExprs, yyDollar[3].setVarExpr) } - case 1633: + case 1726: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7933 +//line sql.y:8636 { - colName, scope, err := VarScopeForColName(yyDollar[1].setVarExpr.Name) + colName, scope, _, err := VarScopeForColName(yyDollar[1].setVarExpr.Name) if err != nil { yylex.Error(err.Error()) return 1 @@ -21088,11 +22739,11 @@ yydefault: yyDollar[1].setVarExpr.Scope = scope yyVAL.setVarExpr = yyDollar[1].setVarExpr } - case 1634: + case 1727: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7944 +//line sql.y:8647 { - _, scope, err := VarScopeForColName(yyDollar[2].setVarExpr.Name) + _, scope, _, err := VarScopeForColName(yyDollar[2].setVarExpr.Name) if err != nil { yylex.Error(err.Error()) return 1 @@ -21103,11 +22754,11 @@ yydefault: yyDollar[2].setVarExpr.Scope = yyDollar[1].setScope yyVAL.setVarExpr = yyDollar[2].setVarExpr } - case 1635: + case 1728: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:7957 +//line sql.y:8660 { - _, scope, err := VarScopeForColName(yyDollar[2].setVarExpr.Name) + _, scope, _, err := VarScopeForColName(yyDollar[2].setVarExpr.Name) if err != nil { yylex.Error(err.Error()) return 1 @@ -21118,57 +22769,57 @@ yydefault: yyDollar[2].setVarExpr.Scope = yyDollar[1].setScope yyVAL.setVarExpr = yyDollar[2].setVarExpr } - case 1636: + case 1729: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:7970 +//line sql.y:8673 { yyVAL.setVarExpr = &SetVarExpr{Name: NewColName(string(yyDollar[1].bytes)), Expr: yyDollar[2].expr, Scope: SetScope_Session} } - case 1637: + case 1730: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7976 +//line sql.y:8679 { yyVAL.setScope = SetScope_Global } - case 1638: + case 1731: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7980 +//line sql.y:8683 { yyVAL.setScope = SetScope_Session } - case 1639: + case 1732: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7986 +//line sql.y:8689 { yyVAL.setScope = SetScope_Session } - case 1640: + case 1733: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7990 +//line sql.y:8693 { yyVAL.setScope = SetScope_Persist } - case 1641: + case 1734: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:7994 +//line sql.y:8697 { yyVAL.setScope = SetScope_PersistOnly } - case 1642: + case 1735: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8000 +//line sql.y:8703 { yyVAL.setVarExpr = &SetVarExpr{Name: yyDollar[1].colName, Expr: NewStrVal(yyDollar[3].bytes), Scope: SetScope_None} } - case 1643: + case 1736: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8004 +//line sql.y:8707 { yyVAL.setVarExpr = &SetVarExpr{Name: yyDollar[1].colName, Expr: NewStrVal(yyDollar[3].bytes), Scope: SetScope_None} } - case 1644: + case 1737: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:8008 +//line sql.y:8711 { // NOTE: This is a fix to allow MySQL dumps to load cleanly when they contain the following: // SET @@GLOBAL.GTID_PURGED= /*!80000 '+'*/ 'beabe64c-9dc6-11ed-8021-a0f9021e8e70:1-126'; @@ -21177,438 +22828,456 @@ yydefault: // In other places we can correctly concatenate adjacent string literals, but the special comments break it yyVAL.setVarExpr = &SetVarExpr{Name: yyDollar[1].colName, Expr: NewStrVal([]byte(string(yyDollar[3].bytes) + string(yyDollar[4].bytes))), Scope: SetScope_None} } - case 1645: + case 1738: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8017 +//line sql.y:8720 { yyVAL.setVarExpr = &SetVarExpr{Name: yyDollar[1].colName, Expr: yyDollar[3].expr, Scope: SetScope_None} } - case 1647: + case 1740: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8024 +//line sql.y:8727 { yyVAL.bytes = []byte("charset") } - case 1649: + case 1742: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8031 +//line sql.y:8734 { yyVAL.expr = NewStrVal([]byte(yyDollar[1].colIdent.String())) } - case 1650: + case 1743: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8035 +//line sql.y:8738 { yyVAL.expr = NewStrVal(yyDollar[1].bytes) } - case 1651: + case 1744: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8039 +//line sql.y:8742 { yyVAL.expr = &Default{} } - case 1654: + case 1747: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8048 +//line sql.y:8751 { yyVAL.byt = 0 } - case 1655: + case 1748: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8050 +//line sql.y:8753 { yyVAL.byt = 1 } - case 1656: + case 1749: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8053 +//line sql.y:8756 { yyVAL.byt = 0 } - case 1657: + case 1750: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8055 +//line sql.y:8758 { yyVAL.byt = 1 } - case 1658: + case 1751: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8058 +//line sql.y:8761 { yyVAL.byt = 0 } - case 1659: + case 1752: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8060 +//line sql.y:8763 { yyVAL.byt = 1 } - case 1660: + case 1753: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8063 +//line sql.y:8766 { yyVAL.str = "" } - case 1661: + case 1754: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8065 +//line sql.y:8768 { yyVAL.str = IgnoreStr } - case 1662: + case 1755: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8068 +//line sql.y:8771 { yyVAL.sqlVal = nil } - case 1663: + case 1756: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8070 +//line sql.y:8773 { yyVAL.sqlVal = NewIntVal(yyDollar[2].bytes) } - case 1664: + case 1757: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8072 +//line sql.y:8775 { yyVAL.sqlVal = NewIntVal(yyDollar[2].bytes) } - case 1665: - yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8076 + case 1758: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:8778 { yyVAL.empty = struct{}{} } - case 1666: + case 1759: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8078 +//line sql.y:8780 { yyVAL.empty = struct{}{} } - case 1667: - yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8081 + case 1760: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8784 { yyVAL.empty = struct{}{} } - case 1668: + case 1761: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8083 +//line sql.y:8786 { yyVAL.empty = struct{}{} } - case 1669: + case 1762: + yyDollar = yyS[yypt-0 : yypt+1] +//line sql.y:8789 + { + yyVAL.empty = struct{}{} + } + case 1763: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8085 +//line sql.y:8791 { yyVAL.empty = struct{}{} } - case 1670: + case 1764: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8089 +//line sql.y:8795 { yyVAL.str = UniqueStr } - case 1671: + case 1765: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8091 +//line sql.y:8797 { yyVAL.str = FulltextStr } - case 1672: + case 1766: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8093 +//line sql.y:8799 { yyVAL.str = SpatialStr } - case 1673: + case 1767: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8096 +//line sql.y:8802 { yyVAL.str = "" } - case 1674: + case 1768: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8098 +//line sql.y:8804 { yyVAL.str = yyDollar[1].str } - case 1675: + case 1769: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8101 +//line sql.y:8807 { yyVAL.colIdent = ColIdent{} } - case 1676: + case 1770: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8103 +//line sql.y:8809 { yyVAL.colIdent = yyDollar[2].colIdent } - case 1677: + case 1771: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8107 +//line sql.y:8813 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1678: + case 1772: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8111 +//line sql.y:8817 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1679: + case 1773: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8117 +//line sql.y:8823 { yyVAL.colIdents = []ColIdent{yyDollar[1].colIdent} } - case 1680: + case 1774: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8121 +//line sql.y:8827 { yyVAL.colIdents = append(yyVAL.colIdents, yyDollar[3].colIdent) } - case 1682: + case 1776: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8128 +//line sql.y:8834 { yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes)) } - case 1683: + case 1777: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8134 +//line sql.y:8840 { yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes)) } - case 1684: + case 1778: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8138 +//line sql.y:8844 { yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes)) } - case 1686: + case 1780: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8145 +//line sql.y:8851 { yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes)) } - case 1687: + case 1781: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8855 + { + yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes)) + } + case 1782: + yyDollar = yyS[yypt-1 : yypt+1] +//line sql.y:8859 + { + yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes)) + } + case 1783: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8150 +//line sql.y:8864 { yyVAL.str = string("") } - case 1688: + case 1784: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8152 +//line sql.y:8866 { yyVAL.str = string(yyDollar[2].bytes) } - case 1689: + case 1785: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8155 +//line sql.y:8869 { yyVAL.str = string("") } - case 1690: + case 1786: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8157 +//line sql.y:8871 { yyVAL.str = IgnoreStr } - case 1691: + case 1787: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8159 +//line sql.y:8873 { yyVAL.str = ReplaceStr } - case 1692: + case 1788: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8162 +//line sql.y:8876 { yyVAL.boolVal = BoolVal(false) } - case 1693: + case 1789: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8164 +//line sql.y:8878 { yyVAL.boolVal = BoolVal(true) } - case 1694: + case 1790: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8167 +//line sql.y:8881 { yyVAL.EnclosedBy = nil } - case 1695: + case 1791: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:8171 +//line sql.y:8885 { yyVAL.EnclosedBy = &EnclosedBy{Optionally: yyDollar[1].boolVal, Delim: NewStrVal(yyDollar[4].bytes)} } - case 1696: + case 1792: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8176 +//line sql.y:8890 { yyVAL.boolVal = BoolVal(false) } - case 1697: + case 1793: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8180 +//line sql.y:8894 { yyVAL.boolVal = BoolVal(true) } - case 1698: + case 1794: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8185 +//line sql.y:8899 { yyVAL.sqlVal = nil } - case 1699: + case 1795: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8189 +//line sql.y:8903 { yyVAL.sqlVal = NewStrVal(yyDollar[3].bytes) } - case 1700: + case 1796: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8194 +//line sql.y:8908 { yyVAL.sqlVal = nil } - case 1701: + case 1797: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8198 +//line sql.y:8912 { yyVAL.sqlVal = NewStrVal(yyDollar[3].bytes) } - case 1702: + case 1798: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8203 +//line sql.y:8920 { yyVAL.Fields = nil } - case 1703: + case 1799: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:8207 +//line sql.y:8924 { yyVAL.Fields = &Fields{TerminatedBy: yyDollar[2].sqlVal, EnclosedBy: yyDollar[3].EnclosedBy, EscapedBy: yyDollar[4].sqlVal} } - case 1704: + case 1800: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8212 +//line sql.y:8929 { yyVAL.Lines = nil } - case 1705: + case 1801: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8216 +//line sql.y:8933 { yyVAL.Lines = &Lines{StartingBy: yyDollar[2].sqlVal, TerminatedBy: yyDollar[3].sqlVal} } - case 1706: + case 1802: yyDollar = yyS[yypt-0 : yypt+1] -//line sql.y:8221 +//line sql.y:8938 { yyVAL.sqlVal = nil } - case 1707: + case 1803: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8225 +//line sql.y:8942 { yyVAL.sqlVal = NewStrVal(yyDollar[3].bytes) } - case 1708: + case 1804: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8231 +//line sql.y:8948 { yyVAL.statement = &LockTables{Tables: yyDollar[3].tableAndLockTypes} } - case 1709: + case 1805: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8237 +//line sql.y:8954 { yyVAL.tableAndLockTypes = TableAndLockTypes{yyDollar[1].tableAndLockType} } - case 1710: + case 1806: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8241 +//line sql.y:8958 { yyVAL.tableAndLockTypes = append(yyDollar[1].tableAndLockTypes, yyDollar[3].tableAndLockType) } - case 1711: + case 1807: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8247 +//line sql.y:8964 { yyVAL.tableAndLockType = &TableAndLockType{Table: &AliasedTableExpr{Expr: yyDollar[1].tableName}, Lock: yyDollar[2].lockType} } - case 1712: + case 1808: yyDollar = yyS[yypt-4 : yypt+1] -//line sql.y:8251 +//line sql.y:8968 { yyVAL.tableAndLockType = &TableAndLockType{Table: &AliasedTableExpr{Expr: yyDollar[1].tableName, As: yyDollar[3].tableIdent}, Lock: yyDollar[4].lockType} } - case 1713: + case 1809: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8257 +//line sql.y:8974 { yyVAL.lockType = LockRead } - case 1714: + case 1810: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8261 +//line sql.y:8978 { yyVAL.lockType = LockReadLocal } - case 1715: + case 1811: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:8265 +//line sql.y:8982 { yyVAL.lockType = LockWrite } - case 1716: + case 1812: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8269 +//line sql.y:8986 { yyVAL.lockType = LockLowPriorityWrite } - case 1717: + case 1813: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8275 +//line sql.y:8992 { yyVAL.statement = &UnlockTables{} } - case 1718: + case 1814: yyDollar = yyS[yypt-2 : yypt+1] -//line sql.y:8281 +//line sql.y:8998 { yyVAL.statement = &Kill{Connection: true, ConnID: NewIntVal(yyDollar[2].bytes)} } - case 1719: + case 1815: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8285 +//line sql.y:9002 { yyVAL.statement = &Kill{ConnID: NewIntVal(yyDollar[3].bytes)} } - case 1720: + case 1816: yyDollar = yyS[yypt-3 : yypt+1] -//line sql.y:8289 +//line sql.y:9006 { yyVAL.statement = &Kill{Connection: true, ConnID: NewIntVal(yyDollar[3].bytes)} } - case 2569: + case 2683: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:9180 +//line sql.y:9918 { if incNesting(yylex) { yylex.Error("max nesting level reached") return 1 } } - case 2570: + case 2684: yyDollar = yyS[yypt-1 : yypt+1] -//line sql.y:9189 +//line sql.y:9927 { decNesting(yylex) } diff --git a/go/vt/sqlparser/sql.y b/go/vt/sqlparser/sql.y index 845140cfb3f..7630f778f27 100755 --- a/go/vt/sqlparser/sql.y +++ b/go/vt/sqlparser/sql.y @@ -101,6 +101,7 @@ func yySpecialCommentMode(yylex interface{}) bool { sqlVal *SQLVal colTuple ColTuple values Values + aliasedvalues AliasedValues valTuple ValTuple whens []*When when *When @@ -140,11 +141,17 @@ func yySpecialCommentMode(yylex interface{}) bool { indexColumns []*IndexColumn constraintDefinition *ConstraintDefinition constraintInfo ConstraintInfo + tableOption *TableOption + tableOptions []*TableOption + partOption *PartitionOption + subpart *SubPartition ReferenceAction ReferenceAction partDefs []*PartitionDefinition partDef *PartitionDefinition partSpec *PartitionSpec + partSpecs []*PartitionSpec viewSpec *ViewSpec + viewCheckOption ViewCheckOption showFilter *ShowFilter frame *Frame frameExtent *FrameExtent @@ -202,6 +209,20 @@ func yySpecialCommentMode(yylex interface{}) bool { srsAttr *SrsAttribute } +// These precedence rules are there to handle shift-reduce conflicts. + +// STRING_TYPE_PREFIX_NON_KEYWORD is used to resolve shift-reduce conflicts occuring due to column_name symbol and +// being able to use keywords like DATE and TIME as prefixes to strings to denote their type. The shift-reduce conflict occurrs because +// after seeing one of these non-reserved keywords, if we see a STRING, then we can either shift to use the STRING typed rule in literal or +// reduce the non-reserved keyword into column_name and eventually use a rule from simple_expr. +// The way to fix this conflict is to give shifting higher precedence than reducing. +// Adding no precedence also works, since shifting is the default, but it reports some conflicts +// Precedence is also assined to shifting on STRING. +// We also need to add a lower precedence to reducing the grammar symbol to non-reserved keywords. +// In order to ensure lower precedence of reduction, this rule has to come before the precedence declaration of STRING. +// This precedence should not be used anywhere else other than with non-reserved-keywords that are also used for type-casting a STRING. +%nonassoc STRING_TYPE_PREFIX_NON_KEYWORD + %token LEX_ERROR // Special tokens @@ -211,7 +232,7 @@ func yySpecialCommentMode(yylex interface{}) bool { %left EXCEPT %left UNION %left INTERSECT -%token SELECT STREAM INSERT UPDATE DELETE FROM WHERE GROUP HAVING ORDER BY LIMIT OFFSET FOR CALL +%token SELECT STREAM INSERT UPDATE DELETE FROM WHERE GROUP HAVING ORDER BY LIMIT OFFSET FOR CALL %token ALL ANY SOME DISTINCT AS EXISTS ASC DESC DUPLICATE DEFAULT SET LOCK UNLOCK KEYS OF %token OUTFILE DUMPFILE DATA LOAD LINES TERMINATED ESCAPED ENCLOSED OPTIONALLY STARTING %right UNIQUE KEY @@ -222,7 +243,8 @@ func yySpecialCommentMode(yylex interface{}) bool { %left JOIN STRAIGHT_JOIN LEFT RIGHT INNER OUTER CROSS NATURAL USE FORCE %left ON USING %token '(' ',' ')' '@' ':' -%token ID HEX STRING INTEGRAL FLOAT HEXNUM VALUE_ARG LIST_ARG COMMENT COMMENT_KEYWORD BIT_LITERAL +%nonassoc STRING +%token ID HEX INTEGRAL FLOAT HEXNUM VALUE_ARG LIST_ARG COMMENT COMMENT_KEYWORD BIT_LITERAL %token NULL TRUE FALSE OFF %right INTO @@ -272,7 +294,12 @@ func yySpecialCommentMode(yylex interface{}) bool { %token SEQUENCE ENABLE DISABLE %token EACH ROW BEFORE FOLLOWS PRECEDES DEFINER INVOKER %token INOUT OUT DETERMINISTIC CONTAINS READS MODIFIES SQL SECURITY TEMPORARY ALGORITHM MERGE TEMPTABLE UNDEFINED -%token EVENT EVENTS SCHEDULE EVERY STARTS ENDS COMPLETION PRESERVE +%token EVENT EVENTS SCHEDULE EVERY STARTS ENDS COMPLETION PRESERVE CASCADED +%token INSTANT INPLACE COPY +%token DISCARD IMPORT +%token SHARED EXCLUSIVE +%token WITHOUT VALIDATION +%token COALESCE EXCHANGE REBUILD REMOVE PARTITIONING // SIGNAL Tokens %token CLASS_ORIGIN SUBCLASS_ORIGIN MESSAGE_TEXT MYSQL_ERRNO CONSTRAINT_CATALOG CONSTRAINT_SCHEMA @@ -301,8 +328,8 @@ func yySpecialCommentMode(yylex interface{}) bool { %token TABLE_ENCRYPTION_ADMIN TP_CONNECTION_ADMIN VERSION_TOKEN_ADMIN XA_RECOVER_ADMIN // Replication Tokens -%token REPLICA SOURCE STOP RESET FILTER -%token SOURCE_HOST SOURCE_USER SOURCE_PASSWORD SOURCE_PORT SOURCE_CONNECT_RETRY SOURCE_RETRY_COUNT +%token REPLICA REPLICAS SOURCE STOP RESET FILTER LOG MASTER +%token SOURCE_HOST SOURCE_USER SOURCE_PASSWORD SOURCE_PORT SOURCE_CONNECT_RETRY SOURCE_RETRY_COUNT SOURCE_AUTO_POSITION %token REPLICATE_DO_TABLE REPLICATE_IGNORE_TABLE // Transaction Tokens @@ -335,7 +362,7 @@ func yySpecialCommentMode(yylex interface{}) bool { %token CURRENT_TIME LOCALTIME LOCALTIMESTAMP %token UTC_DATE UTC_TIME UTC_TIMESTAMP %token REPLACE -%token CONVERT CAST +%token CONVERT CAST POSITION %token SUBSTR SUBSTRING %token TRIM LEADING TRAILING BOTH %token GROUP_CONCAT SEPARATOR @@ -389,7 +416,7 @@ func yySpecialCommentMode(yylex interface{}) bool { %token SENSITIVE SPECIFIC SQL_BIG_RESULT SQL_SMALL_RESULT %token UNUSED DESCRIPTION LATERAL MEMBER RECURSIVE -%token BUCKETS CLONE COMPONENT DEFINITION ENFORCED EXCLUDE FOLLOWING GEOMCOLLECTION GET_MASTER_PUBLIC_KEY HISTOGRAM HISTORY +%token BUCKETS CLONE COMPONENT DEFINITION ENFORCED NOT_ENFORCED EXCLUDE FOLLOWING GEOMCOLLECTION GET_MASTER_PUBLIC_KEY HISTOGRAM HISTORY %token INACTIVE INVISIBLE MASTER_COMPRESSION_ALGORITHMS MASTER_PUBLIC_KEY_PATH MASTER_TLS_CIPHERSUITES MASTER_ZSTD_COMPRESSION_LEVEL %token NESTED NETWORK_NAMESPACE NOWAIT NULLS OJ OLD ORDINALITY ORGANIZATION OTHERS PERSIST PERSIST_ONLY PRECEDING PRIVILEGE_CHECKS_USER PROCESS %token REFERENCE REQUIRE_ROW_FORMAT RESOURCE RESPECT RESTART RETAIN SECONDARY SECONDARY_LOAD SECONDARY_UNLOAD @@ -427,14 +454,16 @@ func yySpecialCommentMode(yylex interface{}) bool { %type declare_handler_condition_list %type declare_handler_action %type signal_condition_value +%type char_or_character %type trigger_time trigger_event -%type alter_statement alter_table_statement alter_database_statement alter_event_statement -%type create_table_prefix rename_list alter_table_statement_part +%type with_or_without +%type alter_statement alter_table_statement alter_database_statement alter_event_statement alter_user_statement +%type create_table_prefix rename_list alter_table_statement_part alter_table_options %type alter_table_statement_list %type analyze_statement analyze_opt show_statement use_statement prepare_statement execute_statement deallocate_statement %type describe_statement explain_statement explainable_statement %type begin_statement commit_statement rollback_statement start_transaction_statement load_statement -%type work_opt no_opt chain_opt release_opt index_name_opt +%type work_opt no_opt chain_opt release_opt index_name_opt no_first_last %type comment_opt comment_list %type distinct_opt union_op intersect_op except_op insert_or_replace %type match_option format_opt @@ -463,15 +492,16 @@ func yySpecialCommentMode(yylex interface{}) bool { %type boolean_value %type all_opt enforced_opt %type compare -%type insert_data -%type value value_expression num_val as_of_opt integral_or_value_arg integral_or_interval_expr timestamp_value +%type insert_data insert_data_alias insert_data_select insert_data_values +%type value value_expression num_val as_of_opt limit_val integral_or_interval_expr timestamp_value %type time_unit non_microsecond_time_unit %type function_call_keyword function_call_nonkeyword function_call_generic function_call_conflict -%type func_datetime_precision function_call_window function_call_aggregate_with_window +%type func_datetime_prec_opt function_call_window function_call_aggregate_with_window function_call_on_update %type is_suffix %type col_tuple %type expression_list group_by_list partition_by_opt %type tuple_list row_list + %type row_tuple tuple_or_empty %type tuple_expression %type column_name @@ -518,10 +548,11 @@ func yySpecialCommentMode(yylex interface{}) bool { %type query_opts %type key_type key_type_opt %type flush_type flush_type_opt -%type to_opt to_or_as as_opt column_opt -%type algorithm_opt definer_opt security_opt +%type to_or_as_opt to_or_as /*to_opt*/ as_opt column_opt +%type algorithm_view_opt algorithm_part_opt definer_opt security_opt %type view_opts -%type reserved_keyword qualified_column_name_safe_reserved_keyword non_reserved_keyword column_name_safe_keyword non_reserved_keyword2 non_reserved_keyword3 all_non_reserved +%type opt_with_check_option +%type reserved_keyword qualified_column_name_safe_reserved_keyword non_reserved_keyword column_name_safe_keyword function_call_keywords non_reserved_keyword2 non_reserved_keyword3 all_non_reserved id_or_non_reserved %type sql_id reserved_sql_id col_alias as_ci_opt using_opt existing_window_name_opt %type reserved_sql_id_list %type charset_value @@ -551,21 +582,29 @@ func yySpecialCommentMode(yylex interface{}) bool { %type name_opt %type equal_opt assignment_op %type table_spec table_column_list -%type table_option_list table_option table_opt_value row_fmt_opt -%type partition_options partition_option linear_partition_opt linear_opt partition_num_opt subpartition_opt subpartition_num_opt +%type table_opt_value row_fmt_opt +%type partition_option_opt partition_option linear_partition_opt +%type subpartition_opt +%type linear_opt +%type range_or_list +%type partition_num_opt subpartition_num_opt %type index_info %type index_column %type index_column_list %type index_option %type index_option_list index_option_list_opt +%type table_option +%type table_option_list %type flush_option +%type flush_tables_read_lock_opt %type replication_option_list replication_filter_option_list %type replication_option replication_filter_option %type relay_logs_attribute %type foreign_key_details check_constraint_info -%type partition_definitions +%type partition_definitions partition_definitions_opt %type partition_definition %type partition_operation +%type partition_operation_list_opt partition_operation_list %type fk_reference_action fk_on_delete fk_on_update drop_statement_action %type pk_name_opt constraint_symbol_opt infile_opt ignore_or_replace_opt %type call_param_list_opt @@ -763,7 +802,6 @@ intersect_stmt: $$ = &SetOp{Type: $2, Left: $1, Right: $3} } -// TODO: add (VALUES ROW(...), ROW(...), ...) support // base_select is either a simple SELECT or a SELECT wrapped in parentheses base_select: base_select_no_cte @@ -868,14 +906,14 @@ into_opt: { $$ = &Into{Variables: $2} } -| INTO OUTFILE STRING - { - $$ = &Into{Outfile: string($3)} - } | INTO DUMPFILE STRING { $$ = &Into{Dumpfile: string($3)} } +| INTO OUTFILE STRING charset_opt fields_opt lines_opt + { + $$ = &Into{Outfile: string($3), Charset: $4, Fields: $5, Lines: $6} + } variable_list: sql_id @@ -913,7 +951,20 @@ common_table_expression: } insert_statement: - with_clause_opt insert_or_replace comment_opt ignore_opt into_table_name opt_partition_clause insert_data on_dup_opt + with_clause_opt insert_or_replace comment_opt ignore_opt into_table_name opt_partition_clause insert_data_alias on_dup_opt + { + // insert_data returns a *Insert pre-filled with Columns & Values + ins := $7 + ins.Action = $2 + ins.Comments = $3 + ins.Ignore = $4 + ins.Table = $5 + ins.Partitions = $6 + ins.OnDup = OnDup($8) + ins.With = $1 + $$ = ins + } +| with_clause_opt insert_or_replace comment_opt ignore_opt into_table_name opt_partition_clause insert_data_select on_dup_opt { // insert_data returns a *Insert pre-filled with Columns & Values ins := $7 @@ -934,7 +985,7 @@ insert_statement: cols = append(cols, updateList.Name.Name) vals = append(vals, updateList.Expr) } - $$ = &Insert{Action: $2, Comments: Comments($3), Ignore: $4, Table: $5, Partitions: $6, Columns: cols, Rows: Values{vals}, OnDup: OnDup($9), With: $1} + $$ = &Insert{Action: $2, Comments: Comments($3), Ignore: $4, Table: $5, Partitions: $6, Columns: cols, Rows: &AliasedValues{Values: Values{vals}}, OnDup: OnDup($9), With: $1} } insert_or_replace: @@ -1126,18 +1177,21 @@ create_statement: ddl := &DDL{Action: AlterStr, Table: $7, IndexSpec: &IndexSpec{Action: CreateStr, ToName: $4, Using: $5, Type: $2, Columns: $9, Options: $11}} $$ = &AlterTable{Table: $7, Statements: []*DDL{ddl}} } -| CREATE view_opts VIEW table_name ins_column_list_opt AS lexer_position special_comment_mode select_statement_with_no_trailing_into lexer_position +| CREATE view_opts VIEW table_name ins_column_list_opt AS lexer_position special_comment_mode select_statement_with_no_trailing_into lexer_position opt_with_check_option { $2.ViewName = $4.ToViewName() $2.ViewExpr = $9 $2.Columns = $5 + $2.CheckOption = $11 $$ = &DDL{Action: CreateStr, ViewSpec: $2, SpecialCommentMode: $8, SubStatementPositionStart: $7, SubStatementPositionEnd: $10 - 1} } -| CREATE OR REPLACE view_opts VIEW table_name AS lexer_position special_comment_mode select_statement_with_no_trailing_into lexer_position +| CREATE OR REPLACE view_opts VIEW table_name ins_column_list_opt AS lexer_position special_comment_mode select_statement_with_no_trailing_into lexer_position opt_with_check_option { $4.ViewName = $6.ToViewName() - $4.ViewExpr = $10 - $$ = &DDL{Action: CreateStr, ViewSpec: $4, SpecialCommentMode: $9, SubStatementPositionStart: $8, SubStatementPositionEnd: $11 - 1, OrReplace: true} + $4.ViewExpr = $11 + $4.Columns = $7 + $4.CheckOption = $13 + $$ = &DDL{Action: CreateStr, ViewSpec: $4, SpecialCommentMode: $10, SubStatementPositionStart: $9, SubStatementPositionEnd: $12 - 1, OrReplace: true} } | CREATE DATABASE not_exists_opt ID creation_option_opt { @@ -1145,7 +1199,7 @@ create_statement: if $3 != 0 { ne = true } - $$ = &DBDDL{Action: CreateStr, DBName: string($4), IfNotExists: ne, CharsetCollate: $5} + $$ = &DBDDL{Action: CreateStr, SchemaOrDatabase: "database", DBName: string($4), IfNotExists: ne, CharsetCollate: $5} } | CREATE SCHEMA not_exists_opt ID creation_option_opt { @@ -1153,7 +1207,7 @@ create_statement: if $3 != 0 { ne = true } - $$ = &DBDDL{Action: CreateStr, DBName: string($4), IfNotExists: ne, CharsetCollate: $5} + $$ = &DBDDL{Action: CreateStr, SchemaOrDatabase: "schema", DBName: string($4), IfNotExists: ne, CharsetCollate: $5} } | CREATE definer_opt TRIGGER trigger_name trigger_time trigger_event ON table_name FOR EACH ROW trigger_order_opt lexer_position special_comment_mode trigger_body lexer_position { @@ -1259,6 +1313,24 @@ srs_attribute: $$ = $1 } +opt_with_check_option: + /* EMPTY */ + { + $$ = ViewCheckOptionUnspecified + } +| WITH CHECK OPTION + { + $$ = ViewCheckOptionCascaded + } +| WITH CASCADED CHECK OPTION + { + $$ = ViewCheckOptionCascaded + } +| WITH LOCAL CHECK OPTION + { + $$ = ViewCheckOptionLocal + } + default_role_opt: { $$ = nil @@ -1948,12 +2020,12 @@ view_opts: { $$ = &ViewSpec{Algorithm: "", Definer: $1, Security: $2} } -| algorithm_opt definer_opt security_opt +| algorithm_view_opt definer_opt security_opt { $$ = &ViewSpec{Algorithm: $1, Definer: $2, Security: $3} } -algorithm_opt: +algorithm_view_opt: ALGORITHM '=' UNDEFINED { $$ = string($3) @@ -2288,6 +2360,10 @@ trigger_begin_end_block: { $$ = &BeginEndBlock{Statements: $2} } +| BEGIN END + { + $$ = &BeginEndBlock{} + } case_statement: CASE expression case_statement_case_list END CASE @@ -2784,10 +2860,13 @@ create_table_prefix: } table_spec: - '(' table_column_list ')' table_option_list partition_options + '(' table_column_list ')' table_option_list partition_option_opt { $$ = $2 - $$.Options = $4 + $5 + for _, opt := range $4 { + $$.AddTableOption(opt) + } + $$.PartitionOpt = $5 } table_column_list: @@ -2801,21 +2880,10 @@ table_column_list: $$ = &TableSpec{} $$.AddConstraint($1) } -| column_definition_for_create check_constraint_definition - { - $$ = &TableSpec{} - $$.AddColumn($1) - $$.AddConstraint($2) - } | table_column_list ',' column_definition_for_create { $$.AddColumn($3) } -| table_column_list ',' column_definition_for_create check_constraint_definition - { - $$.AddColumn($3) - $$.AddConstraint($4) - } | table_column_list ',' index_definition { $$.AddIndex($3) @@ -2888,6 +2956,14 @@ column_definition_for_create: } $$ = &ColumnDefinition{Name: NewColIdent(string($1)), Type: $2} } +| function_call_keywords column_type column_type_options + { + if err := $2.merge($3); err != nil { + yylex.Error(err.Error()) + return 1 + } + $$ = &ColumnDefinition{Name: NewColIdent(string($1)), Type: $2} + } stored_opt: { @@ -3037,6 +3113,15 @@ column_type_options: } $$ = $1 } +| column_type_options check_constraint_definition + { + opt := ColumnType{Constraint: $2} + if err := $1.merge(opt); err != nil { + yylex.Error(err.Error()) + return 1 + } + $$ = $1 + } column_type: numeric_type signed_or_unsigned_opt zero_fill_opt @@ -3195,19 +3280,11 @@ time_type: } char_type: - CHAR char_length_opt + char_or_character char_length_opt { $$ = ColumnType{Type: string($1), Length: $2} } -| CHARACTER char_length_opt - { - $$ = ColumnType{Type: string($1), Length: $2} - } -| NATIONAL CHAR char_length_opt - { - $$ = ColumnType{Type: string($1) + " " + string($2), Length: $3} - } -| NATIONAL CHARACTER char_length_opt +| NATIONAL char_or_character char_length_opt { $$ = ColumnType{Type: string($1) + " " + string($2), Length: $3} } @@ -3243,11 +3320,7 @@ char_type: { $$ = ColumnType{Type: string($1) + " " + string($2), Length: $3} } -| NATIONAL CHAR VARYING char_length_opt - { - $$ = ColumnType{Type: string($1) + " " + string($2) + " " + string($3), Length: $4} - } -| NATIONAL CHARACTER VARYING char_length_opt +| NATIONAL char_or_character VARYING char_length_opt { $$ = ColumnType{Type: string($1) + " " + string($2) + " " + string($3), Length: $4} } @@ -3459,37 +3532,9 @@ column_default: { $$ = $2 } -| DEFAULT CURRENT_TIMESTAMP func_parens_opt - { - $$ = &FuncExpr{Name: NewColIdent(string($2))} - } -| DEFAULT CURRENT_TIMESTAMP openb argument_expression_list closeb - { - $$ = &FuncExpr{Name: NewColIdent(string($2)), Exprs: $4} - } -| DEFAULT LOCALTIME func_parens_opt - { - $$ = &FuncExpr{Name: NewColIdent(string($2))} - } -| DEFAULT LOCALTIME openb argument_expression_list closeb - { - $$ = &FuncExpr{Name: NewColIdent(string($2)), Exprs: $4} - } -| DEFAULT LOCALTIMESTAMP func_parens_opt - { - $$ = &FuncExpr{Name: NewColIdent(string($2))} - } -| DEFAULT LOCALTIMESTAMP openb argument_expression_list closeb - { - $$ = &FuncExpr{Name: NewColIdent(string($2)), Exprs: $4} - } -| DEFAULT NOW openb closeb - { - $$ = &FuncExpr{Name: NewColIdent(string($2))} - } -| DEFAULT NOW openb argument_expression_list closeb +| DEFAULT function_call_nonkeyword { - $$ = &FuncExpr{Name: NewColIdent(string($2)), Exprs: $4} + $$ = $2 } | DEFAULT openb value_expression closeb { @@ -3497,7 +3542,7 @@ column_default: } on_update: - ON UPDATE function_call_nonkeyword + ON UPDATE function_call_on_update { $$ = $3 } @@ -3526,6 +3571,15 @@ character_set: { $$ = string($3) } +| CHARSET ID + { + $$ = string($2) + } +| CHARSET BINARY + { + $$ = string($2) + } + collate_opt: { @@ -3545,6 +3599,10 @@ collate: { $$ = string($2) } +| COLLATE BINARY + { + $$ = string($2) + } default_keyword_opt: { @@ -3719,6 +3777,19 @@ flush_option: { $$ = &FlushOption{Name: string($1)} } +| TABLE table_name_list flush_tables_read_lock_opt + { + $$ = &FlushOption{Name: string($1), Tables: $2, ReadLock: $3} + } +| TABLES table_name_list flush_tables_read_lock_opt + { + $$ = &FlushOption{Name: string($1), Tables: $2, ReadLock: $3} + } + +flush_tables_read_lock_opt: + {$$ = false} +| WITH READ LOCK + {$$ = true} relay_logs_attribute: { $$ = "" } @@ -3799,6 +3870,10 @@ replication_option: { $$ = &ReplicationOption{Name: string($1), Value: mustAtoi(yylex, string($3))} } +| SOURCE_AUTO_POSITION '=' INTEGRAL + { + $$ = &ReplicationOption{Name: string($1), Value: mustAtoi(yylex, string($3))} + } replication_filter_option_list: replication_filter_option @@ -3907,9 +3982,9 @@ index_info: { $$ = &IndexInfo{Type: string($1) + " " + string($2), Name: NewColIdent("PRIMARY"), Primary: true, Unique: true} } -| CONSTRAINT ID PRIMARY KEY name_opt +| CONSTRAINT name_opt PRIMARY KEY name_opt { - $$ = &IndexInfo{Type: string($3) + " " + string($4), Name: NewColIdent(string($2)), Primary: true, Unique: true} + $$ = &IndexInfo{Type: string($3) + " " + string($4), Name: NewColIdent("PRIMARY"), Primary: true, Unique: true} } | SPATIAL index_or_key name_opt { @@ -4006,17 +4081,13 @@ index_column: { $$ = &IndexColumn{Column: NewColIdent(string($1)), Length: $2, Order: $3} } - + foreign_key_definition: - CONSTRAINT ID foreign_key_details + CONSTRAINT id_or_non_reserved foreign_key_details { $$ = &ConstraintDefinition{Name: string($2), Details: $3} } -| CONSTRAINT column_name_safe_keyword foreign_key_details - { - $$ = &ConstraintDefinition{Name: string($2), Details: $3} - } -| foreign_key_details +| foreign_key_details { $$ = &ConstraintDefinition{Details: $1} } @@ -4047,25 +4118,16 @@ index_name_opt: { $$ = nil } -| ID +| id_or_non_reserved { $$ = $1 } check_constraint_definition: - CONSTRAINT ID check_constraint_info + CONSTRAINT id_or_non_reserved check_constraint_info { $$ = &ConstraintDefinition{Name: string($2), Details: $3} } - // TODO: should be possible to use non_reserved_keyword -| CONSTRAINT STATUS check_constraint_info - { - $$ = &ConstraintDefinition{Name: string($2), Details: $3} - } -| CONSTRAINT column_name_safe_keyword check_constraint_info - { - $$ = &ConstraintDefinition{Name: string($2), Details: $3} - } | CONSTRAINT check_constraint_info { $$ = &ConstraintDefinition{Details: $2} @@ -4146,200 +4208,194 @@ enforced_opt: { $$ = true } -| NOT ENFORCED +| NOT_ENFORCED { $$ = false } table_option_list: { - $$ = "" + $$ = nil } | table_option_list table_option { - $$ = $1 + " " + string($2) + $$ = append($1, $2) } | table_option_list ',' table_option { - $$ = string($1) + ", " + string($3) + $$ = append($1, $3) } table_option: AUTOEXTEND_SIZE equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | AUTO_INCREMENT equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | AVG_ROW_LENGTH equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } -| CHARSET equal_opt charset +| default_keyword_opt CHARSET equal_opt charset { - $$ = string($1) + " " + string($3) + " " + $$ = &TableOption{Name: "CHARACTER SET", Value: $4} } -| DEFAULT CHARSET equal_opt charset - { - $$ = string($1) + " " + string($2) + " " + $4 - } -| CHARACTER SET equal_opt charset - { - $$ = string($1) + " " + string($2) + " " + $4 - } -| DEFAULT CHARACTER SET equal_opt charset +| default_keyword_opt CHARACTER SET equal_opt charset { - $$ = string($1) + " " + string($2) + " " + string($3) + " " + $5 + $$ = &TableOption{Name: string($2) + " " + string($3), Value: $5} } | CHECKSUM equal_opt coericble_to_integral { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | TABLE_CHECKSUM equal_opt coericble_to_integral { - $$ = "CHECKSUM" + " " + string($3) - } -| COLLATE equal_opt table_option_collate - { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: "CHECKSUM", Value: string($3)} } -| DEFAULT COLLATE equal_opt table_option_collate +| default_keyword_opt COLLATE equal_opt table_option_collate { - $$ = string($1) + " " + string($2) + " " + $4 + $$ = &TableOption{Name: string($2), Value: $4} } | COMMENT_KEYWORD equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } | COMPRESSION equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } | CONNECTION equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } | DATA DIRECTORY equal_opt STRING { - $$ = string($1) + " " + string($2) + " " + "'" + string($4) + "'" + $$ = &TableOption{Name: string($1) + " " + string($2), Value: string($4)} } | INDEX DIRECTORY equal_opt STRING { - $$ = string($1) + " " + string($2) + " " + "'" + string($4) + "'" + $$ = &TableOption{Name: string($1) + " " + string($2), Value: string($4)} } | DELAY_KEY_WRITE equal_opt coericble_to_integral { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | ENCRYPTION equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } | ENGINE equal_opt any_identifier { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | ENGINE_ATTRIBUTE equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } -| INSERT_METHOD equal_opt NO +| INSERT_METHOD equal_opt no_first_last { - $$ = string($1) + " " + string($3) - } -| INSERT_METHOD equal_opt FIRST - { - $$ = string($1) + " " + string($3) - } -| INSERT_METHOD equal_opt LAST - { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | KEY_BLOCK_SIZE equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | MAX_ROWS equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | MIN_ROWS equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | PACK_KEYS equal_opt coericble_to_integral { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | PASSWORD equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } | ROW_FORMAT equal_opt row_fmt_opt { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | START TRANSACTION { - $$ = string($1) + " " + string($2) + $$ = &TableOption{Name: string($1) + string($2)} } | SECONDARY_ENGINE equal_opt ID { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | SECONDARY_ENGINE equal_opt NULL { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | SECONDARY_ENGINE equal_opt STRING { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | SECONDARY_ENGINE_ATTRIBUTE equal_opt STRING { - $$ = string($1) + " " + "'" + string($3) + "'" + $$ = &TableOption{Name: string($1), Value: string($3)} } | STATS_AUTO_RECALC equal_opt DEFAULT { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } -| STATS_AUTO_RECALC equal_opt INTEGRAL +| STATS_AUTO_RECALC equal_opt coericble_to_integral { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | STATS_PERSISTENT equal_opt DEFAULT { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | STATS_PERSISTENT equal_opt coericble_to_integral { - $$ = string($1) + " " + string($3) + $$ = &TableOption{Name: string($1), Value: string($3)} } | STATS_SAMPLE_PAGES equal_opt table_opt_value { - $$ = string($1) + " " + $3 + $$ = &TableOption{Name: string($1), Value: $3} } | TABLESPACE table_opt_value { - $$ = string($1) + $2 + $$ = &TableOption{Name: string($1), Value: $2} } | TABLESPACE any_identifier - { - $$ = string($1) + " " + string($2) - } + { + $$ = &TableOption{Name: string($1), Value: string($2)} + } | TABLESPACE any_identifier STORAGE DISK { - $$ = string($1) + " " + string($2) + " " + string($3) + " " + string($4) + $$ = &TableOption{Name: string($1), Value: string($2) + " " + string($3) + " " + string($4)} } | TABLESPACE any_identifier STORAGE MEMORY { - $$ = string($1) + " " + string($2) + " " + string($3) + " " + string($4) + $$ = &TableOption{Name: string($1), Value: string($2) + " " + string($3) + " " + string($4)} } | UNION equal_opt openb any_identifier_list closeb { - $$ = string($1) + " " + "(" + $4 + ")" + $$ = &TableOption{Name: string($1), Value: "(" + $4 + ")"} + } + +no_first_last: + NO + { + $$ = $1 + } +| FIRST + { + $$ = $1 + } +| LAST + { + $$ = $1 } table_option_collate: @@ -4431,17 +4487,16 @@ any_identifier: | reserved_keyword // TODO: partition options for table creation will parse, but do nothing for now -partition_options: - { - $$ = "" - } -| PARTITION BY partition_option partition_num_opt subpartition_opt +partition_option_opt: { - $$ = string($1) + " " + string($2) + " " + $3 + $4 + $5 + $$ = nil } -| PARTITION BY partition_option partition_num_opt subpartition_opt openb partition_definitions closeb +| PARTITION BY partition_option partition_num_opt subpartition_opt partition_definitions_opt { - $$ = string($1) + " " + string($2) + " " + $3 + $4 + $5 + "(partition_definitions)" + $3.Partitions = $4 + $3.SubPartition = $5 + $3.Definitions = $6 + $$ = $3 } partition_option: @@ -4449,75 +4504,108 @@ partition_option: { $$ = $1 } -| RANGE openb any_identifier closeb - { - $$ = string($1) + " (" + string($3) + ")" - } -| RANGE COLUMNS openb column_list closeb +| range_or_list openb value_expression closeb { - $$ = string($1) + " " + string($2) + " (column_list)" + $$ = &PartitionOption { + PartitionType: string($1), + Expr: $3, + } } -| LIST openb any_identifier closeb +| range_or_list COLUMNS openb column_list closeb { - $$ = string($1) + " (" + string($3) + ")" + $$ = &PartitionOption { + PartitionType: string($1), + ColList: $4, + } } -| LIST COLUMNS openb column_list closeb - { - $$ = string($1) + " " + string($2) + " (column_list)" - } linear_partition_opt: - linear_opt HASH openb value closeb + linear_opt HASH openb value_expression closeb { - $$ = $1 + string($2) + " (value)" + $$ = &PartitionOption { + IsLinear: $1, + PartitionType: string($2), + Expr: $4, + } } -| linear_opt HASH openb ID closeb +| linear_opt KEY algorithm_part_opt openb column_list closeb { - $$ = $1 + string($2) + " (" + string($4) + ")" + $$ = &PartitionOption { + IsLinear: $1, + PartitionType: string($2), + KeyAlgorithm: $3, + ColList: $5, + } } -| linear_opt KEY openb column_list closeb + +linear_opt: { - $$ = $1 + string($2) + " (column_list)" + $$ = false } -| linear_opt KEY ALGORITHM '=' INTEGRAL openb column_list closeb +| LINEAR { - $$ = $1 + string($2) + " " + string($3) + " " + string($5) + " (column_list)" + $$ = true } -linear_opt: +algorithm_part_opt: { $$ = "" } -| LINEAR +| ALGORITHM '=' INTEGRAL { - $$ = string($1) + " " + $$ = string($1) + " = " + string($3) + } + +range_or_list: + RANGE + { + $$ = string($1) + } +| LIST + { + $$ = string($1) } partition_num_opt: { - $$ = "" + $$ = nil } | PARTITIONS INTEGRAL { - $$ = string($1) + " " + string($2) + " " + $$ = NewIntVal($2) } subpartition_opt: { - $$ = "" + $$ = nil } -| SUBPARTITION BY linear_partition_opt subpartition_num_opt +| SUBPARTITION BY linear_opt HASH openb value_expression closeb subpartition_num_opt { - $$ = string($1) + " " + string($2) + " " + $3 + " " + $4 + $$ = &SubPartition{ + IsLinear: $3, + PartitionType: string($4), + Expr: $6, + SubPartitions: $8, + } + } +| SUBPARTITION BY linear_opt KEY algorithm_part_opt openb value_expression closeb subpartition_num_opt + { + $$ = &SubPartition{ + IsLinear: $3, + PartitionType: string($4), + KeyAlgorithm: $5, + Expr: $7, + SubPartitions: $9, + } } subpartition_num_opt: { - $$ = "" + $$ = nil } | SUBPARTITIONS INTEGRAL { - $$ = string($1) + " " + string($2) + " " + $$ = NewIntVal($2) } constraint_symbol_opt: @@ -4546,28 +4634,33 @@ alter_statement: alter_database_statement | alter_table_statement | alter_event_statement +| alter_user_statement alter_database_statement: ALTER DATABASE ID creation_option_opt { - $$ = &DBDDL{Action: AlterStr, DBName: string($3), CharsetCollate: $4} + $$ = &DBDDL{Action: AlterStr, SchemaOrDatabase: "database", DBName: string($3), CharsetCollate: $4} } | ALTER DATABASE creation_option_opt { - $$ = &DBDDL{Action: AlterStr, CharsetCollate: $3} + $$ = &DBDDL{Action: AlterStr, SchemaOrDatabase: "database", CharsetCollate: $3} } alter_table_statement: - ALTER ignore_opt TABLE table_name alter_table_statement_list + ALTER ignore_opt TABLE table_name alter_table_statement_list partition_operation_list_opt { for i := 0; i < len($5); i++ { - if $5[i].Action == RenameStr { - $5[i].FromTables = append(TableNames{$4}, $5[i].FromTables...) - } else { - $5[i].Table = $4 - } + if $5[i].Action == RenameStr { + $5[i].FromTables = append(TableNames{$4}, $5[i].FromTables...) + } else { + $5[i].Table = $4 + } } - $$ = &AlterTable{Table: $4, Statements: $5} + $$ = &AlterTable{Table: $4, Statements: $5, PartitionSpecs: $6} + } +| ALTER ignore_opt TABLE table_name partition_operation_list + { + $$ = &AlterTable{Table: $4, PartitionSpecs: $5} } alter_table_statement_list: @@ -4583,228 +4676,744 @@ alter_table_statement_list: alter_table_statement_part: ADD column_opt '(' column_definition ')' { - ddl := &DDL{Action: AlterStr, ColumnAction: AddStr, TableSpec: &TableSpec{}} + ddl := &DDL{ + Action: AlterStr, + ColumnAction: AddStr, + TableSpec: &TableSpec{}, + } ddl.TableSpec.AddColumn($4) ddl.Column = $4.Name $$ = ddl } | ADD column_opt column_definition column_order_opt { - ddl := &DDL{Action: AlterStr, ColumnAction: AddStr, TableSpec: &TableSpec{}, ColumnOrder: $4} + ddl := &DDL{ + Action: AlterStr, + ColumnAction: AddStr, + TableSpec: &TableSpec{}, + ColumnOrder: $4, + } ddl.TableSpec.AddColumn($3) ddl.Column = $3.Name $$ = ddl } -| DROP column_opt ID +| ADD index_or_key name_opt using_opt '(' index_column_list ')' index_option_list_opt { - $$ = &DDL{Action: AlterStr, ColumnAction: DropStr, Column: NewColIdent(string($3))} + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: CreateStr, + ToName: NewColIdent($3), + Using: $4, + Columns: $6, + Options: $8, + }, + } } -| DROP column_opt all_non_reserved +| ADD constraint_symbol_opt key_type index_or_key_opt name_opt using_opt '(' index_column_list ')' index_option_list_opt { - $$ = &DDL{Action: AlterStr, ColumnAction: DropStr, Column: NewColIdent(string($3))} + idxName := $5 + if len(idxName) == 0 { + idxName = $2 + } + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: CreateStr, + ToName: NewColIdent(idxName), + Type: $3, + Using: $6, + Columns: $8, + Options: $10, + }, + } + } +// A name may be specified for a primary key, but it is ignored since the primary +// key is always named 'PRIMARY' +| ADD pk_name_opt PRIMARY KEY name_opt '(' index_column_list ')' index_option_list_opt + { + ddl := &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: CreateStr, + }, + } + ddl.IndexSpec = &IndexSpec{ + Action: CreateStr, + Using: NewColIdent(""), + ToName: NewColIdent($2), + Type: PrimaryStr, + Columns: $7, + Options: $9, + } + $$ = ddl } -| RENAME COLUMN ID to_or_as ID +| ADD foreign_key_definition { - $$ = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string($3)), ToColumn: NewColIdent(string($5))} + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: AddStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint($2) + $$ = ddl } -| RENAME COLUMN all_non_reserved to_or_as ID +| ADD check_constraint_definition { - $$ = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string($3)), ToColumn: NewColIdent(string($5))} + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: AddStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint($2) + $$ = ddl + } +| DROP CONSTRAINT id_or_non_reserved + { + $$ = &DDL{ + Action: AlterStr, + ConstraintAction: DropStr, + TableSpec: &TableSpec{ + Constraints: []*ConstraintDefinition{ + &ConstraintDefinition{ + Name: string($3), + }, + }, + }, + } } -| RENAME COLUMN ID to_or_as all_non_reserved +| DROP CHECK id_or_non_reserved + { + $$ = &DDL{ + Action: AlterStr, + ConstraintAction: DropStr, + TableSpec: &TableSpec{ + Constraints: []*ConstraintDefinition{ + &ConstraintDefinition{ + Name: string($3), + Details: &CheckConstraintDefinition{}, + }, + }, + }, + } + } +| ALTER CONSTRAINT id_or_non_reserved ENFORCED { - $$ = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string($3)), ToColumn: NewColIdent(string($5))} + $$ = &DDL{Action: AlterStr} } -| RENAME COLUMN all_non_reserved to_or_as all_non_reserved +| ALTER CHECK id_or_non_reserved ENFORCED { - $$ = &DDL{Action: AlterStr, ColumnAction: RenameStr, Column: NewColIdent(string($3)), ToColumn: NewColIdent(string($5))} + $$ = &DDL{Action: AlterStr} + } +| ALTER CONSTRAINT id_or_non_reserved NOT_ENFORCED + { + $$ = &DDL{Action: AlterStr} + } +| ALTER CHECK id_or_non_reserved NOT_ENFORCED + { + $$ = &DDL{Action: AlterStr} + } +| ALGORITHM equal_opt DEFAULT + { + $$ = &DDL{Action: AlterStr} + } +| ALGORITHM equal_opt INSTANT + { + $$ = &DDL{Action: AlterStr} + } +| ALGORITHM equal_opt INPLACE + { + $$ = &DDL{Action: AlterStr} + } +| ALGORITHM equal_opt COPY + { + $$ = &DDL{Action: AlterStr} + } +| ALTER column_opt sql_id SET DEFAULT value_expression + { + $$ = &DDL{ + Action: AlterStr, + DefaultSpec: &DefaultSpec{ + Action: SetStr, + Column: $3, + Value: $6, + }, + } + } +| ALTER column_opt sql_id DROP DEFAULT + { + $$ = &DDL{ + Action: AlterStr, + DefaultSpec: &DefaultSpec{ + Action: DropStr, + Column: $3, + }, + } + } +| ALTER INDEX id_or_non_reserved VISIBLE + { + $$ = &DDL{Action: AlterStr} } -| RENAME to_opt table_name +| ALTER INDEX id_or_non_reserved INVISIBLE + { + $$ = &DDL{Action: AlterStr} + } +| CHANGE column_opt ID column_definition column_order_opt + { + ddl := &DDL{ + Action: AlterStr, + ColumnAction: ChangeStr, + TableSpec: &TableSpec{}, + Column: NewColIdent(string($3)), + ColumnOrder: $5, + } + ddl.TableSpec.AddColumn($4) + $$ = ddl + } +| default_keyword_opt CHARACTER SET equal_opt charset + { + $$ = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: $5, + Collation: "", + }, + } + } +| default_keyword_opt CHARACTER SET equal_opt charset COLLATE equal_opt charset + { + $$ = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: $5, + Collation: $8, + }, + } + } +| default_keyword_opt COLLATE equal_opt charset + { + $$ = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: "", + Collation: $4, + }, + } + } +| CONVERT TO CHARACTER SET charset + { + $$ = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: $5, + Collation: "", + }, + } + } +| CONVERT TO CHARACTER SET charset COLLATE charset + { + $$ = &DDL{ + Action: AlterStr, + AlterCollationSpec: &AlterCollationSpec{ + CharacterSet: $5, + Collation: $7, + }, + } + } +| DISABLE KEYS + { + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: string($1), + }, + } + } +| ENABLE KEYS + { + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: string($1), + }, + } + } +| DISCARD TABLESPACE + { + $$ = &DDL{Action: AlterStr} + } +| IMPORT TABLESPACE + { + $$ = &DDL{Action: AlterStr} + } +| DROP column_opt id_or_non_reserved + { + $$ = &DDL{ + Action: AlterStr, + ColumnAction: DropStr, + Column: NewColIdent(string($3)), + } + } +| DROP index_or_key sql_id + { + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: DropStr, + ToName: $3, + }, + } + } +| DROP PRIMARY KEY + { + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: DropStr, + Type: PrimaryStr, + }, + } + } +| DROP FOREIGN KEY id_or_non_reserved + { + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: DropStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($4), + Details: &ForeignKeyDefinition{}, + }) + $$ = ddl + } +| FORCE + { + $$ = &DDL{Action: AlterStr} + } +| LOCK equal_opt DEFAULT + { + $$ = &DDL{Action: AlterStr} + } +| LOCK equal_opt NONE + { + $$ = &DDL{Action: AlterStr} + } +| LOCK equal_opt SHARED + { + $$ = &DDL{Action: AlterStr} + } +| LOCK equal_opt EXCLUSIVE + { + $$ = &DDL{Action: AlterStr} + } +| MODIFY column_opt column_definition column_order_opt + { + ddl := &DDL{ + Action: AlterStr, + ColumnAction: ModifyStr, + TableSpec: &TableSpec{}, + ColumnOrder: $4, + } + ddl.TableSpec.AddColumn($3) + ddl.Column = $3.Name + $$ = ddl + } +// | ORDER BY col_name [, col_name] ... +| RENAME COLUMN id_or_non_reserved to_or_as id_or_non_reserved + { + $$ = &DDL{ + Action: AlterStr, + ColumnAction: RenameStr, + Column: NewColIdent(string($3)), + ToColumn: NewColIdent(string($5)), + } + } +| RENAME index_or_key sql_id TO sql_id + { + $$ = &DDL{ + Action: AlterStr, + IndexSpec: &IndexSpec{ + Action: RenameStr, + FromName: $3, + ToName: $5, + }, + } + } +| RENAME to_or_as_opt table_name { // Change this to a rename statement - $$ = &DDL{Action: RenameStr, ToTables: TableNames{$3}} + $$ = &DDL{ + Action: RenameStr, + ToTables: TableNames{$3}, + } } -| ADD index_or_key name_opt using_opt '(' index_column_list ')' index_option_list_opt +| RENAME CONSTRAINT FOREIGN KEY id_or_non_reserved TO id_or_non_reserved { - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: CreateStr, ToName: NewColIdent($3), Using: $4, Columns: $6, Options: $8}} + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: RenameStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($5), + Details: &ForeignKeyDefinition{}, + }) + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($7), + Details: &ForeignKeyDefinition{}, + }) + $$ = ddl } -| ADD constraint_symbol_opt key_type index_or_key_opt name_opt using_opt '(' index_column_list ')' index_option_list_opt +| RENAME CONSTRAINT CHECK id_or_non_reserved TO id_or_non_reserved { - idxName := $5 - if len(idxName) == 0 { - idxName = $2 + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: RenameStr, + TableSpec: &TableSpec{}, } - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: CreateStr, ToName: NewColIdent(idxName), Type: $3, Using: $6, Columns: $8, Options: $10}} + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($4), + Details: &CheckConstraintDefinition{}, + }) + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($6), + Details: &CheckConstraintDefinition{}, + }) + $$ = ddl + } +| RENAME CONSTRAINT id_or_non_reserved TO id_or_non_reserved + { + ddl := &DDL{ + Action: AlterStr, + ConstraintAction: RenameStr, + TableSpec: &TableSpec{}, + } + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($3), + }) + ddl.TableSpec.AddConstraint(&ConstraintDefinition{ + Name: string($5), + }) + $$ = ddl + } +| with_or_without VALIDATION + { + $$ = &DDL{ + Action: AlterStr, + } + } +| alter_table_options + { + $$ = $1 + } + +// TODO: these are the same as table_option_list, but we need to have the return type be different +alter_table_options: + AUTOEXTEND_SIZE equal_opt table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| AUTO_INCREMENT equal_opt expression + { + $$ = &DDL{Action: AlterStr, AutoIncSpec: &AutoIncSpec{Value: $3}} + } +| AVG_ROW_LENGTH equal_opt table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| CHECKSUM equal_opt coericble_to_integral + { + $$ = &DDL{Action: AlterStr} + } +| TABLE_CHECKSUM equal_opt coericble_to_integral + { + $$ = &DDL{Action: AlterStr} + } +| COMMENT_KEYWORD equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| COMPRESSION equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| CONNECTION equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| DATA DIRECTORY equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| INDEX DIRECTORY equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| DELAY_KEY_WRITE equal_opt coericble_to_integral + { + $$ = &DDL{Action: AlterStr} + } +| ENCRYPTION equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| ENGINE equal_opt any_identifier + { + $$ = &DDL{Action: AlterStr} + } +| ENGINE_ATTRIBUTE equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| INSERT_METHOD equal_opt no_first_last + { + $$ = &DDL{Action: AlterStr} + } +| KEY_BLOCK_SIZE equal_opt table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| MAX_ROWS equal_opt table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| MIN_ROWS equal_opt table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| PACK_KEYS equal_opt coericble_to_integral + { + $$ = &DDL{Action: AlterStr} + } +| PASSWORD equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| ROW_FORMAT equal_opt row_fmt_opt + { + $$ = &DDL{Action: AlterStr} + } +| SECONDARY_ENGINE equal_opt ID + { + $$ = &DDL{Action: AlterStr} + } +| SECONDARY_ENGINE equal_opt NULL + { + $$ = &DDL{Action: AlterStr} + } +| SECONDARY_ENGINE equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| SECONDARY_ENGINE_ATTRIBUTE equal_opt STRING + { + $$ = &DDL{Action: AlterStr} + } +| STATS_AUTO_RECALC equal_opt DEFAULT + { + $$ = &DDL{Action: AlterStr} + } +| STATS_AUTO_RECALC equal_opt coericble_to_integral + { + $$ = &DDL{Action: AlterStr} + } +| STATS_PERSISTENT equal_opt DEFAULT + { + $$ = &DDL{Action: AlterStr} + } +| STATS_PERSISTENT equal_opt coericble_to_integral + { + $$ = &DDL{Action: AlterStr} + } +| STATS_SAMPLE_PAGES equal_opt table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| TABLESPACE table_opt_value + { + $$ = &DDL{Action: AlterStr} + } +| TABLESPACE any_identifier + { + $$ = &DDL{Action: AlterStr} + } +| TABLESPACE any_identifier STORAGE DISK + { + $$ = &DDL{Action: AlterStr} } -| DROP CONSTRAINT ID +| TABLESPACE any_identifier STORAGE MEMORY { - $$ = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: - []*ConstraintDefinition{&ConstraintDefinition{Name: string($3)}}}} + $$ = &DDL{Action: AlterStr} } -| DROP CONSTRAINT all_non_reserved +| UNION equal_opt openb any_identifier_list closeb { - $$ = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: - []*ConstraintDefinition{&ConstraintDefinition{Name: string($3)}}}} + $$ = &DDL{Action: AlterStr} } -| DROP CHECK ID + +with_or_without: + WITH { - $$ = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: - []*ConstraintDefinition{&ConstraintDefinition{Name: string($3), Details: &CheckConstraintDefinition{}}}}} + $$ = true } -| DROP CHECK all_non_reserved +| WITHOUT { - $$ = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: - []*ConstraintDefinition{&ConstraintDefinition{Name: string($3), Details: &CheckConstraintDefinition{}}}}} + $$ = false } -| DROP index_or_key sql_id + +id_or_non_reserved: + ID +| all_non_reserved + +alter_user_statement: + ALTER USER exists_opt account_name authentication { - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: DropStr, ToName: $3}} + var ifExists bool + if $3 != 0 { + ifExists = true + } + $$ = &DDL{Action: AlterStr, User: $4, Authentication: $5, IfExists: ifExists} } -| RENAME index_or_key sql_id TO sql_id + +column_order_opt: { - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: RenameStr, FromName: $3, ToName: $5}} + $$ = nil } -| MODIFY column_opt column_definition column_order_opt +| FIRST { - ddl := &DDL{Action: AlterStr, ColumnAction: ModifyStr, TableSpec: &TableSpec{}, ColumnOrder: $4} - ddl.TableSpec.AddColumn($3) - ddl.Column = $3.Name - $$ = ddl + $$ = &ColumnOrder{First: true} } -| CHANGE column_opt ID column_definition column_order_opt +| AFTER ID { - ddl := &DDL{Action: AlterStr, ColumnAction: ChangeStr, TableSpec: &TableSpec{}, Column: NewColIdent(string($3)), ColumnOrder: $5} - ddl.TableSpec.AddColumn($4) - $$ = ddl + $$ = &ColumnOrder{AfterColumn: NewColIdent(string($2))} } -| partition_operation + +column_opt: + { } +| COLUMN + { } + +partition_operation_list_opt: { - $$ = &DDL{Action: AlterStr, PartitionSpec: $1} + $$ = nil } -| ADD foreign_key_definition +| partition_operation_list { - ddl := &DDL{Action: AlterStr, ConstraintAction: AddStr, TableSpec: &TableSpec{}} - ddl.TableSpec.AddConstraint($2) - $$ = ddl + $$ = $1 } -| ADD check_constraint_definition + +partition_operation_list: + partition_operation { - ddl := &DDL{Action: AlterStr, ConstraintAction: AddStr, TableSpec: &TableSpec{}} - ddl.TableSpec.AddConstraint($2) - $$ = ddl + $$ = []*PartitionSpec{$1} } -| DROP FOREIGN KEY ID +| partition_operation_list partition_operation { - $$ = &DDL{Action: AlterStr, ConstraintAction: DropStr, TableSpec: &TableSpec{Constraints: - []*ConstraintDefinition{&ConstraintDefinition{Name: string($4), Details: &ForeignKeyDefinition{}}}}} + $$ = append($1, $2) } -| AUTO_INCREMENT equal_opt expression + +partition_operation: + ADD PARTITION openb partition_definitions closeb { - $$ = &DDL{Action: AlterStr, AutoIncSpec: &AutoIncSpec{Value: $3}} + $$ = &PartitionSpec{Action: AddStr, Definitions: $4} } -| ALTER column_opt sql_id SET DEFAULT value_expression +| DROP PARTITION partition_list { - $$ = &DDL{Action: AlterStr, DefaultSpec: &DefaultSpec{Action: SetStr, Column: $3, Value: $6}} + $$ = &PartitionSpec{Action: DropStr, Names: $3} } -| ALTER column_opt sql_id DROP DEFAULT +| DISCARD PARTITION partition_list TABLESPACE { - $$ = &DDL{Action: AlterStr, DefaultSpec: &DefaultSpec{Action: DropStr, Column: $3}} + $$ = &PartitionSpec{Action: DiscardStr, Names: $3} } -| DROP PRIMARY KEY +| DISCARD PARTITION ALL TABLESPACE { - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: DropStr, Type: PrimaryStr}} + $$ = &PartitionSpec{Action: DiscardStr, IsAll: true} } -// A name may be specified for a primary key, but it is ignored since the primary -// key is always named 'PRIMARY' -| ADD pk_name_opt PRIMARY KEY name_opt '(' index_column_list ')' index_option_list_opt +| IMPORT PARTITION partition_list TABLESPACE { - ddl := &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: CreateStr}} - ddl.IndexSpec = &IndexSpec{Action: CreateStr, Using: NewColIdent(""), ToName: NewColIdent($2), Type: PrimaryStr, Columns: $7, Options: $9} - $$ = ddl + $$ = &PartitionSpec{Action: ImportStr, Names: $3} } -| DISABLE KEYS +| IMPORT PARTITION ALL TABLESPACE { - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: string($1)}} + $$ = &PartitionSpec{Action: ImportStr, IsAll: true} } -| ENABLE KEYS +| TRUNCATE PARTITION partition_list TABLESPACE { - $$ = &DDL{Action: AlterStr, IndexSpec: &IndexSpec{Action: string($1)}} + $$ = &PartitionSpec{Action: TruncateStr, Names: $3} } -| default_keyword_opt CHARACTER SET equal_opt charset +| TRUNCATE PARTITION ALL TABLESPACE { - $$ = &DDL{Action: AlterStr, AlterCollationSpec: &AlterCollationSpec{CharacterSet: $5, Collation: ""}} + $$ = &PartitionSpec{Action: TruncateStr, IsAll: true} } -| default_keyword_opt CHARACTER SET equal_opt charset COLLATE equal_opt charset +| COALESCE PARTITION INTEGRAL { - $$ = &DDL{Action: AlterStr, AlterCollationSpec: &AlterCollationSpec{CharacterSet: $5, Collation: $8}} + $$ = &PartitionSpec{Action: CoalesceStr, Number: NewIntVal($3)} } -| default_keyword_opt COLLATE equal_opt charset +| REORGANIZE PARTITION partition_list INTO openb partition_definitions closeb { - $$ = &DDL{Action: AlterStr, AlterCollationSpec: &AlterCollationSpec{CharacterSet: "", Collation: $4}} + $$ = &PartitionSpec{Action: ReorganizeStr, Names: $3, Definitions: $6} } -| SECONDARY_ENGINE equal_opt ID +| EXCHANGE PARTITION sql_id WITH TABLE table_name { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: ExchangeStr, Names: Partitions{$3}, TableName: $6} } -| SECONDARY_ENGINE equal_opt STRING +| EXCHANGE PARTITION sql_id WITH TABLE table_name with_or_without VALIDATION { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: ExchangeStr, Names: Partitions{$3}, TableName: $6, WithValidation: $7} } - | SECONDARY_ENGINE equal_opt NULL - { - $$ = &DDL{Action: AlterStr} - } -| SECONDARY_ENGINE_ATTRIBUTE equal_opt STRING +| ANALYZE PARTITION partition_list { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: AnalyzeStr, Names: $3} } -| CHECKSUM equal_opt coericble_to_integral +| ANALYZE PARTITION ALL { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: AnalyzeStr, IsAll: true} } -| TABLE_CHECKSUM equal_opt coericble_to_integral +// The parser confuses CHECK with column_definitions +//| CHECK PARTITION partition_list +// { +// $$ = &PartitionSpec{Action: CheckStr, Names: $3} +// } +//| CHECK PARTITION ALL +// { +// $$ = &PartitionSpec{Action: CheckStr, IsAll: true} +// } +| OPTIMIZE PARTITION partition_list { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: OptimizeStr, Names: $3} } -| UNION equal_opt openb any_identifier_list closeb +| OPTIMIZE PARTITION ALL { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: OptimizeStr, IsAll: true} } -| INSERT_METHOD equal_opt NO +| REBUILD PARTITION partition_list { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: RebuildStr, Names: $3} } -| INSERT_METHOD equal_opt FIRST +| REBUILD PARTITION ALL { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: RebuildStr, IsAll: true} } -| INSERT_METHOD equal_opt LAST +| REPAIR PARTITION partition_list { - $$ = &DDL{Action: AlterStr} + $$ = &PartitionSpec{Action: RepairStr, Names: $3} } - -column_order_opt: +| REPAIR PARTITION ALL { - $$ = nil + $$ = &PartitionSpec{Action: RepairStr, IsAll: true} } -| FIRST +| REMOVE PARTITIONING { - $$ = &ColumnOrder{First: true} + $$ = &PartitionSpec{Action: RemoveStr} } -| AFTER ID + +partition_definitions_opt: { - $$ = &ColumnOrder{AfterColumn: NewColIdent(string($2))} + $$ = nil } - -column_opt: - { } -| COLUMN - { } - -partition_operation: - REORGANIZE PARTITION sql_id INTO openb partition_definitions closeb +| openb partition_definitions closeb { - $$ = &PartitionSpec{Action: ReorganizeStr, Name: $3, Definitions: $6} + $$ = $2 } partition_definitions: @@ -4920,7 +5529,7 @@ drop_statement: if $3 != 0 { exists = true } - $$ = &DBDDL{Action: DropStr, DBName: string($4), IfExists: exists} + $$ = &DBDDL{Action: DropStr, SchemaOrDatabase: "database", DBName: string($4), IfExists: exists} } | DROP SCHEMA exists_opt ID { @@ -4928,7 +5537,7 @@ drop_statement: if $3 != 0 { exists = true } - $$ = &DBDDL{Action: DropStr, DBName: string($4), IfExists: exists} + $$ = &DBDDL{Action: DropStr, SchemaOrDatabase: "schema", DBName: string($4), IfExists: exists} } | DROP TRIGGER exists_opt trigger_name { @@ -5256,6 +5865,22 @@ show_statement: { $$ = &Show{Type: string($2), ShowTablesOpt: &ShowTablesOpt{DbName: $3, Filter: $4}} } +| SHOW REPLICAS + { + $$ = &Show{Type: string($2)} + } +| SHOW BINARY LOG STATUS + { + $$ = &Show{Type: string($2) + " " + string($3) + " " + string($4)} + } +| SHOW MASTER STATUS + { + $$ = &Show{Type: "BINARY LOG STATUS"} + } +| SHOW BINARY LOGS + { + $$ = &Show{Type: string($2) + " " + string($3)} + } naked_like: LIKE value_expression like_escape_opt @@ -5657,7 +6282,7 @@ argument_expression: } | table_id '.' reserved_table_id '.' '*' { - $$ = &StarExpr{TableName: TableName{Qualifier: $1, Name: $3}} + $$ = &StarExpr{TableName: TableName{DbQualifier: $1, Name: $3}} } select_expression: @@ -5675,7 +6300,7 @@ select_expression: } | table_id '.' reserved_table_id '.' '*' { - $$ = &StarExpr{TableName: TableName{Qualifier: $1, Name: $3}} + $$ = &StarExpr{TableName: TableName{DbQualifier: $1, Name: $3}} } over: @@ -5950,7 +6575,6 @@ table_factor: | table_function | json_table - values_statement: VALUES row_list { @@ -5958,15 +6582,20 @@ values_statement: } row_list: - ROW row_tuple + row_opt row_tuple { $$ = Values{$2} } -| row_list ',' ROW row_tuple +| row_list ',' row_opt row_tuple { $$ = append($$, $4) } +row_opt: + {} +| ROW + {} + aliased_table_name: table_name aliased_table_options { @@ -6021,7 +6650,7 @@ as_of_clause: { $$ = $1 } - + between_times: FOR_SYSTEM_TIME BETWEEN value_expression AND value_expression { @@ -6194,11 +6823,6 @@ on_expression_opt: | ON expression { $$ = JoinCondition{On: $2} } -as_opt: - { $$ = struct{}{} } -| AS - { $$ = struct{}{} } - table_alias: table_id | column_name_safe_keyword @@ -6399,7 +7023,7 @@ table_name: } | table_id '.' reserved_table_id { - $$ = TableName{Qualifier: $1, Name: $3} + $$ = TableName{DbQualifier: $1, Name: $3} } | column_name_safe_keyword { @@ -6409,6 +7033,10 @@ table_name: { $$ = TableName{Name: NewTableIdent(string($1))} } +| function_call_keywords + { + $$ = TableName{Name: NewTableIdent(string($1))} + } | ACCOUNT { $$ = TableName{Name: NewTableIdent(string($1))} @@ -6776,7 +7404,7 @@ value_expression: } | value_expression COLLATE charset { - $$ = &CollateExpr{Expr: $1, Charset: $3} + $$ = &CollateExpr{Expr: $1, Collation: $3} } | BINARY value_expression %prec UNARY { @@ -7004,16 +7632,20 @@ function_call_keyword: } | CHAR openb argument_expression_list closeb { - $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: $3} + $$ = &CharExpr{Exprs: $3} } | CHAR openb argument_expression_list USING charset closeb { - $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: $3} + $$ = &CharExpr{Exprs: $3, Type: $5} } | CONVERT openb expression USING charset closeb { $$ = &ConvertUsingExpr{Expr: $3, Type: $5} } +| POSITION openb value_expression IN value_expression closeb + { + $$ = &FuncExpr{Name: NewColIdent("LOCATE"), Exprs: []SelectExpr{&AliasedExpr{Expr: $3}, &AliasedExpr{Expr: $5}}} + } | INSERT openb argument_expression_list closeb { $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: $3} @@ -7083,10 +7715,6 @@ function_call_keyword: { $$ = &ValuesFuncExpr{Name: NewColName(string($3))} } -| VERSION openb closeb - { - $$ = &FuncExpr{Name: NewColIdent(string($1))} - } | REPEAT openb argument_expression_list closeb { $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: $3} @@ -7097,87 +7725,71 @@ function_call_keyword: Dedicated grammar rules are needed because of the special syntax */ function_call_nonkeyword: - CURRENT_TIMESTAMP func_parens_opt - { - $$ = &FuncExpr{Name:NewColIdent(string($1))} - } -| UTC_TIMESTAMP func_parens_opt +// functions that do not support fractional second precision (fsp) + CURRENT_DATE func_parens_opt { - $$ = &FuncExpr{Name:NewColIdent(string($1))} + $$ = &FuncExpr{Name: NewColIdent(string($1))} } -| UTC_TIME func_parens_opt +| CURRENT_USER func_parens_opt { - $$ = &FuncExpr{Name:NewColIdent(string($1))} + $$ = &FuncExpr{Name: NewColIdent(string($1))} } -/* doesn't support fsp */ | UTC_DATE func_parens_opt { - $$ = &FuncExpr{Name:NewColIdent(string($1))} - } - // now -| LOCALTIME func_parens_opt - { - $$ = &FuncExpr{Name:NewColIdent(string($1))} - } - // now -| LOCALTIMESTAMP func_parens_opt - { - $$ = &FuncExpr{Name:NewColIdent(string($1))} + $$ = &FuncExpr{Name: NewColIdent(string($1))} } - // curdate -/* doesn't support fsp */ -| CURRENT_DATE func_parens_opt +// functions that can be called with optional second argument +| function_call_on_update { - $$ = &FuncExpr{Name:NewColIdent(string($1))} + $$ = $1 } - // curtime -| CURRENT_TIME func_parens_opt +| CURRENT_TIME func_datetime_prec_opt { - $$ = &FuncExpr{Name:NewColIdent(string($1))} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: $2}}} } -| CURRENT_USER func_parens_opt +| UTC_TIME func_datetime_prec_opt { - $$ = &FuncExpr{Name:NewColIdent(string($1))} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: $2}}} } -// these functions can also be called with an optional argument -| CURRENT_TIMESTAMP func_datetime_precision +| UTC_TIMESTAMP func_datetime_prec_opt { - $$ = &CurTimeFuncExpr{Name:NewColIdent(string($1)), Fsp:$2} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: $2}}} } -| UTC_TIMESTAMP func_datetime_precision +| TIMESTAMPADD openb time_unit ',' value_expression ',' value_expression closeb { - $$ = &CurTimeFuncExpr{Name:NewColIdent(string($1)), Fsp:$2} + $$ = &TimestampFuncExpr{Name:string("timestampadd"), Unit:string($3), Expr1:$5, Expr2:$7} } -| UTC_TIME func_datetime_precision +| TIMESTAMPDIFF openb time_unit ',' value_expression ',' value_expression closeb { - $$ = &CurTimeFuncExpr{Name:NewColIdent(string($1)), Fsp:$2} + $$ = &TimestampFuncExpr{Name:string("timestampdiff"), Unit:string($3), Expr1:$5, Expr2:$7} } - // now -| LOCALTIME func_datetime_precision +| EXTRACT openb time_unit FROM value_expression closeb { - $$ = &CurTimeFuncExpr{Name:NewColIdent(string($1)), Fsp:$2} + $$ = &ExtractFuncExpr{Name: string($1), Unit: string($3), Expr: $5} } - // now -| LOCALTIMESTAMP func_datetime_precision + +// functions that can be used with the ON UPDATE clause +function_call_on_update: + // NOW is special; it can't be called without parentheses + NOW openb closeb { - $$ = &CurTimeFuncExpr{Name:NewColIdent(string($1)), Fsp:$2} + $$ = &FuncExpr{Name: NewColIdent(string($1))} } - // curtime -| CURRENT_TIME func_datetime_precision +| NOW openb INTEGRAL closeb { - $$ = &CurTimeFuncExpr{Name:NewColIdent(string($1)), Fsp:$2} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: NewIntVal($3)}}} } -| TIMESTAMPADD openb time_unit ',' value_expression ',' value_expression closeb +| CURRENT_TIMESTAMP func_datetime_prec_opt { - $$ = &TimestampFuncExpr{Name:string("timestampadd"), Unit:string($3), Expr1:$5, Expr2:$7} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: $2}}} } -| TIMESTAMPDIFF openb time_unit ',' value_expression ',' value_expression closeb +| LOCALTIME func_datetime_prec_opt { - $$ = &TimestampFuncExpr{Name:string("timestampdiff"), Unit:string($3), Expr1:$5, Expr2:$7} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: $2}}} } -| EXTRACT openb time_unit FROM value_expression closeb +| LOCALTIMESTAMP func_datetime_prec_opt { - $$ = &ExtractFuncExpr{Name: string($1), Unit: string($3), Expr: $5} + $$ = &FuncExpr{Name: NewColIdent(string($1)), Exprs: SelectExprs{&AliasedExpr{Expr: $2}}} } // Optional parens for certain keyword functions that don't require them. @@ -7185,10 +7797,16 @@ func_parens_opt: /* empty */ | openb closeb -func_datetime_precision: - openb value_expression closeb +// Optional datetime precision for certain functions. +func_datetime_prec_opt: + // no arg is the same as 0 + func_parens_opt { - $$ = $2 + $$ = NewIntVal([]byte("0")) + } +| openb INTEGRAL closeb + { + $$ = NewIntVal($2) } /* @@ -7252,6 +7870,10 @@ charset: { $$ = string($1) } +| BINARY +{ + $$ = string($1) +} underscore_charsets: UNDERSCORE_ARMSCII8 @@ -7436,6 +8058,14 @@ convert_type: { $$ = &ConvertType{Type: string($1), Length: $2, Charset: string($3)} } +| CHARACTER length_opt charset_opt + { + $$ = &ConvertType{Type: "CHAR", Length: $2, Charset: $3, Operator: CharacterSetStr} + } +| CHARACTER length_opt ID + { + $$ = &ConvertType{Type: "CHAR", Length: $2, Charset: string($3)} + } | DATE { $$ = &ConvertType{Type: string($1)} @@ -7450,6 +8080,22 @@ convert_type: $$.Length = $2.Length $$.Scale = $2.Scale } +| DOUBLE + { + $$ = &ConvertType{Type: string($1)} + } +| DOUBLE PRECISION + { + $$ = &ConvertType{Type: string($1)} + } +| REAL + { + $$ = &ConvertType{Type: string($1)} + } +| FLOAT_TYPE + { + $$ = &ConvertType{Type: string($1)} + } | JSON { $$ = &ConvertType{Type: string($1)} @@ -7478,13 +8124,19 @@ convert_type: { $$ = &ConvertType{Type: string($1)} } -| DOUBLE +| YEAR { $$ = &ConvertType{Type: string($1)} } -| FLOAT_TYPE + +char_or_character: + CHAR { - $$ = &ConvertType{Type: string($1)} + $$ = $1 + } +| CHARACTER + { + $$ = $1 } expression_opt: @@ -7583,9 +8235,13 @@ column_name: { $$ = &ColName{Qualifier: TableName{Name: NewTableIdent(string($1))}, Name: $3} } +| function_call_keywords + { + $$ = &ColName{Name: NewColIdent(string($1))} + } | table_id '.' reserved_table_id '.' reserved_sql_id { - $$ = &ColName{Qualifier: TableName{Qualifier: $1, Name: $3}, Name: $5} + $$ = &ColName{Qualifier: TableName{DbQualifier: $1, Name: $3}, Name: $5} } value: @@ -7593,6 +8249,18 @@ value: { $$ = NewStrVal($1) } +| DATE STRING + { + $$ = NewStrVal($2) + } +| TIME STRING + { + $$ = NewStrVal($2) + } +| TIMESTAMP STRING + { + $$ = NewStrVal($2) + } | HEX { $$ = NewHexVal($1) @@ -7718,20 +8386,20 @@ limit_opt: { $$ = nil } -| LIMIT integral_or_value_arg +| LIMIT limit_val { $$ = &Limit{Rowcount: $2} } -| LIMIT integral_or_value_arg ',' integral_or_value_arg +| LIMIT limit_val ',' limit_val { $$ = &Limit{Offset: $2, Rowcount: $4} } -| LIMIT integral_or_value_arg OFFSET integral_or_value_arg +| LIMIT limit_val OFFSET limit_val { $$ = &Limit{Offset: $4, Rowcount: $2} } -integral_or_value_arg: +limit_val: INTEGRAL { $$ = NewIntVal($1) @@ -7740,6 +8408,10 @@ INTEGRAL { $$ = NewValArg($1) } +| column_name + { + $$ = $1 + } lock_opt: { @@ -7758,6 +8430,23 @@ lock_opt: $$ = ShareModeStr } +insert_data_alias: + insert_data + { + $$ = $1 + } +| insert_data as_opt table_alias column_list_opt + { + $$ = $1 + // Rows is guarenteed to be an *AliasedValues here. + rows := $$.Rows.(*AliasedValues) + rows.As = $3 + if $4 != nil { + rows.Columns = $4 + } + $$.Rows = rows + } + // insert_data expands all combinations into a single rule. // This avoids a shift/reduce conflict while encountering the // following two possible constructs: @@ -7766,35 +8455,49 @@ lock_opt: // Because the rules are together, the parser can keep shifting // the tokens until it disambiguates a as sql_id and select as keyword. insert_data: - value_or_values tuple_list + insert_data_values { - $$ = &Insert{Rows: $2} + $$ = $1 } -| openb closeb value_or_values tuple_list +| openb closeb insert_data_values { - $$ = &Insert{Columns: []ColIdent{}, Rows: $4} + $3.Columns = []ColIdent{} + $$ = $3 + } +| openb ins_column_list closeb insert_data_values + { + $4.Columns = $2 + $$ = $4 } -| select_statement_with_no_trailing_into + +insert_data_select: + select_statement_with_no_trailing_into { $$ = &Insert{Rows: $1} } +| openb ins_column_list closeb select_statement_with_no_trailing_into + { + $$ = &Insert{Columns: $2, Rows: $4} + } | openb select_statement_with_no_trailing_into closeb { // Drop the redundant parenthesis. $$ = &Insert{Rows: $2} } -| openb ins_column_list closeb value_or_values tuple_list +| openb ins_column_list closeb openb select_statement_with_no_trailing_into closeb { + // Drop the redundant parenthesis. $$ = &Insert{Columns: $2, Rows: $5} } -| openb ins_column_list closeb select_statement_with_no_trailing_into + +insert_data_values: + value_or_values tuple_list { - $$ = &Insert{Columns: $2, Rows: $4} + $$ = &Insert{Rows: &AliasedValues{Values: $2}} } -| openb ins_column_list closeb openb select_statement_with_no_trailing_into closeb +| openb insert_data_values closeb { - // Drop the redundant parenthesis. - $$ = &Insert{Columns: $2, Rows: $5} + $$ = $2 } value_or_values: @@ -7866,11 +8569,11 @@ tuple_list: } tuple_or_empty: - row_tuple + row_opt row_tuple { - $$ = $1 + $$ = $2 } -| openb closeb +| row_opt openb closeb { $$ = ValTuple{} } @@ -7931,7 +8634,7 @@ set_list: set_expression: set_expression_assignment { - colName, scope, err := VarScopeForColName($1.Name) + colName, scope, _, err := VarScopeForColName($1.Name) if err != nil { yylex.Error(err.Error()) return 1 @@ -7942,7 +8645,7 @@ set_expression: } | set_scope_primary set_expression_assignment { - _, scope, err := VarScopeForColName($2.Name) + _, scope, _, err := VarScopeForColName($2.Name) if err != nil { yylex.Error(err.Error()) return 1 @@ -7955,7 +8658,7 @@ set_expression: } | set_scope_secondary set_expression_assignment { - _, scope, err := VarScopeForColName($2.Name) + _, scope, _, err := VarScopeForColName($2.Name) if err != nil { yylex.Error(err.Error()) return 1 @@ -8071,15 +8774,18 @@ ignore_number_opt: | IGNORE INTEGRAL ROWS { $$ = NewIntVal($2) } +to_or_as_opt: + { $$ = struct{}{} } +| to_or_as + { $$ = struct{}{} } + to_or_as: TO { $$ = struct{}{} } | AS { $$ = struct{}{} } -to_opt: - { $$ = struct{}{} } -| TO +as_opt: { $$ = struct{}{} } | AS { $$ = struct{}{} } @@ -8145,6 +8851,14 @@ reserved_table_id: { $$ = NewTableIdent(string($1)) } +| non_reserved_keyword2 + { + $$ = NewTableIdent(string($1)) + } +| non_reserved_keyword3 + { + $$ = NewTableIdent(string($1)) + } infile_opt: { $$ = string("") } @@ -8199,6 +8913,9 @@ escaped_by_opt: $$ = NewStrVal($3) } +// TODO: support any number of enclosed_by_opt +// TODO: support any number of escaped_by_opt +// TODO: escaped_by_opt and enclosed_by_opt can appear in any order fields_opt: { $$ = nil @@ -8871,6 +9588,7 @@ non_reserved_keyword: | ARRAY | AT | AUTHENTICATION +| AUTOEXTEND_SIZE | AUTO_INCREMENT | AVG_ROW_LENGTH | BEGIN @@ -8879,6 +9597,7 @@ non_reserved_keyword: | BOOL | BOOLEAN | BUCKETS +| CASCADED | CATALOG_NAME | CHAIN | CHANNEL @@ -8889,6 +9608,7 @@ non_reserved_keyword: | CLIENT | CLONE | CLOSE +| COALESCE | COLLATION | COLUMNS | COLUMN_NAME @@ -8907,7 +9627,7 @@ non_reserved_keyword: | CURRENT | CURSOR_NAME | DATA -| DATE +| DATE %prec STRING_TYPE_PREFIX_NON_KEYWORD | DATETIME | DAY | DEALLOCATE @@ -8917,6 +9637,7 @@ non_reserved_keyword: | DESCRIPTION | DIRECTORY | DISABLE +| DISCARD | DISK | DO | DUMPFILE @@ -8935,6 +9656,7 @@ non_reserved_keyword: | ERRORS | EVENTS | EVERY +| EXCHANGE | EXCLUDE | EXPANSION | EXPIRE @@ -8959,6 +9681,7 @@ non_reserved_keyword: | HISTORY | HOSTS | HOUR +| IMPORT | INACTIVE | INDEXES | INITIAL @@ -8978,7 +9701,9 @@ non_reserved_keyword: | LIST | LOCAL | LOCKED +| LOG | LOGS +| MASTER | MASTER_COMPRESSION_ALGORITHMS | MASTER_PUBLIC_KEY_PATH | MASTER_TLS_CIPHERSUITES @@ -8988,6 +9713,7 @@ non_reserved_keyword: | MAX_ROWS | MAX_UPDATES_PER_HOUR | MAX_USER_CONNECTIONS +| MEMORY | MERGE | MESSAGE_TEXT | MICROSECOND @@ -9008,7 +9734,6 @@ non_reserved_keyword: | NETWORK_NAMESPACE | NEVER | NO -| NOW | NOWAIT | NULLS | NVARCHAR @@ -9022,6 +9747,7 @@ non_reserved_keyword: | ORGANIZATION | OTHERS | PACK_KEYS +| PARTITIONING | PARTITIONS | PATH | PERSIST @@ -9040,13 +9766,16 @@ non_reserved_keyword: | QUARTER | QUERY | RANDOM +| REBUILD | REDUNDANT | REFERENCE | RELAY +| REMOVE | REORGANIZE | REPAIR | REPEATABLE | REPLICA +| REPLICAS | REPLICATE_DO_TABLE | REPLICATE_IGNORE_TABLE | REPLICATION @@ -9084,6 +9813,7 @@ non_reserved_keyword: | SOURCE_HOST | SOURCE_PASSWORD | SOURCE_PORT +| SOURCE_AUTO_POSITION | SOURCE_RETRY_COUNT | SOURCE_USER | SRID @@ -9110,8 +9840,8 @@ non_reserved_keyword: | THAN | THREAD_PRIORITY | TIES -| TIME -| TIMESTAMP +| TIME %prec STRING_TYPE_PREFIX_NON_KEYWORD +| TIMESTAMP %prec STRING_TYPE_PREFIX_NON_KEYWORD | TRANSACTION | TRIGGERS | TRUNCATE @@ -9121,13 +9851,16 @@ non_reserved_keyword: | UNUSED | USER | USER_RESOURCES +| VALIDATION | VALUE | VARIABLES +| VERSION | VCPU | VISIBLE | UNDEFINED | WARNINGS | WEEK +| WITHOUT | WORK | X509 | YEAR @@ -9153,7 +9886,6 @@ non_reserved_keyword2: | SUPER | TIMESTAMPADD | TIMESTAMPDIFF -| VERSION | VERSIONS | VIEW @@ -9175,6 +9907,12 @@ column_name_safe_keyword: | MIN | SUM +// Names of functions that require special grammar support. These aren't reserved or non-reserved in MySQL's docs, but are labeled as keywords in our grammar because of their custom syntax. +function_call_keywords: + CAST +| POSITION +| TRIM + openb: '(' { diff --git a/go/vt/sqlparser/sql_test.go b/go/vt/sqlparser/sql_test.go index c5163b9153d..45d8395c2fc 100644 --- a/go/vt/sqlparser/sql_test.go +++ b/go/vt/sqlparser/sql_test.go @@ -300,8 +300,8 @@ func TestDropIndex(t *testing.T) { { "DROP INDEX idx_v ON tbl_abc", TableName{ - Name: TableIdent{"tbl_abc"}, - Qualifier: TableIdent{}, + Name: TableIdent{"tbl_abc"}, + DbQualifier: TableIdent{}, }, &IndexSpec{ Action: DropStr, @@ -311,8 +311,8 @@ func TestDropIndex(t *testing.T) { { "DROP INDEX otherName ON tableYeah", TableName{ - Name: TableIdent{"tableYeah"}, - Qualifier: TableIdent{}, + Name: TableIdent{"tableYeah"}, + DbQualifier: TableIdent{}, }, &IndexSpec{ Action: DropStr, @@ -323,22 +323,39 @@ func TestDropIndex(t *testing.T) { testIndex(t, tests) } -// TestShowTablePrepared tests that Vitess can correctly walk all the SQLVal instances -// in a parsed SHOW TABLES statement to identify the bound variables. -func TestShowTablePrepared(t *testing.T) { - statement, err := Parse("SHOW TABLES FROM `mydb` WHERE `Tables_in_mydb` = ?") - require.NoError(t, err) - paramsCount := uint16(0) - _ = Walk(func(node SQLNode) (bool, error) { - switch node := node.(type) { - case *SQLVal: - if strings.HasPrefix(string(node.Val), ":v") { - paramsCount++ - } - } - return true, nil - }, statement) - assert.Equal(t, uint16(1), paramsCount) +// TestWalkPrepared tests that Vitess can correctly walk all the SQLVal instances +// in a parsed statement to identify the bound variables. +func TestWalkPrepared(t *testing.T) { + tests := []struct { + q string + paramCnt int + }{ + { + q: "SHOW TABLES FROM `mydb` WHERE `Tables_in_mydb` = ?", + paramCnt: 1, + }, + { + q: "select * from table_function(?,?)", + paramCnt: 2, + }, + } + for _, tt := range tests { + t.Run(fmt.Sprintf("prepare param count: %s", tt.q), func(t *testing.T) { + statement, err := Parse(tt.q) + require.NoError(t, err) + paramsCount := uint16(0) + _ = Walk(func(node SQLNode) (bool, error) { + switch node := node.(type) { + case *SQLVal: + if strings.HasPrefix(string(node.Val), ":v") { + paramsCount++ + } + } + return true, nil + }, statement) + assert.Equal(t, uint16(tt.paramCnt), paramsCount) + }) + } } func TestShowIndex(t *testing.T) { diff --git a/go/vt/sqlparser/token.go b/go/vt/sqlparser/token.go index a5b933bc499..b57fa8a76c9 100644 --- a/go/vt/sqlparser/token.go +++ b/go/vt/sqlparser/token.go @@ -154,12 +154,21 @@ func (tkn *Tokenizer) Lex(lval *yySymType) int { // Error is called by go yacc if there's a parsing error. func (tkn *Tokenizer) Error(err string) { buf := &bytes2.Buffer{} + + position := tkn.Position + // Adjust the position in case we've read ahead any tokens + if len(tkn.digestedTokens) > 0 { + for _, tokenAndValue := range tkn.digestedTokens { + position -= len(tokenAndValue.value) + 1 + } + } + if tkn.lastNonNilToken != nil { - fmt.Fprintf(buf, "%s at position %v near '%s'", err, tkn.Position, tkn.lastNonNilToken) + fmt.Fprintf(buf, "%s at position %v near '%s'", err, position, tkn.lastNonNilToken) } else { - fmt.Fprintf(buf, "%s at position %v", err, tkn.Position) + fmt.Fprintf(buf, "%s at position %v", err, position) } - tkn.LastError = vterrors.SyntaxError{Message: buf.String(), Position: tkn.Position, Statement: string(tkn.buf)} + tkn.LastError = vterrors.SyntaxError{Message: buf.String(), Position: position, Statement: string(tkn.buf)} // Try and re-sync to the next statement tkn.skipStatement() @@ -175,8 +184,9 @@ func (tkn *Tokenizer) digestedToken() (token int, value []byte) { if tkn.digestedTokens == nil || len(tkn.digestedTokens) == 0 { panic("popDigestedToken called with no digested tokens") } - tokenAndValue := tkn.digestedTokens[0] - tkn.digestedTokens = tkn.digestedTokens[1:] + length := len(tkn.digestedTokens) + tokenAndValue := tkn.digestedTokens[length-1] + tkn.digestedTokens = tkn.digestedTokens[0:length-1] if len(tkn.digestedTokens) == 0 { tkn.digestedTokens = nil @@ -443,6 +453,15 @@ func (tkn *Tokenizer) scanIdentifier(firstByte byte, isDbSystemVariable bool) (i tkn.digestToken(token, val) return FOR, buffer.Bytes() } + case NOT: + token, val := tkn.Scan() + switch token { + case ENFORCED: + return NOT_ENFORCED, append(buffer.Bytes(), append([]byte{' '}, val...)...) + default: + tkn.digestToken(token, val) + return NOT, buffer.Bytes() + } } return keywordID, buffer.Bytes() diff --git a/go/vt/tlstest/tlstest_test.go b/go/vt/tlstest/tlstest_test.go index 1956408244b..27df050f4ea 100644 --- a/go/vt/tlstest/tlstest_test.go +++ b/go/vt/tlstest/tlstest_test.go @@ -182,7 +182,7 @@ func testClientServer(t *testing.T, combineCerts bool) { if err == nil { t.Fatalf("Dial or first Read was expected to fail") } - if !strings.Contains(err.Error(), "bad certificate") { + if !strings.Contains(err.Error(), "tls: certificate required") { t.Errorf("Wrong error returned: %v", err) } }