diff --git a/Godeps/Godeps.json b/Godeps/Godeps.json
index 2e18e0e1b..382910e95 100644
--- a/Godeps/Godeps.json
+++ b/Godeps/Godeps.json
@@ -2,14 +2,7 @@
"ImportPath": "github.com/lifei6671/godoc",
"GoVersion": "go1.8",
"GodepVersion": "v79",
- "Packages": [
- "./..."
- ],
"Deps": [
- {
- "ImportPath": "github.com/adamzy/cedar-go",
- "Rev": "d348c21f72432c2b6d5f05f68759fde94f64b227"
- },
{
"ImportPath": "github.com/astaxie/beego",
"Comment": "v1.8.1",
@@ -46,63 +39,44 @@
"Rev": "323a1c4214101331a4b71922c23d19b7409ac71f"
},
{
- "ImportPath": "github.com/astaxie/beego/toolbox",
- "Comment": "v1.8.1",
+ "ImportPath": "github.com/astaxie/beego/session/memcache",
+ "Comment": "v1.8.0",
"Rev": "323a1c4214101331a4b71922c23d19b7409ac71f"
},
{
- "ImportPath": "github.com/astaxie/beego/utils",
- "Comment": "v1.8.1",
+ "ImportPath": "github.com/astaxie/beego/session/mysql",
+ "Comment": "v1.8.0",
"Rev": "323a1c4214101331a4b71922c23d19b7409ac71f"
},
{
- "ImportPath": "github.com/boltdb/bolt",
- "Comment": "v1.3.0-58-ge9cf4fa",
- "Rev": "e9cf4fae01b5a8ff89d0ec6b32f0d9c9f79aefdd"
- },
- {
- "ImportPath": "github.com/cznic/fileutil",
- "Rev": "90cf820aafe8f7df39416fdbb932029ff99bd1ab"
- },
- {
- "ImportPath": "github.com/cznic/internal/buffer",
- "Comment": "1.0.0-1-ge5e1c3e",
- "Rev": "e5e1c3e9165d0a72507c2bbb0ffac1c02b8d3f7c"
- },
- {
- "ImportPath": "github.com/cznic/internal/file",
- "Comment": "1.0.0-1-ge5e1c3e",
- "Rev": "e5e1c3e9165d0a72507c2bbb0ffac1c02b8d3f7c"
- },
- {
- "ImportPath": "github.com/cznic/internal/slice",
- "Comment": "1.0.0-1-ge5e1c3e",
- "Rev": "e5e1c3e9165d0a72507c2bbb0ffac1c02b8d3f7c"
- },
- {
- "ImportPath": "github.com/cznic/kv",
- "Rev": "c5de474a2ccdaed5ba5ff8b5d2d213dbf48a8b5e"
+ "ImportPath": "github.com/astaxie/beego/session/redis",
+ "Comment": "v1.8.0",
+ "Rev": "323a1c4214101331a4b71922c23d19b7409ac71f"
},
{
- "ImportPath": "github.com/cznic/lldb",
- "Comment": "v1.1.0",
- "Rev": "bea8611dd5c407f3c5eab9f9c68e887a27dc6f0e"
+ "ImportPath": "github.com/astaxie/beego/toolbox",
+ "Comment": "v1.8.1",
+ "Rev": "323a1c4214101331a4b71922c23d19b7409ac71f"
},
{
- "ImportPath": "github.com/cznic/mathutil",
- "Rev": "1447ad269d64ca91aa8d7079baa40b6fc8b965e7"
+ "ImportPath": "github.com/astaxie/beego/utils",
+ "Comment": "v1.8.1",
+ "Rev": "323a1c4214101331a4b71922c23d19b7409ac71f"
},
{
- "ImportPath": "github.com/cznic/sortutil",
- "Rev": "4c7342852e65c2088c981288f2c5610d10b9f7f4"
+ "ImportPath": "github.com/bradfitz/gomemcache/memcache",
+ "Comment": "release.r60-46-g1952afa",
+ "Rev": "1952afaa557dc08e8e0d89eafab110fb501c1a2b"
},
{
- "ImportPath": "github.com/cznic/zappy",
- "Rev": "2533cb5b45cc6c07421468ce262899ddc9d53fb7"
+ "ImportPath": "github.com/garyburd/redigo/internal",
+ "Comment": "v1.0.0-23-gac91d6f",
+ "Rev": "ac91d6ff49bd0d278a90201de77a4f8ad9628e25"
},
{
- "ImportPath": "github.com/edsrzf/mmap-go",
- "Rev": "0bce6a6887123b67a60366d2c9fe2dfb74289d2e"
+ "ImportPath": "github.com/garyburd/redigo/redis",
+ "Comment": "v1.0.0-23-gac91d6f",
+ "Rev": "ac91d6ff49bd0d278a90201de77a4f8ad9628e25"
},
{
"ImportPath": "github.com/go-sql-driver/mysql",
@@ -110,45 +84,35 @@
"Rev": "1421caf44f6464fd2ee8de694c7508ee13f92964"
},
{
- "ImportPath": "github.com/huichen/murmur",
- "Rev": "e0489551cf5116e27d7cc69d97a53cdbdd028acf"
+ "ImportPath": "github.com/golang/freetype",
+ "Comment": "release-132-gd9be45a",
+ "Rev": "d9be45aaf7452cc30c0ceb1b1bf7efe1d17b7c87"
},
{
- "ImportPath": "github.com/huichen/sego",
- "Rev": "d06fe1b3abe3877ab593b57e5e43daf6c4c25add"
+ "ImportPath": "github.com/golang/freetype/raster",
+ "Comment": "release-132-gd9be45a",
+ "Rev": "d9be45aaf7452cc30c0ceb1b1bf7efe1d17b7c87"
},
{
- "ImportPath": "github.com/huichen/wukong/core",
- "Comment": "v0.1-94-gd014a1f",
- "Rev": "d014a1f19dae3664677c11bd25549cfc820cd890"
+ "ImportPath": "github.com/golang/freetype/truetype",
+ "Comment": "release-132-gd9be45a",
+ "Rev": "d9be45aaf7452cc30c0ceb1b1bf7efe1d17b7c87"
},
{
- "ImportPath": "github.com/huichen/wukong/engine",
- "Comment": "v0.1-94-gd014a1f",
- "Rev": "d014a1f19dae3664677c11bd25549cfc820cd890"
- },
- {
- "ImportPath": "github.com/huichen/wukong/storage",
- "Comment": "v0.1-94-gd014a1f",
- "Rev": "d014a1f19dae3664677c11bd25549cfc820cd890"
- },
- {
- "ImportPath": "github.com/huichen/wukong/types",
- "Comment": "v0.1-94-gd014a1f",
- "Rev": "d014a1f19dae3664677c11bd25549cfc820cd890"
- },
- {
- "ImportPath": "github.com/huichen/wukong/utils",
- "Comment": "v0.1-94-gd014a1f",
- "Rev": "d014a1f19dae3664677c11bd25549cfc820cd890"
+ "ImportPath": "github.com/lifei6671/gocaptcha",
+ "Rev": "b244e66362327cfd7d47c1a75eb1ca3845ffc52a"
},
{
"ImportPath": "github.com/nfnt/resize",
"Rev": "891127d8d1b52734debe1b3c3d7e747502b6c366"
},
{
- "ImportPath": "golang.org/x/sys/unix",
- "Rev": "9ccfe848b9db8435a24c424abbc07a921adf1df5"
+ "ImportPath": "golang.org/x/image/font",
+ "Rev": "69afd001f792d732a78bd7225793315a8deb09ea"
+ },
+ {
+ "ImportPath": "golang.org/x/image/math/fixed",
+ "Rev": "69afd001f792d732a78bd7225793315a8deb09ea"
}
]
}
diff --git a/vendor/github.com/adamzy/cedar-go/LICENSE.md b/vendor/github.com/adamzy/cedar-go/LICENSE.md
deleted file mode 100644
index 23cb79033..000000000
--- a/vendor/github.com/adamzy/cedar-go/LICENSE.md
+++ /dev/null
@@ -1,339 +0,0 @@
- GNU GENERAL PUBLIC LICENSE
- Version 2, June 1991
-
- Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
- 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
- Preamble
-
- The licenses for most software are designed to take away your
-freedom to share and change it. By contrast, the GNU General Public
-License is intended to guarantee your freedom to share and change free
-software--to make sure the software is free for all its users. This
-General Public License applies to most of the Free Software
-Foundation's software and to any other program whose authors commit to
-using it. (Some other Free Software Foundation software is covered by
-the GNU Lesser General Public License instead.) You can apply it to
-your programs, too.
-
- When we speak of free software, we are referring to freedom, not
-price. Our General Public Licenses are designed to make sure that you
-have the freedom to distribute copies of free software (and charge for
-this service if you wish), that you receive source code or can get it
-if you want it, that you can change the software or use pieces of it
-in new free programs; and that you know you can do these things.
-
- To protect your rights, we need to make restrictions that forbid
-anyone to deny you these rights or to ask you to surrender the rights.
-These restrictions translate to certain responsibilities for you if you
-distribute copies of the software, or if you modify it.
-
- For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must give the recipients all the rights that
-you have. You must make sure that they, too, receive or can get the
-source code. And you must show them these terms so they know their
-rights.
-
- We protect your rights with two steps: (1) copyright the software, and
-(2) offer you this license which gives you legal permission to copy,
-distribute and/or modify the software.
-
- Also, for each author's protection and ours, we want to make certain
-that everyone understands that there is no warranty for this free
-software. If the software is modified by someone else and passed on, we
-want its recipients to know that what they have is not the original, so
-that any problems introduced by others will not reflect on the original
-authors' reputations.
-
- Finally, any free program is threatened constantly by software
-patents. We wish to avoid the danger that redistributors of a free
-program will individually obtain patent licenses, in effect making the
-program proprietary. To prevent this, we have made it clear that any
-patent must be licensed for everyone's free use or not licensed at all.
-
- The precise terms and conditions for copying, distribution and
-modification follow.
-
- GNU GENERAL PUBLIC LICENSE
- TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
-
- 0. This License applies to any program or other work which contains
-a notice placed by the copyright holder saying it may be distributed
-under the terms of this General Public License. The "Program", below,
-refers to any such program or work, and a "work based on the Program"
-means either the Program or any derivative work under copyright law:
-that is to say, a work containing the Program or a portion of it,
-either verbatim or with modifications and/or translated into another
-language. (Hereinafter, translation is included without limitation in
-the term "modification".) Each licensee is addressed as "you".
-
-Activities other than copying, distribution and modification are not
-covered by this License; they are outside its scope. The act of
-running the Program is not restricted, and the output from the Program
-is covered only if its contents constitute a work based on the
-Program (independent of having been made by running the Program).
-Whether that is true depends on what the Program does.
-
- 1. You may copy and distribute verbatim copies of the Program's
-source code as you receive it, in any medium, provided that you
-conspicuously and appropriately publish on each copy an appropriate
-copyright notice and disclaimer of warranty; keep intact all the
-notices that refer to this License and to the absence of any warranty;
-and give any other recipients of the Program a copy of this License
-along with the Program.
-
-You may charge a fee for the physical act of transferring a copy, and
-you may at your option offer warranty protection in exchange for a fee.
-
- 2. You may modify your copy or copies of the Program or any portion
-of it, thus forming a work based on the Program, and copy and
-distribute such modifications or work under the terms of Section 1
-above, provided that you also meet all of these conditions:
-
- a) You must cause the modified files to carry prominent notices
- stating that you changed the files and the date of any change.
-
- b) You must cause any work that you distribute or publish, that in
- whole or in part contains or is derived from the Program or any
- part thereof, to be licensed as a whole at no charge to all third
- parties under the terms of this License.
-
- c) If the modified program normally reads commands interactively
- when run, you must cause it, when started running for such
- interactive use in the most ordinary way, to print or display an
- announcement including an appropriate copyright notice and a
- notice that there is no warranty (or else, saying that you provide
- a warranty) and that users may redistribute the program under
- these conditions, and telling the user how to view a copy of this
- License. (Exception: if the Program itself is interactive but
- does not normally print such an announcement, your work based on
- the Program is not required to print an announcement.)
-
-These requirements apply to the modified work as a whole. If
-identifiable sections of that work are not derived from the Program,
-and can be reasonably considered independent and separate works in
-themselves, then this License, and its terms, do not apply to those
-sections when you distribute them as separate works. But when you
-distribute the same sections as part of a whole which is a work based
-on the Program, the distribution of the whole must be on the terms of
-this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote it.
-
-Thus, it is not the intent of this section to claim rights or contest
-your rights to work written entirely by you; rather, the intent is to
-exercise the right to control the distribution of derivative or
-collective works based on the Program.
-
-In addition, mere aggregation of another work not based on the Program
-with the Program (or with a work based on the Program) on a volume of
-a storage or distribution medium does not bring the other work under
-the scope of this License.
-
- 3. You may copy and distribute the Program (or a work based on it,
-under Section 2) in object code or executable form under the terms of
-Sections 1 and 2 above provided that you also do one of the following:
-
- a) Accompany it with the complete corresponding machine-readable
- source code, which must be distributed under the terms of Sections
- 1 and 2 above on a medium customarily used for software interchange; or,
-
- b) Accompany it with a written offer, valid for at least three
- years, to give any third party, for a charge no more than your
- cost of physically performing source distribution, a complete
- machine-readable copy of the corresponding source code, to be
- distributed under the terms of Sections 1 and 2 above on a medium
- customarily used for software interchange; or,
-
- c) Accompany it with the information you received as to the offer
- to distribute corresponding source code. (This alternative is
- allowed only for noncommercial distribution and only if you
- received the program in object code or executable form with such
- an offer, in accord with Subsection b above.)
-
-The source code for a work means the preferred form of the work for
-making modifications to it. For an executable work, complete source
-code means all the source code for all modules it contains, plus any
-associated interface definition files, plus the scripts used to
-control compilation and installation of the executable. However, as a
-special exception, the source code distributed need not include
-anything that is normally distributed (in either source or binary
-form) with the major components (compiler, kernel, and so on) of the
-operating system on which the executable runs, unless that component
-itself accompanies the executable.
-
-If distribution of executable or object code is made by offering
-access to copy from a designated place, then offering equivalent
-access to copy the source code from the same place counts as
-distribution of the source code, even though third parties are not
-compelled to copy the source along with the object code.
-
- 4. You may not copy, modify, sublicense, or distribute the Program
-except as expressly provided under this License. Any attempt
-otherwise to copy, modify, sublicense or distribute the Program is
-void, and will automatically terminate your rights under this License.
-However, parties who have received copies, or rights, from you under
-this License will not have their licenses terminated so long as such
-parties remain in full compliance.
-
- 5. You are not required to accept this License, since you have not
-signed it. However, nothing else grants you permission to modify or
-distribute the Program or its derivative works. These actions are
-prohibited by law if you do not accept this License. Therefore, by
-modifying or distributing the Program (or any work based on the
-Program), you indicate your acceptance of this License to do so, and
-all its terms and conditions for copying, distributing or modifying
-the Program or works based on it.
-
- 6. Each time you redistribute the Program (or any work based on the
-Program), the recipient automatically receives a license from the
-original licensor to copy, distribute or modify the Program subject to
-these terms and conditions. You may not impose any further
-restrictions on the recipients' exercise of the rights granted herein.
-You are not responsible for enforcing compliance by third parties to
-this License.
-
- 7. If, as a consequence of a court judgment or allegation of patent
-infringement or for any other reason (not limited to patent issues),
-conditions are imposed on you (whether by court order, agreement or
-otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License. If you cannot
-distribute so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you
-may not distribute the Program at all. For example, if a patent
-license would not permit royalty-free redistribution of the Program by
-all those who receive copies directly or indirectly through you, then
-the only way you could satisfy both it and this License would be to
-refrain entirely from distribution of the Program.
-
-If any portion of this section is held invalid or unenforceable under
-any particular circumstance, the balance of the section is intended to
-apply and the section as a whole is intended to apply in other
-circumstances.
-
-It is not the purpose of this section to induce you to infringe any
-patents or other property right claims or to contest validity of any
-such claims; this section has the sole purpose of protecting the
-integrity of the free software distribution system, which is
-implemented by public license practices. Many people have made
-generous contributions to the wide range of software distributed
-through that system in reliance on consistent application of that
-system; it is up to the author/donor to decide if he or she is willing
-to distribute software through any other system and a licensee cannot
-impose that choice.
-
-This section is intended to make thoroughly clear what is believed to
-be a consequence of the rest of this License.
-
- 8. If the distribution and/or use of the Program is restricted in
-certain countries either by patents or by copyrighted interfaces, the
-original copyright holder who places the Program under this License
-may add an explicit geographical distribution limitation excluding
-those countries, so that distribution is permitted only in or among
-countries not thus excluded. In such case, this License incorporates
-the limitation as if written in the body of this License.
-
- 9. The Free Software Foundation may publish revised and/or new versions
-of the General Public License from time to time. Such new versions will
-be similar in spirit to the present version, but may differ in detail to
-address new problems or concerns.
-
-Each version is given a distinguishing version number. If the Program
-specifies a version number of this License which applies to it and "any
-later version", you have the option of following the terms and conditions
-either of that version or of any later version published by the Free
-Software Foundation. If the Program does not specify a version number of
-this License, you may choose any version ever published by the Free Software
-Foundation.
-
- 10. If you wish to incorporate parts of the Program into other free
-programs whose distribution conditions are different, write to the author
-to ask for permission. For software which is copyrighted by the Free
-Software Foundation, write to the Free Software Foundation; we sometimes
-make exceptions for this. Our decision will be guided by the two goals
-of preserving the free status of all derivatives of our free software and
-of promoting the sharing and reuse of software generally.
-
- NO WARRANTY
-
- 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
-FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
-OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
-PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
-OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
-MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
-TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
-PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
-REPAIR OR CORRECTION.
-
- 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
-REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
-INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
-OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
-TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
-YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
-PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
-POSSIBILITY OF SUCH DAMAGES.
-
- END OF TERMS AND CONDITIONS
-
- How to Apply These Terms to Your New Programs
-
- If you develop a new program, and you want it to be of the greatest
-possible use to the public, the best way to achieve this is to make it
-free software which everyone can redistribute and change under these terms.
-
- To do so, attach the following notices to the program. It is safest
-to attach them to the start of each source file to most effectively
-convey the exclusion of warranty; and each file should have at least
-the "copyright" line and a pointer to where the full notice is found.
-
- {description}
- Copyright (C) {year} {fullname}
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License along
- with this program; if not, write to the Free Software Foundation, Inc.,
- 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-
-Also add information on how to contact you by electronic and paper mail.
-
-If the program is interactive, make it output a short notice like this
-when it starts in an interactive mode:
-
- Gnomovision version 69, Copyright (C) year name of author
- Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
- This is free software, and you are welcome to redistribute it
- under certain conditions; type `show c' for details.
-
-The hypothetical commands `show w' and `show c' should show the appropriate
-parts of the General Public License. Of course, the commands you use may
-be called something other than `show w' and `show c'; they could even be
-mouse-clicks or menu items--whatever suits your program.
-
-You should also get your employer (if you work as a programmer) or your
-school, if any, to sign a "copyright disclaimer" for the program, if
-necessary. Here is a sample; alter the names:
-
- Yoyodyne, Inc., hereby disclaims all copyright interest in the program
- `Gnomovision' (which makes passes at compilers) written by James Hacker.
-
- {signature of Ty Coon}, 1 April 1989
- Ty Coon, President of Vice
-
-This General Public License does not permit incorporating your program into
-proprietary programs. If your program is a subroutine library, you may
-consider it more useful to permit linking proprietary applications with the
-library. If this is what you want to do, use the GNU Lesser General
-Public License instead of this License.
diff --git a/vendor/github.com/adamzy/cedar-go/README.md b/vendor/github.com/adamzy/cedar-go/README.md
deleted file mode 100644
index d4821cf33..000000000
--- a/vendor/github.com/adamzy/cedar-go/README.md
+++ /dev/null
@@ -1,83 +0,0 @@
-# cedar-go [![GoDoc](https://godoc.org/github.com/adamzy/cedar-go?status.svg)](https://godoc.org/github.com/adamzy/cedar-go)
-
-Package `cedar-go` implementes double-array trie.
-
-It is a [Golang](https://golang.org/) port of [cedar](http://www.tkl.iis.u-tokyo.ac.jp/~ynaga/cedar) which is written in C++ by Naoki Yoshinaga. `cedar-go` currently implements the `reduced` verion of cedar.
-This package is not thread safe if there is one goroutine doing insertions or deletions.
-
-## Install
-```
-go get github.com/adamzy/cedar-go
-```
-
-## Usage
-```go
-package main
-
-import (
- "fmt"
-
- "github.com/adamzy/cedar-go"
-)
-
-func main() {
- // create a new cedar trie.
- trie := cedar.New()
-
- // a helper function to print the id-key-value triple given trie node id
- printIdKeyValue := func(id int) {
- // the key of node `id`.
- key, _ := trie.Key(id)
- // the value of node `id`.
- value, _ := trie.Value(id)
- fmt.Printf("%d\t%s:%v\n", id, key, value)
- }
-
- // Insert key-value pairs.
- // The order of insertion is not important.
- trie.Insert([]byte("How many"), 0)
- trie.Insert([]byte("How many loved"), 1)
- trie.Insert([]byte("How many loved your moments"), 2)
- trie.Insert([]byte("How many loved your moments of glad grace"), 3)
- trie.Insert([]byte("姑苏"), 4)
- trie.Insert([]byte("姑苏城外"), 5)
- trie.Insert([]byte("姑苏城外寒山寺"), 6)
-
- // Get the associated value of a key directly.
- value, _ := trie.Get([]byte("How many loved your moments of glad grace"))
- fmt.Println(value)
-
- // Or, jump to the node first,
- id, _ := trie.Jump([]byte("How many loved your moments"), 0)
- // then get the key and the value
- printIdKeyValue(id)
-
- fmt.Println("\nPrefixMatch\nid\tkey:value")
- for _, id := range trie.PrefixMatch([]byte("How many loved your moments of glad grace"), 0) {
- printIdKeyValue(id)
- }
-
- fmt.Println("\nPrefixPredict\nid\tkey:value")
- for _, id := range trie.PrefixPredict([]byte("姑苏"), 0) {
- printIdKeyValue(id)
- }
-}
-```
-will produce
-```
-3
-281 How many loved your moments:2
-
-PrefixMatch
-id key:value
-262 How many:0
-268 How many loved:1
-281 How many loved your moments:2
-296 How many loved your moments of glad grace:3
-
-PrefixPredict
-id key:value
-303 姑苏:4
-309 姑苏城外:5
-318 姑苏城外寒山寺:6
-```
diff --git a/vendor/github.com/adamzy/cedar-go/api.go b/vendor/github.com/adamzy/cedar-go/api.go
deleted file mode 100644
index 02794b671..000000000
--- a/vendor/github.com/adamzy/cedar-go/api.go
+++ /dev/null
@@ -1,231 +0,0 @@
-package cedar
-
-// Status reports the following statistics of the cedar:
-// keys: number of keys that are in the cedar,
-// nodes: number of trie nodes (slots in the base array) has been taken,
-// size: the size of the base array used by the cedar,
-// capacity: the capicity of the base array used by the cedar.
-func (da *Cedar) Status() (keys, nodes, size, capacity int) {
- for i := 0; i < da.Size; i++ {
- n := da.Array[i]
- if n.Check >= 0 {
- nodes++
- if n.Value >= 0 {
- keys++
- }
- }
- }
- return keys, nodes, da.Size, da.Capacity
-}
-
-// Jump travels from a node `from` to another node `to` by following the path `path`.
-// For example, if the following keys were inserted:
-// id key
-// 19 abc
-// 23 ab
-// 37 abcd
-// then
-// Jump([]byte("ab"), 0) = 23, nil // reach "ab" from root
-// Jump([]byte("c"), 23) = 19, nil // reach "abc" from "ab"
-// Jump([]byte("cd"), 23) = 37, nil // reach "abcd" from "ab"
-func (da *Cedar) Jump(path []byte, from int) (to int, err error) {
- for _, b := range path {
- if da.Array[from].Value >= 0 {
- return from, ErrNoPath
- }
- to = da.Array[from].base() ^ int(b)
- if da.Array[to].Check != from {
- return from, ErrNoPath
- }
- from = to
- }
- return to, nil
-}
-
-// Key returns the key of the node with the given `id`.
-// It will return ErrNoPath, if the node does not exist.
-func (da *Cedar) Key(id int) (key []byte, err error) {
- for id > 0 {
- from := da.Array[id].Check
- if from < 0 {
- return nil, ErrNoPath
- }
- if char := byte(da.Array[from].base() ^ id); char != 0 {
- key = append(key, char)
- }
- id = from
- }
- if id != 0 || len(key) == 0 {
- return nil, ErrInvalidKey
- }
- for i := 0; i < len(key)/2; i++ {
- key[i], key[len(key)-i-1] = key[len(key)-i-1], key[i]
- }
- return key, nil
-}
-
-// Value returns the value of the node with the given `id`.
-// It will return ErrNoValue, if the node does not have a value.
-func (da *Cedar) Value(id int) (value int, err error) {
- value = da.Array[id].Value
- if value >= 0 {
- return value, nil
- }
- to := da.Array[id].base()
- if da.Array[to].Check == id && da.Array[to].Value >= 0 {
- return da.Array[to].Value, nil
- }
- return 0, ErrNoValue
-}
-
-// Insert adds a key-value pair into the cedar.
-// It will return ErrInvalidValue, if value < 0 or >= ValueLimit.
-func (da *Cedar) Insert(key []byte, value int) error {
- if value < 0 || value >= ValueLimit {
- return ErrInvalidValue
- }
- p := da.get(key, 0, 0)
- *p = value
- return nil
-}
-
-// Update increases the value associated with the `key`.
-// The `key` will be inserted if it is not in the cedar.
-// It will return ErrInvalidValue, if the updated value < 0 or >= ValueLimit.
-func (da *Cedar) Update(key []byte, value int) error {
- p := da.get(key, 0, 0)
- if *p+value < 0 || *p+value >= ValueLimit {
- return ErrInvalidValue
- }
- *p += value
- return nil
-}
-
-// Delete removes a key-value pair from the cedar.
-// It will return ErrNoPath, if the key has not been added.
-func (da *Cedar) Delete(key []byte) error {
- // if the path does not exist, or the end is not a leaf, nothing to delete
- to, err := da.Jump(key, 0)
- if err != nil {
- return ErrNoPath
- }
-
- if da.Array[to].Value < 0 {
- base := da.Array[to].base()
- if da.Array[base].Check == to {
- to = base
- }
- }
-
- for {
- from := da.Array[to].Check
- base := da.Array[from].base()
- label := byte(to ^ base)
-
- // if `to` has sibling, remove `to` from the sibling list, then stop
- if da.Ninfos[to].Sibling != 0 || da.Ninfos[from].Child != label {
- // delete the label from the child ring first
- da.popSibling(from, base, label)
- // then release the current node `to` to the empty node ring
- da.pushEnode(to)
- break
- }
- // otherwise, just release the current node `to` to the empty node ring
- da.pushEnode(to)
- // then check its parent node
- to = from
- }
- return nil
-}
-
-// Get returns the value associated with the given `key`.
-// It is equivalent to
-// id, err1 = Jump(key)
-// value, err2 = Value(id)
-// Thus, it may return ErrNoPath or ErrNoValue,
-func (da *Cedar) Get(key []byte) (value int, err error) {
- to, err := da.Jump(key, 0)
- if err != nil {
- return 0, err
- }
- return da.Value(to)
-}
-
-// PrefixMatch returns a list of at most `num` nodes which match the prefix of the key.
-// If `num` is 0, it returns all matches.
-// For example, if the following keys were inserted:
-// id key
-// 19 abc
-// 23 ab
-// 37 abcd
-// then
-// PrefixMatch([]byte("abc"), 1) = [ 23 ] // match ["ab"]
-// PrefixMatch([]byte("abcd"), 0) = [ 23, 19, 37] // match ["ab", "abc", "abcd"]
-func (da *Cedar) PrefixMatch(key []byte, num int) (ids []int) {
- for from, i := 0, 0; i < len(key); i++ {
- to, err := da.Jump(key[i:i+1], from)
- if err != nil {
- break
- }
- if _, err := da.Value(to); err == nil {
- ids = append(ids, to)
- num--
- if num == 0 {
- return
- }
- }
- from = to
- }
- return
-}
-
-// PrefixPredict returns a list of at most `num` nodes which has the key as their prefix.
-// These nodes are ordered by their keys.
-// If `num` is 0, it returns all matches.
-// For example, if the following keys were inserted:
-// id key
-// 19 abc
-// 23 ab
-// 37 abcd
-// then
-// PrefixPredict([]byte("ab"), 2) = [ 23, 19 ] // predict ["ab", "abc"]
-// PrefixPredict([]byte("ab"), 0) = [ 23, 19, 37 ] // predict ["ab", "abc", "abcd"]
-func (da *Cedar) PrefixPredict(key []byte, num int) (ids []int) {
- root, err := da.Jump(key, 0)
- if err != nil {
- return
- }
- for from, err := da.begin(root); err == nil; from, err = da.next(from, root) {
- ids = append(ids, from)
- num--
- if num == 0 {
- return
- }
- }
- return
-}
-
-func (da *Cedar) begin(from int) (to int, err error) {
- for c := da.Ninfos[from].Child; c != 0; {
- to = da.Array[from].base() ^ int(c)
- c = da.Ninfos[to].Child
- from = to
- }
- if da.Array[from].base() > 0 {
- return da.Array[from].base(), nil
- }
- return from, nil
-}
-
-func (da *Cedar) next(from int, root int) (to int, err error) {
- c := da.Ninfos[from].Sibling
- for c == 0 && from != root && da.Array[from].Check >= 0 {
- from = da.Array[from].Check
- c = da.Ninfos[from].Sibling
- }
- if from == root {
- return 0, ErrNoPath
- }
- from = da.Array[da.Array[from].Check].base() ^ int(c)
- return da.begin(from)
-}
diff --git a/vendor/github.com/adamzy/cedar-go/cedar.go b/vendor/github.com/adamzy/cedar-go/cedar.go
deleted file mode 100644
index 645d089e0..000000000
--- a/vendor/github.com/adamzy/cedar-go/cedar.go
+++ /dev/null
@@ -1,407 +0,0 @@
-package cedar
-
-const ValueLimit = int(^uint(0) >> 1)
-
-type node struct {
- Value int
- Check int
-}
-
-func (n *node) base() int { return -(n.Value + 1) }
-
-type ninfo struct {
- Sibling, Child byte
-}
-
-type block struct {
- Prev, Next, Num, Reject, Trial, Ehead int
-}
-
-func (b *block) init() {
- b.Num = 256
- b.Reject = 257
-}
-
-type Cedar struct {
- *cedar
-}
-
-type cedar struct {
- Array []node
- Ninfos []ninfo
- Blocks []block
- Reject [257]int
- BheadF int
- BheadC int
- BheadO int
- Capacity int
- Size int
- Ordered bool
- MaxTrial int
-}
-
-func New() *Cedar {
- da := cedar{
- Array: make([]node, 256),
- Ninfos: make([]ninfo, 256),
- Blocks: make([]block, 1),
- Capacity: 256,
- Size: 256,
- Ordered: true,
- MaxTrial: 1,
- }
-
- da.Array[0] = node{-2, 0}
- for i := 1; i < 256; i++ {
- da.Array[i] = node{-(i - 1), -(i + 1)}
- }
- da.Array[1].Value = -255
- da.Array[255].Check = -1
-
- da.Blocks[0].Ehead = 1
- da.Blocks[0].init()
-
- for i := 0; i <= 256; i++ {
- da.Reject[i] = i + 1
- }
-
- return &Cedar{&da}
-}
-
-// Get value by key, insert the key if not exist
-func (da *cedar) get(key []byte, from, pos int) *int {
- for ; pos < len(key); pos++ {
- if value := da.Array[from].Value; value >= 0 && value != ValueLimit {
- to := da.follow(from, 0)
- da.Array[to].Value = value
- }
- from = da.follow(from, key[pos])
- }
- to := from
- if da.Array[from].Value < 0 {
- to = da.follow(from, 0)
- }
- return &da.Array[to].Value
-}
-
-func (da *cedar) follow(from int, label byte) int {
- base := da.Array[from].base()
- to := base ^ int(label)
- if base < 0 || da.Array[to].Check < 0 {
- hasChild := false
- if base >= 0 {
- hasChild = (da.Array[base^int(da.Ninfos[from].Child)].Check == from)
- }
- to = da.popEnode(base, label, from)
- da.pushSibling(from, to^int(label), label, hasChild)
- } else if da.Array[to].Check != from {
- to = da.resolve(from, base, label)
- } else if da.Array[to].Check == from {
- } else {
- panic("cedar: internal error, should not be here")
- }
- return to
-}
-
-func (da *cedar) popBlock(bi int, head_in *int, last bool) {
- if last {
- *head_in = 0
- } else {
- b := &da.Blocks[bi]
- da.Blocks[b.Prev].Next = b.Next
- da.Blocks[b.Next].Prev = b.Prev
- if bi == *head_in {
- *head_in = b.Next
- }
- }
-}
-
-func (da *cedar) pushBlock(bi int, head_out *int, empty bool) {
- b := &da.Blocks[bi]
- if empty {
- *head_out, b.Prev, b.Next = bi, bi, bi
- } else {
- tail_out := &da.Blocks[*head_out].Prev
- b.Prev = *tail_out
- b.Next = *head_out
- *head_out, *tail_out, da.Blocks[*tail_out].Next = bi, bi, bi
- }
-}
-
-func (da *cedar) addBlock() int {
- if da.Size == da.Capacity {
- da.Capacity *= 2
-
- oldArray := da.Array
- da.Array = make([]node, da.Capacity)
- copy(da.Array, oldArray)
-
- oldNinfo := da.Ninfos
- da.Ninfos = make([]ninfo, da.Capacity)
- copy(da.Ninfos, oldNinfo)
-
- oldBlock := da.Blocks
- da.Blocks = make([]block, da.Capacity>>8)
- copy(da.Blocks, oldBlock)
- }
-
- da.Blocks[da.Size>>8].init()
- da.Blocks[da.Size>>8].Ehead = da.Size
-
- da.Array[da.Size] = node{-(da.Size + 255), -(da.Size + 1)}
- for i := da.Size + 1; i < da.Size+255; i++ {
- da.Array[i] = node{-(i - 1), -(i + 1)}
- }
- da.Array[da.Size+255] = node{-(da.Size + 254), -da.Size}
-
- da.pushBlock(da.Size>>8, &da.BheadO, da.BheadO == 0)
- da.Size += 256
- return da.Size>>8 - 1
-}
-
-func (da *cedar) transferBlock(bi int, head_in, head_out *int) {
- da.popBlock(bi, head_in, bi == da.Blocks[bi].Next)
- da.pushBlock(bi, head_out, *head_out == 0 && da.Blocks[bi].Num != 0)
-}
-
-func (da *cedar) popEnode(base int, label byte, from int) int {
- e := base ^ int(label)
- if base < 0 {
- e = da.findPlace()
- }
- bi := e >> 8
- n := &da.Array[e]
- b := &da.Blocks[bi]
- b.Num--
- if b.Num == 0 {
- if bi != 0 {
- da.transferBlock(bi, &da.BheadC, &da.BheadF)
- }
- } else {
- da.Array[-n.Value].Check = n.Check
- da.Array[-n.Check].Value = n.Value
- if e == b.Ehead {
- b.Ehead = -n.Check
- }
- if bi != 0 && b.Num == 1 && b.Trial != da.MaxTrial {
- da.transferBlock(bi, &da.BheadO, &da.BheadC)
- }
- }
- n.Value = ValueLimit
- n.Check = from
- if base < 0 {
- da.Array[from].Value = -(e ^ int(label)) - 1
- }
- return e
-}
-
-func (da *cedar) pushEnode(e int) {
- bi := e >> 8
- b := &da.Blocks[bi]
- b.Num++
- if b.Num == 1 {
- b.Ehead = e
- da.Array[e] = node{-e, -e}
- if bi != 0 {
- da.transferBlock(bi, &da.BheadF, &da.BheadC)
- }
- } else {
- prev := b.Ehead
- next := -da.Array[prev].Check
- da.Array[e] = node{-prev, -next}
- da.Array[prev].Check = -e
- da.Array[next].Value = -e
- if b.Num == 2 || b.Trial == da.MaxTrial {
- if bi != 0 {
- da.transferBlock(bi, &da.BheadC, &da.BheadO)
- }
- }
- b.Trial = 0
- }
- if b.Reject < da.Reject[b.Num] {
- b.Reject = da.Reject[b.Num]
- }
- da.Ninfos[e] = ninfo{}
-}
-
-// hasChild: wherether the `from` node has children
-func (da *cedar) pushSibling(from, base int, label byte, hasChild bool) {
- c := &da.Ninfos[from].Child
- keepOrder := *c == 0
- if da.Ordered {
- keepOrder = label > *c
- }
- if hasChild && keepOrder {
- c = &da.Ninfos[base^int(*c)].Sibling
- for da.Ordered && *c != 0 && *c < label {
- c = &da.Ninfos[base^int(*c)].Sibling
- }
- }
- da.Ninfos[base^int(label)].Sibling = *c
- *c = label
-}
-
-func (da *cedar) popSibling(from, base int, label byte) {
- c := &da.Ninfos[from].Child
- for *c != label {
- c = &da.Ninfos[base^int(*c)].Sibling
- }
- *c = da.Ninfos[base^int(*c)].Sibling
-}
-
-func (da *cedar) consult(base_n, base_p int, c_n, c_p byte) bool {
- c_n = da.Ninfos[base_n^int(c_n)].Sibling
- c_p = da.Ninfos[base_p^int(c_p)].Sibling
- for c_n != 0 && c_p != 0 {
- c_n = da.Ninfos[base_n^int(c_n)].Sibling
- c_p = da.Ninfos[base_p^int(c_p)].Sibling
- }
- return c_p != 0
-}
-
-func (da *cedar) setChild(base int, c byte, label byte, flag bool) []byte {
- child := make([]byte, 0, 257)
- if c == 0 {
- child = append(child, c)
- c = da.Ninfos[base^int(c)].Sibling
- }
- if da.Ordered {
- for c != 0 && c <= label {
- child = append(child, c)
- c = da.Ninfos[base^int(c)].Sibling
- }
- }
- if flag {
- child = append(child, label)
- }
- for c != 0 {
- child = append(child, c)
- c = da.Ninfos[base^int(c)].Sibling
- }
- return child
-}
-
-func (da *cedar) findPlace() int {
- if da.BheadC != 0 {
- return da.Blocks[da.BheadC].Ehead
- }
- if da.BheadO != 0 {
- return da.Blocks[da.BheadO].Ehead
- }
- return da.addBlock() << 8
-}
-
-func (da *cedar) findPlaces(child []byte) int {
- bi := da.BheadO
- if bi != 0 {
- bz := da.Blocks[da.BheadO].Prev
- nc := len(child)
- for {
- b := &da.Blocks[bi]
- if b.Num >= nc && nc < b.Reject {
- for e := b.Ehead; ; {
- base := e ^ int(child[0])
- for i := 0; da.Array[base^int(child[i])].Check < 0; i++ {
- if i == len(child)-1 {
- b.Ehead = e
- return e
- }
- }
- e = -da.Array[e].Check
- if e == b.Ehead {
- break
- }
- }
- }
- b.Reject = nc
- if b.Reject < da.Reject[b.Num] {
- da.Reject[b.Num] = b.Reject
- }
- bi_ := b.Next
- b.Trial++
- if b.Trial == da.MaxTrial {
- da.transferBlock(bi, &da.BheadO, &da.BheadC)
- }
- if bi == bz {
- break
- }
- bi = bi_
- }
- }
- return da.addBlock() << 8
-}
-
-func (da *cedar) resolve(from_n, base_n int, label_n byte) int {
- to_pn := base_n ^ int(label_n)
- from_p := da.Array[to_pn].Check
- base_p := da.Array[from_p].base()
-
- flag := da.consult(base_n, base_p, da.Ninfos[from_n].Child, da.Ninfos[from_p].Child)
- var children []byte
- if flag {
- children = da.setChild(base_n, da.Ninfos[from_n].Child, label_n, true)
- } else {
- children = da.setChild(base_p, da.Ninfos[from_p].Child, 255, false)
- }
- var base int
- if len(children) == 1 {
- base = da.findPlace()
- } else {
- base = da.findPlaces(children)
- }
- base ^= int(children[0])
- var from int
- var base_ int
- if flag {
- from = from_n
- base_ = base_n
- } else {
- from = from_p
- base_ = base_p
- }
- if flag && children[0] == label_n {
- da.Ninfos[from].Child = label_n
- }
- da.Array[from].Value = -base - 1
- for i := 0; i < len(children); i++ {
- to := da.popEnode(base, children[i], from)
- to_ := base_ ^ int(children[i])
- if i == len(children)-1 {
- da.Ninfos[to].Sibling = 0
- } else {
- da.Ninfos[to].Sibling = children[i+1]
- }
- if flag && to_ == to_pn { // new node has no child
- continue
- }
- n := &da.Array[to]
- n_ := &da.Array[to_]
- n.Value = n_.Value
- if n.Value < 0 && children[i] != 0 {
- // this node has children, fix their check
- c := da.Ninfos[to_].Child
- da.Ninfos[to].Child = c
- da.Array[n.base()^int(c)].Check = to
- c = da.Ninfos[n.base()^int(c)].Sibling
- for c != 0 {
- da.Array[n.base()^int(c)].Check = to
- c = da.Ninfos[n.base()^int(c)].Sibling
- }
- }
- if !flag && to_ == from_n { // parent node moved
- from_n = to
- }
- if !flag && to_ == to_pn {
- da.pushSibling(from_n, to_pn^int(label_n), label_n, true)
- da.Ninfos[to_].Child = 0
- n_.Value = ValueLimit
- n_.Check = from_n
- } else {
- da.pushEnode(to_)
- }
- }
- if flag {
- return base ^ int(label_n)
- }
- return to_pn
-}
diff --git a/vendor/github.com/adamzy/cedar-go/doc.go b/vendor/github.com/adamzy/cedar-go/doc.go
deleted file mode 100644
index 143bad743..000000000
--- a/vendor/github.com/adamzy/cedar-go/doc.go
+++ /dev/null
@@ -1,12 +0,0 @@
-// Package cedar-go implements double-array trie.
-//
-// It is a golang port of cedar (http://www.tkl.iis.u-tokyo.ac.jp/~ynaga/cedar) which is written in C++ by Naoki Yoshinaga.
-// Currently cedar-go implements the `reduced` verion of cedar.
-// This package is not thread safe if there is one goroutine doing
-// insertions or deletions.
-//
-// Note
-//
-// key must be `[]byte` without zero items,
-// while value must be integer in the range [0, 2<<63-2] or [0, 2<<31-2] depends on the platform.
-package cedar
diff --git a/vendor/github.com/adamzy/cedar-go/errors.go b/vendor/github.com/adamzy/cedar-go/errors.go
deleted file mode 100644
index d38cd0c1e..000000000
--- a/vendor/github.com/adamzy/cedar-go/errors.go
+++ /dev/null
@@ -1,11 +0,0 @@
-package cedar
-
-import "errors"
-
-var (
- ErrInvalidDataType = errors.New("cedar: invalid datatype")
- ErrInvalidValue = errors.New("cedar: invalid value")
- ErrInvalidKey = errors.New("cedar: invalid key")
- ErrNoPath = errors.New("cedar: no path")
- ErrNoValue = errors.New("cedar: no value")
-)
diff --git a/vendor/github.com/adamzy/cedar-go/io.go b/vendor/github.com/adamzy/cedar-go/io.go
deleted file mode 100644
index 01e6f8825..000000000
--- a/vendor/github.com/adamzy/cedar-go/io.go
+++ /dev/null
@@ -1,63 +0,0 @@
-package cedar
-
-import (
- "bufio"
- "encoding/gob"
- "encoding/json"
- "io"
- "os"
-)
-
-// Save saves the cedar to an io.Writer,
-// where dataType is either "json" or "gob".
-func (da *Cedar) Save(out io.Writer, dataType string) error {
- switch dataType {
- case "gob", "GOB":
- dataEecoder := gob.NewEncoder(out)
- return dataEecoder.Encode(da.cedar)
- case "json", "JSON":
- dataEecoder := json.NewEncoder(out)
- return dataEecoder.Encode(da.cedar)
- }
- return ErrInvalidDataType
-}
-
-// SaveToFile saves the cedar to a file,
-// where dataType is either "json" or "gob".
-func (da *Cedar) SaveToFile(fileName string, dataType string) error {
- file, err := os.OpenFile(fileName, os.O_CREATE|os.O_WRONLY, 0666)
- if err != nil {
- return err
- }
- defer file.Close()
- out := bufio.NewWriter(file)
- defer out.Flush()
- da.Save(out, dataType)
- return nil
-}
-
-// Load loads the cedar from an io.Writer,
-// where dataType is either "json" or "gob".
-func (da *Cedar) Load(in io.Reader, dataType string) error {
- switch dataType {
- case "gob", "GOB":
- dataDecoder := gob.NewDecoder(in)
- return dataDecoder.Decode(da.cedar)
- case "json", "JSON":
- dataDecoder := json.NewDecoder(in)
- return dataDecoder.Decode(da.cedar)
- }
- return ErrInvalidDataType
-}
-
-// LoadFromFile loads the cedar from a file,
-// where dataType is either "json" or "gob".
-func (da *Cedar) LoadFromFile(fileName string, dataType string) error {
- file, err := os.OpenFile(fileName, os.O_RDONLY, 0600)
- defer file.Close()
- if err != nil {
- return err
- }
- in := bufio.NewReader(file)
- return da.Load(in, dataType)
-}
diff --git a/vendor/github.com/boltdb/bolt/.gitignore b/vendor/github.com/boltdb/bolt/.gitignore
deleted file mode 100644
index c7bd2b7a5..000000000
--- a/vendor/github.com/boltdb/bolt/.gitignore
+++ /dev/null
@@ -1,4 +0,0 @@
-*.prof
-*.test
-*.swp
-/bin/
diff --git a/vendor/github.com/boltdb/bolt/LICENSE b/vendor/github.com/boltdb/bolt/LICENSE
deleted file mode 100644
index 004e77fe5..000000000
--- a/vendor/github.com/boltdb/bolt/LICENSE
+++ /dev/null
@@ -1,20 +0,0 @@
-The MIT License (MIT)
-
-Copyright (c) 2013 Ben Johnson
-
-Permission is hereby granted, free of charge, to any person obtaining a copy of
-this software and associated documentation files (the "Software"), to deal in
-the Software without restriction, including without limitation the rights to
-use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
-the Software, and to permit persons to whom the Software is furnished to do so,
-subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
-FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
-COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
-IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
-CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/vendor/github.com/boltdb/bolt/Makefile b/vendor/github.com/boltdb/bolt/Makefile
deleted file mode 100644
index e035e63ad..000000000
--- a/vendor/github.com/boltdb/bolt/Makefile
+++ /dev/null
@@ -1,18 +0,0 @@
-BRANCH=`git rev-parse --abbrev-ref HEAD`
-COMMIT=`git rev-parse --short HEAD`
-GOLDFLAGS="-X main.branch $(BRANCH) -X main.commit $(COMMIT)"
-
-default: build
-
-race:
- @go test -v -race -test.run="TestSimulate_(100op|1000op)"
-
-# go get github.com/kisielk/errcheck
-errcheck:
- @errcheck -ignorepkg=bytes -ignore=os:Remove github.com/boltdb/bolt
-
-test:
- @go test -v -cover .
- @go test -v ./cmd/bolt
-
-.PHONY: fmt test
diff --git a/vendor/github.com/boltdb/bolt/README.md b/vendor/github.com/boltdb/bolt/README.md
deleted file mode 100644
index d7f80e977..000000000
--- a/vendor/github.com/boltdb/bolt/README.md
+++ /dev/null
@@ -1,915 +0,0 @@
-Bolt [![Coverage Status](https://coveralls.io/repos/boltdb/bolt/badge.svg?branch=master)](https://coveralls.io/r/boltdb/bolt?branch=master) [![GoDoc](https://godoc.org/github.com/boltdb/bolt?status.svg)](https://godoc.org/github.com/boltdb/bolt) ![Version](https://img.shields.io/badge/version-1.2.1-green.svg)
-====
-
-Bolt is a pure Go key/value store inspired by [Howard Chu's][hyc_symas]
-[LMDB project][lmdb]. The goal of the project is to provide a simple,
-fast, and reliable database for projects that don't require a full database
-server such as Postgres or MySQL.
-
-Since Bolt is meant to be used as such a low-level piece of functionality,
-simplicity is key. The API will be small and only focus on getting values
-and setting values. That's it.
-
-[hyc_symas]: https://twitter.com/hyc_symas
-[lmdb]: http://symas.com/mdb/
-
-## Project Status
-
-Bolt is stable, the API is fixed, and the file format is fixed. Full unit
-test coverage and randomized black box testing are used to ensure database
-consistency and thread safety. Bolt is currently used in high-load production
-environments serving databases as large as 1TB. Many companies such as
-Shopify and Heroku use Bolt-backed services every day.
-
-## Table of Contents
-
-- [Getting Started](#getting-started)
- - [Installing](#installing)
- - [Opening a database](#opening-a-database)
- - [Transactions](#transactions)
- - [Read-write transactions](#read-write-transactions)
- - [Read-only transactions](#read-only-transactions)
- - [Batch read-write transactions](#batch-read-write-transactions)
- - [Managing transactions manually](#managing-transactions-manually)
- - [Using buckets](#using-buckets)
- - [Using key/value pairs](#using-keyvalue-pairs)
- - [Autoincrementing integer for the bucket](#autoincrementing-integer-for-the-bucket)
- - [Iterating over keys](#iterating-over-keys)
- - [Prefix scans](#prefix-scans)
- - [Range scans](#range-scans)
- - [ForEach()](#foreach)
- - [Nested buckets](#nested-buckets)
- - [Database backups](#database-backups)
- - [Statistics](#statistics)
- - [Read-Only Mode](#read-only-mode)
- - [Mobile Use (iOS/Android)](#mobile-use-iosandroid)
-- [Resources](#resources)
-- [Comparison with other databases](#comparison-with-other-databases)
- - [Postgres, MySQL, & other relational databases](#postgres-mysql--other-relational-databases)
- - [LevelDB, RocksDB](#leveldb-rocksdb)
- - [LMDB](#lmdb)
-- [Caveats & Limitations](#caveats--limitations)
-- [Reading the Source](#reading-the-source)
-- [Other Projects Using Bolt](#other-projects-using-bolt)
-
-## Getting Started
-
-### Installing
-
-To start using Bolt, install Go and run `go get`:
-
-```sh
-$ go get github.com/boltdb/bolt/...
-```
-
-This will retrieve the library and install the `bolt` command line utility into
-your `$GOBIN` path.
-
-
-### Opening a database
-
-The top-level object in Bolt is a `DB`. It is represented as a single file on
-your disk and represents a consistent snapshot of your data.
-
-To open your database, simply use the `bolt.Open()` function:
-
-```go
-package main
-
-import (
- "log"
-
- "github.com/boltdb/bolt"
-)
-
-func main() {
- // Open the my.db data file in your current directory.
- // It will be created if it doesn't exist.
- db, err := bolt.Open("my.db", 0600, nil)
- if err != nil {
- log.Fatal(err)
- }
- defer db.Close()
-
- ...
-}
-```
-
-Please note that Bolt obtains a file lock on the data file so multiple processes
-cannot open the same database at the same time. Opening an already open Bolt
-database will cause it to hang until the other process closes it. To prevent
-an indefinite wait you can pass a timeout option to the `Open()` function:
-
-```go
-db, err := bolt.Open("my.db", 0600, &bolt.Options{Timeout: 1 * time.Second})
-```
-
-
-### Transactions
-
-Bolt allows only one read-write transaction at a time but allows as many
-read-only transactions as you want at a time. Each transaction has a consistent
-view of the data as it existed when the transaction started.
-
-Individual transactions and all objects created from them (e.g. buckets, keys)
-are not thread safe. To work with data in multiple goroutines you must start
-a transaction for each one or use locking to ensure only one goroutine accesses
-a transaction at a time. Creating transaction from the `DB` is thread safe.
-
-Read-only transactions and read-write transactions should not depend on one
-another and generally shouldn't be opened simultaneously in the same goroutine.
-This can cause a deadlock as the read-write transaction needs to periodically
-re-map the data file but it cannot do so while a read-only transaction is open.
-
-
-#### Read-write transactions
-
-To start a read-write transaction, you can use the `DB.Update()` function:
-
-```go
-err := db.Update(func(tx *bolt.Tx) error {
- ...
- return nil
-})
-```
-
-Inside the closure, you have a consistent view of the database. You commit the
-transaction by returning `nil` at the end. You can also rollback the transaction
-at any point by returning an error. All database operations are allowed inside
-a read-write transaction.
-
-Always check the return error as it will report any disk failures that can cause
-your transaction to not complete. If you return an error within your closure
-it will be passed through.
-
-
-#### Read-only transactions
-
-To start a read-only transaction, you can use the `DB.View()` function:
-
-```go
-err := db.View(func(tx *bolt.Tx) error {
- ...
- return nil
-})
-```
-
-You also get a consistent view of the database within this closure, however,
-no mutating operations are allowed within a read-only transaction. You can only
-retrieve buckets, retrieve values, and copy the database within a read-only
-transaction.
-
-
-#### Batch read-write transactions
-
-Each `DB.Update()` waits for disk to commit the writes. This overhead
-can be minimized by combining multiple updates with the `DB.Batch()`
-function:
-
-```go
-err := db.Batch(func(tx *bolt.Tx) error {
- ...
- return nil
-})
-```
-
-Concurrent Batch calls are opportunistically combined into larger
-transactions. Batch is only useful when there are multiple goroutines
-calling it.
-
-The trade-off is that `Batch` can call the given
-function multiple times, if parts of the transaction fail. The
-function must be idempotent and side effects must take effect only
-after a successful return from `DB.Batch()`.
-
-For example: don't display messages from inside the function, instead
-set variables in the enclosing scope:
-
-```go
-var id uint64
-err := db.Batch(func(tx *bolt.Tx) error {
- // Find last key in bucket, decode as bigendian uint64, increment
- // by one, encode back to []byte, and add new key.
- ...
- id = newValue
- return nil
-})
-if err != nil {
- return ...
-}
-fmt.Println("Allocated ID %d", id)
-```
-
-
-#### Managing transactions manually
-
-The `DB.View()` and `DB.Update()` functions are wrappers around the `DB.Begin()`
-function. These helper functions will start the transaction, execute a function,
-and then safely close your transaction if an error is returned. This is the
-recommended way to use Bolt transactions.
-
-However, sometimes you may want to manually start and end your transactions.
-You can use the `DB.Begin()` function directly but **please** be sure to close
-the transaction.
-
-```go
-// Start a writable transaction.
-tx, err := db.Begin(true)
-if err != nil {
- return err
-}
-defer tx.Rollback()
-
-// Use the transaction...
-_, err := tx.CreateBucket([]byte("MyBucket"))
-if err != nil {
- return err
-}
-
-// Commit the transaction and check for error.
-if err := tx.Commit(); err != nil {
- return err
-}
-```
-
-The first argument to `DB.Begin()` is a boolean stating if the transaction
-should be writable.
-
-
-### Using buckets
-
-Buckets are collections of key/value pairs within the database. All keys in a
-bucket must be unique. You can create a bucket using the `DB.CreateBucket()`
-function:
-
-```go
-db.Update(func(tx *bolt.Tx) error {
- b, err := tx.CreateBucket([]byte("MyBucket"))
- if err != nil {
- return fmt.Errorf("create bucket: %s", err)
- }
- return nil
-})
-```
-
-You can also create a bucket only if it doesn't exist by using the
-`Tx.CreateBucketIfNotExists()` function. It's a common pattern to call this
-function for all your top-level buckets after you open your database so you can
-guarantee that they exist for future transactions.
-
-To delete a bucket, simply call the `Tx.DeleteBucket()` function.
-
-
-### Using key/value pairs
-
-To save a key/value pair to a bucket, use the `Bucket.Put()` function:
-
-```go
-db.Update(func(tx *bolt.Tx) error {
- b := tx.Bucket([]byte("MyBucket"))
- err := b.Put([]byte("answer"), []byte("42"))
- return err
-})
-```
-
-This will set the value of the `"answer"` key to `"42"` in the `MyBucket`
-bucket. To retrieve this value, we can use the `Bucket.Get()` function:
-
-```go
-db.View(func(tx *bolt.Tx) error {
- b := tx.Bucket([]byte("MyBucket"))
- v := b.Get([]byte("answer"))
- fmt.Printf("The answer is: %s\n", v)
- return nil
-})
-```
-
-The `Get()` function does not return an error because its operation is
-guaranteed to work (unless there is some kind of system failure). If the key
-exists then it will return its byte slice value. If it doesn't exist then it
-will return `nil`. It's important to note that you can have a zero-length value
-set to a key which is different than the key not existing.
-
-Use the `Bucket.Delete()` function to delete a key from the bucket.
-
-Please note that values returned from `Get()` are only valid while the
-transaction is open. If you need to use a value outside of the transaction
-then you must use `copy()` to copy it to another byte slice.
-
-
-### Autoincrementing integer for the bucket
-By using the `NextSequence()` function, you can let Bolt determine a sequence
-which can be used as the unique identifier for your key/value pairs. See the
-example below.
-
-```go
-// CreateUser saves u to the store. The new user ID is set on u once the data is persisted.
-func (s *Store) CreateUser(u *User) error {
- return s.db.Update(func(tx *bolt.Tx) error {
- // Retrieve the users bucket.
- // This should be created when the DB is first opened.
- b := tx.Bucket([]byte("users"))
-
- // Generate ID for the user.
- // This returns an error only if the Tx is closed or not writeable.
- // That can't happen in an Update() call so I ignore the error check.
- id, _ := b.NextSequence()
- u.ID = int(id)
-
- // Marshal user data into bytes.
- buf, err := json.Marshal(u)
- if err != nil {
- return err
- }
-
- // Persist bytes to users bucket.
- return b.Put(itob(u.ID), buf)
- })
-}
-
-// itob returns an 8-byte big endian representation of v.
-func itob(v int) []byte {
- b := make([]byte, 8)
- binary.BigEndian.PutUint64(b, uint64(v))
- return b
-}
-
-type User struct {
- ID int
- ...
-}
-```
-
-### Iterating over keys
-
-Bolt stores its keys in byte-sorted order within a bucket. This makes sequential
-iteration over these keys extremely fast. To iterate over keys we'll use a
-`Cursor`:
-
-```go
-db.View(func(tx *bolt.Tx) error {
- // Assume bucket exists and has keys
- b := tx.Bucket([]byte("MyBucket"))
-
- c := b.Cursor()
-
- for k, v := c.First(); k != nil; k, v = c.Next() {
- fmt.Printf("key=%s, value=%s\n", k, v)
- }
-
- return nil
-})
-```
-
-The cursor allows you to move to a specific point in the list of keys and move
-forward or backward through the keys one at a time.
-
-The following functions are available on the cursor:
-
-```
-First() Move to the first key.
-Last() Move to the last key.
-Seek() Move to a specific key.
-Next() Move to the next key.
-Prev() Move to the previous key.
-```
-
-Each of those functions has a return signature of `(key []byte, value []byte)`.
-When you have iterated to the end of the cursor then `Next()` will return a
-`nil` key. You must seek to a position using `First()`, `Last()`, or `Seek()`
-before calling `Next()` or `Prev()`. If you do not seek to a position then
-these functions will return a `nil` key.
-
-During iteration, if the key is non-`nil` but the value is `nil`, that means
-the key refers to a bucket rather than a value. Use `Bucket.Bucket()` to
-access the sub-bucket.
-
-
-#### Prefix scans
-
-To iterate over a key prefix, you can combine `Seek()` and `bytes.HasPrefix()`:
-
-```go
-db.View(func(tx *bolt.Tx) error {
- // Assume bucket exists and has keys
- c := tx.Bucket([]byte("MyBucket")).Cursor()
-
- prefix := []byte("1234")
- for k, v := c.Seek(prefix); k != nil && bytes.HasPrefix(k, prefix); k, v = c.Next() {
- fmt.Printf("key=%s, value=%s\n", k, v)
- }
-
- return nil
-})
-```
-
-#### Range scans
-
-Another common use case is scanning over a range such as a time range. If you
-use a sortable time encoding such as RFC3339 then you can query a specific
-date range like this:
-
-```go
-db.View(func(tx *bolt.Tx) error {
- // Assume our events bucket exists and has RFC3339 encoded time keys.
- c := tx.Bucket([]byte("Events")).Cursor()
-
- // Our time range spans the 90's decade.
- min := []byte("1990-01-01T00:00:00Z")
- max := []byte("2000-01-01T00:00:00Z")
-
- // Iterate over the 90's.
- for k, v := c.Seek(min); k != nil && bytes.Compare(k, max) <= 0; k, v = c.Next() {
- fmt.Printf("%s: %s\n", k, v)
- }
-
- return nil
-})
-```
-
-Note that, while RFC3339 is sortable, the Golang implementation of RFC3339Nano does not use a fixed number of digits after the decimal point and is therefore not sortable.
-
-
-#### ForEach()
-
-You can also use the function `ForEach()` if you know you'll be iterating over
-all the keys in a bucket:
-
-```go
-db.View(func(tx *bolt.Tx) error {
- // Assume bucket exists and has keys
- b := tx.Bucket([]byte("MyBucket"))
-
- b.ForEach(func(k, v []byte) error {
- fmt.Printf("key=%s, value=%s\n", k, v)
- return nil
- })
- return nil
-})
-```
-
-Please note that keys and values in `ForEach()` are only valid while
-the transaction is open. If you need to use a key or value outside of
-the transaction, you must use `copy()` to copy it to another byte
-slice.
-
-### Nested buckets
-
-You can also store a bucket in a key to create nested buckets. The API is the
-same as the bucket management API on the `DB` object:
-
-```go
-func (*Bucket) CreateBucket(key []byte) (*Bucket, error)
-func (*Bucket) CreateBucketIfNotExists(key []byte) (*Bucket, error)
-func (*Bucket) DeleteBucket(key []byte) error
-```
-
-Say you had a multi-tenant application where the root level bucket was the account bucket. Inside of this bucket was a sequence of accounts which themselves are buckets. And inside the sequence bucket you could have many buckets pertaining to the Account itself (Users, Notes, etc) isolating the information into logical groupings.
-
-```go
-
-// createUser creates a new user in the given account.
-func createUser(accountID int, u *User) error {
- // Start the transaction.
- tx, err := db.Begin(true)
- if err != nil {
- return err
- }
- defer tx.Rollback()
-
- // Retrieve the root bucket for the account.
- // Assume this has already been created when the account was set up.
- root := tx.Bucket([]byte(strconv.FormatUint(accountID, 10)))
-
- // Setup the users bucket.
- bkt, err := root.CreateBucketIfNotExists([]byte("USERS"))
- if err != nil {
- return err
- }
-
- // Generate an ID for the new user.
- userID, err := bkt.NextSequence()
- if err != nil {
- return err
- }
- u.ID = userID
-
- // Marshal and save the encoded user.
- if buf, err := json.Marshal(u); err != nil {
- return err
- } else if err := bkt.Put([]byte(strconv.FormatUint(u.ID, 10)), buf); err != nil {
- return err
- }
-
- // Commit the transaction.
- if err := tx.Commit(); err != nil {
- return err
- }
-
- return nil
-}
-
-```
-
-
-
-
-### Database backups
-
-Bolt is a single file so it's easy to backup. You can use the `Tx.WriteTo()`
-function to write a consistent view of the database to a writer. If you call
-this from a read-only transaction, it will perform a hot backup and not block
-your other database reads and writes.
-
-By default, it will use a regular file handle which will utilize the operating
-system's page cache. See the [`Tx`](https://godoc.org/github.com/boltdb/bolt#Tx)
-documentation for information about optimizing for larger-than-RAM datasets.
-
-One common use case is to backup over HTTP so you can use tools like `cURL` to
-do database backups:
-
-```go
-func BackupHandleFunc(w http.ResponseWriter, req *http.Request) {
- err := db.View(func(tx *bolt.Tx) error {
- w.Header().Set("Content-Type", "application/octet-stream")
- w.Header().Set("Content-Disposition", `attachment; filename="my.db"`)
- w.Header().Set("Content-Length", strconv.Itoa(int(tx.Size())))
- _, err := tx.WriteTo(w)
- return err
- })
- if err != nil {
- http.Error(w, err.Error(), http.StatusInternalServerError)
- }
-}
-```
-
-Then you can backup using this command:
-
-```sh
-$ curl http://localhost/backup > my.db
-```
-
-Or you can open your browser to `http://localhost/backup` and it will download
-automatically.
-
-If you want to backup to another file you can use the `Tx.CopyFile()` helper
-function.
-
-
-### Statistics
-
-The database keeps a running count of many of the internal operations it
-performs so you can better understand what's going on. By grabbing a snapshot
-of these stats at two points in time we can see what operations were performed
-in that time range.
-
-For example, we could start a goroutine to log stats every 10 seconds:
-
-```go
-go func() {
- // Grab the initial stats.
- prev := db.Stats()
-
- for {
- // Wait for 10s.
- time.Sleep(10 * time.Second)
-
- // Grab the current stats and diff them.
- stats := db.Stats()
- diff := stats.Sub(&prev)
-
- // Encode stats to JSON and print to STDERR.
- json.NewEncoder(os.Stderr).Encode(diff)
-
- // Save stats for the next loop.
- prev = stats
- }
-}()
-```
-
-It's also useful to pipe these stats to a service such as statsd for monitoring
-or to provide an HTTP endpoint that will perform a fixed-length sample.
-
-
-### Read-Only Mode
-
-Sometimes it is useful to create a shared, read-only Bolt database. To this,
-set the `Options.ReadOnly` flag when opening your database. Read-only mode
-uses a shared lock to allow multiple processes to read from the database but
-it will block any processes from opening the database in read-write mode.
-
-```go
-db, err := bolt.Open("my.db", 0666, &bolt.Options{ReadOnly: true})
-if err != nil {
- log.Fatal(err)
-}
-```
-
-### Mobile Use (iOS/Android)
-
-Bolt is able to run on mobile devices by leveraging the binding feature of the
-[gomobile](https://github.com/golang/mobile) tool. Create a struct that will
-contain your database logic and a reference to a `*bolt.DB` with a initializing
-constructor that takes in a filepath where the database file will be stored.
-Neither Android nor iOS require extra permissions or cleanup from using this method.
-
-```go
-func NewBoltDB(filepath string) *BoltDB {
- db, err := bolt.Open(filepath+"/demo.db", 0600, nil)
- if err != nil {
- log.Fatal(err)
- }
-
- return &BoltDB{db}
-}
-
-type BoltDB struct {
- db *bolt.DB
- ...
-}
-
-func (b *BoltDB) Path() string {
- return b.db.Path()
-}
-
-func (b *BoltDB) Close() {
- b.db.Close()
-}
-```
-
-Database logic should be defined as methods on this wrapper struct.
-
-To initialize this struct from the native language (both platforms now sync
-their local storage to the cloud. These snippets disable that functionality for the
-database file):
-
-#### Android
-
-```java
-String path;
-if (android.os.Build.VERSION.SDK_INT >=android.os.Build.VERSION_CODES.LOLLIPOP){
- path = getNoBackupFilesDir().getAbsolutePath();
-} else{
- path = getFilesDir().getAbsolutePath();
-}
-Boltmobiledemo.BoltDB boltDB = Boltmobiledemo.NewBoltDB(path)
-```
-
-#### iOS
-
-```objc
-- (void)demo {
- NSString* path = [NSSearchPathForDirectoriesInDomains(NSLibraryDirectory,
- NSUserDomainMask,
- YES) objectAtIndex:0];
- GoBoltmobiledemoBoltDB * demo = GoBoltmobiledemoNewBoltDB(path);
- [self addSkipBackupAttributeToItemAtPath:demo.path];
- //Some DB Logic would go here
- [demo close];
-}
-
-- (BOOL)addSkipBackupAttributeToItemAtPath:(NSString *) filePathString
-{
- NSURL* URL= [NSURL fileURLWithPath: filePathString];
- assert([[NSFileManager defaultManager] fileExistsAtPath: [URL path]]);
-
- NSError *error = nil;
- BOOL success = [URL setResourceValue: [NSNumber numberWithBool: YES]
- forKey: NSURLIsExcludedFromBackupKey error: &error];
- if(!success){
- NSLog(@"Error excluding %@ from backup %@", [URL lastPathComponent], error);
- }
- return success;
-}
-
-```
-
-## Resources
-
-For more information on getting started with Bolt, check out the following articles:
-
-* [Intro to BoltDB: Painless Performant Persistence](http://npf.io/2014/07/intro-to-boltdb-painless-performant-persistence/) by [Nate Finch](https://github.com/natefinch).
-* [Bolt -- an embedded key/value database for Go](https://www.progville.com/go/bolt-embedded-db-golang/) by Progville
-
-
-## Comparison with other databases
-
-### Postgres, MySQL, & other relational databases
-
-Relational databases structure data into rows and are only accessible through
-the use of SQL. This approach provides flexibility in how you store and query
-your data but also incurs overhead in parsing and planning SQL statements. Bolt
-accesses all data by a byte slice key. This makes Bolt fast to read and write
-data by key but provides no built-in support for joining values together.
-
-Most relational databases (with the exception of SQLite) are standalone servers
-that run separately from your application. This gives your systems
-flexibility to connect multiple application servers to a single database
-server but also adds overhead in serializing and transporting data over the
-network. Bolt runs as a library included in your application so all data access
-has to go through your application's process. This brings data closer to your
-application but limits multi-process access to the data.
-
-
-### LevelDB, RocksDB
-
-LevelDB and its derivatives (RocksDB, HyperLevelDB) are similar to Bolt in that
-they are libraries bundled into the application, however, their underlying
-structure is a log-structured merge-tree (LSM tree). An LSM tree optimizes
-random writes by using a write ahead log and multi-tiered, sorted files called
-SSTables. Bolt uses a B+tree internally and only a single file. Both approaches
-have trade-offs.
-
-If you require a high random write throughput (>10,000 w/sec) or you need to use
-spinning disks then LevelDB could be a good choice. If your application is
-read-heavy or does a lot of range scans then Bolt could be a good choice.
-
-One other important consideration is that LevelDB does not have transactions.
-It supports batch writing of key/values pairs and it supports read snapshots
-but it will not give you the ability to do a compare-and-swap operation safely.
-Bolt supports fully serializable ACID transactions.
-
-
-### LMDB
-
-Bolt was originally a port of LMDB so it is architecturally similar. Both use
-a B+tree, have ACID semantics with fully serializable transactions, and support
-lock-free MVCC using a single writer and multiple readers.
-
-The two projects have somewhat diverged. LMDB heavily focuses on raw performance
-while Bolt has focused on simplicity and ease of use. For example, LMDB allows
-several unsafe actions such as direct writes for the sake of performance. Bolt
-opts to disallow actions which can leave the database in a corrupted state. The
-only exception to this in Bolt is `DB.NoSync`.
-
-There are also a few differences in API. LMDB requires a maximum mmap size when
-opening an `mdb_env` whereas Bolt will handle incremental mmap resizing
-automatically. LMDB overloads the getter and setter functions with multiple
-flags whereas Bolt splits these specialized cases into their own functions.
-
-
-## Caveats & Limitations
-
-It's important to pick the right tool for the job and Bolt is no exception.
-Here are a few things to note when evaluating and using Bolt:
-
-* Bolt is good for read intensive workloads. Sequential write performance is
- also fast but random writes can be slow. You can use `DB.Batch()` or add a
- write-ahead log to help mitigate this issue.
-
-* Bolt uses a B+tree internally so there can be a lot of random page access.
- SSDs provide a significant performance boost over spinning disks.
-
-* Try to avoid long running read transactions. Bolt uses copy-on-write so
- old pages cannot be reclaimed while an old transaction is using them.
-
-* Byte slices returned from Bolt are only valid during a transaction. Once the
- transaction has been committed or rolled back then the memory they point to
- can be reused by a new page or can be unmapped from virtual memory and you'll
- see an `unexpected fault address` panic when accessing it.
-
-* Bolt uses an exclusive write lock on the database file so it cannot be
- shared by multiple processes.
-
-* Be careful when using `Bucket.FillPercent`. Setting a high fill percent for
- buckets that have random inserts will cause your database to have very poor
- page utilization.
-
-* Use larger buckets in general. Smaller buckets causes poor page utilization
- once they become larger than the page size (typically 4KB).
-
-* Bulk loading a lot of random writes into a new bucket can be slow as the
- page will not split until the transaction is committed. Randomly inserting
- more than 100,000 key/value pairs into a single new bucket in a single
- transaction is not advised.
-
-* Bolt uses a memory-mapped file so the underlying operating system handles the
- caching of the data. Typically, the OS will cache as much of the file as it
- can in memory and will release memory as needed to other processes. This means
- that Bolt can show very high memory usage when working with large databases.
- However, this is expected and the OS will release memory as needed. Bolt can
- handle databases much larger than the available physical RAM, provided its
- memory-map fits in the process virtual address space. It may be problematic
- on 32-bits systems.
-
-* The data structures in the Bolt database are memory mapped so the data file
- will be endian specific. This means that you cannot copy a Bolt file from a
- little endian machine to a big endian machine and have it work. For most
- users this is not a concern since most modern CPUs are little endian.
-
-* Because of the way pages are laid out on disk, Bolt cannot truncate data files
- and return free pages back to the disk. Instead, Bolt maintains a free list
- of unused pages within its data file. These free pages can be reused by later
- transactions. This works well for many use cases as databases generally tend
- to grow. However, it's important to note that deleting large chunks of data
- will not allow you to reclaim that space on disk.
-
- For more information on page allocation, [see this comment][page-allocation].
-
-[page-allocation]: https://github.com/boltdb/bolt/issues/308#issuecomment-74811638
-
-
-## Reading the Source
-
-Bolt is a relatively small code base (<3KLOC) for an embedded, serializable,
-transactional key/value database so it can be a good starting point for people
-interested in how databases work.
-
-The best places to start are the main entry points into Bolt:
-
-- `Open()` - Initializes the reference to the database. It's responsible for
- creating the database if it doesn't exist, obtaining an exclusive lock on the
- file, reading the meta pages, & memory-mapping the file.
-
-- `DB.Begin()` - Starts a read-only or read-write transaction depending on the
- value of the `writable` argument. This requires briefly obtaining the "meta"
- lock to keep track of open transactions. Only one read-write transaction can
- exist at a time so the "rwlock" is acquired during the life of a read-write
- transaction.
-
-- `Bucket.Put()` - Writes a key/value pair into a bucket. After validating the
- arguments, a cursor is used to traverse the B+tree to the page and position
- where they key & value will be written. Once the position is found, the bucket
- materializes the underlying page and the page's parent pages into memory as
- "nodes". These nodes are where mutations occur during read-write transactions.
- These changes get flushed to disk during commit.
-
-- `Bucket.Get()` - Retrieves a key/value pair from a bucket. This uses a cursor
- to move to the page & position of a key/value pair. During a read-only
- transaction, the key and value data is returned as a direct reference to the
- underlying mmap file so there's no allocation overhead. For read-write
- transactions, this data may reference the mmap file or one of the in-memory
- node values.
-
-- `Cursor` - This object is simply for traversing the B+tree of on-disk pages
- or in-memory nodes. It can seek to a specific key, move to the first or last
- value, or it can move forward or backward. The cursor handles the movement up
- and down the B+tree transparently to the end user.
-
-- `Tx.Commit()` - Converts the in-memory dirty nodes and the list of free pages
- into pages to be written to disk. Writing to disk then occurs in two phases.
- First, the dirty pages are written to disk and an `fsync()` occurs. Second, a
- new meta page with an incremented transaction ID is written and another
- `fsync()` occurs. This two phase write ensures that partially written data
- pages are ignored in the event of a crash since the meta page pointing to them
- is never written. Partially written meta pages are invalidated because they
- are written with a checksum.
-
-If you have additional notes that could be helpful for others, please submit
-them via pull request.
-
-
-## Other Projects Using Bolt
-
-Below is a list of public, open source projects that use Bolt:
-
-* [BoltDbWeb](https://github.com/evnix/boltdbweb) - A web based GUI for BoltDB files.
-* [Operation Go: A Routine Mission](http://gocode.io) - An online programming game for Golang using Bolt for user accounts and a leaderboard.
-* [Bazil](https://bazil.org/) - A file system that lets your data reside where it is most convenient for it to reside.
-* [DVID](https://github.com/janelia-flyem/dvid) - Added Bolt as optional storage engine and testing it against Basho-tuned leveldb.
-* [Skybox Analytics](https://github.com/skybox/skybox) - A standalone funnel analysis tool for web analytics.
-* [Scuttlebutt](https://github.com/benbjohnson/scuttlebutt) - Uses Bolt to store and process all Twitter mentions of GitHub projects.
-* [Wiki](https://github.com/peterhellberg/wiki) - A tiny wiki using Goji, BoltDB and Blackfriday.
-* [ChainStore](https://github.com/pressly/chainstore) - Simple key-value interface to a variety of storage engines organized as a chain of operations.
-* [MetricBase](https://github.com/msiebuhr/MetricBase) - Single-binary version of Graphite.
-* [Gitchain](https://github.com/gitchain/gitchain) - Decentralized, peer-to-peer Git repositories aka "Git meets Bitcoin".
-* [event-shuttle](https://github.com/sclasen/event-shuttle) - A Unix system service to collect and reliably deliver messages to Kafka.
-* [ipxed](https://github.com/kelseyhightower/ipxed) - Web interface and api for ipxed.
-* [BoltStore](https://github.com/yosssi/boltstore) - Session store using Bolt.
-* [photosite/session](https://godoc.org/bitbucket.org/kardianos/photosite/session) - Sessions for a photo viewing site.
-* [LedisDB](https://github.com/siddontang/ledisdb) - A high performance NoSQL, using Bolt as optional storage.
-* [ipLocator](https://github.com/AndreasBriese/ipLocator) - A fast ip-geo-location-server using bolt with bloom filters.
-* [cayley](https://github.com/google/cayley) - Cayley is an open-source graph database using Bolt as optional backend.
-* [bleve](http://www.blevesearch.com/) - A pure Go search engine similar to ElasticSearch that uses Bolt as the default storage backend.
-* [tentacool](https://github.com/optiflows/tentacool) - REST api server to manage system stuff (IP, DNS, Gateway...) on a linux server.
-* [Seaweed File System](https://github.com/chrislusf/seaweedfs) - Highly scalable distributed key~file system with O(1) disk read.
-* [InfluxDB](https://influxdata.com) - Scalable datastore for metrics, events, and real-time analytics.
-* [Freehold](http://tshannon.bitbucket.org/freehold/) - An open, secure, and lightweight platform for your files and data.
-* [Prometheus Annotation Server](https://github.com/oliver006/prom_annotation_server) - Annotation server for PromDash & Prometheus service monitoring system.
-* [Consul](https://github.com/hashicorp/consul) - Consul is service discovery and configuration made easy. Distributed, highly available, and datacenter-aware.
-* [Kala](https://github.com/ajvb/kala) - Kala is a modern job scheduler optimized to run on a single node. It is persistent, JSON over HTTP API, ISO 8601 duration notation, and dependent jobs.
-* [drive](https://github.com/odeke-em/drive) - drive is an unofficial Google Drive command line client for \*NIX operating systems.
-* [stow](https://github.com/djherbis/stow) - a persistence manager for objects
- backed by boltdb.
-* [buckets](https://github.com/joyrexus/buckets) - a bolt wrapper streamlining
- simple tx and key scans.
-* [mbuckets](https://github.com/abhigupta912/mbuckets) - A Bolt wrapper that allows easy operations on multi level (nested) buckets.
-* [Request Baskets](https://github.com/darklynx/request-baskets) - A web service to collect arbitrary HTTP requests and inspect them via REST API or simple web UI, similar to [RequestBin](http://requestb.in/) service
-* [Go Report Card](https://goreportcard.com/) - Go code quality report cards as a (free and open source) service.
-* [Boltdb Boilerplate](https://github.com/bobintornado/boltdb-boilerplate) - Boilerplate wrapper around bolt aiming to make simple calls one-liners.
-* [lru](https://github.com/crowdriff/lru) - Easy to use Bolt-backed Least-Recently-Used (LRU) read-through cache with chainable remote stores.
-* [Storm](https://github.com/asdine/storm) - Simple and powerful ORM for BoltDB.
-* [GoWebApp](https://github.com/josephspurrier/gowebapp) - A basic MVC web application in Go using BoltDB.
-* [SimpleBolt](https://github.com/xyproto/simplebolt) - A simple way to use BoltDB. Deals mainly with strings.
-* [Algernon](https://github.com/xyproto/algernon) - A HTTP/2 web server with built-in support for Lua. Uses BoltDB as the default database backend.
-* [MuLiFS](https://github.com/dankomiocevic/mulifs) - Music Library Filesystem creates a filesystem to organise your music files.
-* [GoShort](https://github.com/pankajkhairnar/goShort) - GoShort is a URL shortener written in Golang and BoltDB for persistent key/value storage and for routing it's using high performent HTTPRouter.
-* [torrent](https://github.com/anacrolix/torrent) - Full-featured BitTorrent client package and utilities in Go. BoltDB is a storage backend in development.
-* [gopherpit](https://github.com/gopherpit/gopherpit) - A web service to manage Go remote import paths with custom domains
-* [bolter](https://github.com/hasit/bolter) - Command-line app for viewing BoltDB file in your terminal.
-* [btcwallet](https://github.com/btcsuite/btcwallet) - A bitcoin wallet.
-* [dcrwallet](https://github.com/decred/dcrwallet) - A wallet for the Decred cryptocurrency.
-* [Ironsmith](https://github.com/timshannon/ironsmith) - A simple, script-driven continuous integration (build - > test -> release) tool, with no external dependencies
-* [BoltHold](https://github.com/timshannon/bolthold) - An embeddable NoSQL store for Go types built on BoltDB
-
-If you are using Bolt in a project please send a pull request to add it to the list.
diff --git a/vendor/github.com/boltdb/bolt/appveyor.yml b/vendor/github.com/boltdb/bolt/appveyor.yml
deleted file mode 100644
index 6e26e941d..000000000
--- a/vendor/github.com/boltdb/bolt/appveyor.yml
+++ /dev/null
@@ -1,18 +0,0 @@
-version: "{build}"
-
-os: Windows Server 2012 R2
-
-clone_folder: c:\gopath\src\github.com\boltdb\bolt
-
-environment:
- GOPATH: c:\gopath
-
-install:
- - echo %PATH%
- - echo %GOPATH%
- - go version
- - go env
- - go get -v -t ./...
-
-build_script:
- - go test -v ./...
diff --git a/vendor/github.com/boltdb/bolt/bolt_386.go b/vendor/github.com/boltdb/bolt/bolt_386.go
deleted file mode 100644
index 820d533c1..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_386.go
+++ /dev/null
@@ -1,10 +0,0 @@
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0x7FFFFFFF // 2GB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0xFFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned = false
diff --git a/vendor/github.com/boltdb/bolt/bolt_amd64.go b/vendor/github.com/boltdb/bolt/bolt_amd64.go
deleted file mode 100644
index 98fafdb47..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_amd64.go
+++ /dev/null
@@ -1,10 +0,0 @@
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0xFFFFFFFFFFFF // 256TB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0x7FFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned = false
diff --git a/vendor/github.com/boltdb/bolt/bolt_arm.go b/vendor/github.com/boltdb/bolt/bolt_arm.go
deleted file mode 100644
index 7e5cb4b94..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_arm.go
+++ /dev/null
@@ -1,28 +0,0 @@
-package bolt
-
-import "unsafe"
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0x7FFFFFFF // 2GB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0xFFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned bool
-
-func init() {
- // Simple check to see whether this arch handles unaligned load/stores
- // correctly.
-
- // ARM9 and older devices require load/stores to be from/to aligned
- // addresses. If not, the lower 2 bits are cleared and that address is
- // read in a jumbled up order.
-
- // See http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.faqs/ka15414.html
-
- raw := [6]byte{0xfe, 0xef, 0x11, 0x22, 0x22, 0x11}
- val := *(*uint32)(unsafe.Pointer(uintptr(unsafe.Pointer(&raw)) + 2))
-
- brokenUnaligned = val != 0x11222211
-}
diff --git a/vendor/github.com/boltdb/bolt/bolt_arm64.go b/vendor/github.com/boltdb/bolt/bolt_arm64.go
deleted file mode 100644
index b26d84f91..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_arm64.go
+++ /dev/null
@@ -1,12 +0,0 @@
-// +build arm64
-
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0xFFFFFFFFFFFF // 256TB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0x7FFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned = false
diff --git a/vendor/github.com/boltdb/bolt/bolt_linux.go b/vendor/github.com/boltdb/bolt/bolt_linux.go
deleted file mode 100644
index 2b6766614..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_linux.go
+++ /dev/null
@@ -1,10 +0,0 @@
-package bolt
-
-import (
- "syscall"
-)
-
-// fdatasync flushes written data to a file descriptor.
-func fdatasync(db *DB) error {
- return syscall.Fdatasync(int(db.file.Fd()))
-}
diff --git a/vendor/github.com/boltdb/bolt/bolt_openbsd.go b/vendor/github.com/boltdb/bolt/bolt_openbsd.go
deleted file mode 100644
index 7058c3d73..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_openbsd.go
+++ /dev/null
@@ -1,27 +0,0 @@
-package bolt
-
-import (
- "syscall"
- "unsafe"
-)
-
-const (
- msAsync = 1 << iota // perform asynchronous writes
- msSync // perform synchronous writes
- msInvalidate // invalidate cached data
-)
-
-func msync(db *DB) error {
- _, _, errno := syscall.Syscall(syscall.SYS_MSYNC, uintptr(unsafe.Pointer(db.data)), uintptr(db.datasz), msInvalidate)
- if errno != 0 {
- return errno
- }
- return nil
-}
-
-func fdatasync(db *DB) error {
- if db.data != nil {
- return msync(db)
- }
- return db.file.Sync()
-}
diff --git a/vendor/github.com/boltdb/bolt/bolt_ppc.go b/vendor/github.com/boltdb/bolt/bolt_ppc.go
deleted file mode 100644
index 645ddc3ed..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_ppc.go
+++ /dev/null
@@ -1,9 +0,0 @@
-// +build ppc
-
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0x7FFFFFFF // 2GB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0xFFFFFFF
diff --git a/vendor/github.com/boltdb/bolt/bolt_ppc64.go b/vendor/github.com/boltdb/bolt/bolt_ppc64.go
deleted file mode 100644
index 9331d9771..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_ppc64.go
+++ /dev/null
@@ -1,12 +0,0 @@
-// +build ppc64
-
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0xFFFFFFFFFFFF // 256TB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0x7FFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned = false
diff --git a/vendor/github.com/boltdb/bolt/bolt_ppc64le.go b/vendor/github.com/boltdb/bolt/bolt_ppc64le.go
deleted file mode 100644
index 8c143bc5d..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_ppc64le.go
+++ /dev/null
@@ -1,12 +0,0 @@
-// +build ppc64le
-
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0xFFFFFFFFFFFF // 256TB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0x7FFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned = false
diff --git a/vendor/github.com/boltdb/bolt/bolt_s390x.go b/vendor/github.com/boltdb/bolt/bolt_s390x.go
deleted file mode 100644
index d7c39af92..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_s390x.go
+++ /dev/null
@@ -1,12 +0,0 @@
-// +build s390x
-
-package bolt
-
-// maxMapSize represents the largest mmap size supported by Bolt.
-const maxMapSize = 0xFFFFFFFFFFFF // 256TB
-
-// maxAllocSize is the size used when creating array pointers.
-const maxAllocSize = 0x7FFFFFFF
-
-// Are unaligned load/stores broken on this arch?
-var brokenUnaligned = false
diff --git a/vendor/github.com/boltdb/bolt/bolt_unix.go b/vendor/github.com/boltdb/bolt/bolt_unix.go
deleted file mode 100644
index cad62dda1..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_unix.go
+++ /dev/null
@@ -1,89 +0,0 @@
-// +build !windows,!plan9,!solaris
-
-package bolt
-
-import (
- "fmt"
- "os"
- "syscall"
- "time"
- "unsafe"
-)
-
-// flock acquires an advisory lock on a file descriptor.
-func flock(db *DB, mode os.FileMode, exclusive bool, timeout time.Duration) error {
- var t time.Time
- for {
- // If we're beyond our timeout then return an error.
- // This can only occur after we've attempted a flock once.
- if t.IsZero() {
- t = time.Now()
- } else if timeout > 0 && time.Since(t) > timeout {
- return ErrTimeout
- }
- flag := syscall.LOCK_SH
- if exclusive {
- flag = syscall.LOCK_EX
- }
-
- // Otherwise attempt to obtain an exclusive lock.
- err := syscall.Flock(int(db.file.Fd()), flag|syscall.LOCK_NB)
- if err == nil {
- return nil
- } else if err != syscall.EWOULDBLOCK {
- return err
- }
-
- // Wait for a bit and try again.
- time.Sleep(50 * time.Millisecond)
- }
-}
-
-// funlock releases an advisory lock on a file descriptor.
-func funlock(db *DB) error {
- return syscall.Flock(int(db.file.Fd()), syscall.LOCK_UN)
-}
-
-// mmap memory maps a DB's data file.
-func mmap(db *DB, sz int) error {
- // Map the data file to memory.
- b, err := syscall.Mmap(int(db.file.Fd()), 0, sz, syscall.PROT_READ, syscall.MAP_SHARED|db.MmapFlags)
- if err != nil {
- return err
- }
-
- // Advise the kernel that the mmap is accessed randomly.
- if err := madvise(b, syscall.MADV_RANDOM); err != nil {
- return fmt.Errorf("madvise: %s", err)
- }
-
- // Save the original byte slice and convert to a byte array pointer.
- db.dataref = b
- db.data = (*[maxMapSize]byte)(unsafe.Pointer(&b[0]))
- db.datasz = sz
- return nil
-}
-
-// munmap unmaps a DB's data file from memory.
-func munmap(db *DB) error {
- // Ignore the unmap if we have no mapped data.
- if db.dataref == nil {
- return nil
- }
-
- // Unmap using the original byte slice.
- err := syscall.Munmap(db.dataref)
- db.dataref = nil
- db.data = nil
- db.datasz = 0
- return err
-}
-
-// NOTE: This function is copied from stdlib because it is not available on darwin.
-func madvise(b []byte, advice int) (err error) {
- _, _, e1 := syscall.Syscall(syscall.SYS_MADVISE, uintptr(unsafe.Pointer(&b[0])), uintptr(len(b)), uintptr(advice))
- if e1 != 0 {
- err = e1
- }
- return
-}
diff --git a/vendor/github.com/boltdb/bolt/bolt_unix_solaris.go b/vendor/github.com/boltdb/bolt/bolt_unix_solaris.go
deleted file mode 100644
index 307bf2b3e..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_unix_solaris.go
+++ /dev/null
@@ -1,90 +0,0 @@
-package bolt
-
-import (
- "fmt"
- "os"
- "syscall"
- "time"
- "unsafe"
-
- "golang.org/x/sys/unix"
-)
-
-// flock acquires an advisory lock on a file descriptor.
-func flock(db *DB, mode os.FileMode, exclusive bool, timeout time.Duration) error {
- var t time.Time
- for {
- // If we're beyond our timeout then return an error.
- // This can only occur after we've attempted a flock once.
- if t.IsZero() {
- t = time.Now()
- } else if timeout > 0 && time.Since(t) > timeout {
- return ErrTimeout
- }
- var lock syscall.Flock_t
- lock.Start = 0
- lock.Len = 0
- lock.Pid = 0
- lock.Whence = 0
- lock.Pid = 0
- if exclusive {
- lock.Type = syscall.F_WRLCK
- } else {
- lock.Type = syscall.F_RDLCK
- }
- err := syscall.FcntlFlock(db.file.Fd(), syscall.F_SETLK, &lock)
- if err == nil {
- return nil
- } else if err != syscall.EAGAIN {
- return err
- }
-
- // Wait for a bit and try again.
- time.Sleep(50 * time.Millisecond)
- }
-}
-
-// funlock releases an advisory lock on a file descriptor.
-func funlock(db *DB) error {
- var lock syscall.Flock_t
- lock.Start = 0
- lock.Len = 0
- lock.Type = syscall.F_UNLCK
- lock.Whence = 0
- return syscall.FcntlFlock(uintptr(db.file.Fd()), syscall.F_SETLK, &lock)
-}
-
-// mmap memory maps a DB's data file.
-func mmap(db *DB, sz int) error {
- // Map the data file to memory.
- b, err := unix.Mmap(int(db.file.Fd()), 0, sz, syscall.PROT_READ, syscall.MAP_SHARED|db.MmapFlags)
- if err != nil {
- return err
- }
-
- // Advise the kernel that the mmap is accessed randomly.
- if err := unix.Madvise(b, syscall.MADV_RANDOM); err != nil {
- return fmt.Errorf("madvise: %s", err)
- }
-
- // Save the original byte slice and convert to a byte array pointer.
- db.dataref = b
- db.data = (*[maxMapSize]byte)(unsafe.Pointer(&b[0]))
- db.datasz = sz
- return nil
-}
-
-// munmap unmaps a DB's data file from memory.
-func munmap(db *DB) error {
- // Ignore the unmap if we have no mapped data.
- if db.dataref == nil {
- return nil
- }
-
- // Unmap using the original byte slice.
- err := unix.Munmap(db.dataref)
- db.dataref = nil
- db.data = nil
- db.datasz = 0
- return err
-}
diff --git a/vendor/github.com/boltdb/bolt/bolt_windows.go b/vendor/github.com/boltdb/bolt/bolt_windows.go
deleted file mode 100644
index b00fb0720..000000000
--- a/vendor/github.com/boltdb/bolt/bolt_windows.go
+++ /dev/null
@@ -1,144 +0,0 @@
-package bolt
-
-import (
- "fmt"
- "os"
- "syscall"
- "time"
- "unsafe"
-)
-
-// LockFileEx code derived from golang build filemutex_windows.go @ v1.5.1
-var (
- modkernel32 = syscall.NewLazyDLL("kernel32.dll")
- procLockFileEx = modkernel32.NewProc("LockFileEx")
- procUnlockFileEx = modkernel32.NewProc("UnlockFileEx")
-)
-
-const (
- lockExt = ".lock"
-
- // see https://msdn.microsoft.com/en-us/library/windows/desktop/aa365203(v=vs.85).aspx
- flagLockExclusive = 2
- flagLockFailImmediately = 1
-
- // see https://msdn.microsoft.com/en-us/library/windows/desktop/ms681382(v=vs.85).aspx
- errLockViolation syscall.Errno = 0x21
-)
-
-func lockFileEx(h syscall.Handle, flags, reserved, locklow, lockhigh uint32, ol *syscall.Overlapped) (err error) {
- r, _, err := procLockFileEx.Call(uintptr(h), uintptr(flags), uintptr(reserved), uintptr(locklow), uintptr(lockhigh), uintptr(unsafe.Pointer(ol)))
- if r == 0 {
- return err
- }
- return nil
-}
-
-func unlockFileEx(h syscall.Handle, reserved, locklow, lockhigh uint32, ol *syscall.Overlapped) (err error) {
- r, _, err := procUnlockFileEx.Call(uintptr(h), uintptr(reserved), uintptr(locklow), uintptr(lockhigh), uintptr(unsafe.Pointer(ol)), 0)
- if r == 0 {
- return err
- }
- return nil
-}
-
-// fdatasync flushes written data to a file descriptor.
-func fdatasync(db *DB) error {
- return db.file.Sync()
-}
-
-// flock acquires an advisory lock on a file descriptor.
-func flock(db *DB, mode os.FileMode, exclusive bool, timeout time.Duration) error {
- // Create a separate lock file on windows because a process
- // cannot share an exclusive lock on the same file. This is
- // needed during Tx.WriteTo().
- f, err := os.OpenFile(db.path+lockExt, os.O_CREATE, mode)
- if err != nil {
- return err
- }
- db.lockfile = f
-
- var t time.Time
- for {
- // If we're beyond our timeout then return an error.
- // This can only occur after we've attempted a flock once.
- if t.IsZero() {
- t = time.Now()
- } else if timeout > 0 && time.Since(t) > timeout {
- return ErrTimeout
- }
-
- var flag uint32 = flagLockFailImmediately
- if exclusive {
- flag |= flagLockExclusive
- }
-
- err := lockFileEx(syscall.Handle(db.lockfile.Fd()), flag, 0, 1, 0, &syscall.Overlapped{})
- if err == nil {
- return nil
- } else if err != errLockViolation {
- return err
- }
-
- // Wait for a bit and try again.
- time.Sleep(50 * time.Millisecond)
- }
-}
-
-// funlock releases an advisory lock on a file descriptor.
-func funlock(db *DB) error {
- err := unlockFileEx(syscall.Handle(db.lockfile.Fd()), 0, 1, 0, &syscall.Overlapped{})
- db.lockfile.Close()
- os.Remove(db.path + lockExt)
- return err
-}
-
-// mmap memory maps a DB's data file.
-// Based on: https://github.com/edsrzf/mmap-go
-func mmap(db *DB, sz int) error {
- if !db.readOnly {
- // Truncate the database to the size of the mmap.
- if err := db.file.Truncate(int64(sz)); err != nil {
- return fmt.Errorf("truncate: %s", err)
- }
- }
-
- // Open a file mapping handle.
- sizelo := uint32(sz >> 32)
- sizehi := uint32(sz) & 0xffffffff
- h, errno := syscall.CreateFileMapping(syscall.Handle(db.file.Fd()), nil, syscall.PAGE_READONLY, sizelo, sizehi, nil)
- if h == 0 {
- return os.NewSyscallError("CreateFileMapping", errno)
- }
-
- // Create the memory map.
- addr, errno := syscall.MapViewOfFile(h, syscall.FILE_MAP_READ, 0, 0, uintptr(sz))
- if addr == 0 {
- return os.NewSyscallError("MapViewOfFile", errno)
- }
-
- // Close mapping handle.
- if err := syscall.CloseHandle(syscall.Handle(h)); err != nil {
- return os.NewSyscallError("CloseHandle", err)
- }
-
- // Convert to a byte array.
- db.data = ((*[maxMapSize]byte)(unsafe.Pointer(addr)))
- db.datasz = sz
-
- return nil
-}
-
-// munmap unmaps a pointer from a file.
-// Based on: https://github.com/edsrzf/mmap-go
-func munmap(db *DB) error {
- if db.data == nil {
- return nil
- }
-
- addr := (uintptr)(unsafe.Pointer(&db.data[0]))
- if err := syscall.UnmapViewOfFile(addr); err != nil {
- return os.NewSyscallError("UnmapViewOfFile", err)
- }
- return nil
-}
diff --git a/vendor/github.com/boltdb/bolt/boltsync_unix.go b/vendor/github.com/boltdb/bolt/boltsync_unix.go
deleted file mode 100644
index f50442523..000000000
--- a/vendor/github.com/boltdb/bolt/boltsync_unix.go
+++ /dev/null
@@ -1,8 +0,0 @@
-// +build !windows,!plan9,!linux,!openbsd
-
-package bolt
-
-// fdatasync flushes written data to a file descriptor.
-func fdatasync(db *DB) error {
- return db.file.Sync()
-}
diff --git a/vendor/github.com/boltdb/bolt/bucket.go b/vendor/github.com/boltdb/bolt/bucket.go
deleted file mode 100644
index 0c5bf2746..000000000
--- a/vendor/github.com/boltdb/bolt/bucket.go
+++ /dev/null
@@ -1,777 +0,0 @@
-package bolt
-
-import (
- "bytes"
- "fmt"
- "unsafe"
-)
-
-const (
- // MaxKeySize is the maximum length of a key, in bytes.
- MaxKeySize = 32768
-
- // MaxValueSize is the maximum length of a value, in bytes.
- MaxValueSize = (1 << 31) - 2
-)
-
-const (
- maxUint = ^uint(0)
- minUint = 0
- maxInt = int(^uint(0) >> 1)
- minInt = -maxInt - 1
-)
-
-const bucketHeaderSize = int(unsafe.Sizeof(bucket{}))
-
-const (
- minFillPercent = 0.1
- maxFillPercent = 1.0
-)
-
-// DefaultFillPercent is the percentage that split pages are filled.
-// This value can be changed by setting Bucket.FillPercent.
-const DefaultFillPercent = 0.5
-
-// Bucket represents a collection of key/value pairs inside the database.
-type Bucket struct {
- *bucket
- tx *Tx // the associated transaction
- buckets map[string]*Bucket // subbucket cache
- page *page // inline page reference
- rootNode *node // materialized node for the root page.
- nodes map[pgid]*node // node cache
-
- // Sets the threshold for filling nodes when they split. By default,
- // the bucket will fill to 50% but it can be useful to increase this
- // amount if you know that your write workloads are mostly append-only.
- //
- // This is non-persisted across transactions so it must be set in every Tx.
- FillPercent float64
-}
-
-// bucket represents the on-file representation of a bucket.
-// This is stored as the "value" of a bucket key. If the bucket is small enough,
-// then its root page can be stored inline in the "value", after the bucket
-// header. In the case of inline buckets, the "root" will be 0.
-type bucket struct {
- root pgid // page id of the bucket's root-level page
- sequence uint64 // monotonically incrementing, used by NextSequence()
-}
-
-// newBucket returns a new bucket associated with a transaction.
-func newBucket(tx *Tx) Bucket {
- var b = Bucket{tx: tx, FillPercent: DefaultFillPercent}
- if tx.writable {
- b.buckets = make(map[string]*Bucket)
- b.nodes = make(map[pgid]*node)
- }
- return b
-}
-
-// Tx returns the tx of the bucket.
-func (b *Bucket) Tx() *Tx {
- return b.tx
-}
-
-// Root returns the root of the bucket.
-func (b *Bucket) Root() pgid {
- return b.root
-}
-
-// Writable returns whether the bucket is writable.
-func (b *Bucket) Writable() bool {
- return b.tx.writable
-}
-
-// Cursor creates a cursor associated with the bucket.
-// The cursor is only valid as long as the transaction is open.
-// Do not use a cursor after the transaction is closed.
-func (b *Bucket) Cursor() *Cursor {
- // Update transaction statistics.
- b.tx.stats.CursorCount++
-
- // Allocate and return a cursor.
- return &Cursor{
- bucket: b,
- stack: make([]elemRef, 0),
- }
-}
-
-// Bucket retrieves a nested bucket by name.
-// Returns nil if the bucket does not exist.
-// The bucket instance is only valid for the lifetime of the transaction.
-func (b *Bucket) Bucket(name []byte) *Bucket {
- if b.buckets != nil {
- if child := b.buckets[string(name)]; child != nil {
- return child
- }
- }
-
- // Move cursor to key.
- c := b.Cursor()
- k, v, flags := c.seek(name)
-
- // Return nil if the key doesn't exist or it is not a bucket.
- if !bytes.Equal(name, k) || (flags&bucketLeafFlag) == 0 {
- return nil
- }
-
- // Otherwise create a bucket and cache it.
- var child = b.openBucket(v)
- if b.buckets != nil {
- b.buckets[string(name)] = child
- }
-
- return child
-}
-
-// Helper method that re-interprets a sub-bucket value
-// from a parent into a Bucket
-func (b *Bucket) openBucket(value []byte) *Bucket {
- var child = newBucket(b.tx)
-
- // If unaligned load/stores are broken on this arch and value is
- // unaligned simply clone to an aligned byte array.
- unaligned := brokenUnaligned && uintptr(unsafe.Pointer(&value[0]))&3 != 0
-
- if unaligned {
- value = cloneBytes(value)
- }
-
- // If this is a writable transaction then we need to copy the bucket entry.
- // Read-only transactions can point directly at the mmap entry.
- if b.tx.writable && !unaligned {
- child.bucket = &bucket{}
- *child.bucket = *(*bucket)(unsafe.Pointer(&value[0]))
- } else {
- child.bucket = (*bucket)(unsafe.Pointer(&value[0]))
- }
-
- // Save a reference to the inline page if the bucket is inline.
- if child.root == 0 {
- child.page = (*page)(unsafe.Pointer(&value[bucketHeaderSize]))
- }
-
- return &child
-}
-
-// CreateBucket creates a new bucket at the given key and returns the new bucket.
-// Returns an error if the key already exists, if the bucket name is blank, or if the bucket name is too long.
-// The bucket instance is only valid for the lifetime of the transaction.
-func (b *Bucket) CreateBucket(key []byte) (*Bucket, error) {
- if b.tx.db == nil {
- return nil, ErrTxClosed
- } else if !b.tx.writable {
- return nil, ErrTxNotWritable
- } else if len(key) == 0 {
- return nil, ErrBucketNameRequired
- }
-
- // Move cursor to correct position.
- c := b.Cursor()
- k, _, flags := c.seek(key)
-
- // Return an error if there is an existing key.
- if bytes.Equal(key, k) {
- if (flags & bucketLeafFlag) != 0 {
- return nil, ErrBucketExists
- }
- return nil, ErrIncompatibleValue
- }
-
- // Create empty, inline bucket.
- var bucket = Bucket{
- bucket: &bucket{},
- rootNode: &node{isLeaf: true},
- FillPercent: DefaultFillPercent,
- }
- var value = bucket.write()
-
- // Insert into node.
- key = cloneBytes(key)
- c.node().put(key, key, value, 0, bucketLeafFlag)
-
- // Since subbuckets are not allowed on inline buckets, we need to
- // dereference the inline page, if it exists. This will cause the bucket
- // to be treated as a regular, non-inline bucket for the rest of the tx.
- b.page = nil
-
- return b.Bucket(key), nil
-}
-
-// CreateBucketIfNotExists creates a new bucket if it doesn't already exist and returns a reference to it.
-// Returns an error if the bucket name is blank, or if the bucket name is too long.
-// The bucket instance is only valid for the lifetime of the transaction.
-func (b *Bucket) CreateBucketIfNotExists(key []byte) (*Bucket, error) {
- child, err := b.CreateBucket(key)
- if err == ErrBucketExists {
- return b.Bucket(key), nil
- } else if err != nil {
- return nil, err
- }
- return child, nil
-}
-
-// DeleteBucket deletes a bucket at the given key.
-// Returns an error if the bucket does not exists, or if the key represents a non-bucket value.
-func (b *Bucket) DeleteBucket(key []byte) error {
- if b.tx.db == nil {
- return ErrTxClosed
- } else if !b.Writable() {
- return ErrTxNotWritable
- }
-
- // Move cursor to correct position.
- c := b.Cursor()
- k, _, flags := c.seek(key)
-
- // Return an error if bucket doesn't exist or is not a bucket.
- if !bytes.Equal(key, k) {
- return ErrBucketNotFound
- } else if (flags & bucketLeafFlag) == 0 {
- return ErrIncompatibleValue
- }
-
- // Recursively delete all child buckets.
- child := b.Bucket(key)
- err := child.ForEach(func(k, v []byte) error {
- if v == nil {
- if err := child.DeleteBucket(k); err != nil {
- return fmt.Errorf("delete bucket: %s", err)
- }
- }
- return nil
- })
- if err != nil {
- return err
- }
-
- // Remove cached copy.
- delete(b.buckets, string(key))
-
- // Release all bucket pages to freelist.
- child.nodes = nil
- child.rootNode = nil
- child.free()
-
- // Delete the node if we have a matching key.
- c.node().del(key)
-
- return nil
-}
-
-// Get retrieves the value for a key in the bucket.
-// Returns a nil value if the key does not exist or if the key is a nested bucket.
-// The returned value is only valid for the life of the transaction.
-func (b *Bucket) Get(key []byte) []byte {
- k, v, flags := b.Cursor().seek(key)
-
- // Return nil if this is a bucket.
- if (flags & bucketLeafFlag) != 0 {
- return nil
- }
-
- // If our target node isn't the same key as what's passed in then return nil.
- if !bytes.Equal(key, k) {
- return nil
- }
- return v
-}
-
-// Put sets the value for a key in the bucket.
-// If the key exist then its previous value will be overwritten.
-// Supplied value must remain valid for the life of the transaction.
-// Returns an error if the bucket was created from a read-only transaction, if the key is blank, if the key is too large, or if the value is too large.
-func (b *Bucket) Put(key []byte, value []byte) error {
- if b.tx.db == nil {
- return ErrTxClosed
- } else if !b.Writable() {
- return ErrTxNotWritable
- } else if len(key) == 0 {
- return ErrKeyRequired
- } else if len(key) > MaxKeySize {
- return ErrKeyTooLarge
- } else if int64(len(value)) > MaxValueSize {
- return ErrValueTooLarge
- }
-
- // Move cursor to correct position.
- c := b.Cursor()
- k, _, flags := c.seek(key)
-
- // Return an error if there is an existing key with a bucket value.
- if bytes.Equal(key, k) && (flags&bucketLeafFlag) != 0 {
- return ErrIncompatibleValue
- }
-
- // Insert into node.
- key = cloneBytes(key)
- c.node().put(key, key, value, 0, 0)
-
- return nil
-}
-
-// Delete removes a key from the bucket.
-// If the key does not exist then nothing is done and a nil error is returned.
-// Returns an error if the bucket was created from a read-only transaction.
-func (b *Bucket) Delete(key []byte) error {
- if b.tx.db == nil {
- return ErrTxClosed
- } else if !b.Writable() {
- return ErrTxNotWritable
- }
-
- // Move cursor to correct position.
- c := b.Cursor()
- _, _, flags := c.seek(key)
-
- // Return an error if there is already existing bucket value.
- if (flags & bucketLeafFlag) != 0 {
- return ErrIncompatibleValue
- }
-
- // Delete the node if we have a matching key.
- c.node().del(key)
-
- return nil
-}
-
-// Sequence returns the current integer for the bucket without incrementing it.
-func (b *Bucket) Sequence() uint64 { return b.bucket.sequence }
-
-// SetSequence updates the sequence number for the bucket.
-func (b *Bucket) SetSequence(v uint64) error {
- if b.tx.db == nil {
- return ErrTxClosed
- } else if !b.Writable() {
- return ErrTxNotWritable
- }
-
- // Materialize the root node if it hasn't been already so that the
- // bucket will be saved during commit.
- if b.rootNode == nil {
- _ = b.node(b.root, nil)
- }
-
- // Increment and return the sequence.
- b.bucket.sequence = v
- return nil
-}
-
-// NextSequence returns an autoincrementing integer for the bucket.
-func (b *Bucket) NextSequence() (uint64, error) {
- if b.tx.db == nil {
- return 0, ErrTxClosed
- } else if !b.Writable() {
- return 0, ErrTxNotWritable
- }
-
- // Materialize the root node if it hasn't been already so that the
- // bucket will be saved during commit.
- if b.rootNode == nil {
- _ = b.node(b.root, nil)
- }
-
- // Increment and return the sequence.
- b.bucket.sequence++
- return b.bucket.sequence, nil
-}
-
-// ForEach executes a function for each key/value pair in a bucket.
-// If the provided function returns an error then the iteration is stopped and
-// the error is returned to the caller. The provided function must not modify
-// the bucket; this will result in undefined behavior.
-func (b *Bucket) ForEach(fn func(k, v []byte) error) error {
- if b.tx.db == nil {
- return ErrTxClosed
- }
- c := b.Cursor()
- for k, v := c.First(); k != nil; k, v = c.Next() {
- if err := fn(k, v); err != nil {
- return err
- }
- }
- return nil
-}
-
-// Stat returns stats on a bucket.
-func (b *Bucket) Stats() BucketStats {
- var s, subStats BucketStats
- pageSize := b.tx.db.pageSize
- s.BucketN += 1
- if b.root == 0 {
- s.InlineBucketN += 1
- }
- b.forEachPage(func(p *page, depth int) {
- if (p.flags & leafPageFlag) != 0 {
- s.KeyN += int(p.count)
-
- // used totals the used bytes for the page
- used := pageHeaderSize
-
- if p.count != 0 {
- // If page has any elements, add all element headers.
- used += leafPageElementSize * int(p.count-1)
-
- // Add all element key, value sizes.
- // The computation takes advantage of the fact that the position
- // of the last element's key/value equals to the total of the sizes
- // of all previous elements' keys and values.
- // It also includes the last element's header.
- lastElement := p.leafPageElement(p.count - 1)
- used += int(lastElement.pos + lastElement.ksize + lastElement.vsize)
- }
-
- if b.root == 0 {
- // For inlined bucket just update the inline stats
- s.InlineBucketInuse += used
- } else {
- // For non-inlined bucket update all the leaf stats
- s.LeafPageN++
- s.LeafInuse += used
- s.LeafOverflowN += int(p.overflow)
-
- // Collect stats from sub-buckets.
- // Do that by iterating over all element headers
- // looking for the ones with the bucketLeafFlag.
- for i := uint16(0); i < p.count; i++ {
- e := p.leafPageElement(i)
- if (e.flags & bucketLeafFlag) != 0 {
- // For any bucket element, open the element value
- // and recursively call Stats on the contained bucket.
- subStats.Add(b.openBucket(e.value()).Stats())
- }
- }
- }
- } else if (p.flags & branchPageFlag) != 0 {
- s.BranchPageN++
- lastElement := p.branchPageElement(p.count - 1)
-
- // used totals the used bytes for the page
- // Add header and all element headers.
- used := pageHeaderSize + (branchPageElementSize * int(p.count-1))
-
- // Add size of all keys and values.
- // Again, use the fact that last element's position equals to
- // the total of key, value sizes of all previous elements.
- used += int(lastElement.pos + lastElement.ksize)
- s.BranchInuse += used
- s.BranchOverflowN += int(p.overflow)
- }
-
- // Keep track of maximum page depth.
- if depth+1 > s.Depth {
- s.Depth = (depth + 1)
- }
- })
-
- // Alloc stats can be computed from page counts and pageSize.
- s.BranchAlloc = (s.BranchPageN + s.BranchOverflowN) * pageSize
- s.LeafAlloc = (s.LeafPageN + s.LeafOverflowN) * pageSize
-
- // Add the max depth of sub-buckets to get total nested depth.
- s.Depth += subStats.Depth
- // Add the stats for all sub-buckets
- s.Add(subStats)
- return s
-}
-
-// forEachPage iterates over every page in a bucket, including inline pages.
-func (b *Bucket) forEachPage(fn func(*page, int)) {
- // If we have an inline page then just use that.
- if b.page != nil {
- fn(b.page, 0)
- return
- }
-
- // Otherwise traverse the page hierarchy.
- b.tx.forEachPage(b.root, 0, fn)
-}
-
-// forEachPageNode iterates over every page (or node) in a bucket.
-// This also includes inline pages.
-func (b *Bucket) forEachPageNode(fn func(*page, *node, int)) {
- // If we have an inline page or root node then just use that.
- if b.page != nil {
- fn(b.page, nil, 0)
- return
- }
- b._forEachPageNode(b.root, 0, fn)
-}
-
-func (b *Bucket) _forEachPageNode(pgid pgid, depth int, fn func(*page, *node, int)) {
- var p, n = b.pageNode(pgid)
-
- // Execute function.
- fn(p, n, depth)
-
- // Recursively loop over children.
- if p != nil {
- if (p.flags & branchPageFlag) != 0 {
- for i := 0; i < int(p.count); i++ {
- elem := p.branchPageElement(uint16(i))
- b._forEachPageNode(elem.pgid, depth+1, fn)
- }
- }
- } else {
- if !n.isLeaf {
- for _, inode := range n.inodes {
- b._forEachPageNode(inode.pgid, depth+1, fn)
- }
- }
- }
-}
-
-// spill writes all the nodes for this bucket to dirty pages.
-func (b *Bucket) spill() error {
- // Spill all child buckets first.
- for name, child := range b.buckets {
- // If the child bucket is small enough and it has no child buckets then
- // write it inline into the parent bucket's page. Otherwise spill it
- // like a normal bucket and make the parent value a pointer to the page.
- var value []byte
- if child.inlineable() {
- child.free()
- value = child.write()
- } else {
- if err := child.spill(); err != nil {
- return err
- }
-
- // Update the child bucket header in this bucket.
- value = make([]byte, unsafe.Sizeof(bucket{}))
- var bucket = (*bucket)(unsafe.Pointer(&value[0]))
- *bucket = *child.bucket
- }
-
- // Skip writing the bucket if there are no materialized nodes.
- if child.rootNode == nil {
- continue
- }
-
- // Update parent node.
- var c = b.Cursor()
- k, _, flags := c.seek([]byte(name))
- if !bytes.Equal([]byte(name), k) {
- panic(fmt.Sprintf("misplaced bucket header: %x -> %x", []byte(name), k))
- }
- if flags&bucketLeafFlag == 0 {
- panic(fmt.Sprintf("unexpected bucket header flag: %x", flags))
- }
- c.node().put([]byte(name), []byte(name), value, 0, bucketLeafFlag)
- }
-
- // Ignore if there's not a materialized root node.
- if b.rootNode == nil {
- return nil
- }
-
- // Spill nodes.
- if err := b.rootNode.spill(); err != nil {
- return err
- }
- b.rootNode = b.rootNode.root()
-
- // Update the root node for this bucket.
- if b.rootNode.pgid >= b.tx.meta.pgid {
- panic(fmt.Sprintf("pgid (%d) above high water mark (%d)", b.rootNode.pgid, b.tx.meta.pgid))
- }
- b.root = b.rootNode.pgid
-
- return nil
-}
-
-// inlineable returns true if a bucket is small enough to be written inline
-// and if it contains no subbuckets. Otherwise returns false.
-func (b *Bucket) inlineable() bool {
- var n = b.rootNode
-
- // Bucket must only contain a single leaf node.
- if n == nil || !n.isLeaf {
- return false
- }
-
- // Bucket is not inlineable if it contains subbuckets or if it goes beyond
- // our threshold for inline bucket size.
- var size = pageHeaderSize
- for _, inode := range n.inodes {
- size += leafPageElementSize + len(inode.key) + len(inode.value)
-
- if inode.flags&bucketLeafFlag != 0 {
- return false
- } else if size > b.maxInlineBucketSize() {
- return false
- }
- }
-
- return true
-}
-
-// Returns the maximum total size of a bucket to make it a candidate for inlining.
-func (b *Bucket) maxInlineBucketSize() int {
- return b.tx.db.pageSize / 4
-}
-
-// write allocates and writes a bucket to a byte slice.
-func (b *Bucket) write() []byte {
- // Allocate the appropriate size.
- var n = b.rootNode
- var value = make([]byte, bucketHeaderSize+n.size())
-
- // Write a bucket header.
- var bucket = (*bucket)(unsafe.Pointer(&value[0]))
- *bucket = *b.bucket
-
- // Convert byte slice to a fake page and write the root node.
- var p = (*page)(unsafe.Pointer(&value[bucketHeaderSize]))
- n.write(p)
-
- return value
-}
-
-// rebalance attempts to balance all nodes.
-func (b *Bucket) rebalance() {
- for _, n := range b.nodes {
- n.rebalance()
- }
- for _, child := range b.buckets {
- child.rebalance()
- }
-}
-
-// node creates a node from a page and associates it with a given parent.
-func (b *Bucket) node(pgid pgid, parent *node) *node {
- _assert(b.nodes != nil, "nodes map expected")
-
- // Retrieve node if it's already been created.
- if n := b.nodes[pgid]; n != nil {
- return n
- }
-
- // Otherwise create a node and cache it.
- n := &node{bucket: b, parent: parent}
- if parent == nil {
- b.rootNode = n
- } else {
- parent.children = append(parent.children, n)
- }
-
- // Use the inline page if this is an inline bucket.
- var p = b.page
- if p == nil {
- p = b.tx.page(pgid)
- }
-
- // Read the page into the node and cache it.
- n.read(p)
- b.nodes[pgid] = n
-
- // Update statistics.
- b.tx.stats.NodeCount++
-
- return n
-}
-
-// free recursively frees all pages in the bucket.
-func (b *Bucket) free() {
- if b.root == 0 {
- return
- }
-
- var tx = b.tx
- b.forEachPageNode(func(p *page, n *node, _ int) {
- if p != nil {
- tx.db.freelist.free(tx.meta.txid, p)
- } else {
- n.free()
- }
- })
- b.root = 0
-}
-
-// dereference removes all references to the old mmap.
-func (b *Bucket) dereference() {
- if b.rootNode != nil {
- b.rootNode.root().dereference()
- }
-
- for _, child := range b.buckets {
- child.dereference()
- }
-}
-
-// pageNode returns the in-memory node, if it exists.
-// Otherwise returns the underlying page.
-func (b *Bucket) pageNode(id pgid) (*page, *node) {
- // Inline buckets have a fake page embedded in their value so treat them
- // differently. We'll return the rootNode (if available) or the fake page.
- if b.root == 0 {
- if id != 0 {
- panic(fmt.Sprintf("inline bucket non-zero page access(2): %d != 0", id))
- }
- if b.rootNode != nil {
- return nil, b.rootNode
- }
- return b.page, nil
- }
-
- // Check the node cache for non-inline buckets.
- if b.nodes != nil {
- if n := b.nodes[id]; n != nil {
- return nil, n
- }
- }
-
- // Finally lookup the page from the transaction if no node is materialized.
- return b.tx.page(id), nil
-}
-
-// BucketStats records statistics about resources used by a bucket.
-type BucketStats struct {
- // Page count statistics.
- BranchPageN int // number of logical branch pages
- BranchOverflowN int // number of physical branch overflow pages
- LeafPageN int // number of logical leaf pages
- LeafOverflowN int // number of physical leaf overflow pages
-
- // Tree statistics.
- KeyN int // number of keys/value pairs
- Depth int // number of levels in B+tree
-
- // Page size utilization.
- BranchAlloc int // bytes allocated for physical branch pages
- BranchInuse int // bytes actually used for branch data
- LeafAlloc int // bytes allocated for physical leaf pages
- LeafInuse int // bytes actually used for leaf data
-
- // Bucket statistics
- BucketN int // total number of buckets including the top bucket
- InlineBucketN int // total number on inlined buckets
- InlineBucketInuse int // bytes used for inlined buckets (also accounted for in LeafInuse)
-}
-
-func (s *BucketStats) Add(other BucketStats) {
- s.BranchPageN += other.BranchPageN
- s.BranchOverflowN += other.BranchOverflowN
- s.LeafPageN += other.LeafPageN
- s.LeafOverflowN += other.LeafOverflowN
- s.KeyN += other.KeyN
- if s.Depth < other.Depth {
- s.Depth = other.Depth
- }
- s.BranchAlloc += other.BranchAlloc
- s.BranchInuse += other.BranchInuse
- s.LeafAlloc += other.LeafAlloc
- s.LeafInuse += other.LeafInuse
-
- s.BucketN += other.BucketN
- s.InlineBucketN += other.InlineBucketN
- s.InlineBucketInuse += other.InlineBucketInuse
-}
-
-// cloneBytes returns a copy of a given slice.
-func cloneBytes(v []byte) []byte {
- var clone = make([]byte, len(v))
- copy(clone, v)
- return clone
-}
diff --git a/vendor/github.com/boltdb/bolt/cursor.go b/vendor/github.com/boltdb/bolt/cursor.go
deleted file mode 100644
index 1be9f35e3..000000000
--- a/vendor/github.com/boltdb/bolt/cursor.go
+++ /dev/null
@@ -1,400 +0,0 @@
-package bolt
-
-import (
- "bytes"
- "fmt"
- "sort"
-)
-
-// Cursor represents an iterator that can traverse over all key/value pairs in a bucket in sorted order.
-// Cursors see nested buckets with value == nil.
-// Cursors can be obtained from a transaction and are valid as long as the transaction is open.
-//
-// Keys and values returned from the cursor are only valid for the life of the transaction.
-//
-// Changing data while traversing with a cursor may cause it to be invalidated
-// and return unexpected keys and/or values. You must reposition your cursor
-// after mutating data.
-type Cursor struct {
- bucket *Bucket
- stack []elemRef
-}
-
-// Bucket returns the bucket that this cursor was created from.
-func (c *Cursor) Bucket() *Bucket {
- return c.bucket
-}
-
-// First moves the cursor to the first item in the bucket and returns its key and value.
-// If the bucket is empty then a nil key and value are returned.
-// The returned key and value are only valid for the life of the transaction.
-func (c *Cursor) First() (key []byte, value []byte) {
- _assert(c.bucket.tx.db != nil, "tx closed")
- c.stack = c.stack[:0]
- p, n := c.bucket.pageNode(c.bucket.root)
- c.stack = append(c.stack, elemRef{page: p, node: n, index: 0})
- c.first()
-
- // If we land on an empty page then move to the next value.
- // https://github.com/boltdb/bolt/issues/450
- if c.stack[len(c.stack)-1].count() == 0 {
- c.next()
- }
-
- k, v, flags := c.keyValue()
- if (flags & uint32(bucketLeafFlag)) != 0 {
- return k, nil
- }
- return k, v
-
-}
-
-// Last moves the cursor to the last item in the bucket and returns its key and value.
-// If the bucket is empty then a nil key and value are returned.
-// The returned key and value are only valid for the life of the transaction.
-func (c *Cursor) Last() (key []byte, value []byte) {
- _assert(c.bucket.tx.db != nil, "tx closed")
- c.stack = c.stack[:0]
- p, n := c.bucket.pageNode(c.bucket.root)
- ref := elemRef{page: p, node: n}
- ref.index = ref.count() - 1
- c.stack = append(c.stack, ref)
- c.last()
- k, v, flags := c.keyValue()
- if (flags & uint32(bucketLeafFlag)) != 0 {
- return k, nil
- }
- return k, v
-}
-
-// Next moves the cursor to the next item in the bucket and returns its key and value.
-// If the cursor is at the end of the bucket then a nil key and value are returned.
-// The returned key and value are only valid for the life of the transaction.
-func (c *Cursor) Next() (key []byte, value []byte) {
- _assert(c.bucket.tx.db != nil, "tx closed")
- k, v, flags := c.next()
- if (flags & uint32(bucketLeafFlag)) != 0 {
- return k, nil
- }
- return k, v
-}
-
-// Prev moves the cursor to the previous item in the bucket and returns its key and value.
-// If the cursor is at the beginning of the bucket then a nil key and value are returned.
-// The returned key and value are only valid for the life of the transaction.
-func (c *Cursor) Prev() (key []byte, value []byte) {
- _assert(c.bucket.tx.db != nil, "tx closed")
-
- // Attempt to move back one element until we're successful.
- // Move up the stack as we hit the beginning of each page in our stack.
- for i := len(c.stack) - 1; i >= 0; i-- {
- elem := &c.stack[i]
- if elem.index > 0 {
- elem.index--
- break
- }
- c.stack = c.stack[:i]
- }
-
- // If we've hit the end then return nil.
- if len(c.stack) == 0 {
- return nil, nil
- }
-
- // Move down the stack to find the last element of the last leaf under this branch.
- c.last()
- k, v, flags := c.keyValue()
- if (flags & uint32(bucketLeafFlag)) != 0 {
- return k, nil
- }
- return k, v
-}
-
-// Seek moves the cursor to a given key and returns it.
-// If the key does not exist then the next key is used. If no keys
-// follow, a nil key is returned.
-// The returned key and value are only valid for the life of the transaction.
-func (c *Cursor) Seek(seek []byte) (key []byte, value []byte) {
- k, v, flags := c.seek(seek)
-
- // If we ended up after the last element of a page then move to the next one.
- if ref := &c.stack[len(c.stack)-1]; ref.index >= ref.count() {
- k, v, flags = c.next()
- }
-
- if k == nil {
- return nil, nil
- } else if (flags & uint32(bucketLeafFlag)) != 0 {
- return k, nil
- }
- return k, v
-}
-
-// Delete removes the current key/value under the cursor from the bucket.
-// Delete fails if current key/value is a bucket or if the transaction is not writable.
-func (c *Cursor) Delete() error {
- if c.bucket.tx.db == nil {
- return ErrTxClosed
- } else if !c.bucket.Writable() {
- return ErrTxNotWritable
- }
-
- key, _, flags := c.keyValue()
- // Return an error if current value is a bucket.
- if (flags & bucketLeafFlag) != 0 {
- return ErrIncompatibleValue
- }
- c.node().del(key)
-
- return nil
-}
-
-// seek moves the cursor to a given key and returns it.
-// If the key does not exist then the next key is used.
-func (c *Cursor) seek(seek []byte) (key []byte, value []byte, flags uint32) {
- _assert(c.bucket.tx.db != nil, "tx closed")
-
- // Start from root page/node and traverse to correct page.
- c.stack = c.stack[:0]
- c.search(seek, c.bucket.root)
- ref := &c.stack[len(c.stack)-1]
-
- // If the cursor is pointing to the end of page/node then return nil.
- if ref.index >= ref.count() {
- return nil, nil, 0
- }
-
- // If this is a bucket then return a nil value.
- return c.keyValue()
-}
-
-// first moves the cursor to the first leaf element under the last page in the stack.
-func (c *Cursor) first() {
- for {
- // Exit when we hit a leaf page.
- var ref = &c.stack[len(c.stack)-1]
- if ref.isLeaf() {
- break
- }
-
- // Keep adding pages pointing to the first element to the stack.
- var pgid pgid
- if ref.node != nil {
- pgid = ref.node.inodes[ref.index].pgid
- } else {
- pgid = ref.page.branchPageElement(uint16(ref.index)).pgid
- }
- p, n := c.bucket.pageNode(pgid)
- c.stack = append(c.stack, elemRef{page: p, node: n, index: 0})
- }
-}
-
-// last moves the cursor to the last leaf element under the last page in the stack.
-func (c *Cursor) last() {
- for {
- // Exit when we hit a leaf page.
- ref := &c.stack[len(c.stack)-1]
- if ref.isLeaf() {
- break
- }
-
- // Keep adding pages pointing to the last element in the stack.
- var pgid pgid
- if ref.node != nil {
- pgid = ref.node.inodes[ref.index].pgid
- } else {
- pgid = ref.page.branchPageElement(uint16(ref.index)).pgid
- }
- p, n := c.bucket.pageNode(pgid)
-
- var nextRef = elemRef{page: p, node: n}
- nextRef.index = nextRef.count() - 1
- c.stack = append(c.stack, nextRef)
- }
-}
-
-// next moves to the next leaf element and returns the key and value.
-// If the cursor is at the last leaf element then it stays there and returns nil.
-func (c *Cursor) next() (key []byte, value []byte, flags uint32) {
- for {
- // Attempt to move over one element until we're successful.
- // Move up the stack as we hit the end of each page in our stack.
- var i int
- for i = len(c.stack) - 1; i >= 0; i-- {
- elem := &c.stack[i]
- if elem.index < elem.count()-1 {
- elem.index++
- break
- }
- }
-
- // If we've hit the root page then stop and return. This will leave the
- // cursor on the last element of the last page.
- if i == -1 {
- return nil, nil, 0
- }
-
- // Otherwise start from where we left off in the stack and find the
- // first element of the first leaf page.
- c.stack = c.stack[:i+1]
- c.first()
-
- // If this is an empty page then restart and move back up the stack.
- // https://github.com/boltdb/bolt/issues/450
- if c.stack[len(c.stack)-1].count() == 0 {
- continue
- }
-
- return c.keyValue()
- }
-}
-
-// search recursively performs a binary search against a given page/node until it finds a given key.
-func (c *Cursor) search(key []byte, pgid pgid) {
- p, n := c.bucket.pageNode(pgid)
- if p != nil && (p.flags&(branchPageFlag|leafPageFlag)) == 0 {
- panic(fmt.Sprintf("invalid page type: %d: %x", p.id, p.flags))
- }
- e := elemRef{page: p, node: n}
- c.stack = append(c.stack, e)
-
- // If we're on a leaf page/node then find the specific node.
- if e.isLeaf() {
- c.nsearch(key)
- return
- }
-
- if n != nil {
- c.searchNode(key, n)
- return
- }
- c.searchPage(key, p)
-}
-
-func (c *Cursor) searchNode(key []byte, n *node) {
- var exact bool
- index := sort.Search(len(n.inodes), func(i int) bool {
- // TODO(benbjohnson): Optimize this range search. It's a bit hacky right now.
- // sort.Search() finds the lowest index where f() != -1 but we need the highest index.
- ret := bytes.Compare(n.inodes[i].key, key)
- if ret == 0 {
- exact = true
- }
- return ret != -1
- })
- if !exact && index > 0 {
- index--
- }
- c.stack[len(c.stack)-1].index = index
-
- // Recursively search to the next page.
- c.search(key, n.inodes[index].pgid)
-}
-
-func (c *Cursor) searchPage(key []byte, p *page) {
- // Binary search for the correct range.
- inodes := p.branchPageElements()
-
- var exact bool
- index := sort.Search(int(p.count), func(i int) bool {
- // TODO(benbjohnson): Optimize this range search. It's a bit hacky right now.
- // sort.Search() finds the lowest index where f() != -1 but we need the highest index.
- ret := bytes.Compare(inodes[i].key(), key)
- if ret == 0 {
- exact = true
- }
- return ret != -1
- })
- if !exact && index > 0 {
- index--
- }
- c.stack[len(c.stack)-1].index = index
-
- // Recursively search to the next page.
- c.search(key, inodes[index].pgid)
-}
-
-// nsearch searches the leaf node on the top of the stack for a key.
-func (c *Cursor) nsearch(key []byte) {
- e := &c.stack[len(c.stack)-1]
- p, n := e.page, e.node
-
- // If we have a node then search its inodes.
- if n != nil {
- index := sort.Search(len(n.inodes), func(i int) bool {
- return bytes.Compare(n.inodes[i].key, key) != -1
- })
- e.index = index
- return
- }
-
- // If we have a page then search its leaf elements.
- inodes := p.leafPageElements()
- index := sort.Search(int(p.count), func(i int) bool {
- return bytes.Compare(inodes[i].key(), key) != -1
- })
- e.index = index
-}
-
-// keyValue returns the key and value of the current leaf element.
-func (c *Cursor) keyValue() ([]byte, []byte, uint32) {
- ref := &c.stack[len(c.stack)-1]
- if ref.count() == 0 || ref.index >= ref.count() {
- return nil, nil, 0
- }
-
- // Retrieve value from node.
- if ref.node != nil {
- inode := &ref.node.inodes[ref.index]
- return inode.key, inode.value, inode.flags
- }
-
- // Or retrieve value from page.
- elem := ref.page.leafPageElement(uint16(ref.index))
- return elem.key(), elem.value(), elem.flags
-}
-
-// node returns the node that the cursor is currently positioned on.
-func (c *Cursor) node() *node {
- _assert(len(c.stack) > 0, "accessing a node with a zero-length cursor stack")
-
- // If the top of the stack is a leaf node then just return it.
- if ref := &c.stack[len(c.stack)-1]; ref.node != nil && ref.isLeaf() {
- return ref.node
- }
-
- // Start from root and traverse down the hierarchy.
- var n = c.stack[0].node
- if n == nil {
- n = c.bucket.node(c.stack[0].page.id, nil)
- }
- for _, ref := range c.stack[:len(c.stack)-1] {
- _assert(!n.isLeaf, "expected branch node")
- n = n.childAt(int(ref.index))
- }
- _assert(n.isLeaf, "expected leaf node")
- return n
-}
-
-// elemRef represents a reference to an element on a given page/node.
-type elemRef struct {
- page *page
- node *node
- index int
-}
-
-// isLeaf returns whether the ref is pointing at a leaf page/node.
-func (r *elemRef) isLeaf() bool {
- if r.node != nil {
- return r.node.isLeaf
- }
- return (r.page.flags & leafPageFlag) != 0
-}
-
-// count returns the number of inodes or page elements.
-func (r *elemRef) count() int {
- if r.node != nil {
- return len(r.node.inodes)
- }
- return int(r.page.count)
-}
diff --git a/vendor/github.com/boltdb/bolt/db.go b/vendor/github.com/boltdb/bolt/db.go
deleted file mode 100644
index f352ff14f..000000000
--- a/vendor/github.com/boltdb/bolt/db.go
+++ /dev/null
@@ -1,1039 +0,0 @@
-package bolt
-
-import (
- "errors"
- "fmt"
- "hash/fnv"
- "log"
- "os"
- "runtime"
- "runtime/debug"
- "strings"
- "sync"
- "time"
- "unsafe"
-)
-
-// The largest step that can be taken when remapping the mmap.
-const maxMmapStep = 1 << 30 // 1GB
-
-// The data file format version.
-const version = 2
-
-// Represents a marker value to indicate that a file is a Bolt DB.
-const magic uint32 = 0xED0CDAED
-
-// IgnoreNoSync specifies whether the NoSync field of a DB is ignored when
-// syncing changes to a file. This is required as some operating systems,
-// such as OpenBSD, do not have a unified buffer cache (UBC) and writes
-// must be synchronized using the msync(2) syscall.
-const IgnoreNoSync = runtime.GOOS == "openbsd"
-
-// Default values if not set in a DB instance.
-const (
- DefaultMaxBatchSize int = 1000
- DefaultMaxBatchDelay = 10 * time.Millisecond
- DefaultAllocSize = 16 * 1024 * 1024
-)
-
-// default page size for db is set to the OS page size.
-var defaultPageSize = os.Getpagesize()
-
-// DB represents a collection of buckets persisted to a file on disk.
-// All data access is performed through transactions which can be obtained through the DB.
-// All the functions on DB will return a ErrDatabaseNotOpen if accessed before Open() is called.
-type DB struct {
- // When enabled, the database will perform a Check() after every commit.
- // A panic is issued if the database is in an inconsistent state. This
- // flag has a large performance impact so it should only be used for
- // debugging purposes.
- StrictMode bool
-
- // Setting the NoSync flag will cause the database to skip fsync()
- // calls after each commit. This can be useful when bulk loading data
- // into a database and you can restart the bulk load in the event of
- // a system failure or database corruption. Do not set this flag for
- // normal use.
- //
- // If the package global IgnoreNoSync constant is true, this value is
- // ignored. See the comment on that constant for more details.
- //
- // THIS IS UNSAFE. PLEASE USE WITH CAUTION.
- NoSync bool
-
- // When true, skips the truncate call when growing the database.
- // Setting this to true is only safe on non-ext3/ext4 systems.
- // Skipping truncation avoids preallocation of hard drive space and
- // bypasses a truncate() and fsync() syscall on remapping.
- //
- // https://github.com/boltdb/bolt/issues/284
- NoGrowSync bool
-
- // If you want to read the entire database fast, you can set MmapFlag to
- // syscall.MAP_POPULATE on Linux 2.6.23+ for sequential read-ahead.
- MmapFlags int
-
- // MaxBatchSize is the maximum size of a batch. Default value is
- // copied from DefaultMaxBatchSize in Open.
- //
- // If <=0, disables batching.
- //
- // Do not change concurrently with calls to Batch.
- MaxBatchSize int
-
- // MaxBatchDelay is the maximum delay before a batch starts.
- // Default value is copied from DefaultMaxBatchDelay in Open.
- //
- // If <=0, effectively disables batching.
- //
- // Do not change concurrently with calls to Batch.
- MaxBatchDelay time.Duration
-
- // AllocSize is the amount of space allocated when the database
- // needs to create new pages. This is done to amortize the cost
- // of truncate() and fsync() when growing the data file.
- AllocSize int
-
- path string
- file *os.File
- lockfile *os.File // windows only
- dataref []byte // mmap'ed readonly, write throws SEGV
- data *[maxMapSize]byte
- datasz int
- filesz int // current on disk file size
- meta0 *meta
- meta1 *meta
- pageSize int
- opened bool
- rwtx *Tx
- txs []*Tx
- freelist *freelist
- stats Stats
-
- pagePool sync.Pool
-
- batchMu sync.Mutex
- batch *batch
-
- rwlock sync.Mutex // Allows only one writer at a time.
- metalock sync.Mutex // Protects meta page access.
- mmaplock sync.RWMutex // Protects mmap access during remapping.
- statlock sync.RWMutex // Protects stats access.
-
- ops struct {
- writeAt func(b []byte, off int64) (n int, err error)
- }
-
- // Read only mode.
- // When true, Update() and Begin(true) return ErrDatabaseReadOnly immediately.
- readOnly bool
-}
-
-// Path returns the path to currently open database file.
-func (db *DB) Path() string {
- return db.path
-}
-
-// GoString returns the Go string representation of the database.
-func (db *DB) GoString() string {
- return fmt.Sprintf("bolt.DB{path:%q}", db.path)
-}
-
-// String returns the string representation of the database.
-func (db *DB) String() string {
- return fmt.Sprintf("DB<%q>", db.path)
-}
-
-// Open creates and opens a database at the given path.
-// If the file does not exist then it will be created automatically.
-// Passing in nil options will cause Bolt to open the database with the default options.
-func Open(path string, mode os.FileMode, options *Options) (*DB, error) {
- var db = &DB{opened: true}
-
- // Set default options if no options are provided.
- if options == nil {
- options = DefaultOptions
- }
- db.NoGrowSync = options.NoGrowSync
- db.MmapFlags = options.MmapFlags
-
- // Set default values for later DB operations.
- db.MaxBatchSize = DefaultMaxBatchSize
- db.MaxBatchDelay = DefaultMaxBatchDelay
- db.AllocSize = DefaultAllocSize
-
- flag := os.O_RDWR
- if options.ReadOnly {
- flag = os.O_RDONLY
- db.readOnly = true
- }
-
- // Open data file and separate sync handler for metadata writes.
- db.path = path
- var err error
- if db.file, err = os.OpenFile(db.path, flag|os.O_CREATE, mode); err != nil {
- _ = db.close()
- return nil, err
- }
-
- // Lock file so that other processes using Bolt in read-write mode cannot
- // use the database at the same time. This would cause corruption since
- // the two processes would write meta pages and free pages separately.
- // The database file is locked exclusively (only one process can grab the lock)
- // if !options.ReadOnly.
- // The database file is locked using the shared lock (more than one process may
- // hold a lock at the same time) otherwise (options.ReadOnly is set).
- if err := flock(db, mode, !db.readOnly, options.Timeout); err != nil {
- _ = db.close()
- return nil, err
- }
-
- // Default values for test hooks
- db.ops.writeAt = db.file.WriteAt
-
- // Initialize the database if it doesn't exist.
- if info, err := db.file.Stat(); err != nil {
- return nil, err
- } else if info.Size() == 0 {
- // Initialize new files with meta pages.
- if err := db.init(); err != nil {
- return nil, err
- }
- } else {
- // Read the first meta page to determine the page size.
- var buf [0x1000]byte
- if _, err := db.file.ReadAt(buf[:], 0); err == nil {
- m := db.pageInBuffer(buf[:], 0).meta()
- if err := m.validate(); err != nil {
- // If we can't read the page size, we can assume it's the same
- // as the OS -- since that's how the page size was chosen in the
- // first place.
- //
- // If the first page is invalid and this OS uses a different
- // page size than what the database was created with then we
- // are out of luck and cannot access the database.
- db.pageSize = os.Getpagesize()
- } else {
- db.pageSize = int(m.pageSize)
- }
- }
- }
-
- // Initialize page pool.
- db.pagePool = sync.Pool{
- New: func() interface{} {
- return make([]byte, db.pageSize)
- },
- }
-
- // Memory map the data file.
- if err := db.mmap(options.InitialMmapSize); err != nil {
- _ = db.close()
- return nil, err
- }
-
- // Read in the freelist.
- db.freelist = newFreelist()
- db.freelist.read(db.page(db.meta().freelist))
-
- // Mark the database as opened and return.
- return db, nil
-}
-
-// mmap opens the underlying memory-mapped file and initializes the meta references.
-// minsz is the minimum size that the new mmap can be.
-func (db *DB) mmap(minsz int) error {
- db.mmaplock.Lock()
- defer db.mmaplock.Unlock()
-
- info, err := db.file.Stat()
- if err != nil {
- return fmt.Errorf("mmap stat error: %s", err)
- } else if int(info.Size()) < db.pageSize*2 {
- return fmt.Errorf("file size too small")
- }
-
- // Ensure the size is at least the minimum size.
- var size = int(info.Size())
- if size < minsz {
- size = minsz
- }
- size, err = db.mmapSize(size)
- if err != nil {
- return err
- }
-
- // Dereference all mmap references before unmapping.
- if db.rwtx != nil {
- db.rwtx.root.dereference()
- }
-
- // Unmap existing data before continuing.
- if err := db.munmap(); err != nil {
- return err
- }
-
- // Memory-map the data file as a byte slice.
- if err := mmap(db, size); err != nil {
- return err
- }
-
- // Save references to the meta pages.
- db.meta0 = db.page(0).meta()
- db.meta1 = db.page(1).meta()
-
- // Validate the meta pages. We only return an error if both meta pages fail
- // validation, since meta0 failing validation means that it wasn't saved
- // properly -- but we can recover using meta1. And vice-versa.
- err0 := db.meta0.validate()
- err1 := db.meta1.validate()
- if err0 != nil && err1 != nil {
- return err0
- }
-
- return nil
-}
-
-// munmap unmaps the data file from memory.
-func (db *DB) munmap() error {
- if err := munmap(db); err != nil {
- return fmt.Errorf("unmap error: " + err.Error())
- }
- return nil
-}
-
-// mmapSize determines the appropriate size for the mmap given the current size
-// of the database. The minimum size is 32KB and doubles until it reaches 1GB.
-// Returns an error if the new mmap size is greater than the max allowed.
-func (db *DB) mmapSize(size int) (int, error) {
- // Double the size from 32KB until 1GB.
- for i := uint(15); i <= 30; i++ {
- if size <= 1< maxMapSize {
- return 0, fmt.Errorf("mmap too large")
- }
-
- // If larger than 1GB then grow by 1GB at a time.
- sz := int64(size)
- if remainder := sz % int64(maxMmapStep); remainder > 0 {
- sz += int64(maxMmapStep) - remainder
- }
-
- // Ensure that the mmap size is a multiple of the page size.
- // This should always be true since we're incrementing in MBs.
- pageSize := int64(db.pageSize)
- if (sz % pageSize) != 0 {
- sz = ((sz / pageSize) + 1) * pageSize
- }
-
- // If we've exceeded the max size then only grow up to the max size.
- if sz > maxMapSize {
- sz = maxMapSize
- }
-
- return int(sz), nil
-}
-
-// init creates a new database file and initializes its meta pages.
-func (db *DB) init() error {
- // Set the page size to the OS page size.
- db.pageSize = os.Getpagesize()
-
- // Create two meta pages on a buffer.
- buf := make([]byte, db.pageSize*4)
- for i := 0; i < 2; i++ {
- p := db.pageInBuffer(buf[:], pgid(i))
- p.id = pgid(i)
- p.flags = metaPageFlag
-
- // Initialize the meta page.
- m := p.meta()
- m.magic = magic
- m.version = version
- m.pageSize = uint32(db.pageSize)
- m.freelist = 2
- m.root = bucket{root: 3}
- m.pgid = 4
- m.txid = txid(i)
- m.checksum = m.sum64()
- }
-
- // Write an empty freelist at page 3.
- p := db.pageInBuffer(buf[:], pgid(2))
- p.id = pgid(2)
- p.flags = freelistPageFlag
- p.count = 0
-
- // Write an empty leaf page at page 4.
- p = db.pageInBuffer(buf[:], pgid(3))
- p.id = pgid(3)
- p.flags = leafPageFlag
- p.count = 0
-
- // Write the buffer to our data file.
- if _, err := db.ops.writeAt(buf, 0); err != nil {
- return err
- }
- if err := fdatasync(db); err != nil {
- return err
- }
-
- return nil
-}
-
-// Close releases all database resources.
-// All transactions must be closed before closing the database.
-func (db *DB) Close() error {
- db.rwlock.Lock()
- defer db.rwlock.Unlock()
-
- db.metalock.Lock()
- defer db.metalock.Unlock()
-
- db.mmaplock.RLock()
- defer db.mmaplock.RUnlock()
-
- return db.close()
-}
-
-func (db *DB) close() error {
- if !db.opened {
- return nil
- }
-
- db.opened = false
-
- db.freelist = nil
-
- // Clear ops.
- db.ops.writeAt = nil
-
- // Close the mmap.
- if err := db.munmap(); err != nil {
- return err
- }
-
- // Close file handles.
- if db.file != nil {
- // No need to unlock read-only file.
- if !db.readOnly {
- // Unlock the file.
- if err := funlock(db); err != nil {
- log.Printf("bolt.Close(): funlock error: %s", err)
- }
- }
-
- // Close the file descriptor.
- if err := db.file.Close(); err != nil {
- return fmt.Errorf("db file close: %s", err)
- }
- db.file = nil
- }
-
- db.path = ""
- return nil
-}
-
-// Begin starts a new transaction.
-// Multiple read-only transactions can be used concurrently but only one
-// write transaction can be used at a time. Starting multiple write transactions
-// will cause the calls to block and be serialized until the current write
-// transaction finishes.
-//
-// Transactions should not be dependent on one another. Opening a read
-// transaction and a write transaction in the same goroutine can cause the
-// writer to deadlock because the database periodically needs to re-mmap itself
-// as it grows and it cannot do that while a read transaction is open.
-//
-// If a long running read transaction (for example, a snapshot transaction) is
-// needed, you might want to set DB.InitialMmapSize to a large enough value
-// to avoid potential blocking of write transaction.
-//
-// IMPORTANT: You must close read-only transactions after you are finished or
-// else the database will not reclaim old pages.
-func (db *DB) Begin(writable bool) (*Tx, error) {
- if writable {
- return db.beginRWTx()
- }
- return db.beginTx()
-}
-
-func (db *DB) beginTx() (*Tx, error) {
- // Lock the meta pages while we initialize the transaction. We obtain
- // the meta lock before the mmap lock because that's the order that the
- // write transaction will obtain them.
- db.metalock.Lock()
-
- // Obtain a read-only lock on the mmap. When the mmap is remapped it will
- // obtain a write lock so all transactions must finish before it can be
- // remapped.
- db.mmaplock.RLock()
-
- // Exit if the database is not open yet.
- if !db.opened {
- db.mmaplock.RUnlock()
- db.metalock.Unlock()
- return nil, ErrDatabaseNotOpen
- }
-
- // Create a transaction associated with the database.
- t := &Tx{}
- t.init(db)
-
- // Keep track of transaction until it closes.
- db.txs = append(db.txs, t)
- n := len(db.txs)
-
- // Unlock the meta pages.
- db.metalock.Unlock()
-
- // Update the transaction stats.
- db.statlock.Lock()
- db.stats.TxN++
- db.stats.OpenTxN = n
- db.statlock.Unlock()
-
- return t, nil
-}
-
-func (db *DB) beginRWTx() (*Tx, error) {
- // If the database was opened with Options.ReadOnly, return an error.
- if db.readOnly {
- return nil, ErrDatabaseReadOnly
- }
-
- // Obtain writer lock. This is released by the transaction when it closes.
- // This enforces only one writer transaction at a time.
- db.rwlock.Lock()
-
- // Once we have the writer lock then we can lock the meta pages so that
- // we can set up the transaction.
- db.metalock.Lock()
- defer db.metalock.Unlock()
-
- // Exit if the database is not open yet.
- if !db.opened {
- db.rwlock.Unlock()
- return nil, ErrDatabaseNotOpen
- }
-
- // Create a transaction associated with the database.
- t := &Tx{writable: true}
- t.init(db)
- db.rwtx = t
-
- // Free any pages associated with closed read-only transactions.
- var minid txid = 0xFFFFFFFFFFFFFFFF
- for _, t := range db.txs {
- if t.meta.txid < minid {
- minid = t.meta.txid
- }
- }
- if minid > 0 {
- db.freelist.release(minid - 1)
- }
-
- return t, nil
-}
-
-// removeTx removes a transaction from the database.
-func (db *DB) removeTx(tx *Tx) {
- // Release the read lock on the mmap.
- db.mmaplock.RUnlock()
-
- // Use the meta lock to restrict access to the DB object.
- db.metalock.Lock()
-
- // Remove the transaction.
- for i, t := range db.txs {
- if t == tx {
- last := len(db.txs) - 1
- db.txs[i] = db.txs[last]
- db.txs[last] = nil
- db.txs = db.txs[:last]
- break
- }
- }
- n := len(db.txs)
-
- // Unlock the meta pages.
- db.metalock.Unlock()
-
- // Merge statistics.
- db.statlock.Lock()
- db.stats.OpenTxN = n
- db.stats.TxStats.add(&tx.stats)
- db.statlock.Unlock()
-}
-
-// Update executes a function within the context of a read-write managed transaction.
-// If no error is returned from the function then the transaction is committed.
-// If an error is returned then the entire transaction is rolled back.
-// Any error that is returned from the function or returned from the commit is
-// returned from the Update() method.
-//
-// Attempting to manually commit or rollback within the function will cause a panic.
-func (db *DB) Update(fn func(*Tx) error) error {
- t, err := db.Begin(true)
- if err != nil {
- return err
- }
-
- // Make sure the transaction rolls back in the event of a panic.
- defer func() {
- if t.db != nil {
- t.rollback()
- }
- }()
-
- // Mark as a managed tx so that the inner function cannot manually commit.
- t.managed = true
-
- // If an error is returned from the function then rollback and return error.
- err = fn(t)
- t.managed = false
- if err != nil {
- _ = t.Rollback()
- return err
- }
-
- return t.Commit()
-}
-
-// View executes a function within the context of a managed read-only transaction.
-// Any error that is returned from the function is returned from the View() method.
-//
-// Attempting to manually rollback within the function will cause a panic.
-func (db *DB) View(fn func(*Tx) error) error {
- t, err := db.Begin(false)
- if err != nil {
- return err
- }
-
- // Make sure the transaction rolls back in the event of a panic.
- defer func() {
- if t.db != nil {
- t.rollback()
- }
- }()
-
- // Mark as a managed tx so that the inner function cannot manually rollback.
- t.managed = true
-
- // If an error is returned from the function then pass it through.
- err = fn(t)
- t.managed = false
- if err != nil {
- _ = t.Rollback()
- return err
- }
-
- if err := t.Rollback(); err != nil {
- return err
- }
-
- return nil
-}
-
-// Batch calls fn as part of a batch. It behaves similar to Update,
-// except:
-//
-// 1. concurrent Batch calls can be combined into a single Bolt
-// transaction.
-//
-// 2. the function passed to Batch may be called multiple times,
-// regardless of whether it returns error or not.
-//
-// This means that Batch function side effects must be idempotent and
-// take permanent effect only after a successful return is seen in
-// caller.
-//
-// The maximum batch size and delay can be adjusted with DB.MaxBatchSize
-// and DB.MaxBatchDelay, respectively.
-//
-// Batch is only useful when there are multiple goroutines calling it.
-func (db *DB) Batch(fn func(*Tx) error) error {
- errCh := make(chan error, 1)
-
- db.batchMu.Lock()
- if (db.batch == nil) || (db.batch != nil && len(db.batch.calls) >= db.MaxBatchSize) {
- // There is no existing batch, or the existing batch is full; start a new one.
- db.batch = &batch{
- db: db,
- }
- db.batch.timer = time.AfterFunc(db.MaxBatchDelay, db.batch.trigger)
- }
- db.batch.calls = append(db.batch.calls, call{fn: fn, err: errCh})
- if len(db.batch.calls) >= db.MaxBatchSize {
- // wake up batch, it's ready to run
- go db.batch.trigger()
- }
- db.batchMu.Unlock()
-
- err := <-errCh
- if err == trySolo {
- err = db.Update(fn)
- }
- return err
-}
-
-type call struct {
- fn func(*Tx) error
- err chan<- error
-}
-
-type batch struct {
- db *DB
- timer *time.Timer
- start sync.Once
- calls []call
-}
-
-// trigger runs the batch if it hasn't already been run.
-func (b *batch) trigger() {
- b.start.Do(b.run)
-}
-
-// run performs the transactions in the batch and communicates results
-// back to DB.Batch.
-func (b *batch) run() {
- b.db.batchMu.Lock()
- b.timer.Stop()
- // Make sure no new work is added to this batch, but don't break
- // other batches.
- if b.db.batch == b {
- b.db.batch = nil
- }
- b.db.batchMu.Unlock()
-
-retry:
- for len(b.calls) > 0 {
- var failIdx = -1
- err := b.db.Update(func(tx *Tx) error {
- for i, c := range b.calls {
- if err := safelyCall(c.fn, tx); err != nil {
- failIdx = i
- return err
- }
- }
- return nil
- })
-
- if failIdx >= 0 {
- // take the failing transaction out of the batch. it's
- // safe to shorten b.calls here because db.batch no longer
- // points to us, and we hold the mutex anyway.
- c := b.calls[failIdx]
- b.calls[failIdx], b.calls = b.calls[len(b.calls)-1], b.calls[:len(b.calls)-1]
- // tell the submitter re-run it solo, continue with the rest of the batch
- c.err <- trySolo
- continue retry
- }
-
- // pass success, or bolt internal errors, to all callers
- for _, c := range b.calls {
- if c.err != nil {
- c.err <- err
- }
- }
- break retry
- }
-}
-
-// trySolo is a special sentinel error value used for signaling that a
-// transaction function should be re-run. It should never be seen by
-// callers.
-var trySolo = errors.New("batch function returned an error and should be re-run solo")
-
-type panicked struct {
- reason interface{}
-}
-
-func (p panicked) Error() string {
- if err, ok := p.reason.(error); ok {
- return err.Error()
- }
- return fmt.Sprintf("panic: %v", p.reason)
-}
-
-func safelyCall(fn func(*Tx) error, tx *Tx) (err error) {
- defer func() {
- if p := recover(); p != nil {
- err = panicked{p}
- }
- }()
- return fn(tx)
-}
-
-// Sync executes fdatasync() against the database file handle.
-//
-// This is not necessary under normal operation, however, if you use NoSync
-// then it allows you to force the database file to sync against the disk.
-func (db *DB) Sync() error { return fdatasync(db) }
-
-// Stats retrieves ongoing performance stats for the database.
-// This is only updated when a transaction closes.
-func (db *DB) Stats() Stats {
- db.statlock.RLock()
- defer db.statlock.RUnlock()
- return db.stats
-}
-
-// This is for internal access to the raw data bytes from the C cursor, use
-// carefully, or not at all.
-func (db *DB) Info() *Info {
- return &Info{uintptr(unsafe.Pointer(&db.data[0])), db.pageSize}
-}
-
-// page retrieves a page reference from the mmap based on the current page size.
-func (db *DB) page(id pgid) *page {
- pos := id * pgid(db.pageSize)
- return (*page)(unsafe.Pointer(&db.data[pos]))
-}
-
-// pageInBuffer retrieves a page reference from a given byte array based on the current page size.
-func (db *DB) pageInBuffer(b []byte, id pgid) *page {
- return (*page)(unsafe.Pointer(&b[id*pgid(db.pageSize)]))
-}
-
-// meta retrieves the current meta page reference.
-func (db *DB) meta() *meta {
- // We have to return the meta with the highest txid which doesn't fail
- // validation. Otherwise, we can cause errors when in fact the database is
- // in a consistent state. metaA is the one with the higher txid.
- metaA := db.meta0
- metaB := db.meta1
- if db.meta1.txid > db.meta0.txid {
- metaA = db.meta1
- metaB = db.meta0
- }
-
- // Use higher meta page if valid. Otherwise fallback to previous, if valid.
- if err := metaA.validate(); err == nil {
- return metaA
- } else if err := metaB.validate(); err == nil {
- return metaB
- }
-
- // This should never be reached, because both meta1 and meta0 were validated
- // on mmap() and we do fsync() on every write.
- panic("bolt.DB.meta(): invalid meta pages")
-}
-
-// allocate returns a contiguous block of memory starting at a given page.
-func (db *DB) allocate(count int) (*page, error) {
- // Allocate a temporary buffer for the page.
- var buf []byte
- if count == 1 {
- buf = db.pagePool.Get().([]byte)
- } else {
- buf = make([]byte, count*db.pageSize)
- }
- p := (*page)(unsafe.Pointer(&buf[0]))
- p.overflow = uint32(count - 1)
-
- // Use pages from the freelist if they are available.
- if p.id = db.freelist.allocate(count); p.id != 0 {
- return p, nil
- }
-
- // Resize mmap() if we're at the end.
- p.id = db.rwtx.meta.pgid
- var minsz = int((p.id+pgid(count))+1) * db.pageSize
- if minsz >= db.datasz {
- if err := db.mmap(minsz); err != nil {
- return nil, fmt.Errorf("mmap allocate error: %s", err)
- }
- }
-
- // Move the page id high water mark.
- db.rwtx.meta.pgid += pgid(count)
-
- return p, nil
-}
-
-// grow grows the size of the database to the given sz.
-func (db *DB) grow(sz int) error {
- // Ignore if the new size is less than available file size.
- if sz <= db.filesz {
- return nil
- }
-
- // If the data is smaller than the alloc size then only allocate what's needed.
- // Once it goes over the allocation size then allocate in chunks.
- if db.datasz < db.AllocSize {
- sz = db.datasz
- } else {
- sz += db.AllocSize
- }
-
- // Truncate and fsync to ensure file size metadata is flushed.
- // https://github.com/boltdb/bolt/issues/284
- if !db.NoGrowSync && !db.readOnly {
- if runtime.GOOS != "windows" {
- if err := db.file.Truncate(int64(sz)); err != nil {
- return fmt.Errorf("file resize error: %s", err)
- }
- }
- if err := db.file.Sync(); err != nil {
- return fmt.Errorf("file sync error: %s", err)
- }
- }
-
- db.filesz = sz
- return nil
-}
-
-func (db *DB) IsReadOnly() bool {
- return db.readOnly
-}
-
-// Options represents the options that can be set when opening a database.
-type Options struct {
- // Timeout is the amount of time to wait to obtain a file lock.
- // When set to zero it will wait indefinitely. This option is only
- // available on Darwin and Linux.
- Timeout time.Duration
-
- // Sets the DB.NoGrowSync flag before memory mapping the file.
- NoGrowSync bool
-
- // Open database in read-only mode. Uses flock(..., LOCK_SH |LOCK_NB) to
- // grab a shared lock (UNIX).
- ReadOnly bool
-
- // Sets the DB.MmapFlags flag before memory mapping the file.
- MmapFlags int
-
- // InitialMmapSize is the initial mmap size of the database
- // in bytes. Read transactions won't block write transaction
- // if the InitialMmapSize is large enough to hold database mmap
- // size. (See DB.Begin for more information)
- //
- // If <=0, the initial map size is 0.
- // If initialMmapSize is smaller than the previous database size,
- // it takes no effect.
- InitialMmapSize int
-}
-
-// DefaultOptions represent the options used if nil options are passed into Open().
-// No timeout is used which will cause Bolt to wait indefinitely for a lock.
-var DefaultOptions = &Options{
- Timeout: 0,
- NoGrowSync: false,
-}
-
-// Stats represents statistics about the database.
-type Stats struct {
- // Freelist stats
- FreePageN int // total number of free pages on the freelist
- PendingPageN int // total number of pending pages on the freelist
- FreeAlloc int // total bytes allocated in free pages
- FreelistInuse int // total bytes used by the freelist
-
- // Transaction stats
- TxN int // total number of started read transactions
- OpenTxN int // number of currently open read transactions
-
- TxStats TxStats // global, ongoing stats.
-}
-
-// Sub calculates and returns the difference between two sets of database stats.
-// This is useful when obtaining stats at two different points and time and
-// you need the performance counters that occurred within that time span.
-func (s *Stats) Sub(other *Stats) Stats {
- if other == nil {
- return *s
- }
- var diff Stats
- diff.FreePageN = s.FreePageN
- diff.PendingPageN = s.PendingPageN
- diff.FreeAlloc = s.FreeAlloc
- diff.FreelistInuse = s.FreelistInuse
- diff.TxN = s.TxN - other.TxN
- diff.TxStats = s.TxStats.Sub(&other.TxStats)
- return diff
-}
-
-func (s *Stats) add(other *Stats) {
- s.TxStats.add(&other.TxStats)
-}
-
-type Info struct {
- Data uintptr
- PageSize int
-}
-
-type meta struct {
- magic uint32
- version uint32
- pageSize uint32
- flags uint32
- root bucket
- freelist pgid
- pgid pgid
- txid txid
- checksum uint64
-}
-
-// validate checks the marker bytes and version of the meta page to ensure it matches this binary.
-func (m *meta) validate() error {
- if m.magic != magic {
- return ErrInvalid
- } else if m.version != version {
- return ErrVersionMismatch
- } else if m.checksum != 0 && m.checksum != m.sum64() {
- return ErrChecksum
- }
- return nil
-}
-
-// copy copies one meta object to another.
-func (m *meta) copy(dest *meta) {
- *dest = *m
-}
-
-// write writes the meta onto a page.
-func (m *meta) write(p *page) {
- if m.root.root >= m.pgid {
- panic(fmt.Sprintf("root bucket pgid (%d) above high water mark (%d)", m.root.root, m.pgid))
- } else if m.freelist >= m.pgid {
- panic(fmt.Sprintf("freelist pgid (%d) above high water mark (%d)", m.freelist, m.pgid))
- }
-
- // Page id is either going to be 0 or 1 which we can determine by the transaction ID.
- p.id = pgid(m.txid % 2)
- p.flags |= metaPageFlag
-
- // Calculate the checksum.
- m.checksum = m.sum64()
-
- m.copy(p.meta())
-}
-
-// generates the checksum for the meta.
-func (m *meta) sum64() uint64 {
- var h = fnv.New64a()
- _, _ = h.Write((*[unsafe.Offsetof(meta{}.checksum)]byte)(unsafe.Pointer(m))[:])
- return h.Sum64()
-}
-
-// _assert will panic with a given formatted message if the given condition is false.
-func _assert(condition bool, msg string, v ...interface{}) {
- if !condition {
- panic(fmt.Sprintf("assertion failed: "+msg, v...))
- }
-}
-
-func warn(v ...interface{}) { fmt.Fprintln(os.Stderr, v...) }
-func warnf(msg string, v ...interface{}) { fmt.Fprintf(os.Stderr, msg+"\n", v...) }
-
-func printstack() {
- stack := strings.Join(strings.Split(string(debug.Stack()), "\n")[2:], "\n")
- fmt.Fprintln(os.Stderr, stack)
-}
diff --git a/vendor/github.com/boltdb/bolt/doc.go b/vendor/github.com/boltdb/bolt/doc.go
deleted file mode 100644
index cc937845d..000000000
--- a/vendor/github.com/boltdb/bolt/doc.go
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
-Package bolt implements a low-level key/value store in pure Go. It supports
-fully serializable transactions, ACID semantics, and lock-free MVCC with
-multiple readers and a single writer. Bolt can be used for projects that
-want a simple data store without the need to add large dependencies such as
-Postgres or MySQL.
-
-Bolt is a single-level, zero-copy, B+tree data store. This means that Bolt is
-optimized for fast read access and does not require recovery in the event of a
-system crash. Transactions which have not finished committing will simply be
-rolled back in the event of a crash.
-
-The design of Bolt is based on Howard Chu's LMDB database project.
-
-Bolt currently works on Windows, Mac OS X, and Linux.
-
-
-Basics
-
-There are only a few types in Bolt: DB, Bucket, Tx, and Cursor. The DB is
-a collection of buckets and is represented by a single file on disk. A bucket is
-a collection of unique keys that are associated with values.
-
-Transactions provide either read-only or read-write access to the database.
-Read-only transactions can retrieve key/value pairs and can use Cursors to
-iterate over the dataset sequentially. Read-write transactions can create and
-delete buckets and can insert and remove keys. Only one read-write transaction
-is allowed at a time.
-
-
-Caveats
-
-The database uses a read-only, memory-mapped data file to ensure that
-applications cannot corrupt the database, however, this means that keys and
-values returned from Bolt cannot be changed. Writing to a read-only byte slice
-will cause Go to panic.
-
-Keys and values retrieved from the database are only valid for the life of
-the transaction. When used outside the transaction, these byte slices can
-point to different data or can point to invalid memory which will cause a panic.
-
-
-*/
-package bolt
diff --git a/vendor/github.com/boltdb/bolt/errors.go b/vendor/github.com/boltdb/bolt/errors.go
deleted file mode 100644
index a3620a3eb..000000000
--- a/vendor/github.com/boltdb/bolt/errors.go
+++ /dev/null
@@ -1,71 +0,0 @@
-package bolt
-
-import "errors"
-
-// These errors can be returned when opening or calling methods on a DB.
-var (
- // ErrDatabaseNotOpen is returned when a DB instance is accessed before it
- // is opened or after it is closed.
- ErrDatabaseNotOpen = errors.New("database not open")
-
- // ErrDatabaseOpen is returned when opening a database that is
- // already open.
- ErrDatabaseOpen = errors.New("database already open")
-
- // ErrInvalid is returned when both meta pages on a database are invalid.
- // This typically occurs when a file is not a bolt database.
- ErrInvalid = errors.New("invalid database")
-
- // ErrVersionMismatch is returned when the data file was created with a
- // different version of Bolt.
- ErrVersionMismatch = errors.New("version mismatch")
-
- // ErrChecksum is returned when either meta page checksum does not match.
- ErrChecksum = errors.New("checksum error")
-
- // ErrTimeout is returned when a database cannot obtain an exclusive lock
- // on the data file after the timeout passed to Open().
- ErrTimeout = errors.New("timeout")
-)
-
-// These errors can occur when beginning or committing a Tx.
-var (
- // ErrTxNotWritable is returned when performing a write operation on a
- // read-only transaction.
- ErrTxNotWritable = errors.New("tx not writable")
-
- // ErrTxClosed is returned when committing or rolling back a transaction
- // that has already been committed or rolled back.
- ErrTxClosed = errors.New("tx closed")
-
- // ErrDatabaseReadOnly is returned when a mutating transaction is started on a
- // read-only database.
- ErrDatabaseReadOnly = errors.New("database is in read-only mode")
-)
-
-// These errors can occur when putting or deleting a value or a bucket.
-var (
- // ErrBucketNotFound is returned when trying to access a bucket that has
- // not been created yet.
- ErrBucketNotFound = errors.New("bucket not found")
-
- // ErrBucketExists is returned when creating a bucket that already exists.
- ErrBucketExists = errors.New("bucket already exists")
-
- // ErrBucketNameRequired is returned when creating a bucket with a blank name.
- ErrBucketNameRequired = errors.New("bucket name required")
-
- // ErrKeyRequired is returned when inserting a zero-length key.
- ErrKeyRequired = errors.New("key required")
-
- // ErrKeyTooLarge is returned when inserting a key that is larger than MaxKeySize.
- ErrKeyTooLarge = errors.New("key too large")
-
- // ErrValueTooLarge is returned when inserting a value that is larger than MaxValueSize.
- ErrValueTooLarge = errors.New("value too large")
-
- // ErrIncompatibleValue is returned when trying create or delete a bucket
- // on an existing non-bucket key or when trying to create or delete a
- // non-bucket key on an existing bucket key.
- ErrIncompatibleValue = errors.New("incompatible value")
-)
diff --git a/vendor/github.com/boltdb/bolt/freelist.go b/vendor/github.com/boltdb/bolt/freelist.go
deleted file mode 100644
index aba48f58c..000000000
--- a/vendor/github.com/boltdb/bolt/freelist.go
+++ /dev/null
@@ -1,252 +0,0 @@
-package bolt
-
-import (
- "fmt"
- "sort"
- "unsafe"
-)
-
-// freelist represents a list of all pages that are available for allocation.
-// It also tracks pages that have been freed but are still in use by open transactions.
-type freelist struct {
- ids []pgid // all free and available free page ids.
- pending map[txid][]pgid // mapping of soon-to-be free page ids by tx.
- cache map[pgid]bool // fast lookup of all free and pending page ids.
-}
-
-// newFreelist returns an empty, initialized freelist.
-func newFreelist() *freelist {
- return &freelist{
- pending: make(map[txid][]pgid),
- cache: make(map[pgid]bool),
- }
-}
-
-// size returns the size of the page after serialization.
-func (f *freelist) size() int {
- n := f.count()
- if n >= 0xFFFF {
- // The first element will be used to store the count. See freelist.write.
- n++
- }
- return pageHeaderSize + (int(unsafe.Sizeof(pgid(0))) * n)
-}
-
-// count returns count of pages on the freelist
-func (f *freelist) count() int {
- return f.free_count() + f.pending_count()
-}
-
-// free_count returns count of free pages
-func (f *freelist) free_count() int {
- return len(f.ids)
-}
-
-// pending_count returns count of pending pages
-func (f *freelist) pending_count() int {
- var count int
- for _, list := range f.pending {
- count += len(list)
- }
- return count
-}
-
-// copyall copies into dst a list of all free ids and all pending ids in one sorted list.
-// f.count returns the minimum length required for dst.
-func (f *freelist) copyall(dst []pgid) {
- m := make(pgids, 0, f.pending_count())
- for _, list := range f.pending {
- m = append(m, list...)
- }
- sort.Sort(m)
- mergepgids(dst, f.ids, m)
-}
-
-// allocate returns the starting page id of a contiguous list of pages of a given size.
-// If a contiguous block cannot be found then 0 is returned.
-func (f *freelist) allocate(n int) pgid {
- if len(f.ids) == 0 {
- return 0
- }
-
- var initial, previd pgid
- for i, id := range f.ids {
- if id <= 1 {
- panic(fmt.Sprintf("invalid page allocation: %d", id))
- }
-
- // Reset initial page if this is not contiguous.
- if previd == 0 || id-previd != 1 {
- initial = id
- }
-
- // If we found a contiguous block then remove it and return it.
- if (id-initial)+1 == pgid(n) {
- // If we're allocating off the beginning then take the fast path
- // and just adjust the existing slice. This will use extra memory
- // temporarily but the append() in free() will realloc the slice
- // as is necessary.
- if (i + 1) == n {
- f.ids = f.ids[i+1:]
- } else {
- copy(f.ids[i-n+1:], f.ids[i+1:])
- f.ids = f.ids[:len(f.ids)-n]
- }
-
- // Remove from the free cache.
- for i := pgid(0); i < pgid(n); i++ {
- delete(f.cache, initial+i)
- }
-
- return initial
- }
-
- previd = id
- }
- return 0
-}
-
-// free releases a page and its overflow for a given transaction id.
-// If the page is already free then a panic will occur.
-func (f *freelist) free(txid txid, p *page) {
- if p.id <= 1 {
- panic(fmt.Sprintf("cannot free page 0 or 1: %d", p.id))
- }
-
- // Free page and all its overflow pages.
- var ids = f.pending[txid]
- for id := p.id; id <= p.id+pgid(p.overflow); id++ {
- // Verify that page is not already free.
- if f.cache[id] {
- panic(fmt.Sprintf("page %d already freed", id))
- }
-
- // Add to the freelist and cache.
- ids = append(ids, id)
- f.cache[id] = true
- }
- f.pending[txid] = ids
-}
-
-// release moves all page ids for a transaction id (or older) to the freelist.
-func (f *freelist) release(txid txid) {
- m := make(pgids, 0)
- for tid, ids := range f.pending {
- if tid <= txid {
- // Move transaction's pending pages to the available freelist.
- // Don't remove from the cache since the page is still free.
- m = append(m, ids...)
- delete(f.pending, tid)
- }
- }
- sort.Sort(m)
- f.ids = pgids(f.ids).merge(m)
-}
-
-// rollback removes the pages from a given pending tx.
-func (f *freelist) rollback(txid txid) {
- // Remove page ids from cache.
- for _, id := range f.pending[txid] {
- delete(f.cache, id)
- }
-
- // Remove pages from pending list.
- delete(f.pending, txid)
-}
-
-// freed returns whether a given page is in the free list.
-func (f *freelist) freed(pgid pgid) bool {
- return f.cache[pgid]
-}
-
-// read initializes the freelist from a freelist page.
-func (f *freelist) read(p *page) {
- // If the page.count is at the max uint16 value (64k) then it's considered
- // an overflow and the size of the freelist is stored as the first element.
- idx, count := 0, int(p.count)
- if count == 0xFFFF {
- idx = 1
- count = int(((*[maxAllocSize]pgid)(unsafe.Pointer(&p.ptr)))[0])
- }
-
- // Copy the list of page ids from the freelist.
- if count == 0 {
- f.ids = nil
- } else {
- ids := ((*[maxAllocSize]pgid)(unsafe.Pointer(&p.ptr)))[idx:count]
- f.ids = make([]pgid, len(ids))
- copy(f.ids, ids)
-
- // Make sure they're sorted.
- sort.Sort(pgids(f.ids))
- }
-
- // Rebuild the page cache.
- f.reindex()
-}
-
-// write writes the page ids onto a freelist page. All free and pending ids are
-// saved to disk since in the event of a program crash, all pending ids will
-// become free.
-func (f *freelist) write(p *page) error {
- // Combine the old free pgids and pgids waiting on an open transaction.
-
- // Update the header flag.
- p.flags |= freelistPageFlag
-
- // The page.count can only hold up to 64k elements so if we overflow that
- // number then we handle it by putting the size in the first element.
- lenids := f.count()
- if lenids == 0 {
- p.count = uint16(lenids)
- } else if lenids < 0xFFFF {
- p.count = uint16(lenids)
- f.copyall(((*[maxAllocSize]pgid)(unsafe.Pointer(&p.ptr)))[:])
- } else {
- p.count = 0xFFFF
- ((*[maxAllocSize]pgid)(unsafe.Pointer(&p.ptr)))[0] = pgid(lenids)
- f.copyall(((*[maxAllocSize]pgid)(unsafe.Pointer(&p.ptr)))[1:])
- }
-
- return nil
-}
-
-// reload reads the freelist from a page and filters out pending items.
-func (f *freelist) reload(p *page) {
- f.read(p)
-
- // Build a cache of only pending pages.
- pcache := make(map[pgid]bool)
- for _, pendingIDs := range f.pending {
- for _, pendingID := range pendingIDs {
- pcache[pendingID] = true
- }
- }
-
- // Check each page in the freelist and build a new available freelist
- // with any pages not in the pending lists.
- var a []pgid
- for _, id := range f.ids {
- if !pcache[id] {
- a = append(a, id)
- }
- }
- f.ids = a
-
- // Once the available list is rebuilt then rebuild the free cache so that
- // it includes the available and pending free pages.
- f.reindex()
-}
-
-// reindex rebuilds the free cache based on available and pending free lists.
-func (f *freelist) reindex() {
- f.cache = make(map[pgid]bool, len(f.ids))
- for _, id := range f.ids {
- f.cache[id] = true
- }
- for _, pendingIDs := range f.pending {
- for _, pendingID := range pendingIDs {
- f.cache[pendingID] = true
- }
- }
-}
diff --git a/vendor/github.com/boltdb/bolt/node.go b/vendor/github.com/boltdb/bolt/node.go
deleted file mode 100644
index 159318b22..000000000
--- a/vendor/github.com/boltdb/bolt/node.go
+++ /dev/null
@@ -1,604 +0,0 @@
-package bolt
-
-import (
- "bytes"
- "fmt"
- "sort"
- "unsafe"
-)
-
-// node represents an in-memory, deserialized page.
-type node struct {
- bucket *Bucket
- isLeaf bool
- unbalanced bool
- spilled bool
- key []byte
- pgid pgid
- parent *node
- children nodes
- inodes inodes
-}
-
-// root returns the top-level node this node is attached to.
-func (n *node) root() *node {
- if n.parent == nil {
- return n
- }
- return n.parent.root()
-}
-
-// minKeys returns the minimum number of inodes this node should have.
-func (n *node) minKeys() int {
- if n.isLeaf {
- return 1
- }
- return 2
-}
-
-// size returns the size of the node after serialization.
-func (n *node) size() int {
- sz, elsz := pageHeaderSize, n.pageElementSize()
- for i := 0; i < len(n.inodes); i++ {
- item := &n.inodes[i]
- sz += elsz + len(item.key) + len(item.value)
- }
- return sz
-}
-
-// sizeLessThan returns true if the node is less than a given size.
-// This is an optimization to avoid calculating a large node when we only need
-// to know if it fits inside a certain page size.
-func (n *node) sizeLessThan(v int) bool {
- sz, elsz := pageHeaderSize, n.pageElementSize()
- for i := 0; i < len(n.inodes); i++ {
- item := &n.inodes[i]
- sz += elsz + len(item.key) + len(item.value)
- if sz >= v {
- return false
- }
- }
- return true
-}
-
-// pageElementSize returns the size of each page element based on the type of node.
-func (n *node) pageElementSize() int {
- if n.isLeaf {
- return leafPageElementSize
- }
- return branchPageElementSize
-}
-
-// childAt returns the child node at a given index.
-func (n *node) childAt(index int) *node {
- if n.isLeaf {
- panic(fmt.Sprintf("invalid childAt(%d) on a leaf node", index))
- }
- return n.bucket.node(n.inodes[index].pgid, n)
-}
-
-// childIndex returns the index of a given child node.
-func (n *node) childIndex(child *node) int {
- index := sort.Search(len(n.inodes), func(i int) bool { return bytes.Compare(n.inodes[i].key, child.key) != -1 })
- return index
-}
-
-// numChildren returns the number of children.
-func (n *node) numChildren() int {
- return len(n.inodes)
-}
-
-// nextSibling returns the next node with the same parent.
-func (n *node) nextSibling() *node {
- if n.parent == nil {
- return nil
- }
- index := n.parent.childIndex(n)
- if index >= n.parent.numChildren()-1 {
- return nil
- }
- return n.parent.childAt(index + 1)
-}
-
-// prevSibling returns the previous node with the same parent.
-func (n *node) prevSibling() *node {
- if n.parent == nil {
- return nil
- }
- index := n.parent.childIndex(n)
- if index == 0 {
- return nil
- }
- return n.parent.childAt(index - 1)
-}
-
-// put inserts a key/value.
-func (n *node) put(oldKey, newKey, value []byte, pgid pgid, flags uint32) {
- if pgid >= n.bucket.tx.meta.pgid {
- panic(fmt.Sprintf("pgid (%d) above high water mark (%d)", pgid, n.bucket.tx.meta.pgid))
- } else if len(oldKey) <= 0 {
- panic("put: zero-length old key")
- } else if len(newKey) <= 0 {
- panic("put: zero-length new key")
- }
-
- // Find insertion index.
- index := sort.Search(len(n.inodes), func(i int) bool { return bytes.Compare(n.inodes[i].key, oldKey) != -1 })
-
- // Add capacity and shift nodes if we don't have an exact match and need to insert.
- exact := (len(n.inodes) > 0 && index < len(n.inodes) && bytes.Equal(n.inodes[index].key, oldKey))
- if !exact {
- n.inodes = append(n.inodes, inode{})
- copy(n.inodes[index+1:], n.inodes[index:])
- }
-
- inode := &n.inodes[index]
- inode.flags = flags
- inode.key = newKey
- inode.value = value
- inode.pgid = pgid
- _assert(len(inode.key) > 0, "put: zero-length inode key")
-}
-
-// del removes a key from the node.
-func (n *node) del(key []byte) {
- // Find index of key.
- index := sort.Search(len(n.inodes), func(i int) bool { return bytes.Compare(n.inodes[i].key, key) != -1 })
-
- // Exit if the key isn't found.
- if index >= len(n.inodes) || !bytes.Equal(n.inodes[index].key, key) {
- return
- }
-
- // Delete inode from the node.
- n.inodes = append(n.inodes[:index], n.inodes[index+1:]...)
-
- // Mark the node as needing rebalancing.
- n.unbalanced = true
-}
-
-// read initializes the node from a page.
-func (n *node) read(p *page) {
- n.pgid = p.id
- n.isLeaf = ((p.flags & leafPageFlag) != 0)
- n.inodes = make(inodes, int(p.count))
-
- for i := 0; i < int(p.count); i++ {
- inode := &n.inodes[i]
- if n.isLeaf {
- elem := p.leafPageElement(uint16(i))
- inode.flags = elem.flags
- inode.key = elem.key()
- inode.value = elem.value()
- } else {
- elem := p.branchPageElement(uint16(i))
- inode.pgid = elem.pgid
- inode.key = elem.key()
- }
- _assert(len(inode.key) > 0, "read: zero-length inode key")
- }
-
- // Save first key so we can find the node in the parent when we spill.
- if len(n.inodes) > 0 {
- n.key = n.inodes[0].key
- _assert(len(n.key) > 0, "read: zero-length node key")
- } else {
- n.key = nil
- }
-}
-
-// write writes the items onto one or more pages.
-func (n *node) write(p *page) {
- // Initialize page.
- if n.isLeaf {
- p.flags |= leafPageFlag
- } else {
- p.flags |= branchPageFlag
- }
-
- if len(n.inodes) >= 0xFFFF {
- panic(fmt.Sprintf("inode overflow: %d (pgid=%d)", len(n.inodes), p.id))
- }
- p.count = uint16(len(n.inodes))
-
- // Stop here if there are no items to write.
- if p.count == 0 {
- return
- }
-
- // Loop over each item and write it to the page.
- b := (*[maxAllocSize]byte)(unsafe.Pointer(&p.ptr))[n.pageElementSize()*len(n.inodes):]
- for i, item := range n.inodes {
- _assert(len(item.key) > 0, "write: zero-length inode key")
-
- // Write the page element.
- if n.isLeaf {
- elem := p.leafPageElement(uint16(i))
- elem.pos = uint32(uintptr(unsafe.Pointer(&b[0])) - uintptr(unsafe.Pointer(elem)))
- elem.flags = item.flags
- elem.ksize = uint32(len(item.key))
- elem.vsize = uint32(len(item.value))
- } else {
- elem := p.branchPageElement(uint16(i))
- elem.pos = uint32(uintptr(unsafe.Pointer(&b[0])) - uintptr(unsafe.Pointer(elem)))
- elem.ksize = uint32(len(item.key))
- elem.pgid = item.pgid
- _assert(elem.pgid != p.id, "write: circular dependency occurred")
- }
-
- // If the length of key+value is larger than the max allocation size
- // then we need to reallocate the byte array pointer.
- //
- // See: https://github.com/boltdb/bolt/pull/335
- klen, vlen := len(item.key), len(item.value)
- if len(b) < klen+vlen {
- b = (*[maxAllocSize]byte)(unsafe.Pointer(&b[0]))[:]
- }
-
- // Write data for the element to the end of the page.
- copy(b[0:], item.key)
- b = b[klen:]
- copy(b[0:], item.value)
- b = b[vlen:]
- }
-
- // DEBUG ONLY: n.dump()
-}
-
-// split breaks up a node into multiple smaller nodes, if appropriate.
-// This should only be called from the spill() function.
-func (n *node) split(pageSize int) []*node {
- var nodes []*node
-
- node := n
- for {
- // Split node into two.
- a, b := node.splitTwo(pageSize)
- nodes = append(nodes, a)
-
- // If we can't split then exit the loop.
- if b == nil {
- break
- }
-
- // Set node to b so it gets split on the next iteration.
- node = b
- }
-
- return nodes
-}
-
-// splitTwo breaks up a node into two smaller nodes, if appropriate.
-// This should only be called from the split() function.
-func (n *node) splitTwo(pageSize int) (*node, *node) {
- // Ignore the split if the page doesn't have at least enough nodes for
- // two pages or if the nodes can fit in a single page.
- if len(n.inodes) <= (minKeysPerPage*2) || n.sizeLessThan(pageSize) {
- return n, nil
- }
-
- // Determine the threshold before starting a new node.
- var fillPercent = n.bucket.FillPercent
- if fillPercent < minFillPercent {
- fillPercent = minFillPercent
- } else if fillPercent > maxFillPercent {
- fillPercent = maxFillPercent
- }
- threshold := int(float64(pageSize) * fillPercent)
-
- // Determine split position and sizes of the two pages.
- splitIndex, _ := n.splitIndex(threshold)
-
- // Split node into two separate nodes.
- // If there's no parent then we'll need to create one.
- if n.parent == nil {
- n.parent = &node{bucket: n.bucket, children: []*node{n}}
- }
-
- // Create a new node and add it to the parent.
- next := &node{bucket: n.bucket, isLeaf: n.isLeaf, parent: n.parent}
- n.parent.children = append(n.parent.children, next)
-
- // Split inodes across two nodes.
- next.inodes = n.inodes[splitIndex:]
- n.inodes = n.inodes[:splitIndex]
-
- // Update the statistics.
- n.bucket.tx.stats.Split++
-
- return n, next
-}
-
-// splitIndex finds the position where a page will fill a given threshold.
-// It returns the index as well as the size of the first page.
-// This is only be called from split().
-func (n *node) splitIndex(threshold int) (index, sz int) {
- sz = pageHeaderSize
-
- // Loop until we only have the minimum number of keys required for the second page.
- for i := 0; i < len(n.inodes)-minKeysPerPage; i++ {
- index = i
- inode := n.inodes[i]
- elsize := n.pageElementSize() + len(inode.key) + len(inode.value)
-
- // If we have at least the minimum number of keys and adding another
- // node would put us over the threshold then exit and return.
- if i >= minKeysPerPage && sz+elsize > threshold {
- break
- }
-
- // Add the element size to the total size.
- sz += elsize
- }
-
- return
-}
-
-// spill writes the nodes to dirty pages and splits nodes as it goes.
-// Returns an error if dirty pages cannot be allocated.
-func (n *node) spill() error {
- var tx = n.bucket.tx
- if n.spilled {
- return nil
- }
-
- // Spill child nodes first. Child nodes can materialize sibling nodes in
- // the case of split-merge so we cannot use a range loop. We have to check
- // the children size on every loop iteration.
- sort.Sort(n.children)
- for i := 0; i < len(n.children); i++ {
- if err := n.children[i].spill(); err != nil {
- return err
- }
- }
-
- // We no longer need the child list because it's only used for spill tracking.
- n.children = nil
-
- // Split nodes into appropriate sizes. The first node will always be n.
- var nodes = n.split(tx.db.pageSize)
- for _, node := range nodes {
- // Add node's page to the freelist if it's not new.
- if node.pgid > 0 {
- tx.db.freelist.free(tx.meta.txid, tx.page(node.pgid))
- node.pgid = 0
- }
-
- // Allocate contiguous space for the node.
- p, err := tx.allocate((node.size() / tx.db.pageSize) + 1)
- if err != nil {
- return err
- }
-
- // Write the node.
- if p.id >= tx.meta.pgid {
- panic(fmt.Sprintf("pgid (%d) above high water mark (%d)", p.id, tx.meta.pgid))
- }
- node.pgid = p.id
- node.write(p)
- node.spilled = true
-
- // Insert into parent inodes.
- if node.parent != nil {
- var key = node.key
- if key == nil {
- key = node.inodes[0].key
- }
-
- node.parent.put(key, node.inodes[0].key, nil, node.pgid, 0)
- node.key = node.inodes[0].key
- _assert(len(node.key) > 0, "spill: zero-length node key")
- }
-
- // Update the statistics.
- tx.stats.Spill++
- }
-
- // If the root node split and created a new root then we need to spill that
- // as well. We'll clear out the children to make sure it doesn't try to respill.
- if n.parent != nil && n.parent.pgid == 0 {
- n.children = nil
- return n.parent.spill()
- }
-
- return nil
-}
-
-// rebalance attempts to combine the node with sibling nodes if the node fill
-// size is below a threshold or if there are not enough keys.
-func (n *node) rebalance() {
- if !n.unbalanced {
- return
- }
- n.unbalanced = false
-
- // Update statistics.
- n.bucket.tx.stats.Rebalance++
-
- // Ignore if node is above threshold (25%) and has enough keys.
- var threshold = n.bucket.tx.db.pageSize / 4
- if n.size() > threshold && len(n.inodes) > n.minKeys() {
- return
- }
-
- // Root node has special handling.
- if n.parent == nil {
- // If root node is a branch and only has one node then collapse it.
- if !n.isLeaf && len(n.inodes) == 1 {
- // Move root's child up.
- child := n.bucket.node(n.inodes[0].pgid, n)
- n.isLeaf = child.isLeaf
- n.inodes = child.inodes[:]
- n.children = child.children
-
- // Reparent all child nodes being moved.
- for _, inode := range n.inodes {
- if child, ok := n.bucket.nodes[inode.pgid]; ok {
- child.parent = n
- }
- }
-
- // Remove old child.
- child.parent = nil
- delete(n.bucket.nodes, child.pgid)
- child.free()
- }
-
- return
- }
-
- // If node has no keys then just remove it.
- if n.numChildren() == 0 {
- n.parent.del(n.key)
- n.parent.removeChild(n)
- delete(n.bucket.nodes, n.pgid)
- n.free()
- n.parent.rebalance()
- return
- }
-
- _assert(n.parent.numChildren() > 1, "parent must have at least 2 children")
-
- // Destination node is right sibling if idx == 0, otherwise left sibling.
- var target *node
- var useNextSibling = (n.parent.childIndex(n) == 0)
- if useNextSibling {
- target = n.nextSibling()
- } else {
- target = n.prevSibling()
- }
-
- // If both this node and the target node are too small then merge them.
- if useNextSibling {
- // Reparent all child nodes being moved.
- for _, inode := range target.inodes {
- if child, ok := n.bucket.nodes[inode.pgid]; ok {
- child.parent.removeChild(child)
- child.parent = n
- child.parent.children = append(child.parent.children, child)
- }
- }
-
- // Copy over inodes from target and remove target.
- n.inodes = append(n.inodes, target.inodes...)
- n.parent.del(target.key)
- n.parent.removeChild(target)
- delete(n.bucket.nodes, target.pgid)
- target.free()
- } else {
- // Reparent all child nodes being moved.
- for _, inode := range n.inodes {
- if child, ok := n.bucket.nodes[inode.pgid]; ok {
- child.parent.removeChild(child)
- child.parent = target
- child.parent.children = append(child.parent.children, child)
- }
- }
-
- // Copy over inodes to target and remove node.
- target.inodes = append(target.inodes, n.inodes...)
- n.parent.del(n.key)
- n.parent.removeChild(n)
- delete(n.bucket.nodes, n.pgid)
- n.free()
- }
-
- // Either this node or the target node was deleted from the parent so rebalance it.
- n.parent.rebalance()
-}
-
-// removes a node from the list of in-memory children.
-// This does not affect the inodes.
-func (n *node) removeChild(target *node) {
- for i, child := range n.children {
- if child == target {
- n.children = append(n.children[:i], n.children[i+1:]...)
- return
- }
- }
-}
-
-// dereference causes the node to copy all its inode key/value references to heap memory.
-// This is required when the mmap is reallocated so inodes are not pointing to stale data.
-func (n *node) dereference() {
- if n.key != nil {
- key := make([]byte, len(n.key))
- copy(key, n.key)
- n.key = key
- _assert(n.pgid == 0 || len(n.key) > 0, "dereference: zero-length node key on existing node")
- }
-
- for i := range n.inodes {
- inode := &n.inodes[i]
-
- key := make([]byte, len(inode.key))
- copy(key, inode.key)
- inode.key = key
- _assert(len(inode.key) > 0, "dereference: zero-length inode key")
-
- value := make([]byte, len(inode.value))
- copy(value, inode.value)
- inode.value = value
- }
-
- // Recursively dereference children.
- for _, child := range n.children {
- child.dereference()
- }
-
- // Update statistics.
- n.bucket.tx.stats.NodeDeref++
-}
-
-// free adds the node's underlying page to the freelist.
-func (n *node) free() {
- if n.pgid != 0 {
- n.bucket.tx.db.freelist.free(n.bucket.tx.meta.txid, n.bucket.tx.page(n.pgid))
- n.pgid = 0
- }
-}
-
-// dump writes the contents of the node to STDERR for debugging purposes.
-/*
-func (n *node) dump() {
- // Write node header.
- var typ = "branch"
- if n.isLeaf {
- typ = "leaf"
- }
- warnf("[NODE %d {type=%s count=%d}]", n.pgid, typ, len(n.inodes))
-
- // Write out abbreviated version of each item.
- for _, item := range n.inodes {
- if n.isLeaf {
- if item.flags&bucketLeafFlag != 0 {
- bucket := (*bucket)(unsafe.Pointer(&item.value[0]))
- warnf("+L %08x -> (bucket root=%d)", trunc(item.key, 4), bucket.root)
- } else {
- warnf("+L %08x -> %08x", trunc(item.key, 4), trunc(item.value, 4))
- }
- } else {
- warnf("+B %08x -> pgid=%d", trunc(item.key, 4), item.pgid)
- }
- }
- warn("")
-}
-*/
-
-type nodes []*node
-
-func (s nodes) Len() int { return len(s) }
-func (s nodes) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-func (s nodes) Less(i, j int) bool { return bytes.Compare(s[i].inodes[0].key, s[j].inodes[0].key) == -1 }
-
-// inode represents an internal node inside of a node.
-// It can be used to point to elements in a page or point
-// to an element which hasn't been added to a page yet.
-type inode struct {
- flags uint32
- pgid pgid
- key []byte
- value []byte
-}
-
-type inodes []inode
diff --git a/vendor/github.com/boltdb/bolt/page.go b/vendor/github.com/boltdb/bolt/page.go
deleted file mode 100644
index cde403ae8..000000000
--- a/vendor/github.com/boltdb/bolt/page.go
+++ /dev/null
@@ -1,197 +0,0 @@
-package bolt
-
-import (
- "fmt"
- "os"
- "sort"
- "unsafe"
-)
-
-const pageHeaderSize = int(unsafe.Offsetof(((*page)(nil)).ptr))
-
-const minKeysPerPage = 2
-
-const branchPageElementSize = int(unsafe.Sizeof(branchPageElement{}))
-const leafPageElementSize = int(unsafe.Sizeof(leafPageElement{}))
-
-const (
- branchPageFlag = 0x01
- leafPageFlag = 0x02
- metaPageFlag = 0x04
- freelistPageFlag = 0x10
-)
-
-const (
- bucketLeafFlag = 0x01
-)
-
-type pgid uint64
-
-type page struct {
- id pgid
- flags uint16
- count uint16
- overflow uint32
- ptr uintptr
-}
-
-// typ returns a human readable page type string used for debugging.
-func (p *page) typ() string {
- if (p.flags & branchPageFlag) != 0 {
- return "branch"
- } else if (p.flags & leafPageFlag) != 0 {
- return "leaf"
- } else if (p.flags & metaPageFlag) != 0 {
- return "meta"
- } else if (p.flags & freelistPageFlag) != 0 {
- return "freelist"
- }
- return fmt.Sprintf("unknown<%02x>", p.flags)
-}
-
-// meta returns a pointer to the metadata section of the page.
-func (p *page) meta() *meta {
- return (*meta)(unsafe.Pointer(&p.ptr))
-}
-
-// leafPageElement retrieves the leaf node by index
-func (p *page) leafPageElement(index uint16) *leafPageElement {
- n := &((*[0x7FFFFFF]leafPageElement)(unsafe.Pointer(&p.ptr)))[index]
- return n
-}
-
-// leafPageElements retrieves a list of leaf nodes.
-func (p *page) leafPageElements() []leafPageElement {
- if p.count == 0 {
- return nil
- }
- return ((*[0x7FFFFFF]leafPageElement)(unsafe.Pointer(&p.ptr)))[:]
-}
-
-// branchPageElement retrieves the branch node by index
-func (p *page) branchPageElement(index uint16) *branchPageElement {
- return &((*[0x7FFFFFF]branchPageElement)(unsafe.Pointer(&p.ptr)))[index]
-}
-
-// branchPageElements retrieves a list of branch nodes.
-func (p *page) branchPageElements() []branchPageElement {
- if p.count == 0 {
- return nil
- }
- return ((*[0x7FFFFFF]branchPageElement)(unsafe.Pointer(&p.ptr)))[:]
-}
-
-// dump writes n bytes of the page to STDERR as hex output.
-func (p *page) hexdump(n int) {
- buf := (*[maxAllocSize]byte)(unsafe.Pointer(p))[:n]
- fmt.Fprintf(os.Stderr, "%x\n", buf)
-}
-
-type pages []*page
-
-func (s pages) Len() int { return len(s) }
-func (s pages) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-func (s pages) Less(i, j int) bool { return s[i].id < s[j].id }
-
-// branchPageElement represents a node on a branch page.
-type branchPageElement struct {
- pos uint32
- ksize uint32
- pgid pgid
-}
-
-// key returns a byte slice of the node key.
-func (n *branchPageElement) key() []byte {
- buf := (*[maxAllocSize]byte)(unsafe.Pointer(n))
- return (*[maxAllocSize]byte)(unsafe.Pointer(&buf[n.pos]))[:n.ksize]
-}
-
-// leafPageElement represents a node on a leaf page.
-type leafPageElement struct {
- flags uint32
- pos uint32
- ksize uint32
- vsize uint32
-}
-
-// key returns a byte slice of the node key.
-func (n *leafPageElement) key() []byte {
- buf := (*[maxAllocSize]byte)(unsafe.Pointer(n))
- return (*[maxAllocSize]byte)(unsafe.Pointer(&buf[n.pos]))[:n.ksize:n.ksize]
-}
-
-// value returns a byte slice of the node value.
-func (n *leafPageElement) value() []byte {
- buf := (*[maxAllocSize]byte)(unsafe.Pointer(n))
- return (*[maxAllocSize]byte)(unsafe.Pointer(&buf[n.pos+n.ksize]))[:n.vsize:n.vsize]
-}
-
-// PageInfo represents human readable information about a page.
-type PageInfo struct {
- ID int
- Type string
- Count int
- OverflowCount int
-}
-
-type pgids []pgid
-
-func (s pgids) Len() int { return len(s) }
-func (s pgids) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-func (s pgids) Less(i, j int) bool { return s[i] < s[j] }
-
-// merge returns the sorted union of a and b.
-func (a pgids) merge(b pgids) pgids {
- // Return the opposite slice if one is nil.
- if len(a) == 0 {
- return b
- }
- if len(b) == 0 {
- return a
- }
- merged := make(pgids, len(a)+len(b))
- mergepgids(merged, a, b)
- return merged
-}
-
-// mergepgids copies the sorted union of a and b into dst.
-// If dst is too small, it panics.
-func mergepgids(dst, a, b pgids) {
- if len(dst) < len(a)+len(b) {
- panic(fmt.Errorf("mergepgids bad len %d < %d + %d", len(dst), len(a), len(b)))
- }
- // Copy in the opposite slice if one is nil.
- if len(a) == 0 {
- copy(dst, b)
- return
- }
- if len(b) == 0 {
- copy(dst, a)
- return
- }
-
- // Merged will hold all elements from both lists.
- merged := dst[:0]
-
- // Assign lead to the slice with a lower starting value, follow to the higher value.
- lead, follow := a, b
- if b[0] < a[0] {
- lead, follow = b, a
- }
-
- // Continue while there are elements in the lead.
- for len(lead) > 0 {
- // Merge largest prefix of lead that is ahead of follow[0].
- n := sort.Search(len(lead), func(i int) bool { return lead[i] > follow[0] })
- merged = append(merged, lead[:n]...)
- if n >= len(lead) {
- break
- }
-
- // Swap lead and follow.
- lead, follow = follow, lead[n:]
- }
-
- // Append what's left in follow.
- _ = append(merged, follow...)
-}
diff --git a/vendor/github.com/boltdb/bolt/tx.go b/vendor/github.com/boltdb/bolt/tx.go
deleted file mode 100644
index 6700308a2..000000000
--- a/vendor/github.com/boltdb/bolt/tx.go
+++ /dev/null
@@ -1,684 +0,0 @@
-package bolt
-
-import (
- "fmt"
- "io"
- "os"
- "sort"
- "strings"
- "time"
- "unsafe"
-)
-
-// txid represents the internal transaction identifier.
-type txid uint64
-
-// Tx represents a read-only or read/write transaction on the database.
-// Read-only transactions can be used for retrieving values for keys and creating cursors.
-// Read/write transactions can create and remove buckets and create and remove keys.
-//
-// IMPORTANT: You must commit or rollback transactions when you are done with
-// them. Pages can not be reclaimed by the writer until no more transactions
-// are using them. A long running read transaction can cause the database to
-// quickly grow.
-type Tx struct {
- writable bool
- managed bool
- db *DB
- meta *meta
- root Bucket
- pages map[pgid]*page
- stats TxStats
- commitHandlers []func()
-
- // WriteFlag specifies the flag for write-related methods like WriteTo().
- // Tx opens the database file with the specified flag to copy the data.
- //
- // By default, the flag is unset, which works well for mostly in-memory
- // workloads. For databases that are much larger than available RAM,
- // set the flag to syscall.O_DIRECT to avoid trashing the page cache.
- WriteFlag int
-}
-
-// init initializes the transaction.
-func (tx *Tx) init(db *DB) {
- tx.db = db
- tx.pages = nil
-
- // Copy the meta page since it can be changed by the writer.
- tx.meta = &meta{}
- db.meta().copy(tx.meta)
-
- // Copy over the root bucket.
- tx.root = newBucket(tx)
- tx.root.bucket = &bucket{}
- *tx.root.bucket = tx.meta.root
-
- // Increment the transaction id and add a page cache for writable transactions.
- if tx.writable {
- tx.pages = make(map[pgid]*page)
- tx.meta.txid += txid(1)
- }
-}
-
-// ID returns the transaction id.
-func (tx *Tx) ID() int {
- return int(tx.meta.txid)
-}
-
-// DB returns a reference to the database that created the transaction.
-func (tx *Tx) DB() *DB {
- return tx.db
-}
-
-// Size returns current database size in bytes as seen by this transaction.
-func (tx *Tx) Size() int64 {
- return int64(tx.meta.pgid) * int64(tx.db.pageSize)
-}
-
-// Writable returns whether the transaction can perform write operations.
-func (tx *Tx) Writable() bool {
- return tx.writable
-}
-
-// Cursor creates a cursor associated with the root bucket.
-// All items in the cursor will return a nil value because all root bucket keys point to buckets.
-// The cursor is only valid as long as the transaction is open.
-// Do not use a cursor after the transaction is closed.
-func (tx *Tx) Cursor() *Cursor {
- return tx.root.Cursor()
-}
-
-// Stats retrieves a copy of the current transaction statistics.
-func (tx *Tx) Stats() TxStats {
- return tx.stats
-}
-
-// Bucket retrieves a bucket by name.
-// Returns nil if the bucket does not exist.
-// The bucket instance is only valid for the lifetime of the transaction.
-func (tx *Tx) Bucket(name []byte) *Bucket {
- return tx.root.Bucket(name)
-}
-
-// CreateBucket creates a new bucket.
-// Returns an error if the bucket already exists, if the bucket name is blank, or if the bucket name is too long.
-// The bucket instance is only valid for the lifetime of the transaction.
-func (tx *Tx) CreateBucket(name []byte) (*Bucket, error) {
- return tx.root.CreateBucket(name)
-}
-
-// CreateBucketIfNotExists creates a new bucket if it doesn't already exist.
-// Returns an error if the bucket name is blank, or if the bucket name is too long.
-// The bucket instance is only valid for the lifetime of the transaction.
-func (tx *Tx) CreateBucketIfNotExists(name []byte) (*Bucket, error) {
- return tx.root.CreateBucketIfNotExists(name)
-}
-
-// DeleteBucket deletes a bucket.
-// Returns an error if the bucket cannot be found or if the key represents a non-bucket value.
-func (tx *Tx) DeleteBucket(name []byte) error {
- return tx.root.DeleteBucket(name)
-}
-
-// ForEach executes a function for each bucket in the root.
-// If the provided function returns an error then the iteration is stopped and
-// the error is returned to the caller.
-func (tx *Tx) ForEach(fn func(name []byte, b *Bucket) error) error {
- return tx.root.ForEach(func(k, v []byte) error {
- if err := fn(k, tx.root.Bucket(k)); err != nil {
- return err
- }
- return nil
- })
-}
-
-// OnCommit adds a handler function to be executed after the transaction successfully commits.
-func (tx *Tx) OnCommit(fn func()) {
- tx.commitHandlers = append(tx.commitHandlers, fn)
-}
-
-// Commit writes all changes to disk and updates the meta page.
-// Returns an error if a disk write error occurs, or if Commit is
-// called on a read-only transaction.
-func (tx *Tx) Commit() error {
- _assert(!tx.managed, "managed tx commit not allowed")
- if tx.db == nil {
- return ErrTxClosed
- } else if !tx.writable {
- return ErrTxNotWritable
- }
-
- // TODO(benbjohnson): Use vectorized I/O to write out dirty pages.
-
- // Rebalance nodes which have had deletions.
- var startTime = time.Now()
- tx.root.rebalance()
- if tx.stats.Rebalance > 0 {
- tx.stats.RebalanceTime += time.Since(startTime)
- }
-
- // spill data onto dirty pages.
- startTime = time.Now()
- if err := tx.root.spill(); err != nil {
- tx.rollback()
- return err
- }
- tx.stats.SpillTime += time.Since(startTime)
-
- // Free the old root bucket.
- tx.meta.root.root = tx.root.root
-
- opgid := tx.meta.pgid
-
- // Free the freelist and allocate new pages for it. This will overestimate
- // the size of the freelist but not underestimate the size (which would be bad).
- tx.db.freelist.free(tx.meta.txid, tx.db.page(tx.meta.freelist))
- p, err := tx.allocate((tx.db.freelist.size() / tx.db.pageSize) + 1)
- if err != nil {
- tx.rollback()
- return err
- }
- if err := tx.db.freelist.write(p); err != nil {
- tx.rollback()
- return err
- }
- tx.meta.freelist = p.id
-
- // If the high water mark has moved up then attempt to grow the database.
- if tx.meta.pgid > opgid {
- if err := tx.db.grow(int(tx.meta.pgid+1) * tx.db.pageSize); err != nil {
- tx.rollback()
- return err
- }
- }
-
- // Write dirty pages to disk.
- startTime = time.Now()
- if err := tx.write(); err != nil {
- tx.rollback()
- return err
- }
-
- // If strict mode is enabled then perform a consistency check.
- // Only the first consistency error is reported in the panic.
- if tx.db.StrictMode {
- ch := tx.Check()
- var errs []string
- for {
- err, ok := <-ch
- if !ok {
- break
- }
- errs = append(errs, err.Error())
- }
- if len(errs) > 0 {
- panic("check fail: " + strings.Join(errs, "\n"))
- }
- }
-
- // Write meta to disk.
- if err := tx.writeMeta(); err != nil {
- tx.rollback()
- return err
- }
- tx.stats.WriteTime += time.Since(startTime)
-
- // Finalize the transaction.
- tx.close()
-
- // Execute commit handlers now that the locks have been removed.
- for _, fn := range tx.commitHandlers {
- fn()
- }
-
- return nil
-}
-
-// Rollback closes the transaction and ignores all previous updates. Read-only
-// transactions must be rolled back and not committed.
-func (tx *Tx) Rollback() error {
- _assert(!tx.managed, "managed tx rollback not allowed")
- if tx.db == nil {
- return ErrTxClosed
- }
- tx.rollback()
- return nil
-}
-
-func (tx *Tx) rollback() {
- if tx.db == nil {
- return
- }
- if tx.writable {
- tx.db.freelist.rollback(tx.meta.txid)
- tx.db.freelist.reload(tx.db.page(tx.db.meta().freelist))
- }
- tx.close()
-}
-
-func (tx *Tx) close() {
- if tx.db == nil {
- return
- }
- if tx.writable {
- // Grab freelist stats.
- var freelistFreeN = tx.db.freelist.free_count()
- var freelistPendingN = tx.db.freelist.pending_count()
- var freelistAlloc = tx.db.freelist.size()
-
- // Remove transaction ref & writer lock.
- tx.db.rwtx = nil
- tx.db.rwlock.Unlock()
-
- // Merge statistics.
- tx.db.statlock.Lock()
- tx.db.stats.FreePageN = freelistFreeN
- tx.db.stats.PendingPageN = freelistPendingN
- tx.db.stats.FreeAlloc = (freelistFreeN + freelistPendingN) * tx.db.pageSize
- tx.db.stats.FreelistInuse = freelistAlloc
- tx.db.stats.TxStats.add(&tx.stats)
- tx.db.statlock.Unlock()
- } else {
- tx.db.removeTx(tx)
- }
-
- // Clear all references.
- tx.db = nil
- tx.meta = nil
- tx.root = Bucket{tx: tx}
- tx.pages = nil
-}
-
-// Copy writes the entire database to a writer.
-// This function exists for backwards compatibility. Use WriteTo() instead.
-func (tx *Tx) Copy(w io.Writer) error {
- _, err := tx.WriteTo(w)
- return err
-}
-
-// WriteTo writes the entire database to a writer.
-// If err == nil then exactly tx.Size() bytes will be written into the writer.
-func (tx *Tx) WriteTo(w io.Writer) (n int64, err error) {
- // Attempt to open reader with WriteFlag
- f, err := os.OpenFile(tx.db.path, os.O_RDONLY|tx.WriteFlag, 0)
- if err != nil {
- return 0, err
- }
- defer func() { _ = f.Close() }()
-
- // Generate a meta page. We use the same page data for both meta pages.
- buf := make([]byte, tx.db.pageSize)
- page := (*page)(unsafe.Pointer(&buf[0]))
- page.flags = metaPageFlag
- *page.meta() = *tx.meta
-
- // Write meta 0.
- page.id = 0
- page.meta().checksum = page.meta().sum64()
- nn, err := w.Write(buf)
- n += int64(nn)
- if err != nil {
- return n, fmt.Errorf("meta 0 copy: %s", err)
- }
-
- // Write meta 1 with a lower transaction id.
- page.id = 1
- page.meta().txid -= 1
- page.meta().checksum = page.meta().sum64()
- nn, err = w.Write(buf)
- n += int64(nn)
- if err != nil {
- return n, fmt.Errorf("meta 1 copy: %s", err)
- }
-
- // Move past the meta pages in the file.
- if _, err := f.Seek(int64(tx.db.pageSize*2), os.SEEK_SET); err != nil {
- return n, fmt.Errorf("seek: %s", err)
- }
-
- // Copy data pages.
- wn, err := io.CopyN(w, f, tx.Size()-int64(tx.db.pageSize*2))
- n += wn
- if err != nil {
- return n, err
- }
-
- return n, f.Close()
-}
-
-// CopyFile copies the entire database to file at the given path.
-// A reader transaction is maintained during the copy so it is safe to continue
-// using the database while a copy is in progress.
-func (tx *Tx) CopyFile(path string, mode os.FileMode) error {
- f, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC, mode)
- if err != nil {
- return err
- }
-
- err = tx.Copy(f)
- if err != nil {
- _ = f.Close()
- return err
- }
- return f.Close()
-}
-
-// Check performs several consistency checks on the database for this transaction.
-// An error is returned if any inconsistency is found.
-//
-// It can be safely run concurrently on a writable transaction. However, this
-// incurs a high cost for large databases and databases with a lot of subbuckets
-// because of caching. This overhead can be removed if running on a read-only
-// transaction, however, it is not safe to execute other writer transactions at
-// the same time.
-func (tx *Tx) Check() <-chan error {
- ch := make(chan error)
- go tx.check(ch)
- return ch
-}
-
-func (tx *Tx) check(ch chan error) {
- // Check if any pages are double freed.
- freed := make(map[pgid]bool)
- all := make([]pgid, tx.db.freelist.count())
- tx.db.freelist.copyall(all)
- for _, id := range all {
- if freed[id] {
- ch <- fmt.Errorf("page %d: already freed", id)
- }
- freed[id] = true
- }
-
- // Track every reachable page.
- reachable := make(map[pgid]*page)
- reachable[0] = tx.page(0) // meta0
- reachable[1] = tx.page(1) // meta1
- for i := uint32(0); i <= tx.page(tx.meta.freelist).overflow; i++ {
- reachable[tx.meta.freelist+pgid(i)] = tx.page(tx.meta.freelist)
- }
-
- // Recursively check buckets.
- tx.checkBucket(&tx.root, reachable, freed, ch)
-
- // Ensure all pages below high water mark are either reachable or freed.
- for i := pgid(0); i < tx.meta.pgid; i++ {
- _, isReachable := reachable[i]
- if !isReachable && !freed[i] {
- ch <- fmt.Errorf("page %d: unreachable unfreed", int(i))
- }
- }
-
- // Close the channel to signal completion.
- close(ch)
-}
-
-func (tx *Tx) checkBucket(b *Bucket, reachable map[pgid]*page, freed map[pgid]bool, ch chan error) {
- // Ignore inline buckets.
- if b.root == 0 {
- return
- }
-
- // Check every page used by this bucket.
- b.tx.forEachPage(b.root, 0, func(p *page, _ int) {
- if p.id > tx.meta.pgid {
- ch <- fmt.Errorf("page %d: out of bounds: %d", int(p.id), int(b.tx.meta.pgid))
- }
-
- // Ensure each page is only referenced once.
- for i := pgid(0); i <= pgid(p.overflow); i++ {
- var id = p.id + i
- if _, ok := reachable[id]; ok {
- ch <- fmt.Errorf("page %d: multiple references", int(id))
- }
- reachable[id] = p
- }
-
- // We should only encounter un-freed leaf and branch pages.
- if freed[p.id] {
- ch <- fmt.Errorf("page %d: reachable freed", int(p.id))
- } else if (p.flags&branchPageFlag) == 0 && (p.flags&leafPageFlag) == 0 {
- ch <- fmt.Errorf("page %d: invalid type: %s", int(p.id), p.typ())
- }
- })
-
- // Check each bucket within this bucket.
- _ = b.ForEach(func(k, v []byte) error {
- if child := b.Bucket(k); child != nil {
- tx.checkBucket(child, reachable, freed, ch)
- }
- return nil
- })
-}
-
-// allocate returns a contiguous block of memory starting at a given page.
-func (tx *Tx) allocate(count int) (*page, error) {
- p, err := tx.db.allocate(count)
- if err != nil {
- return nil, err
- }
-
- // Save to our page cache.
- tx.pages[p.id] = p
-
- // Update statistics.
- tx.stats.PageCount++
- tx.stats.PageAlloc += count * tx.db.pageSize
-
- return p, nil
-}
-
-// write writes any dirty pages to disk.
-func (tx *Tx) write() error {
- // Sort pages by id.
- pages := make(pages, 0, len(tx.pages))
- for _, p := range tx.pages {
- pages = append(pages, p)
- }
- // Clear out page cache early.
- tx.pages = make(map[pgid]*page)
- sort.Sort(pages)
-
- // Write pages to disk in order.
- for _, p := range pages {
- size := (int(p.overflow) + 1) * tx.db.pageSize
- offset := int64(p.id) * int64(tx.db.pageSize)
-
- // Write out page in "max allocation" sized chunks.
- ptr := (*[maxAllocSize]byte)(unsafe.Pointer(p))
- for {
- // Limit our write to our max allocation size.
- sz := size
- if sz > maxAllocSize-1 {
- sz = maxAllocSize - 1
- }
-
- // Write chunk to disk.
- buf := ptr[:sz]
- if _, err := tx.db.ops.writeAt(buf, offset); err != nil {
- return err
- }
-
- // Update statistics.
- tx.stats.Write++
-
- // Exit inner for loop if we've written all the chunks.
- size -= sz
- if size == 0 {
- break
- }
-
- // Otherwise move offset forward and move pointer to next chunk.
- offset += int64(sz)
- ptr = (*[maxAllocSize]byte)(unsafe.Pointer(&ptr[sz]))
- }
- }
-
- // Ignore file sync if flag is set on DB.
- if !tx.db.NoSync || IgnoreNoSync {
- if err := fdatasync(tx.db); err != nil {
- return err
- }
- }
-
- // Put small pages back to page pool.
- for _, p := range pages {
- // Ignore page sizes over 1 page.
- // These are allocated using make() instead of the page pool.
- if int(p.overflow) != 0 {
- continue
- }
-
- buf := (*[maxAllocSize]byte)(unsafe.Pointer(p))[:tx.db.pageSize]
-
- // See https://go.googlesource.com/go/+/f03c9202c43e0abb130669852082117ca50aa9b1
- for i := range buf {
- buf[i] = 0
- }
- tx.db.pagePool.Put(buf)
- }
-
- return nil
-}
-
-// writeMeta writes the meta to the disk.
-func (tx *Tx) writeMeta() error {
- // Create a temporary buffer for the meta page.
- buf := make([]byte, tx.db.pageSize)
- p := tx.db.pageInBuffer(buf, 0)
- tx.meta.write(p)
-
- // Write the meta page to file.
- if _, err := tx.db.ops.writeAt(buf, int64(p.id)*int64(tx.db.pageSize)); err != nil {
- return err
- }
- if !tx.db.NoSync || IgnoreNoSync {
- if err := fdatasync(tx.db); err != nil {
- return err
- }
- }
-
- // Update statistics.
- tx.stats.Write++
-
- return nil
-}
-
-// page returns a reference to the page with a given id.
-// If page has been written to then a temporary buffered page is returned.
-func (tx *Tx) page(id pgid) *page {
- // Check the dirty pages first.
- if tx.pages != nil {
- if p, ok := tx.pages[id]; ok {
- return p
- }
- }
-
- // Otherwise return directly from the mmap.
- return tx.db.page(id)
-}
-
-// forEachPage iterates over every page within a given page and executes a function.
-func (tx *Tx) forEachPage(pgid pgid, depth int, fn func(*page, int)) {
- p := tx.page(pgid)
-
- // Execute function.
- fn(p, depth)
-
- // Recursively loop over children.
- if (p.flags & branchPageFlag) != 0 {
- for i := 0; i < int(p.count); i++ {
- elem := p.branchPageElement(uint16(i))
- tx.forEachPage(elem.pgid, depth+1, fn)
- }
- }
-}
-
-// Page returns page information for a given page number.
-// This is only safe for concurrent use when used by a writable transaction.
-func (tx *Tx) Page(id int) (*PageInfo, error) {
- if tx.db == nil {
- return nil, ErrTxClosed
- } else if pgid(id) >= tx.meta.pgid {
- return nil, nil
- }
-
- // Build the page info.
- p := tx.db.page(pgid(id))
- info := &PageInfo{
- ID: id,
- Count: int(p.count),
- OverflowCount: int(p.overflow),
- }
-
- // Determine the type (or if it's free).
- if tx.db.freelist.freed(pgid(id)) {
- info.Type = "free"
- } else {
- info.Type = p.typ()
- }
-
- return info, nil
-}
-
-// TxStats represents statistics about the actions performed by the transaction.
-type TxStats struct {
- // Page statistics.
- PageCount int // number of page allocations
- PageAlloc int // total bytes allocated
-
- // Cursor statistics.
- CursorCount int // number of cursors created
-
- // Node statistics
- NodeCount int // number of node allocations
- NodeDeref int // number of node dereferences
-
- // Rebalance statistics.
- Rebalance int // number of node rebalances
- RebalanceTime time.Duration // total time spent rebalancing
-
- // Split/Spill statistics.
- Split int // number of nodes split
- Spill int // number of nodes spilled
- SpillTime time.Duration // total time spent spilling
-
- // Write statistics.
- Write int // number of writes performed
- WriteTime time.Duration // total time spent writing to disk
-}
-
-func (s *TxStats) add(other *TxStats) {
- s.PageCount += other.PageCount
- s.PageAlloc += other.PageAlloc
- s.CursorCount += other.CursorCount
- s.NodeCount += other.NodeCount
- s.NodeDeref += other.NodeDeref
- s.Rebalance += other.Rebalance
- s.RebalanceTime += other.RebalanceTime
- s.Split += other.Split
- s.Spill += other.Spill
- s.SpillTime += other.SpillTime
- s.Write += other.Write
- s.WriteTime += other.WriteTime
-}
-
-// Sub calculates and returns the difference between two sets of transaction stats.
-// This is useful when obtaining stats at two different points and time and
-// you need the performance counters that occurred within that time span.
-func (s *TxStats) Sub(other *TxStats) TxStats {
- var diff TxStats
- diff.PageCount = s.PageCount - other.PageCount
- diff.PageAlloc = s.PageAlloc - other.PageAlloc
- diff.CursorCount = s.CursorCount - other.CursorCount
- diff.NodeCount = s.NodeCount - other.NodeCount
- diff.NodeDeref = s.NodeDeref - other.NodeDeref
- diff.Rebalance = s.Rebalance - other.Rebalance
- diff.RebalanceTime = s.RebalanceTime - other.RebalanceTime
- diff.Split = s.Split - other.Split
- diff.Spill = s.Spill - other.Spill
- diff.SpillTime = s.SpillTime - other.SpillTime
- diff.Write = s.Write - other.Write
- diff.WriteTime = s.WriteTime - other.WriteTime
- return diff
-}
diff --git a/vendor/github.com/cznic/fileutil/AUTHORS b/vendor/github.com/cznic/fileutil/AUTHORS
deleted file mode 100644
index 3a5e488b5..000000000
--- a/vendor/github.com/cznic/fileutil/AUTHORS
+++ /dev/null
@@ -1,15 +0,0 @@
-# This file lists authors for copyright purposes. This file is distinct from
-# the CONTRIBUTORS files. See the latter for an explanation.
-#
-# Names should be added to this file as:
-# Name or Organization
-#
-# The email address is not required for organizations.
-#
-# Please keep the list sorted.
-
-CZ.NIC z.s.p.o.
-Jan Mercl <0xjnml@gmail.com>
-Linelane GmbH
-Aaron Bieber
-
diff --git a/vendor/github.com/cznic/fileutil/CONTRIBUTORS b/vendor/github.com/cznic/fileutil/CONTRIBUTORS
deleted file mode 100644
index 988a13960..000000000
--- a/vendor/github.com/cznic/fileutil/CONTRIBUTORS
+++ /dev/null
@@ -1,15 +0,0 @@
-# This file lists people who contributed code to this repository. The AUTHORS
-# file lists the copyright holders; this file lists people.
-#
-# Names should be added to this file like so:
-# Name
-#
-# Please keep the list sorted.
-
-Andris Valums
-Bill Thiede
-Gary Burd
-Jan Mercl <0xjnml@gmail.com>
-Nick Owens
-Tamás Gulácsi
-Aaron Bieber
diff --git a/vendor/github.com/cznic/fileutil/LICENSE b/vendor/github.com/cznic/fileutil/LICENSE
deleted file mode 100644
index 50bbdd241..000000000
--- a/vendor/github.com/cznic/fileutil/LICENSE
+++ /dev/null
@@ -1,27 +0,0 @@
-Copyright (c) 2014 The fileutil Authors. All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are
-met:
-
- * Redistributions of source code must retain the above copyright
-notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above
-copyright notice, this list of conditions and the following disclaimer
-in the documentation and/or other materials provided with the
-distribution.
- * Neither the names of the authors nor the names of the
-contributors may be used to endorse or promote products derived from
-this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/github.com/cznic/fileutil/Makefile b/vendor/github.com/cznic/fileutil/Makefile
deleted file mode 100644
index 5849cc20a..000000000
--- a/vendor/github.com/cznic/fileutil/Makefile
+++ /dev/null
@@ -1,27 +0,0 @@
-# Copyright (c) 2014 The fileutil authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean editor todo
-
-all: editor
- go vet
- golint .
- go install
- make todo
-
-editor:
- go fmt
- go test -i
- go test
- go build
-
-todo:
- @grep -n ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* *.go || true
- @grep -n TODO *.go || true
- @grep -n BUG *.go || true
- @grep -n println *.go || true
-
-clean:
- @go clean
- rm -f y.output
diff --git a/vendor/github.com/cznic/fileutil/README b/vendor/github.com/cznic/fileutil/README
deleted file mode 100644
index f43d5f004..000000000
--- a/vendor/github.com/cznic/fileutil/README
+++ /dev/null
@@ -1,16 +0,0 @@
-This is a goinstall-able mirror of modified code already published at:
-http://git.nic.cz/redmine/projects/gofileutil/repository
-
-Packages in this repository:
-
-Install: $go get github.com/cznic/fileutil
-Godocs: http://godoc.org/github.com/cznic/fileutil
-
-Install: $go get github.com/cznic/fileutil/storage
-Godocs: http://godoc.org/github.com/cznic/fileutil/storage
-
-Install: $go get github.com/cznic/fileutil/falloc
-Godocs: http://godoc.org/github.com/cznic/fileutil/falloc
-
-Install: $go get github.com/cznic/fileutil/hdb
-Godocs: http://godoc.org/github.com/cznic/fileutil/hdb
diff --git a/vendor/github.com/cznic/fileutil/fileutil.go b/vendor/github.com/cznic/fileutil/fileutil.go
deleted file mode 100644
index 2f0f7ab15..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil.go
+++ /dev/null
@@ -1,223 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package fileutil collects some file utility functions.
-package fileutil
-
-import (
- "fmt"
- "io"
- "os"
- "path/filepath"
- "runtime"
- "strconv"
- "sync"
- "time"
-)
-
-// GoMFile is a concurrent access safe version of MFile.
-type GoMFile struct {
- mfile *MFile
- mutex sync.Mutex
-}
-
-// NewGoMFile return a newly created GoMFile.
-func NewGoMFile(fname string, flag int, perm os.FileMode, delta_ns int64) (m *GoMFile, err error) {
- m = &GoMFile{}
- if m.mfile, err = NewMFile(fname, flag, perm, delta_ns); err != nil {
- m = nil
- }
- return
-}
-
-func (m *GoMFile) File() (file *os.File, err error) {
- m.mutex.Lock()
- defer m.mutex.Unlock()
- return m.mfile.File()
-}
-
-func (m *GoMFile) SetChanged() {
- m.mutex.Lock()
- defer m.mutex.Unlock()
- m.mfile.SetChanged()
-}
-
-func (m *GoMFile) SetHandler(h MFileHandler) {
- m.mutex.Lock()
- defer m.mutex.Unlock()
- m.mfile.SetHandler(h)
-}
-
-// MFileHandler resolves modifications of File.
-// Possible File context is expected to be a part of the handler's closure.
-type MFileHandler func(*os.File) error
-
-// MFile represents an os.File with a guard/handler on change/modification.
-// Example use case is an app with a configuration file which can be modified at any time
-// and have to be reloaded in such event prior to performing something configurable by that
-// file. The checks are made only on access to the MFile file by
-// File() and a time threshold/hysteresis value can be chosen on creating a new MFile.
-type MFile struct {
- file *os.File
- handler MFileHandler
- t0 int64
- delta int64
- ctime int64
-}
-
-// NewMFile returns a newly created MFile or Error if any.
-// The fname, flag and perm parameters have the same meaning as in os.Open.
-// For meaning of the delta_ns parameter please see the (m *MFile) File() docs.
-func NewMFile(fname string, flag int, perm os.FileMode, delta_ns int64) (m *MFile, err error) {
- m = &MFile{}
- m.t0 = time.Now().UnixNano()
- if m.file, err = os.OpenFile(fname, flag, perm); err != nil {
- return
- }
-
- var fi os.FileInfo
- if fi, err = m.file.Stat(); err != nil {
- return
- }
-
- m.ctime = fi.ModTime().UnixNano()
- m.delta = delta_ns
- runtime.SetFinalizer(m, func(m *MFile) {
- m.file.Close()
- })
- return
-}
-
-// SetChanged forces next File() to unconditionally handle modification of the wrapped os.File.
-func (m *MFile) SetChanged() {
- m.ctime = -1
-}
-
-// SetHandler sets a function to be invoked when modification of MFile is to be processed.
-func (m *MFile) SetHandler(h MFileHandler) {
- m.handler = h
-}
-
-// File returns an os.File from MFile. If time elapsed between the last invocation of this function
-// and now is at least delta_ns ns (a parameter of NewMFile) then the file is checked for
-// change/modification. For delta_ns == 0 the modification is checked w/o getting os.Time().
-// If a change is detected a handler is invoked on the MFile file.
-// Any of these steps can produce an Error. If that happens the function returns nil, Error.
-func (m *MFile) File() (file *os.File, err error) {
- var now int64
-
- mustCheck := m.delta == 0
- if !mustCheck {
- now = time.Now().UnixNano()
- mustCheck = now-m.t0 > m.delta
- }
-
- if mustCheck { // check interval reached
- var fi os.FileInfo
- if fi, err = m.file.Stat(); err != nil {
- return
- }
-
- if fi.ModTime().UnixNano() != m.ctime { // modification detected
- if m.handler == nil {
- return nil, fmt.Errorf("no handler set for modified file %q", m.file.Name())
- }
- if err = m.handler(m.file); err != nil {
- return
- }
-
- m.ctime = fi.ModTime().UnixNano()
- }
- m.t0 = now
- }
-
- return m.file, nil
-}
-
-// Read reads buf from r. It will either fill the full buf or fail.
-// It wraps the functionality of an io.Reader which may return less bytes than requested,
-// but may block if not all data are ready for the io.Reader.
-func Read(r io.Reader, buf []byte) (err error) {
- have := 0
- remain := len(buf)
- got := 0
- for remain > 0 {
- if got, err = r.Read(buf[have:]); err != nil {
- return
- }
-
- remain -= got
- have += got
- }
- return
-}
-
-// "os" and/or "syscall" extensions
-
-// FadviseAdvice is used by Fadvise.
-type FadviseAdvice int
-
-// FAdviseAdvice values.
-const (
- // $ grep FADV /usr/include/bits/fcntl.h
- POSIX_FADV_NORMAL FadviseAdvice = iota // No further special treatment.
- POSIX_FADV_RANDOM // Expect random page references.
- POSIX_FADV_SEQUENTIAL // Expect sequential page references.
- POSIX_FADV_WILLNEED // Will need these pages.
- POSIX_FADV_DONTNEED // Don't need these pages.
- POSIX_FADV_NOREUSE // Data will be accessed once.
-)
-
-// TempFile creates a new temporary file in the directory dir with a name
-// ending with suffix, basename starting with prefix, opens the file for
-// reading and writing, and returns the resulting *os.File. If dir is the
-// empty string, TempFile uses the default directory for temporary files (see
-// os.TempDir). Multiple programs calling TempFile simultaneously will not
-// choose the same file. The caller can use f.Name() to find the pathname of
-// the file. It is the caller's responsibility to remove the file when no
-// longer needed.
-//
-// NOTE: This function differs from ioutil.TempFile.
-func TempFile(dir, prefix, suffix string) (f *os.File, err error) {
- if dir == "" {
- dir = os.TempDir()
- }
-
- nconflict := 0
- for i := 0; i < 10000; i++ {
- name := filepath.Join(dir, prefix+nextInfix()+suffix)
- f, err = os.OpenFile(name, os.O_RDWR|os.O_CREATE|os.O_EXCL, 0600)
- if os.IsExist(err) {
- if nconflict++; nconflict > 10 {
- rand = reseed()
- }
- continue
- }
- break
- }
- return
-}
-
-// Random number state.
-// We generate random temporary file names so that there's a good
-// chance the file doesn't exist yet - keeps the number of tries in
-// TempFile to a minimum.
-var rand uint32
-var randmu sync.Mutex
-
-func reseed() uint32 {
- return uint32(time.Now().UnixNano() + int64(os.Getpid()))
-}
-
-func nextInfix() string {
- randmu.Lock()
- r := rand
- if r == 0 {
- r = reseed()
- }
- r = r*1664525 + 1013904223 // constants from Numerical Recipes
- rand = r
- randmu.Unlock()
- return strconv.Itoa(int(1e9 + r%1e9))[1:]
-}
diff --git a/vendor/github.com/cznic/fileutil/fileutil_arm.go b/vendor/github.com/cznic/fileutil/fileutil_arm.go
deleted file mode 100644
index c7b54f02b..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_arm.go
+++ /dev/null
@@ -1,27 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Not supported on ARM.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'. Not supported on ARM.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_darwin.go b/vendor/github.com/cznic/fileutil/fileutil_darwin.go
deleted file mode 100644
index 5d939b2fa..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_darwin.go
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !arm
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Not supported on OSX.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'. Not supported on OSX.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_freebsd.go b/vendor/github.com/cznic/fileutil/fileutil_freebsd.go
deleted file mode 100644
index 5a769939d..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_freebsd.go
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !arm
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Unimplemented on FreeBSD.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'. Unimplemented on FreeBSD.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_linux.go b/vendor/github.com/cznic/fileutil/fileutil_linux.go
deleted file mode 100644
index a894cb726..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_linux.go
+++ /dev/null
@@ -1,98 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !arm
-
-package fileutil
-
-import (
- "bytes"
- "io"
- "io/ioutil"
- "os"
- "strconv"
- "syscall"
-)
-
-const hasPunchHole = true
-
-func n(s []byte) byte {
- for i, c := range s {
- if c < '0' || c > '9' {
- s = s[:i]
- break
- }
- }
- v, _ := strconv.Atoi(string(s))
- return byte(v)
-}
-
-func init() {
- b, err := ioutil.ReadFile("/proc/sys/kernel/osrelease")
- if err != nil {
- panic(err)
- }
-
- tokens := bytes.Split(b, []byte("."))
- if len(tokens) > 3 {
- tokens = tokens[:3]
- }
- switch len(tokens) {
- case 3:
- // Supported since kernel 2.6.38
- if bytes.Compare([]byte{n(tokens[0]), n(tokens[1]), n(tokens[2])}, []byte{2, 6, 38}) < 0 {
- puncher = func(*os.File, int64, int64) error { return nil }
- }
- case 2:
- if bytes.Compare([]byte{n(tokens[0]), n(tokens[1])}, []byte{2, 7}) < 0 {
- puncher = func(*os.File, int64, int64) error { return nil }
- }
- default:
- puncher = func(*os.File, int64, int64) error { return nil }
- }
-}
-
-var puncher = func(f *os.File, off, len int64) error {
- const (
- /*
- /usr/include/linux$ grep FL_ falloc.h
- */
- _FALLOC_FL_KEEP_SIZE = 0x01 // default is extend size
- _FALLOC_FL_PUNCH_HOLE = 0x02 // de-allocates range
- )
-
- _, _, errno := syscall.Syscall6(
- syscall.SYS_FALLOCATE,
- uintptr(f.Fd()),
- uintptr(_FALLOC_FL_KEEP_SIZE|_FALLOC_FL_PUNCH_HOLE),
- uintptr(off),
- uintptr(len),
- 0, 0)
- if errno != 0 {
- return os.NewSyscallError("SYS_FALLOCATE", errno)
- }
- return nil
-}
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. No-op for kernels < 2.6.38 (or < 2.7).
-func PunchHole(f *os.File, off, len int64) error {
- return puncher(f, off, len)
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- _, _, errno := syscall.Syscall6(
- syscall.SYS_FADVISE64,
- uintptr(f.Fd()),
- uintptr(off),
- uintptr(len),
- uintptr(advice),
- 0, 0)
- return os.NewSyscallError("SYS_FADVISE64", errno)
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_netbsd.go b/vendor/github.com/cznic/fileutil/fileutil_netbsd.go
deleted file mode 100644
index d64102143..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_netbsd.go
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !arm
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Similar to FreeBSD, this is
-// unimplemented.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Unimplemented on NetBSD.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_openbsd.go b/vendor/github.com/cznic/fileutil/fileutil_openbsd.go
deleted file mode 100644
index 5c0898916..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_openbsd.go
+++ /dev/null
@@ -1,27 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Similar to FreeBSD, this is
-// unimplemented.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Unimplemented on OpenBSD.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_plan9.go b/vendor/github.com/cznic/fileutil/fileutil_plan9.go
deleted file mode 100644
index 86787e5a9..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_plan9.go
+++ /dev/null
@@ -1,27 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Unimplemented on Plan 9.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'. Unimplemented on Plan 9.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_solaris.go b/vendor/github.com/cznic/fileutil/fileutil_solaris.go
deleted file mode 100644
index 3866686b6..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_solaris.go
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright (c) 2013 jnml. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build go1.3
-
-package fileutil
-
-import (
- "io"
- "os"
-)
-
-const hasPunchHole = false
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Not supported on Solaris.
-func PunchHole(f *os.File, off, len int64) error {
- return nil
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'. Not supported on Solaris.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool { return err == io.EOF }
diff --git a/vendor/github.com/cznic/fileutil/fileutil_windows.go b/vendor/github.com/cznic/fileutil/fileutil_windows.go
deleted file mode 100644
index 1e5d62978..000000000
--- a/vendor/github.com/cznic/fileutil/fileutil_windows.go
+++ /dev/null
@@ -1,185 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package fileutil
-
-import (
- "io"
- "os"
- "sync"
- "syscall"
- "unsafe"
-)
-
-const hasPunchHole = true
-
-// PunchHole deallocates space inside a file in the byte range starting at
-// offset and continuing for len bytes. Not supported on Windows.
-func PunchHole(f *os.File, off, len int64) error {
- return puncher(f, off, len)
-}
-
-// Fadvise predeclares an access pattern for file data. See also 'man 2
-// posix_fadvise'. Not supported on Windows.
-func Fadvise(f *os.File, off, len int64, advice FadviseAdvice) error {
- return nil
-}
-
-// IsEOF reports whether err is an EOF condition.
-func IsEOF(err error) bool {
- if err == io.EOF {
- return true
- }
-
- // http://social.technet.microsoft.com/Forums/windowsserver/en-US/1a16311b-c625-46cf-830b-6a26af488435/how-to-solve-error-38-0x26-errorhandleeof-using-fsctlgetretrievalpointers
- x, ok := err.(*os.PathError)
- return ok && x.Op == "read" && x.Err.(syscall.Errno) == 0x26
-}
-
-var (
- modkernel32 = syscall.NewLazyDLL("kernel32.dll")
-
- procDeviceIOControl = modkernel32.NewProc("DeviceIoControl")
-
- sparseFilesMu sync.Mutex
- sparseFiles map[uintptr]struct{}
-)
-
-func init() {
- // sparseFiles is an fd set for already "sparsed" files - according to
- // msdn.microsoft.com/en-us/library/windows/desktop/aa364225(v=vs.85).aspx
- // the file handles are unique per process.
- sparseFiles = make(map[uintptr]struct{})
-}
-
-// puncHoleWindows punches a hole into the given file starting at offset,
-// measuring "size" bytes
-// (http://msdn.microsoft.com/en-us/library/windows/desktop/aa364597%28v=vs.85%29.aspx)
-func puncher(file *os.File, offset, size int64) error {
- if err := ensureFileSparse(file); err != nil {
- return err
- }
-
- // http://msdn.microsoft.com/en-us/library/windows/desktop/aa364411%28v=vs.85%29.aspx
- // typedef struct _FILE_ZERO_DATA_INFORMATION {
- // LARGE_INTEGER FileOffset;
- // LARGE_INTEGER BeyondFinalZero;
- //} FILE_ZERO_DATA_INFORMATION, *PFILE_ZERO_DATA_INFORMATION;
- type fileZeroDataInformation struct {
- FileOffset, BeyondFinalZero int64
- }
-
- lpInBuffer := fileZeroDataInformation{
- FileOffset: offset,
- BeyondFinalZero: offset + size}
- return deviceIOControl(false, file.Fd(), uintptr(unsafe.Pointer(&lpInBuffer)), 16)
-}
-
-// // http://msdn.microsoft.com/en-us/library/windows/desktop/cc948908%28v=vs.85%29.aspx
-// type fileSetSparseBuffer struct {
-// SetSparse bool
-// }
-
-func ensureFileSparse(file *os.File) (err error) {
- fd := file.Fd()
- sparseFilesMu.Lock()
- if _, ok := sparseFiles[fd]; ok {
- sparseFilesMu.Unlock()
- return nil
- }
-
- if err = deviceIOControl(true, fd, 0, 0); err == nil {
- sparseFiles[fd] = struct{}{}
- }
- sparseFilesMu.Unlock()
- return err
-}
-
-func deviceIOControl(setSparse bool, fd, inBuf, inBufLen uintptr) (err error) {
- const (
- //http://source.winehq.org/source/include/winnt.h#L4605
- file_read_data = 1
- file_write_data = 2
-
- // METHOD_BUFFERED 0
- method_buffered = 0
- // FILE_ANY_ACCESS 0
- file_any_access = 0
- // FILE_DEVICE_FILE_SYSTEM 0x00000009
- file_device_file_system = 0x00000009
- // FILE_SPECIAL_ACCESS (FILE_ANY_ACCESS)
- file_special_access = file_any_access
- file_read_access = file_read_data
- file_write_access = file_write_data
-
- // http://source.winehq.org/source/include/winioctl.h
- // #define CTL_CODE ( DeviceType,
- // Function,
- // Method,
- // Access )
- // ((DeviceType) << 16) | ((Access) << 14) | ((Function) << 2) | (Method)
-
- // FSCTL_SET_COMPRESSION CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 16, METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
- fsctl_set_compression = (file_device_file_system << 16) | ((file_read_access | file_write_access) << 14) | (16 << 2) | method_buffered
- // FSCTL_SET_SPARSE CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 49, METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
- fsctl_set_sparse = (file_device_file_system << 16) | (file_special_access << 14) | (49 << 2) | method_buffered
- // FSCTL_SET_ZERO_DATA CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 50, METHOD_BUFFERED, FILE_WRITE_DATA)
- fsctl_set_zero_data = (file_device_file_system << 16) | (file_write_data << 14) | (50 << 2) | method_buffered
- )
- retPtr := uintptr(unsafe.Pointer(&(make([]byte, 8)[0])))
- var r1 uintptr
- var e1 syscall.Errno
- if setSparse {
- // BOOL
- // WINAPI
- // DeviceIoControl( (HANDLE) hDevice, // handle to a file
- // FSCTL_SET_SPARSE, // dwIoControlCode
- // (PFILE_SET_SPARSE_BUFFER) lpInBuffer, // input buffer
- // (DWORD) nInBufferSize, // size of input buffer
- // NULL, // lpOutBuffer
- // 0, // nOutBufferSize
- // (LPDWORD) lpBytesReturned, // number of bytes returned
- // (LPOVERLAPPED) lpOverlapped ); // OVERLAPPED structure
- r1, _, e1 = syscall.Syscall9(procDeviceIOControl.Addr(), 8,
- fd,
- uintptr(fsctl_set_sparse),
- // If the lpInBuffer parameter is NULL, the operation will behave the same as if the SetSparse member of the FILE_SET_SPARSE_BUFFER structure were TRUE. In other words, the operation sets the file to a sparse file.
- 0, // uintptr(unsafe.Pointer(&lpInBuffer)),
- 0, // 1,
- 0,
- 0,
- retPtr,
- 0,
- 0)
- } else {
- // BOOL
- // WINAPI
- // DeviceIoControl( (HANDLE) hDevice, // handle to a file
- // FSCTL_SET_ZERO_DATA, // dwIoControlCode
- // (LPVOID) lpInBuffer, // input buffer
- // (DWORD) nInBufferSize, // size of input buffer
- // NULL, // lpOutBuffer
- // 0, // nOutBufferSize
- // (LPDWORD) lpBytesReturned, // number of bytes returned
- // (LPOVERLAPPED) lpOverlapped ); // OVERLAPPED structure
- r1, _, e1 = syscall.Syscall9(procDeviceIOControl.Addr(), 8,
- fd,
- uintptr(fsctl_set_zero_data),
- inBuf,
- inBufLen,
- 0,
- 0,
- retPtr,
- 0,
- 0)
- }
- if r1 == 0 {
- if e1 != 0 {
- err = error(e1)
- } else {
- err = syscall.EINVAL
- }
- }
- return err
-}
diff --git a/vendor/github.com/cznic/fileutil/test_deps.go b/vendor/github.com/cznic/fileutil/test_deps.go
deleted file mode 100644
index eec608ab3..000000000
--- a/vendor/github.com/cznic/fileutil/test_deps.go
+++ /dev/null
@@ -1,13 +0,0 @@
-// Copyright (c) 2014 The fileutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// blame: jnml, labs.nic.cz
-
-package fileutil
-
-// Pull test dependencies too.
-// Enables easy 'go test X' after 'go get X'
-import (
-// nothing yet
-)
diff --git a/vendor/github.com/cznic/internal/buffer/Makefile b/vendor/github.com/cznic/internal/buffer/Makefile
deleted file mode 100644
index 0676c6dc7..000000000
--- a/vendor/github.com/cznic/internal/buffer/Makefile
+++ /dev/null
@@ -1,60 +0,0 @@
-# Copyright 2016 The Internal Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
- codesweep || true
- maligned || true
- unconvert -apply
-
-clean:
- go clean
- rm -f *~ *.test *.out
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- @ 1>/dev/null 2>/dev/null gvim -p Makefile log *.go
-
-editor:
- gofmt -l -s -w *.go
- go test -i
- go test 2>&1 | tee log
- go install
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench . -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * | grep -v $(ngrep) || true
- @grep -nr $(grep) TODO * | grep -v $(ngrep) || true
- @grep -nr $(grep) BUG * | grep -v $(ngrep) || true
- @grep -nr $(grep) [^[:alpha:]]println * | grep -v $(ngrep) || true
diff --git a/vendor/github.com/cznic/internal/buffer/buffer.go b/vendor/github.com/cznic/internal/buffer/buffer.go
deleted file mode 100644
index 683687537..000000000
--- a/vendor/github.com/cznic/internal/buffer/buffer.go
+++ /dev/null
@@ -1,146 +0,0 @@
-// Copyright 2016 The Internal Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package buffer implements a pool of pointers to byte slices.
-//
-// Example usage pattern
-//
-// p := buffer.Get(size)
-// b := *p // Now you can use b in any way you need.
-// ...
-// // When b will not be used anymore
-// buffer.Put(p)
-// ...
-// // If b or p are not going out of scope soon, optionally
-// b = nil
-// p = nil
-//
-// Otherwise the pool cannot release the buffer on garbage collection.
-//
-// Do not do
-//
-// p := buffer.Get(size)
-// b := *p
-// ...
-// buffer.Put(&b)
-//
-// or
-//
-// b := *buffer.Get(size)
-// ...
-// buffer.Put(&b)
-package buffer
-
-import (
- "github.com/cznic/internal/slice"
- "io"
-)
-
-// CGet returns a pointer to a byte slice of len size. The pointed to byte
-// slice is zeroed up to its cap. CGet panics for size < 0.
-//
-// CGet is safe for concurrent use by multiple goroutines.
-func CGet(size int) *[]byte { return slice.Bytes.CGet(size).(*[]byte) }
-
-// Get returns a pointer to a byte slice of len size. The pointed to byte slice
-// is not zeroed. Get panics for size < 0.
-//
-// Get is safe for concurrent use by multiple goroutines.
-func Get(size int) *[]byte { return slice.Bytes.Get(size).(*[]byte) }
-
-// Put puts a pointer to a byte slice into a pool for possible later reuse by
-// CGet or Get.
-//
-// Put is safe for concurrent use by multiple goroutines.
-func Put(p *[]byte) { slice.Bytes.Put(p) }
-
-// Bytes is similar to bytes.Buffer but may generate less garbage when properly
-// Closed. Zero value is ready to use.
-type Bytes struct {
- p *[]byte
-}
-
-// Bytes return the content of b. The result is R/O.
-func (b *Bytes) Bytes() []byte {
- if b.p != nil {
- return *b.p
- }
-
- return nil
-}
-
-// Close will recycle the underlying storage, if any. After Close, b is again
-// the zero value.
-func (b *Bytes) Close() error {
- if b.p != nil {
- Put(b.p)
- b.p = nil
- }
- return nil
-}
-
-// Len returns the size of content in b.
-func (b *Bytes) Len() int {
- if b.p != nil {
- return len(*b.p)
- }
-
- return 0
-}
-
-// Reset discard the content of Bytes while keeping the internal storage, if any.
-func (b *Bytes) Reset() {
- if b.p != nil {
- *b.p = (*b.p)[:0]
- }
-}
-
-// Write writes p into b and returns (len(p), nil).
-func (b *Bytes) Write(p []byte) (int, error) {
- n := b.Len()
- b.grow(n + len(p))
- copy((*b.p)[n:], p)
- return len(p), nil
-}
-
-// WriteByte writes p into b and returns nil.
-func (b *Bytes) WriteByte(p byte) error {
- n := b.Len()
- b.grow(n + 1)
- (*b.p)[n] = p
- return nil
-}
-
-// WriteTo writes b's content to w and returns the number of bytes written to w
-// and an error, if any.
-func (b *Bytes) WriteTo(w io.Writer) (int64, error) {
- n, err := w.Write(b.Bytes())
- return int64(n), err
-}
-
-// WriteString writes s to b and returns (len(s), nil).
-func (b *Bytes) WriteString(s string) (int, error) {
- n := b.Len()
- b.grow(n + len(s))
- copy((*b.p)[n:], s)
- return len(s), nil
-}
-
-func (b *Bytes) grow(n int) {
- if b.p != nil {
- if n <= cap(*b.p) {
- *b.p = (*b.p)[:n]
- return
- }
-
- np := Get(2 * n)
- *np = (*np)[:n]
- copy(*np, *b.p)
- Put(b.p)
- b.p = np
- return
- }
-
- b.p = Get(n)
-}
diff --git a/vendor/github.com/cznic/internal/file/Makefile b/vendor/github.com/cznic/internal/file/Makefile
deleted file mode 100644
index c94c5b996..000000000
--- a/vendor/github.com/cznic/internal/file/Makefile
+++ /dev/null
@@ -1,55 +0,0 @@
-# Copyright 2016 The Internal Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
-
-clean:
- go clean
- rm -f *~ *.test *.out
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- @ 1>/dev/null 2>/dev/null gvim -p Makefile log *.go
-
-editor:
- gofmt -l -s -w *.go
- go test 2>&1 | tee log
- go build
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench BenchmarkReadWrite -benchmem -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * | grep -v $(ngrep) || true
- @grep -nr $(grep) TODO * | grep -v $(ngrep) || true
- @grep -nr $(grep) BUG * | grep -v $(ngrep) || true
- @grep -nr $(grep) [^[:alpha:]]println * | grep -v $(ngrep) || true
diff --git a/vendor/github.com/cznic/internal/file/file.go b/vendor/github.com/cznic/internal/file/file.go
deleted file mode 100644
index 2e5b89bb8..000000000
--- a/vendor/github.com/cznic/internal/file/file.go
+++ /dev/null
@@ -1,434 +0,0 @@
-// Copyright 2016 The Internal Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package file provides an os.File-like interface of a memory mapped file.
-package file
-
-import (
- "fmt"
- "io"
- "os"
- "time"
-
- "github.com/cznic/fileutil"
- "github.com/cznic/internal/buffer"
- "github.com/cznic/mathutil"
- "github.com/edsrzf/mmap-go"
-)
-
-const copyBufSize = 1 << 20 // 1 MB.
-
-var (
- _ Interface = (*mem)(nil)
- _ Interface = (*file)(nil)
-
- _ os.FileInfo = stat{}
-
- sysPage = os.Getpagesize()
-)
-
-// Interface is a os.File-like entity.
-type Interface interface {
- io.ReaderAt
- io.ReaderFrom
- io.WriterAt
- io.WriterTo
-
- Close() error
- Stat() (os.FileInfo, error)
- Sync() error
- Truncate(int64) error
-}
-
-// Open returns a new Interface backed by f, or an error, if any.
-func Open(f *os.File) (Interface, error) { return newFile(f, 1<<30, 20) }
-
-// OpenMem returns a new Interface, or an error, if any. The Interface content
-// is volatile, it's backed only by process' memory.
-func OpenMem(name string) (Interface, error) { return newMem(name, 18), nil }
-
-type memMap map[int64]*[]byte
-
-type mem struct {
- m memMap
- modTime time.Time
- name string
- pgBits uint
- pgMask int
- pgSize int
- size int64
-}
-
-func newMem(name string, pgBits uint) *mem {
- pgSize := 1 << pgBits
- return &mem{
- m: memMap{},
- modTime: time.Now(),
- name: name,
- pgBits: pgBits,
- pgMask: pgSize - 1,
- pgSize: pgSize,
- }
-}
-
-func (f *mem) IsDir() bool { return false }
-func (f *mem) Mode() os.FileMode { return os.ModeTemporary + 0600 }
-func (f *mem) ModTime() time.Time { return f.modTime }
-func (f *mem) Name() string { return f.name }
-func (f *mem) ReadFrom(r io.Reader) (n int64, err error) { return readFrom(f, r) }
-func (f *mem) Size() (n int64) { return f.size }
-func (f *mem) Stat() (os.FileInfo, error) { return f, nil }
-func (f *mem) Sync() error { return nil }
-func (f *mem) Sys() interface{} { return nil }
-func (f *mem) WriteTo(w io.Writer) (n int64, err error) { return writeTo(f, w) }
-
-func (f *mem) Close() error {
- f.Truncate(0)
- f.m = nil
- return nil
-}
-
-func (f *mem) ReadAt(b []byte, off int64) (n int, err error) {
- avail := f.size - off
- pi := off >> f.pgBits
- po := int(off) & f.pgMask
- rem := len(b)
- if int64(rem) >= avail {
- rem = int(avail)
- err = io.EOF
- }
- var zeroPage *[]byte
- for rem != 0 && avail > 0 {
- pg := f.m[pi]
- if pg == nil {
- if zeroPage == nil {
- zeroPage = buffer.CGet(f.pgSize)
- defer buffer.Put(zeroPage)
- }
- pg = zeroPage
- }
- nc := copy(b[:mathutil.Min(rem, f.pgSize)], (*pg)[po:])
- pi++
- po = 0
- rem -= nc
- n += nc
- b = b[nc:]
- }
- return n, err
-}
-
-func (f *mem) Truncate(size int64) (err error) {
- if size < 0 {
- return fmt.Errorf("invalid truncate size: %d", size)
- }
-
- first := size >> f.pgBits
- if size&int64(f.pgMask) != 0 {
- first++
- }
- last := f.size >> f.pgBits
- if f.size&int64(f.pgMask) != 0 {
- last++
- }
- for ; first <= last; first++ {
- if p := f.m[first]; p != nil {
- buffer.Put(p)
- }
- delete(f.m, first)
- }
-
- f.size = size
- return nil
-}
-
-func (f *mem) WriteAt(b []byte, off int64) (n int, err error) {
- pi := off >> f.pgBits
- po := int(off) & f.pgMask
- n = len(b)
- rem := n
- var nc int
- for rem != 0 {
- pg := f.m[pi]
- if pg == nil {
- pg = buffer.CGet(f.pgSize)
- f.m[pi] = pg
- }
- nc = copy((*pg)[po:], b)
- pi++
- po = 0
- rem -= nc
- b = b[nc:]
- }
- f.size = mathutil.MaxInt64(f.size, off+int64(n))
- return n, nil
-}
-
-type stat struct {
- os.FileInfo
- size int64
-}
-
-func (s stat) Size() int64 { return s.size }
-
-type fileMap map[int64]mmap.MMap
-
-type file struct {
- f *os.File
- m fileMap
- maxPages int
- pgBits uint
- pgMask int
- pgSize int
- size int64
- fsize int64
-}
-
-func newFile(f *os.File, maxSize int64, pgBits uint) (*file, error) {
- if maxSize < 0 {
- panic("internal error")
- }
-
- pgSize := 1 << pgBits
- switch {
- case sysPage > pgSize:
- pgBits = uint(mathutil.Log2Uint64(uint64(sysPage)))
- default:
- pgBits = uint(mathutil.Log2Uint64(uint64(pgSize / sysPage * sysPage)))
- }
- pgSize = 1 << pgBits
- fi := &file{
- f: f,
- m: fileMap{},
- maxPages: int(mathutil.MinInt64(
- 1024,
- mathutil.MaxInt64(maxSize/int64(pgSize), 1)),
- ),
- pgBits: pgBits,
- pgMask: pgSize - 1,
- pgSize: pgSize,
- }
- info, err := f.Stat()
- if err != nil {
- return nil, err
- }
-
- if err = fi.Truncate(info.Size()); err != nil {
- return nil, err
- }
-
- return fi, nil
-}
-
-func (f *file) ReadFrom(r io.Reader) (n int64, err error) { return readFrom(f, r) }
-func (f *file) Sync() (err error) { return f.f.Sync() }
-func (f *file) WriteTo(w io.Writer) (n int64, err error) { return writeTo(f, w) }
-
-func (f *file) Close() (err error) {
- for _, p := range f.m {
- if err = p.Unmap(); err != nil {
- return err
- }
- }
-
- if err = f.f.Truncate(f.size); err != nil {
- return err
- }
-
- if err = f.f.Sync(); err != nil {
- return err
- }
-
- if err = f.f.Close(); err != nil {
- return err
- }
-
- f.m = nil
- f.f = nil
- return nil
-}
-
-func (f *file) page(index int64) (mmap.MMap, error) {
- if len(f.m) == f.maxPages {
- for i, p := range f.m {
- if err := p.Unmap(); err != nil {
- return nil, err
- }
-
- delete(f.m, i)
- break
- }
- }
-
- off := index << f.pgBits
- fsize := off + int64(f.pgSize)
- if fsize > f.fsize {
- if err := f.f.Truncate(fsize); err != nil {
- return nil, err
- }
-
- f.fsize = fsize
- }
- p, err := mmap.MapRegion(f.f, f.pgSize, mmap.RDWR, 0, off)
- if err != nil {
- return nil, err
- }
-
- f.m[index] = p
- return p, nil
-}
-
-func (f *file) ReadAt(b []byte, off int64) (n int, err error) {
- avail := f.size - off
- pi := off >> f.pgBits
- po := int(off) & f.pgMask
- rem := len(b)
- if int64(rem) >= avail {
- rem = int(avail)
- err = io.EOF
- }
- for rem != 0 && avail > 0 {
- pg := f.m[pi]
- if pg == nil {
- if pg, err = f.page(pi); err != nil {
- return n, err
- }
- }
- nc := copy(b[:mathutil.Min(rem, f.pgSize)], pg[po:])
- pi++
- po = 0
- rem -= nc
- n += nc
- b = b[nc:]
- }
- return n, err
-}
-
-func (f *file) Stat() (os.FileInfo, error) {
- fi, err := f.f.Stat()
- if err != nil {
- return nil, err
- }
-
- return stat{fi, f.size}, nil
-}
-
-func (f *file) Truncate(size int64) (err error) {
- if size < 0 {
- return fmt.Errorf("invalid truncate size: %d", size)
- }
-
- first := size >> f.pgBits
- if size&int64(f.pgMask) != 0 {
- first++
- }
- last := f.size >> f.pgBits
- if f.size&int64(f.pgMask) != 0 {
- last++
- }
- for ; first <= last; first++ {
- if p := f.m[first]; p != nil {
- if err := p.Unmap(); err != nil {
- return err
- }
- }
-
- delete(f.m, first)
- }
-
- f.size = size
- fsize := (size + int64(f.pgSize) - 1) &^ int64(f.pgMask)
- if fsize != f.fsize {
- if err := f.f.Truncate(fsize); err != nil {
- return err
- }
-
- }
- f.fsize = fsize
- return nil
-}
-
-func (f *file) WriteAt(b []byte, off int64) (n int, err error) {
- pi := off >> f.pgBits
- po := int(off) & f.pgMask
- n = len(b)
- rem := n
- var nc int
- for rem != 0 {
- pg := f.m[pi]
- if pg == nil {
- pg, err = f.page(pi)
- if err != nil {
- return n, err
- }
- }
- nc = copy(pg[po:], b)
- pi++
- po = 0
- rem -= nc
- b = b[nc:]
- }
- f.size = mathutil.MaxInt64(f.size, off+int64(n))
- return n, nil
-}
-
-// ----------------------------------------------------------------------------
-
-func readFrom(f Interface, r io.Reader) (n int64, err error) {
- f.Truncate(0)
- p := buffer.Get(copyBufSize)
- b := *p
- defer buffer.Put(p)
-
- var off int64
- var werr error
- for {
- rn, rerr := r.Read(b)
- if rn != 0 {
- _, werr = f.WriteAt(b[:rn], off)
- n += int64(rn)
- off += int64(rn)
- }
- if rerr != nil {
- if !fileutil.IsEOF(rerr) {
- err = rerr
- }
- break
- }
-
- if werr != nil {
- err = werr
- break
- }
- }
- return n, err
-}
-
-func writeTo(f Interface, w io.Writer) (n int64, err error) {
- p := buffer.Get(copyBufSize)
- b := *p
- defer buffer.Put(p)
-
- var off int64
- var werr error
- for {
- rn, rerr := f.ReadAt(b, off)
- if rn != 0 {
- _, werr = w.Write(b[:rn])
- n += int64(rn)
- off += int64(rn)
- }
- if rerr != nil {
- if !fileutil.IsEOF(rerr) {
- err = rerr
- }
- break
- }
-
- if werr != nil {
- err = werr
- break
- }
- }
- return n, err
-}
diff --git a/vendor/github.com/cznic/internal/slice/Makefile b/vendor/github.com/cznic/internal/slice/Makefile
deleted file mode 100644
index 5b8b148dc..000000000
--- a/vendor/github.com/cznic/internal/slice/Makefile
+++ /dev/null
@@ -1,55 +0,0 @@
-# Copyright 2016 The Internal Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
-
-clean:
- go clean
- rm -f *~ *.test *.out
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- @ 1>/dev/null 2>/dev/null gvim -p Makefile log *.go
-
-editor:
- gofmt -l -s -w *.go
- go test 2>&1 | tee log
- go build
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench . -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * | grep -v $(ngrep) || true
- @grep -nr $(grep) TODO * | grep -v $(ngrep) || true
- @grep -nr $(grep) BUG * | grep -v $(ngrep) || true
- @grep -nr $(grep) [^[:alpha:]]println * | grep -v $(ngrep) || true
diff --git a/vendor/github.com/cznic/internal/slice/pool.go b/vendor/github.com/cznic/internal/slice/pool.go
deleted file mode 100644
index f3ee2295c..000000000
--- a/vendor/github.com/cznic/internal/slice/pool.go
+++ /dev/null
@@ -1,173 +0,0 @@
-// Copyright 2016 The Internal Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package slice implements pools of pointers to slices.
-package slice
-
-import (
- "sync"
-
- "github.com/cznic/mathutil"
-)
-
-var (
- // Bytes is a ready to use *[]byte Pool.
- Bytes *Pool
- // Ints is a ready to use *[]int Pool.
- Ints *Pool
-)
-
-func init() {
- Bytes = newBytes()
- Ints = NewPool(
- func(size int) interface{} { // create
- b := make([]int, size)
- return &b
- },
- func(s interface{}) { // clear
- b := *s.(*[]int)
- b = b[:cap(b)]
- for i := range b {
- b[i] = 0
- }
- },
- func(s interface{}, size int) { // setSize
- p := s.(*[]int)
- *p = (*p)[:size]
- },
- func(s interface{}) int { return cap(*s.(*[]int)) }, // cap
- )
-}
-
-func newBytes() *Pool {
- return NewPool(
- func(size int) interface{} { // create
- b := make([]byte, size)
- return &b
- },
- func(s interface{}) { // clear
- b := *s.(*[]byte)
- b = b[:cap(b)]
- for i := range b {
- b[i] = 0
- }
- },
- func(s interface{}, size int) { // setSize
- p := s.(*[]byte)
- *p = (*p)[:size]
- },
- func(s interface{}) int { return cap(*s.(*[]byte)) }, // cap
- )
-}
-
-// Pool implements a pool of pointers to slices.
-//
-// Example usage pattern (assuming pool is, for example, a *[]byte Pool)
-//
-// p := pool.Get(size).(*[]byte)
-// b := *p // Now you can use b in any way you need.
-// ...
-// // When b will not be used anymore
-// pool.Put(p)
-// ...
-// // If b or p are not going out of scope soon, optionally
-// b = nil
-// p = nil
-//
-// Otherwise the pool cannot release the slice on garbage collection.
-//
-// Do not do
-//
-// p := pool.Get(size).(*[]byte)
-// b := *p
-// ...
-// pool.Put(&b)
-//
-// or
-//
-// b := *pool.Get(size).(*[]byte)
-// ...
-// pool.Put(&b)
-type Pool struct {
- cap func(interface{}) int
- clear func(interface{})
- m [63]sync.Pool
- null interface{}
- setSize func(interface{}, int)
-}
-
-// NewPool returns a newly created Pool. Assuming the desired slice type is
-// []T:
-//
-// The create function returns a *[]T of len == cap == size.
-//
-// The argument of clear is *[]T and the function sets all the slice elements
-// to the respective zero value.
-//
-// The setSize function gets a *[]T and sets its len to size.
-//
-// The cap function gets a *[]T and returns its capacity.
-func NewPool(
- create func(size int) interface{},
- clear func(interface{}),
- setSize func(p interface{}, size int),
- cap func(p interface{}) int,
-) *Pool {
- p := &Pool{clear: clear, setSize: setSize, cap: cap, null: create(0)}
- for i := range p.m {
- size := 1 << uint(i)
- p.m[i] = sync.Pool{New: func() interface{} {
- // 0: 1 - 1
- // 1: 10 - 10
- // 2: 11 - 100
- // 3: 101 - 1000
- // 4: 1001 - 10000
- // 5: 10001 - 100000
- return create(size)
- }}
- }
- return p
-}
-
-// CGet returns a *[]T of len size. The pointed to slice is zeroed up to its
-// cap. CGet panics for size < 0.
-//
-// CGet is safe for concurrent use by multiple goroutines.
-func (p *Pool) CGet(size int) interface{} {
- s := p.Get(size)
- p.clear(s)
- return s
-}
-
-// Get returns a *[]T of len size. The pointed to slice is not zeroed. Get
-// panics for size < 0.
-//
-// Get is safe for concurrent use by multiple goroutines.
-func (p *Pool) Get(size int) interface{} {
- var index int
- switch {
- case size < 0:
- panic("Pool.Get: negative size")
- case size == 0:
- return p.null
- case size > 1:
- index = mathutil.Log2Uint64(uint64(size-1)) + 1
- }
- s := p.m[index].Get()
- p.setSize(s, size)
- return s
-}
-
-// Put puts a *[]T into a pool for possible later reuse by CGet or Get. Put
-// panics is its argument is not of type *[]T.
-//
-// Put is safe for concurrent use by multiple goroutines.
-func (p *Pool) Put(b interface{}) {
- size := p.cap(b)
- if size == 0 {
- return
- }
-
- p.m[mathutil.Log2Uint64(uint64(size))].Put(b)
-}
diff --git a/vendor/github.com/cznic/kv/AUTHORS b/vendor/github.com/cznic/kv/AUTHORS
deleted file mode 100644
index 0078f5f5b..000000000
--- a/vendor/github.com/cznic/kv/AUTHORS
+++ /dev/null
@@ -1,11 +0,0 @@
-# This file lists authors for copyright purposes. This file is distinct from
-# the CONTRIBUTORS files. See the latter for an explanation.
-#
-# Names should be added to this file as:
-# Name or Organization
-#
-# The email address is not required for organizations.
-#
-# Please keep the list sorted.
-
-Jan Mercl <0xjnml@gmail.com>
diff --git a/vendor/github.com/cznic/kv/CONTRIBUTORS b/vendor/github.com/cznic/kv/CONTRIBUTORS
deleted file mode 100644
index f432c38c7..000000000
--- a/vendor/github.com/cznic/kv/CONTRIBUTORS
+++ /dev/null
@@ -1,13 +0,0 @@
-# This file lists people who contributed code to this repository. The AUTHORS
-# file lists the copyright holders; this file lists people.
-#
-# Names should be added to this file like so:
-# Name
-#
-# Please keep the list sorted.
-
-Brad Fitzpatrick
-Jan Mercl <0xjnml@gmail.com>
-Patrick Mézard
-Salmān Aljammāz
-Tamás Gulácsi
diff --git a/vendor/github.com/cznic/kv/LICENSE b/vendor/github.com/cznic/kv/LICENSE
deleted file mode 100644
index bffe74609..000000000
--- a/vendor/github.com/cznic/kv/LICENSE
+++ /dev/null
@@ -1,27 +0,0 @@
-Copyright (c) 2014 The kv Authors. All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are
-met:
-
- * Redistributions of source code must retain the above copyright
-notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above
-copyright notice, this list of conditions and the following disclaimer
-in the documentation and/or other materials provided with the
-distribution.
- * Neither the names of the authors nor the names of the
-contributors may be used to endorse or promote products derived from
-this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/github.com/cznic/kv/Makefile b/vendor/github.com/cznic/kv/Makefile
deleted file mode 100644
index adabc0f7f..000000000
--- a/vendor/github.com/cznic/kv/Makefile
+++ /dev/null
@@ -1,55 +0,0 @@
-# Copyright 2014 The kv Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
-
-clean:
- go clean
- rm -f *~ *.test *.out _testdata/temp*
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- gvim -p Makefile *.go
-
-editor:
- gofmt -l -s -w *.go
- go test 2>&1 | tee log
- go build
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench . -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * || true
- @grep -nr $(grep) TODO * || true
- @grep -nr $(grep) BUG * || true
- @grep -nr $(grep) [^[:alpha:]]println * || true
diff --git a/vendor/github.com/cznic/kv/README.md b/vendor/github.com/cznic/kv/README.md
deleted file mode 100644
index a22116d65..000000000
--- a/vendor/github.com/cznic/kv/README.md
+++ /dev/null
@@ -1,10 +0,0 @@
-kv
-==
-
-Package kv implements a simple and easy to use persistent key/value (KV) store.
-
-Installation
-
- $ go get github.com/cznic/kv
-
-Documentation: [godoc.org/github.com/cznic/kv](http://godoc.org/github.com/cznic/kv)
diff --git a/vendor/github.com/cznic/kv/doc.go b/vendor/github.com/cznic/kv/doc.go
deleted file mode 100644
index 815eaf4bf..000000000
--- a/vendor/github.com/cznic/kv/doc.go
+++ /dev/null
@@ -1,86 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-/*
-
-Package kv implements a simple and easy to use persistent key/value (KV) store.
-
-Changelog
-
-2016-07-11: KV now uses the stable version of lldb. (github.com/cznic/lldb).
-
-The stored KV pairs are sorted in the key collation order defined by an user
-supplied 'compare' function (passed as a field in Options).
-
-Keys and Values Limits
-
-Keys, as well as the values associated with them, are opaque []bytes. Maximum
-size of a "native" key or value is 65787 bytes. Larger keys or values have to
-be composed of the "native" ones in client code.
-
-Database limits
-
-The maximum DB size kv can handle is 2^60 bytes (1 exabyte). See also [4]:
-"Block handles".
-
-ACID and transactional properties
-
-Transactions are resource limited. All changes made by a transaction are held
-in memory until the top level transaction is committed. ACID[1] implementation
-notes/details follows.
-
-Atomicity
-
-A successfully committed transaction appears (by its effects on the database)
-to be indivisible ("atomic") iff the transaction is performed in isolation. An
-aborted (via RollBack) transaction appears like it never happened under the
-same limitation.
-
-Atomic updates to the DB, via functions like Set, Inc, etc., are performed in
-their own automatic transaction. If the partial progress of any such function
-fails at any point, the automatic transaction is canceled via Rollback before
-returning from the function. A non nil error is returned in that case.
-
-Consistency
-
-All reads, including those made from any other concurrent non isolated
-transaction(s), performed during a not yet committed transaction, are dirty
-reads, i.e. the data returned are consistent with the in-progress state of the
-open transaction, or all of the open transactions. Obviously, conflicts, data
-races and inconsistent states can happen, but iff non isolated transactions are
-performed.
-
-Performing a Rollback at a nested transaction level properly returns the
-transaction state (and data read from the DB) to what it was before the
-respective BeginTransaction.
-
-Isolation
-
-Transactions of the atomic updating functions (Set, Put, Delete ...) are always
-isolated. Transactions controlled by BeginTransaction/Commit/RollBack, are
-isolated iff their execution is serialized.
-
-Durability
-
-Transactions are committed using the two phase commit protocol(2PC)[2] and a
-write ahead log(WAL)[3]. DB recovery after a crash is performed automatically
-using data from the WAL. Last transaction data, either of an in progress
-transaction or a transaction being committed at the moment of the crash, can get
-lost.
-
-No protection from non readable files, files corrupted by other processes or by
-memory faults or other HW problems, is provided. Always properly backup your DB
-data file(s).
-
-Links
-
-Referenced from above:
-
- [1]: http://en.wikipedia.org/wiki/ACID
- [2]: http://en.wikipedia.org/wiki/2PC
- [3]: http://en.wikipedia.org/wiki/Write_ahead_logging
- [4]: http://godoc.org/github.com/cznic/lldb#Allocator
-
-*/
-package kv
diff --git a/vendor/github.com/cznic/kv/etc.go b/vendor/github.com/cznic/kv/etc.go
deleted file mode 100644
index f10cefef4..000000000
--- a/vendor/github.com/cznic/kv/etc.go
+++ /dev/null
@@ -1,31 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package kv
-
-import (
- "bytes"
- "fmt"
-)
-
-type header struct {
- magic []byte
- ver byte
- reserved []byte
-}
-
-func (h *header) rd(b []byte) error {
- if len(b) != 16 {
- panic("internal error")
- }
-
- if h.magic = b[:4]; !bytes.Equal(h.magic, []byte(magic)) {
- return fmt.Errorf("Unknown file format")
- }
-
- b = b[4:]
- h.ver = b[0]
- h.reserved = b[1:]
- return nil
-}
diff --git a/vendor/github.com/cznic/kv/kv.go b/vendor/github.com/cznic/kv/kv.go
deleted file mode 100644
index d852aba13..000000000
--- a/vendor/github.com/cznic/kv/kv.go
+++ /dev/null
@@ -1,851 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package kv
-
-import (
- "encoding/binary"
- "fmt"
- "io"
- "os"
- "sync"
- "time"
-
- "github.com/cznic/fileutil"
- "github.com/cznic/internal/buffer"
- "github.com/cznic/lldb"
-)
-
-const (
- magic = "\x60\xdbKV"
-)
-
-const (
- stDisabled = iota // stDisabled must be zero
- stIdle
- stCollecting
- stIdleArmed
- stCollectingArmed
- stCollectingTriggered
- stEndUpdateFailed
-)
-
-func init() {
- if stDisabled != 0 {
- panic("stDisabled != 0")
- }
-}
-
-// DB represents the database (the KV store).
-type DB struct {
- acidNest int // Grace period nesting level
- acidState int // Grace period FSM state.
- acidTimer *time.Timer // Grace period timer
- alloc *lldb.Allocator // The machinery. Wraps filer
- bkl sync.Mutex // Big Kernel Lock
- closeMu sync.Mutex // Close() coordination
- closed bool // it was
- filer lldb.Filer // Wraps f
- gracePeriod time.Duration // WAL grace period
- isMem bool // No signal capture
- lastCommitErr error // from failed EndUpdate
- lock io.Closer // The DB file lock
- opts *Options
- root *lldb.BTree // The KV layer
- wal *os.File // WAL if any
-}
-
-// CreateFromFiler is like Create but accepts an arbitrary backing storage
-// provided by filer.
-//
-// For the meaning of opts please see documentation of Options.
-func CreateFromFiler(filer lldb.Filer, opts *Options) (db *DB, err error) {
- opts = opts.clone()
- opts._ACID = _ACIDFull
- return create(filer, opts, false)
-}
-
-// Create creates the named DB file mode 0666 (before umask). The file must not
-// already exist. If successful, methods on the returned DB can be used for
-// I/O; the associated file descriptor has mode os.O_RDWR. If there is an
-// error, it will be of type *os.PathError.
-//
-// For the meaning of opts please see documentation of Options.
-func Create(name string, opts *Options) (db *DB, err error) {
- opts = opts.clone()
- opts._ACID = _ACIDFull
- f, err := os.OpenFile(name, os.O_RDWR|os.O_CREATE|os.O_EXCL, 0666)
- if err != nil {
- return
- }
-
- return CreateFromFiler(lldb.NewSimpleFileFiler(f), opts)
-}
-
-func create(filer lldb.Filer, opts *Options, isMem bool) (db *DB, err error) {
- defer func() {
- if db != nil {
- db.opts = opts
- }
- }()
- defer func() {
- lock := opts.lock
- if err != nil && lock != nil {
- lock.Close()
- db = nil
- }
- }()
-
- if err = opts.check(filer.Name(), true, !isMem); err != nil {
- return
- }
-
- b := [16]byte{byte(magic[0]), byte(magic[1]), byte(magic[2]), byte(magic[3]), 0x00} // ver 0x00
- if n, err := filer.WriteAt(b[:], 0); n != 16 {
- return nil, &os.PathError{Op: "kv.create.WriteAt", Path: filer.Name(), Err: err}
- }
-
- db = &DB{lock: opts.lock}
-
- filer = lldb.NewInnerFiler(filer, 16)
- if filer, err = opts.acidFiler(db, filer); err != nil {
- return nil, err
- }
-
- db.filer = filer
- if err = filer.BeginUpdate(); err != nil {
- return
- }
-
- defer func() {
- if e := filer.EndUpdate(); e != nil {
- if err == nil {
- err = e
- }
- }
- }()
-
- if db.alloc, err = lldb.NewAllocator(filer, &lldb.Options{}); err != nil {
- return nil, &os.PathError{Op: "kv.create", Path: filer.Name(), Err: err}
- }
-
- db.alloc.Compress = true
- db.isMem = isMem
- var h int64
- if db.root, h, err = lldb.CreateBTree(db.alloc, opts.Compare); err != nil {
- return
- }
-
- if h != 1 {
- panic("internal error")
- }
-
- db.wal = opts.wal
- return
-}
-
-// CreateMem creates a new instance of an in-memory DB not backed by a disk
-// file. Memory DBs are resource limited as they are completely held in memory
-// and are not automatically persisted.
-//
-// For the meaning of opts please see documentation of Options.
-func CreateMem(opts *Options) (db *DB, err error) {
- opts = opts.clone()
- opts._ACID = _ACIDTransactions
- f := lldb.NewMemFiler()
- return create(f, opts, true)
-}
-
-// CreateTemp creates a new temporary DB in the directory dir with a basename
-// beginning with prefix and name ending in suffix. If dir is the empty string,
-// CreateTemp uses the default directory for temporary files (see os.TempDir).
-// Multiple programs calling CreateTemp simultaneously will not choose the same
-// file name for the DB. The caller can use Name() to find the pathname of the
-// DB file. It is the caller's responsibility to remove the file when no longer
-// needed.
-//
-// For the meaning of opts please see documentation of Options.
-func CreateTemp(dir, prefix, suffix string, opts *Options) (db *DB, err error) {
- opts = opts.clone()
- opts._ACID = _ACIDFull
- f, err := fileutil.TempFile(dir, prefix, suffix)
- if err != nil {
- return
- }
-
- return create(lldb.NewSimpleFileFiler(f), opts, false)
-}
-
-// Open opens the named DB file for reading/writing. If successful, methods on
-// the returned DB can be used for I/O; the associated file descriptor has mode
-// os.O_RDWR. If there is an error, it will be of type *os.PathError.
-//
-// Note: While a DB is opened, it is locked and cannot be simultaneously opened
-// again.
-//
-// For the meaning of opts please see documentation of Options.
-func Open(name string, opts *Options) (db *DB, err error) {
- f, err := os.OpenFile(name, os.O_RDWR, 0666)
- if err != nil {
- return nil, err
- }
-
- return OpenFromFiler(lldb.NewSimpleFileFiler(f), opts)
-}
-
-// OpenFromFiler is like Open but it accepts an arbitrary backing storage
-// provided by filer.
-func OpenFromFiler(filer lldb.Filer, opts *Options) (db *DB, err error) {
- opts = opts.clone()
- opts._ACID = _ACIDFull
- defer func() {
- if db != nil {
- db.opts = opts
- }
- }()
- defer func() {
- lock := opts.lock
- if err != nil && lock != nil {
- lock.Close()
- db = nil
- }
- if err != nil {
- if db != nil {
- db.Close()
- db = nil
- }
- }
- }()
-
- name := filer.Name()
- if err = opts.check(name, false, true); err != nil {
- return
- }
-
- sz, err := filer.Size()
- if err != nil {
- return
- }
-
- if sz%16 != 0 {
- return nil, &os.PathError{Op: "kv.Open:", Path: name, Err: fmt.Errorf("file size %d(%#x) is not 0 (mod 16)", sz, sz)}
- }
-
- var b [16]byte
- if n, err := filer.ReadAt(b[:], 0); n != 16 || err != nil {
- return nil, &os.PathError{Op: "kv.Open.ReadAt", Path: name, Err: err}
- }
-
- var h header
- if err = h.rd(b[:]); err != nil {
- return nil, &os.PathError{Op: "kv.Open:validate header", Path: name, Err: err}
- }
-
- db = &DB{lock: opts.lock}
- if filer, err = opts.acidFiler(db, filer); err != nil {
- return nil, err
- }
-
- db.filer = filer
- switch h.ver {
- default:
- return nil, &os.PathError{Op: "kv.Open", Path: name, Err: fmt.Errorf("unknown/unsupported kv file format version %#x", h.ver)}
- case 0x00:
- if _, err = open00(name, db); err != nil {
- return nil, err
- }
- }
-
- db.root, err = lldb.OpenBTree(db.alloc, opts.Compare, 1)
- db.wal = opts.wal
- if opts.VerifyDbAfterOpen {
- err = verifyAllocator(db.alloc)
- }
- return
-}
-
-// Close closes the DB, rendering it unusable for I/O. It returns an error, if
-// any. Failing to call Close before exiting a program can lose the last open
-// or being committed transaction.
-//
-// Successful Close is idempotent.
-func (db *DB) Close() (err error) {
- db.closeMu.Lock()
- defer db.closeMu.Unlock()
- if db.closed {
- return
- }
-
- db.closed = true
-
- if err = db.enter(); err != nil {
- return
- }
-
- doLeave := true
- defer func() {
- db.wal = nil
- if e := recover(); e != nil {
- err = fmt.Errorf("%v", e)
- }
- if doLeave {
- db.leave(&err)
- }
- }()
-
- if db.acidTimer != nil {
- db.acidTimer.Stop()
- }
-
- var e error
- for db.acidNest > 0 {
- db.acidNest--
- if e = db.filer.EndUpdate(); err == nil {
- err = e
- }
- }
-
- doLeave = false
- if e = db.leave(&err); err == nil {
- err = e
- }
- if db.opts.VerifyDbBeforeClose {
- if e = verifyAllocator(db.alloc); err == nil {
- err = e
- }
- }
- if e = db.close(); err == nil {
- err = e
- }
- if lock := db.lock; lock != nil {
- if e = lock.Close(); err == nil {
- err = e
- }
- }
- if wal := db.wal; wal != nil {
- e = wal.Close()
- db.wal = nil
- if err == nil {
- err = e
- }
- }
- return
-}
-
-func (db *DB) close() (err error) {
- // We are safe to close due to locked db.closeMu, but not safe against
- // any other goroutine concurrently calling other exported db methods,
- // causing a race[0] in the db.enter() mechanism. So we must lock
- // db.bkl.
- //
- // [0]: https://github.com/cznic/kv/issues/17#issuecomment-31960658
- db.bkl.Lock()
- defer db.bkl.Unlock()
-
- if db.isMem { // lldb.MemFiler
- return
- }
-
- err = db.filer.Sync()
- if e := db.filer.Close(); err == nil {
- err = e
- }
- if db.opts.VerifyDbAfterClose {
- if e := verifyDbFile(db.Name()); err == nil {
- err = e
- }
- }
- return
-}
-
-// Name returns the name of the DB file.
-func (db *DB) Name() string {
- return db.filer.Name()
-}
-
-// Size returns the size of the DB file.
-func (db *DB) Size() (sz int64, err error) {
- db.bkl.Lock()
- defer func() {
- if e := recover(); e != nil {
- err = fmt.Errorf("%v", e)
- }
- db.bkl.Unlock()
- }()
-
- return db.filer.Size()
-}
-
-func (db *DB) enter() (err error) {
- db.bkl.Lock()
- switch db.acidState {
- default:
- panic("internal error")
- case stDisabled:
- db.acidNest++
- if db.acidNest == 1 {
- if err = db.filer.BeginUpdate(); err != nil {
- return err
- }
- }
- case stIdle:
- if err = db.filer.BeginUpdate(); err != nil {
- return err
- }
-
- db.acidNest = 1
- db.acidTimer = time.AfterFunc(db.gracePeriod, db.timeout)
- db.acidState = stCollecting
- case stCollecting:
- db.acidNest++
- case stIdleArmed:
- db.acidNest = 1
- db.acidState = stCollectingArmed
- case stCollectingArmed:
- db.acidNest++
- case stCollectingTriggered:
- db.acidNest++
- case stEndUpdateFailed:
- return db.leave(&err)
- }
-
- return nil
-}
-
-func (db *DB) leave(err *error) error {
- switch db.acidState {
- default:
- panic("internal error")
- case stDisabled:
- db.acidNest--
- if db.acidNest == 0 {
- if e := db.filer.EndUpdate(); e != nil && *err == nil {
- *err = e
- }
- }
- case stCollecting:
- db.acidNest--
- if db.acidNest == 0 {
- db.acidState = stIdleArmed
- }
- case stCollectingArmed:
- db.acidNest--
- if db.acidNest == 0 {
- db.acidState = stIdleArmed
- }
- case stCollectingTriggered:
- db.acidNest--
- if db.acidNest == 0 {
- if e := db.filer.EndUpdate(); e != nil && *err == nil {
- *err = e
- }
- db.acidState = stIdle
- }
- case stEndUpdateFailed:
- db.bkl.Unlock()
- return fmt.Errorf("Last transaction commit failed: %v", db.lastCommitErr)
- }
-
- if *err != nil {
- db.filer.Rollback() // return the original, input error
- }
- db.bkl.Unlock()
- return *err
-}
-
-func (db *DB) timeout() {
- db.closeMu.Lock()
- defer db.closeMu.Unlock()
- if db.closed {
- return
- }
-
- db.bkl.Lock()
- defer db.bkl.Unlock()
-
- switch db.acidState {
- default:
- panic("internal error")
- case stIdle:
- panic("internal error")
- case stCollecting:
- db.acidState = stCollectingTriggered
- case stIdleArmed:
- if err := db.filer.EndUpdate(); err != nil { // If EndUpdate fails, no WAL was written (automatic Rollback)
- db.acidState = stEndUpdateFailed
- db.lastCommitErr = err
- return
- }
-
- db.acidState = stIdle
- case stCollectingArmed:
- db.acidState = stCollectingTriggered
- case stCollectingTriggered:
- panic("internal error")
- }
-}
-
-// BeginTransaction starts a new transaction. Every call to BeginTransaction
-// must be eventually "balanced" by exactly one call to Commit or Rollback (but
-// not both). Calls to BeginTransaction may nest.
-//
-// BeginTransaction is atomic and it is safe for concurrent use by multiple
-// goroutines (if/when that makes sense).
-func (db *DB) BeginTransaction() (err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- defer func() {
- if e := recover(); e != nil {
- err = fmt.Errorf("%v", e)
- }
- db.leave(&err)
- }()
-
- db.acidNest++
- return db.filer.BeginUpdate()
-}
-
-// Commit commits the current transaction. If the transaction is the top level
-// one, then all of the changes made within the transaction are atomically made
-// persistent in the DB. Invocation of an unbalanced Commit is an error.
-//
-// Commit is atomic and it is safe for concurrent use by multiple goroutines
-// (if/when that makes sense).
-func (db *DB) Commit() (err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- defer func() {
- if e := recover(); e != nil {
- err = fmt.Errorf("%v", e)
- }
- db.leave(&err)
- }()
-
- db.acidNest--
- return db.filer.EndUpdate()
-}
-
-// Rollback cancels and undoes the innermost transaction level. If the
-// transaction is the top level one, then no of the changes made within the
-// transactions are persisted. Invocation of an unbalanced Rollback is an
-// error.
-//
-// Rollback is atomic and it is safe for concurrent use by multiple goroutines
-// (if/when that makes sense).
-func (db *DB) Rollback() (err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- defer func() {
- if e := recover(); e != nil {
- err = fmt.Errorf("%v", e)
- }
- db.leave(&err)
- }()
-
- db.acidNest--
- return db.filer.Rollback()
-}
-
-// Verify attempts to find any structural errors in DB wrt the organization of
-// it as defined by lldb.Allocator. Any problems found are reported to 'log'
-// except non verify related errors like disk read fails etc. If 'log' returns
-// false or the error doesn't allow to (reliably) continue, the verification
-// process is stopped and an error is returned from the Verify function.
-// Passing a nil log works like providing a log function always returning
-// false. Any non-structural errors, like for instance Filer read errors, are
-// NOT reported to 'log', but returned as the Verify's return value, because
-// Verify cannot proceed in such cases. Verify returns nil only if it fully
-// completed verifying DB without detecting any error.
-//
-// It is recommended to limit the number reported problems by returning false
-// from 'log' after reaching some limit. Huge and corrupted DB can produce an
-// overwhelming error report dataset.
-//
-// The verifying process will scan the whole DB at least 3 times (a trade
-// between processing space and time consumed). It doesn't read the content of
-// free blocks above the head/tail info bytes. If the 3rd phase detects lost
-// free space, then a 4th scan (a faster one) is performed to precisely report
-// all of them.
-//
-// Statistics are returned via 'stats' if non nil. The statistics are valid
-// only if Verify succeeded, ie. it didn't reported anything to log and it
-// returned a nil error.
-func (db *DB) Verify(log func(error) bool, stats *lldb.AllocStats) (err error) {
- bitmapf, err := fileutil.TempFile("", "verifier", ".tmp")
- if err != nil {
- return
- }
-
- defer func() {
- tn := bitmapf.Name()
- bitmapf.Close()
- os.Remove(tn)
- }()
-
- bitmap := lldb.NewSimpleFileFiler(bitmapf)
-
- if err = db.enter(); err != nil {
- return
- }
-
- defer func() {
- if e := recover(); e != nil {
- err = fmt.Errorf("%v", e)
- }
- db.leave(&err)
- }()
-
- return db.alloc.Verify(bitmap, log, stats)
-}
-
-// Delete deletes key and its associated value from the DB.
-//
-// Delete is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Delete(key []byte) (err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- err = db.root.Delete(key)
- return db.leave(&err)
-}
-
-// Extract is a combination of Get and Delete. If the key exists in the DB, it
-// is returned (like Get) and also deleted from the DB in a more efficient way
-// which doesn't search for the key twice. The returned slice may be a
-// sub-slice of buf if buf was large enough to hold the entire content.
-// Otherwise, a newly allocated slice will be returned. It is valid to pass a
-// nil buf.
-//
-// Extract is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Extract(buf, key []byte) (value []byte, err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- value, err = db.root.Extract(buf, key)
- db.leave(&err)
- return
-}
-
-// First returns the first KV pair in the DB, if it exists. Otherwise key ==
-// nil and value == nil.
-//
-// First is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) First() (key, value []byte, err error) {
- db.bkl.Lock()
- defer db.bkl.Unlock()
- return db.root.First()
-}
-
-// Get returns the value associated with key, or nil if no such value exists.
-// The returned slice may be a sub-slice of buf if buf was large enough to hold
-// the entire content. Otherwise, a newly allocated slice will be returned. It
-// is valid to pass a nil buf.
-//
-// Get is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Get(buf, key []byte) (value []byte, err error) {
- db.bkl.Lock()
- defer db.bkl.Unlock()
- return db.root.Get(buf, key)
-}
-
-// Last returns the last KV pair of the DB, if it exists. Otherwise key ==
-// nil and value == nil.
-//
-// Last is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Last() (key, value []byte, err error) {
- db.bkl.Lock()
- defer db.bkl.Unlock()
- return db.root.Last()
-}
-
-// Put combines Get and Set in a more efficient way where the DB is searched
-// for the key only once. The upd(ater) receives the current (key, old-value),
-// if that exists or (key, nil) otherwise. It can then return a (new-value,
-// true, nil) to create or overwrite the existing value in the KV pair, or
-// (whatever, false, nil) if it decides not to create or not to update the
-// value of the KV pair.
-//
-// db.Set(k, v)
-//
-// conceptually equals
-//
-// db.Put(k, func(k, v []byte){ return v, true }([]byte, bool))
-//
-// modulo the differing return values.
-//
-// The returned slice may be a sub-slice of buf if buf was large enough to hold
-// the entire content. Otherwise, a newly allocated slice will be returned. It
-// is valid to pass a nil buf.
-//
-// Put is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Put(buf, key []byte, upd func(key, old []byte) (new []byte, write bool, err error)) (old []byte, written bool, err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- old, written, err = db.root.Put(buf, key, upd)
- db.leave(&err)
- return
-}
-
-// Seek returns an enumerator positioned on the first key/value pair whose key
-// is 'greater than or equal to' the given key. There may be no such pair, in
-// which case the Next,Prev methods of the returned enumerator will always
-// return io.EOF.
-//
-// Seek is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Seek(key []byte) (enum *Enumerator, hit bool, err error) {
- db.bkl.Lock()
- defer db.bkl.Unlock()
- enum0, hit, err := db.root.Seek(key)
- if err != nil {
- return
- }
-
- enum = &Enumerator{
- db: db,
- enum: enum0,
- }
- return
-}
-
-// SeekFirst returns an enumerator positioned on the first KV pair in the DB,
-// if any. For an empty DB, err == io.EOF is returned.
-//
-// SeekFirst is atomic and it is safe for concurrent use by multiple
-// goroutines.
-func (db *DB) SeekFirst() (enum *Enumerator, err error) {
- db.bkl.Lock()
- defer db.bkl.Unlock()
- enum0, err := db.root.SeekFirst()
- if err != nil {
- return
- }
-
- enum = &Enumerator{
- db: db,
- enum: enum0,
- }
- return
-}
-
-// SeekLast returns an enumerator positioned on the last KV pair in the DB,
-// if any. For an empty DB, err == io.EOF is returned.
-//
-// SeekLast is atomic and it is safe for concurrent use by multiple
-// goroutines.
-func (db *DB) SeekLast() (enum *Enumerator, err error) {
- db.bkl.Lock()
- defer db.bkl.Unlock()
- enum0, err := db.root.SeekLast()
- if err != nil {
- return
- }
-
- enum = &Enumerator{
- db: db,
- enum: enum0,
- }
- return
-}
-
-// Set sets the value associated with key. Any previous value, if existed, is
-// overwritten by the new one.
-//
-// Set is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Set(key, value []byte) (err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- err = db.root.Set(key, value)
- db.leave(&err)
- return
-}
-
-// Enumerator captures the state of enumerating a DB. It is returned from the
-// Seek* methods. Multiple enumerations may be in progress simultaneously. The
-// enumerator is aware of any mutations made to the tree in the process of
-// enumerating it and automatically resumes the enumeration.
-//
-// Multiple concurrently executing enumerations may be in progress.
-type Enumerator struct {
- db *DB
- enum *lldb.BTreeEnumerator
-}
-
-// Next returns the currently enumerated KV pair, if it exists and moves to the
-// next KV in the key collation order. If there is no KV pair to return, err ==
-// io.EOF is returned.
-//
-// Next is atomic and it is safe for concurrent use by multiple goroutines.
-func (e *Enumerator) Next() (key, value []byte, err error) {
- e.db.bkl.Lock()
- defer e.db.bkl.Unlock()
- return e.enum.Next()
-}
-
-// Prev returns the currently enumerated KV pair, if it exists and moves to the
-// previous KV in the key collation order. If there is no KV pair to return,
-// err == io.EOF is returned.
-//
-// Prev is atomic and it is safe for concurrent use by multiple goroutines.
-func (e *Enumerator) Prev() (key, value []byte, err error) {
- e.db.bkl.Lock()
- defer e.db.bkl.Unlock()
- return e.enum.Prev()
-}
-
-// Inc atomically increments the value associated with key by delta and
-// returns the new value. If the value doesn't exists before calling Inc or if
-// the value is not an [8]byte, the value is considered to be zero before peforming Inc.
-//
-// Inc is atomic and it is safe for concurrent use by multiple goroutines.
-func (db *DB) Inc(key []byte, delta int64) (val int64, err error) {
- if err = db.enter(); err != nil {
- return
- }
-
- defer db.leave(&err)
-
- pbuf := buffer.Get(8)
- defer buffer.Put(pbuf)
- _, _, err = db.root.Put(
- *pbuf,
- key,
- func(key []byte, old []byte) (new []byte, write bool, err error) {
- write = true
- if len(old) == 8 {
- val = int64(binary.BigEndian.Uint64(old))
- } else {
- old = make([]byte, 8)
- val = 0
- }
- val += delta
- binary.BigEndian.PutUint64(old, uint64(val))
- new = old
- return
- },
- )
-
- return
-}
-
-// WALName returns the name of the WAL file in use or an empty string for memory
-// or closed databases.
-func (db *DB) WALName() string {
- if f := db.wal; f != nil {
- return f.Name()
- }
-
- return ""
-}
diff --git a/vendor/github.com/cznic/kv/lock.go b/vendor/github.com/cznic/kv/lock.go
deleted file mode 100644
index 183523f99..000000000
--- a/vendor/github.com/cznic/kv/lock.go
+++ /dev/null
@@ -1,58 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package kv
-
-import (
- "crypto/sha1"
- "fmt"
- "io"
- "os"
- "path/filepath"
- "sync"
-)
-
-func lockName(dbname string) string {
- base := filepath.Base(filepath.Clean(dbname)) + "lockfile"
- h := sha1.New()
- io.WriteString(h, base)
- return filepath.Join(filepath.Dir(dbname), fmt.Sprintf(".%x", h.Sum(nil)))
-}
-
-func defaultLocker(dbname string) (io.Closer, error) {
- lname := lockName(dbname)
- abs, err := filepath.Abs(lname)
- if err != nil {
- return nil, err
- }
- f, err := os.OpenFile(abs, os.O_CREATE|os.O_EXCL|os.O_RDONLY, 0666)
- if os.IsExist(err) {
- return nil, fmt.Errorf("cannot access DB %q: lock file %q exists", dbname, abs)
- }
- if err != nil {
- return nil, err
- }
- return &lockCloser{f: f, abs: abs}, nil
-}
-
-type lockCloser struct {
- f *os.File
- abs string
- once sync.Once
- err error
-}
-
-func (lc *lockCloser) Close() error {
- lc.once.Do(lc.close)
- return lc.err
-}
-
-func (lc *lockCloser) close() {
- if err := lc.f.Close(); err != nil {
- lc.err = err
- }
- if err := os.Remove(lc.abs); err != nil {
- lc.err = err
- }
-}
diff --git a/vendor/github.com/cznic/kv/options.go b/vendor/github.com/cznic/kv/options.go
deleted file mode 100644
index 00d15a862..000000000
--- a/vendor/github.com/cznic/kv/options.go
+++ /dev/null
@@ -1,246 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package kv
-
-import (
- "crypto/sha1"
- "fmt"
- "io"
- "os"
- "path/filepath"
- "time"
-
- "github.com/cznic/lldb"
-)
-
-const (
- // BeginUpdate/EndUpdate/Rollback will be no-ops. All operations
- // updating a DB will be written immediately including partial updates
- // during operation's progress. If any update fails, the DB can become
- // unusable. The same applies to DB crashes and/or any other non clean
- // DB shutdown.
- _ACIDNone = iota
-
- // Enable transactions. BeginUpdate/EndUpdate/Rollback will be
- // effective. All operations on the DB will be automatically performed
- // within a transaction. Operations will thus either succeed completely
- // or have no effect at all - they will be rollbacked in case of any
- // error. If any update fails the DB will not be corrupted. DB crashes
- // and/or any other non clean DB shutdown may still render the DB
- // unusable.
- _ACIDTransactions
-
- // Enable durability. Same as ACIDTransactions plus enables 2PC and
- // WAL. Updates to the DB will be first made permanent in a WAL and
- // only after that reflected in the DB. A DB will automatically recover
- // from crashes and/or any other non clean DB shutdown. Only last
- // uncommitted transaction (transaction in progress ATM of a crash) can
- // get lost.
- //
- // NOTE: Options.GracePeriod may extend the span of a single
- // transaction to a batch of multiple transactions.
- //
- // NOTE2: Non zero GracePeriod requires GOMAXPROCS > 1 to work. Dbm
- // checks GOMAXPROCS in such case and if the value is 1 it
- // automatically sets GOMAXPROCS = 2.
- _ACIDFull
-)
-
-// Options are passed to the DB create/open functions to amend the behavior of
-// those functions. The compatibility promise is the same as of struct types in
-// the Go standard library - introducing changes can be made only by adding new
-// exported fields, which is backward compatible as long as client code uses
-// field names to assign values of imported struct types literals.
-type Options struct {
- // Compare compares x and y. Compare may be nil, then bytes.Compare is
- // used instead.
- //
- // Compare returns:
- //
- // -1 if x < y
- // 0 if x == y
- // +1 if x > y
- Compare func(x, y []byte) int
-
- // Locker specifies a function to lock a named file.
- // On success it returns an io.Closer to release the lock.
- // If nil, a default implementation is used.
- Locker func(name string) (io.Closer, error)
-
- // See the ACID* constants documentation.
- _ACID int
-
- // The write ahead log pathname. Applicable iff ACID == ACIDFull. May
- // be left empty in which case an unspecified pathname will be chosen,
- // which is computed from the DB name and which will be in the same
- // directory as the DB. Moving or renaming the DB while it is shut down
- // will break it's connection to the automatically computed name.
- // Moving both the files (the DB and the WAL) into another directory
- // with no renaming is safe.
- //
- // On creating a new DB the WAL file must not exist or it must be
- // empty. It's not safe to write to a non empty WAL file as it may
- // contain unprocessed DB recovery data.
- WAL string
-
- // Time to collect transactions before committing them into the WAL.
- // Applicable iff ACID == ACIDFull. All updates are held in memory
- // during the grace period so it should not be more than few seconds at
- // most.
- //
- // Recommended value for GracePeriod is 1 second.
- //
- // NOTE: Using small GracePeriod values will make DB updates very slow.
- // Zero GracePeriod will make every single update a separate 2PC/WAL
- // transaction. Values smaller than about 100-200 milliseconds
- // (particularly for mechanical, rotational HDs) are not recommended
- // and they may not be always honored.
- _GracePeriod time.Duration
- wal *os.File
- lock io.Closer
-
- noClone bool // test hook
-
- // VerifyDbBeforeOpen turns on structural verification of the DB before
- // it is opened. This verification may legitimately fail if the DB
- // crashed and a yet-to-be-processed non empty WAL file exists.
- VerifyDbBeforeOpen bool
-
- // VerifyDbAfterOpen turns on structural verification of the DB after
- // it is opened and possibly recovered from WAL.
- VerifyDbAfterOpen bool
-
- // VerifyDbBeforeClose turns on structural verification of the DB
- // before it is closed.
- VerifyDbBeforeClose bool
-
- // VerifyDbAfterClose turns on structural verification of the DB after
- // it is closed.
- VerifyDbAfterClose bool
-
- // Turns on verification of every single mutation of the DB. Before any
- // such mutation a snapshot of the DB is created and the specific
- // mutation operation and parameters are recorded. After the mutation
- // the whole DB is verified. If the verification fails the last known
- // good state (the snapshot discussed above) and the corrupted state
- // are "core" dumped to a well known location (TBD).
- //
- //MAYBE ParanoidUpdates bool
-}
-
-func (o *Options) locker(dbname string) (io.Closer, error) {
- if o == nil || o.Locker == nil {
- return defaultLocker(dbname)
- }
- return o.Locker(dbname)
-}
-
-func (o *Options) clone() *Options {
- if o.noClone {
- return o
- }
-
- r := &Options{}
- *r = *o
- return r
-}
-
-func (o *Options) check(dbname string, new, lock bool) (err error) {
- if lock {
- if o.lock, err = o.locker(dbname); err != nil {
- return
- }
- }
-
- if o.VerifyDbBeforeOpen && !new {
- if err = verifyDbFile(dbname); err != nil {
- return
- }
- }
-
- switch o._ACID {
- default:
- panic("internal error")
- case _ACIDTransactions:
- case _ACIDFull:
- o._GracePeriod = time.Second
- if o.WAL == "" {
- o.WAL = o.walName(dbname, o.WAL)
- }
-
- switch new {
- case true:
- if o.wal, err = os.OpenFile(o.WAL, os.O_CREATE|os.O_EXCL|os.O_RDWR, 0666); err != nil {
- if os.IsExist(err) {
- fi, e := os.Stat(o.WAL)
- if e != nil {
- return e
- }
-
- if sz := fi.Size(); sz != 0 {
- return fmt.Errorf("cannot create DB %q: non empty WAL file %q (size %d) exists", dbname, o.WAL, sz)
- }
-
- o.wal, err = os.OpenFile(o.WAL, os.O_RDWR, 0666)
- }
- return
- }
- case false:
- if o.wal, err = os.OpenFile(o.WAL, os.O_RDWR, 0666); err != nil {
- if os.IsNotExist(err) {
- if o.wal, err = os.OpenFile(o.WAL, os.O_CREATE|os.O_EXCL|os.O_RDWR, 0666); err != nil {
- return fmt.Errorf("cannot open DB %q: failed to create WAL file %q: %v", dbname, o.WAL, err)
- }
-
- err = nil
- }
- return err
- }
- }
- }
-
- return err
-}
-
-func (o *Options) walName(dbname, wal string) (r string) {
- if wal != "" {
- return filepath.Clean(wal)
- }
-
- base := filepath.Base(filepath.Clean(dbname))
- h := sha1.New()
- io.WriteString(h, base)
- return filepath.Join(filepath.Dir(dbname), fmt.Sprintf(".%x", h.Sum(nil)))
-}
-
-func (o *Options) acidFiler(db *DB, f lldb.Filer) (r lldb.Filer, err error) {
- switch o._ACID {
- default:
- panic("internal error")
- case _ACIDTransactions:
- if r, err = lldb.NewRollbackFiler(
- f,
- func(sz int64) error {
- return f.Truncate(sz)
- },
- f,
- ); err != nil {
- return nil, err
- }
-
- return r, nil
- case _ACIDFull:
- if r, err = lldb.NewACIDFiler(f, o.wal); err != nil {
- return nil, err
- }
-
- db.acidState = stIdle
- db.gracePeriod = o._GracePeriod
- if o._GracePeriod == 0 {
- panic("internal error")
- }
- return r, nil
- }
-}
diff --git a/vendor/github.com/cznic/kv/perf-4670.log b/vendor/github.com/cznic/kv/perf-4670.log
deleted file mode 100644
index 326497028..000000000
--- a/vendor/github.com/cznic/kv/perf-4670.log
+++ /dev/null
@@ -1,35 +0,0 @@
-$ benchcmp -mag -changed log-bench-2016-02-08-2109-120f703e log-bench-2016-07-19-1813-32e56c29-lldb-2016-07-24-1458-74c3b196
-benchmark old ns/op new ns/op delta
-BenchmarkFirst16-4 4715 3680 -21.95%
-BenchmarkSet16-4 105255 88470 -15.95%
-BenchmarkPut16-4 121708 104760 -13.93%
-BenchmarkGet16-4 108211 93534 -13.56%
-BenchmarkDelete16-4 111052 96004 -13.55%
-BenchmarkExtract16-4 107820 93991 -12.83%
-BenchmarkSeek-4 104365 93677 -10.24%
-BenchmarkLast16-4 4075 3671 -9.91%
-BenchmarkInc-4 2207 2046 -7.29%
-BenchmarkEnumerateDB-4 231182 227247 -1.70%
-BenchmarkNext1e3-4 222782 222161 -0.28%
-
-benchmark old allocs new allocs delta
-BenchmarkFirst16-4 4 6 +50.00%
-BenchmarkLast16-4 4 6 +50.00%
-BenchmarkSeek-4 19 22 +15.79%
-BenchmarkPut16-4 15 14 -6.67%
-BenchmarkDelete16-4 18 19 +5.56%
-BenchmarkGet16-4 18 19 +5.56%
-BenchmarkEnumerateDB-4 3008 3010 +0.07%
-
-benchmark old bytes new bytes delta
-BenchmarkDelete16-4 10193 502 -95.08%
-BenchmarkGet16-4 147867 31569 -78.65%
-BenchmarkSeek-4 133654 31436 -76.48%
-BenchmarkPut16-4 1127 360 -68.06%
-BenchmarkExtract16-4 1042 360 -65.45%
-BenchmarkSet16-4 874 350 -59.95%
-BenchmarkFirst16-4 24944 16730 -32.93%
-BenchmarkLast16-4 20848 16730 -19.75%
-BenchmarkEnumerateDB-4 65159 57065 -12.42%
-BenchmarkInc-4 32 36 +12.50%
-BenchmarkNext1e3-4 24002 24000 -0.01%
diff --git a/vendor/github.com/cznic/kv/perf-r550.log b/vendor/github.com/cznic/kv/perf-r550.log
deleted file mode 100644
index 071f82299..000000000
--- a/vendor/github.com/cznic/kv/perf-r550.log
+++ /dev/null
@@ -1,35 +0,0 @@
-$ benchcmp -mag -changed log-bench-2016-02-08-2109-120f703e log-bench-2016-07-19-1813-32e56c29-lldb-2016-07-24-1458-74c3b196
-benchmark old ns/op new ns/op delta
-BenchmarkGet16-4 263400 180228 -31.58%
-BenchmarkSeek-4 256307 181534 -29.17%
-BenchmarkDelete16-4 237945 181734 -23.62%
-BenchmarkFirst16-4 16199 12430 -23.27%
-BenchmarkExtract16-4 231676 189059 -18.40%
-BenchmarkLast16-4 13875 11783 -15.08%
-BenchmarkPut16-4 206700 177933 -13.92%
-BenchmarkSet16-4 174694 154715 -11.44%
-BenchmarkInc-4 5907 5565 -5.79%
-BenchmarkEnumerateDB-4 432438 427689 -1.10%
-BenchmarkNext1e3-4 421038 421171 +0.03%
-
-benchmark old allocs new allocs delta
-BenchmarkFirst16-4 4 6 +50.00%
-BenchmarkLast16-4 4 6 +50.00%
-BenchmarkPut16-4 15 13 -13.33%
-BenchmarkSeek-4 19 21 +10.53%
-BenchmarkSet16-4 14 13 -7.14%
-BenchmarkExtract16-4 17 16 -5.88%
-BenchmarkEnumerateDB-4 3007 3010 +0.10%
-
-benchmark old bytes new bytes delta
-BenchmarkDelete16-4 10118 391 -96.14%
-BenchmarkGet16-4 147861 30234 -79.55%
-BenchmarkPut16-4 1631 334 -79.52%
-BenchmarkExtract16-4 1329 300 -77.43%
-BenchmarkSeek-4 133640 30385 -77.26%
-BenchmarkSet16-4 1293 399 -69.14%
-BenchmarkFirst16-4 24945 16730 -32.93%
-BenchmarkLast16-4 20849 16730 -19.76%
-BenchmarkEnumerateDB-4 65121 57066 -12.37%
-BenchmarkInc-4 32 36 +12.50%
-BenchmarkNext1e3-4 24008 24006 -0.01%
diff --git a/vendor/github.com/cznic/kv/v0.go b/vendor/github.com/cznic/kv/v0.go
deleted file mode 100644
index e05ed4944..000000000
--- a/vendor/github.com/cznic/kv/v0.go
+++ /dev/null
@@ -1,21 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package kv
-
-import (
- "os"
-
- "github.com/cznic/lldb"
-)
-
-func open00(name string, in *DB) (db *DB, err error) {
- db = in
- if db.alloc, err = lldb.NewAllocator(lldb.NewInnerFiler(db.filer, 16), &lldb.Options{}); err != nil {
- return nil, &os.PathError{Op: "kv.open00", Path: name, Err: err}
- }
-
- db.alloc.Compress = true
- return
-}
diff --git a/vendor/github.com/cznic/kv/verify.go b/vendor/github.com/cznic/kv/verify.go
deleted file mode 100644
index b9d893c28..000000000
--- a/vendor/github.com/cznic/kv/verify.go
+++ /dev/null
@@ -1,89 +0,0 @@
-// Copyright 2014 The kv Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package kv
-
-import (
- "fmt"
- "io"
- "io/ioutil"
- "os"
-
- "github.com/cznic/lldb"
-)
-
-func verifyAllocator(a *lldb.Allocator) error {
- bits, err := ioutil.TempFile("", "kv-verify-")
- if err != nil {
- return err
- }
-
- sf := lldb.NewSimpleFileFiler(bits)
-
- defer func() {
- nm := bits.Name()
- sf.Close()
- os.Remove(nm)
- }()
-
- var lerr error
- if err = a.Verify(
- sf,
- func(err error) bool {
- lerr = err
- return false
- },
- nil,
- ); err != nil {
- return err
- }
-
- if lerr != nil {
- return lerr
- }
-
- t, err := lldb.OpenBTree(a, nil, 1)
- if err != nil {
- return err
- }
-
- e, err := t.SeekFirst()
- if err != nil {
- if err == io.EOF {
- err = nil
- }
- return err
- }
-
- for {
- _, _, err := e.Next()
- if err != nil {
- if err == io.EOF {
- err = nil
- }
- return err
- }
- }
-}
-
-func verifyDbFile(fn string) error {
- f, err := os.OpenFile(fn, os.O_RDWR, 0666)
- if err != nil {
- return err
- }
-
- sf := lldb.NewSimpleFileFiler(f)
- if f == nil {
- return fmt.Errorf("cannot create %s", fn)
- }
-
- defer sf.Close()
-
- a, err := lldb.NewAllocator(lldb.NewInnerFiler(sf, 16), &lldb.Options{})
- if err != nil {
- return err
- }
-
- return verifyAllocator(a)
-}
diff --git a/vendor/github.com/cznic/lldb/2pc.go b/vendor/github.com/cznic/lldb/2pc.go
deleted file mode 100644
index 396ffabce..000000000
--- a/vendor/github.com/cznic/lldb/2pc.go
+++ /dev/null
@@ -1,400 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Two Phase Commit & Structural ACID
-
-package lldb
-
-import (
- "bufio"
- "encoding/binary"
- "fmt"
- "io"
- "os"
-
- "github.com/cznic/fileutil"
- "github.com/cznic/mathutil"
-)
-
-var _ Filer = &ACIDFiler0{} // Ensure ACIDFiler0 is a Filer
-
-type acidWrite struct {
- b []byte
- off int64
-}
-
-type acidWriter0 ACIDFiler0
-
-func (a *acidWriter0) WriteAt(b []byte, off int64) (n int, err error) {
- f := (*ACIDFiler0)(a)
- if f.newEpoch {
- f.newEpoch = false
- f.data = f.data[:0]
- if err = a.writePacket([]interface{}{wpt00Header, walTypeACIDFiler0, ""}); err != nil {
- return
- }
- }
-
- if err = a.writePacket([]interface{}{wpt00WriteData, b, off}); err != nil {
- return
- }
-
- f.data = append(f.data, acidWrite{b, off})
- return len(b), nil
-}
-
-func (a *acidWriter0) writePacket(items []interface{}) (err error) {
- f := (*ACIDFiler0)(a)
- b, err := EncodeScalars(items...)
- if err != nil {
- return
- }
-
- var b4 [4]byte
- binary.BigEndian.PutUint32(b4[:], uint32(len(b)))
- if _, err = f.bwal.Write(b4[:]); err != nil {
- return
- }
-
- if _, err = f.bwal.Write(b); err != nil {
- return
- }
-
- if m := (4 + len(b)) % 16; m != 0 {
- var pad [15]byte
- _, err = f.bwal.Write(pad[:16-m])
- }
- return
-}
-
-// WAL Packet Tags
-const (
- wpt00Header = iota
- wpt00WriteData
- wpt00Checkpoint
- wpt00Empty
-)
-
-const (
- walTypeACIDFiler0 = iota
-)
-
-// ACIDFiler0 is a very simple, synchronous implementation of 2PC. It uses a
-// single write ahead log file to provide the structural atomicity
-// (BeginUpdate/EndUpdate/Rollback) and durability (DB can be recovered from
-// WAL if a crash occurred).
-//
-// ACIDFiler0 is a Filer.
-//
-// NOTE: Durable synchronous 2PC involves three fsyncs in this implementation
-// (WAL, DB, zero truncated WAL). Where possible, it's recommended to collect
-// transactions for, say one second before performing the two phase commit as
-// the typical performance for rotational hard disks is about few tens of
-// fsyncs per second atmost. For an example of such collective transaction
-// approach please see the colecting FSM STT in Dbm's documentation[1].
-//
-// [1]: http://godoc.org/github.com/cznic/exp/dbm
-type ACIDFiler0 struct {
- *RollbackFiler
- bwal *bufio.Writer
- data []acidWrite
- newEpoch bool
- peakWal int64 // tracks WAL maximum used size
- testHook bool // keeps WAL untruncated (once)
- wal *os.File
- walOptions walOptions
-}
-
-type walOptions struct {
- headroom int64 // Minimum WAL size.
-}
-
-// WALOption amends WAL properties.
-type WALOption func(*walOptions) error
-
-// MinWAL sets the minimum size a WAL file will have. The "extra" allocated
-// file space serves as a headroom. Commits that fit into the headroom should
-// not fail due to 'not enough space on the volume' errors.
-//
-// The min parameter is first rounded-up to a non negative multiple of the size
-// of the Allocator atom.
-//
-// Note: Setting minimum WAL size may render the DB non-recoverable when a
-// crash occurs and the DB is opened in an earlier version of LLDB that does
-// not support minimum WAL sizes.
-func MinWAL(min int64) WALOption {
- min = mathutil.MaxInt64(0, min)
- if r := min % 16; r != 0 {
- min += 16 - r
- }
- return func(o *walOptions) error {
- o.headroom = min
- return nil
- }
-}
-
-// NewACIDFiler0 returns a newly created ACIDFiler0 with WAL in wal.
-//
-// If the WAL is zero sized then a previous clean shutdown of db is taken for
-// granted and no recovery procedure is taken.
-//
-// If the WAL is of non zero size then it is checked for having a
-// committed/fully finished transaction not yet been reflected in db. If such
-// transaction exists it's committed to db. If the recovery process finishes
-// successfully, the WAL is truncated to the minimum WAL size and fsync'ed
-// prior to return from NewACIDFiler0.
-//
-// opts allow to amend WAL properties.
-func NewACIDFiler(db Filer, wal *os.File, opts ...WALOption) (r *ACIDFiler0, err error) {
- fi, err := wal.Stat()
- if err != nil {
- return
- }
-
- r = &ACIDFiler0{wal: wal}
- for _, o := range opts {
- if err := o(&r.walOptions); err != nil {
- return nil, err
- }
- }
-
- if fi.Size() != 0 {
- if err = r.recoverDb(db); err != nil {
- return
- }
- }
-
- r.bwal = bufio.NewWriter(r.wal)
- r.newEpoch = true
- acidWriter := (*acidWriter0)(r)
-
- if r.RollbackFiler, err = NewRollbackFiler(
- db,
- func(sz int64) (err error) {
- // Checkpoint
- if err = acidWriter.writePacket([]interface{}{wpt00Checkpoint, sz}); err != nil {
- return
- }
-
- if err = r.bwal.Flush(); err != nil {
- return
- }
-
- if err = r.wal.Sync(); err != nil {
- return
- }
-
- var wfi os.FileInfo
- if wfi, err = r.wal.Stat(); err != nil {
- return
- }
- r.peakWal = mathutil.MaxInt64(wfi.Size(), r.peakWal)
-
- // Phase 1 commit complete
-
- for _, v := range r.data {
- n := len(v.b)
- if m := v.off + int64(n); m > sz {
- if n -= int(m - sz); n <= 0 {
- continue
- }
- }
-
- if _, err = db.WriteAt(v.b[:n], v.off); err != nil {
- return err
- }
- }
-
- if err = db.Truncate(sz); err != nil {
- return
- }
-
- if err = db.Sync(); err != nil {
- return
- }
-
- // Phase 2 commit complete
-
- if !r.testHook {
- if err := r.emptyWAL(); err != nil {
- return err
- }
- }
-
- r.testHook = false
- r.bwal.Reset(r.wal)
- r.newEpoch = true
- return r.wal.Sync()
-
- },
- acidWriter,
- ); err != nil {
- return
- }
-
- return r, nil
-}
-
-func (a *ACIDFiler0) emptyWAL() error {
- if err := a.wal.Truncate(a.walOptions.headroom); err != nil {
- return err
- }
-
- if _, err := a.wal.Seek(0, 0); err != nil {
- return err
- }
-
- if a.walOptions.headroom != 0 {
- a.bwal.Reset(a.wal)
- if err := (*acidWriter0)(a).writePacket([]interface{}{wpt00Empty}); err != nil {
- return err
- }
-
- if err := a.bwal.Flush(); err != nil {
- return err
- }
-
- if _, err := a.wal.Seek(0, 0); err != nil {
- return err
- }
- }
-
- return nil
-}
-
-// PeakWALSize reports the maximum size WAL has ever used.
-func (a ACIDFiler0) PeakWALSize() int64 {
- return a.peakWal
-}
-
-func (a *ACIDFiler0) readPacket(f *bufio.Reader) (items []interface{}, err error) {
- var b4 [4]byte
- n, err := io.ReadAtLeast(f, b4[:], 4)
- if n != 4 {
- return
- }
-
- ln := int(binary.BigEndian.Uint32(b4[:]))
- m := (4 + ln) % 16
- padd := (16 - m) % 16
- b := make([]byte, ln+padd)
- if n, err = io.ReadAtLeast(f, b, len(b)); n != len(b) {
- return
- }
-
- return DecodeScalars(b[:ln])
-}
-
-func (a *ACIDFiler0) recoverDb(db Filer) (err error) {
- fi, err := a.wal.Stat()
- if err != nil {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: err}
- }
-
- if sz := fi.Size(); sz%16 != 0 {
- return &ErrILSEQ{Type: ErrFileSize, Name: a.wal.Name(), Arg: sz}
- }
-
- f := bufio.NewReader(a.wal)
- items, err := a.readPacket(f)
- if err != nil {
- return
- }
-
- if items[0] == int64(wpt00Empty) {
- if len(items) != 1 {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("invalid packet items %#v", items)}
- }
-
- return nil
- }
-
- if len(items) != 3 || items[0] != int64(wpt00Header) || items[1] != int64(walTypeACIDFiler0) {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("invalid packet items %#v", items)}
- }
-
- tr := NewBTree(nil)
-
- for {
- items, err = a.readPacket(f)
- if err != nil {
- return
- }
-
- if len(items) < 2 {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("too few packet items %#v", items)}
- }
-
- switch items[0] {
- case int64(wpt00WriteData):
- if len(items) != 3 {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("invalid data packet items %#v", items)}
- }
-
- b, off := items[1].([]byte), items[2].(int64)
- var key [8]byte
- binary.BigEndian.PutUint64(key[:], uint64(off))
- if err = tr.Set(key[:], b); err != nil {
- return
- }
- case int64(wpt00Checkpoint):
- var b1 [1]byte
- if n, err := f.Read(b1[:]); n != 0 || err == nil {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("checkpoint n %d, err %v", n, err)}
- }
-
- if len(items) != 2 {
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("checkpoint packet invalid items %#v", items)}
- }
-
- sz := items[1].(int64)
- enum, err := tr.seekFirst()
- if err != nil {
- return err
- }
-
- for {
- var k, v []byte
- k, v, err = enum.current()
- if err != nil {
- if fileutil.IsEOF(err) {
- break
- }
-
- return err
- }
-
- if _, err = db.WriteAt(v, int64(binary.BigEndian.Uint64(k))); err != nil {
- return err
- }
-
- if err = enum.next(); err != nil {
- if fileutil.IsEOF(err) {
- break
- }
-
- return err
- }
- }
-
- if err = db.Truncate(sz); err != nil {
- return err
- }
-
- if err = db.Sync(); err != nil {
- return err
- }
-
- // Recovery complete
-
- if err := a.emptyWAL(); err != nil {
- return err
- }
-
- return a.wal.Sync()
- default:
- return &ErrILSEQ{Type: ErrInvalidWAL, Name: a.wal.Name(), More: fmt.Sprintf("packet tag %v", items[0])}
- }
- }
-}
diff --git a/vendor/github.com/cznic/lldb/2pc_docs.go b/vendor/github.com/cznic/lldb/2pc_docs.go
deleted file mode 100644
index e045865f2..000000000
--- a/vendor/github.com/cznic/lldb/2pc_docs.go
+++ /dev/null
@@ -1,48 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-/*
-
-Anatomy of a WAL file
-
-WAL file
- A sequence of packets
-
-WAL packet, parts in slice notation
- [0:4], 4 bytes: N uint32 // network byte order
- [4:4+N], N bytes: payload []byte // gb encoded scalars
-
-Packets, including the 4 byte 'size' prefix, MUST BE padded to size == 0 (mod
-16). The values of the padding bytes MUST BE zero.
-
-Encoded scalars first item is a packet type number (packet tag). The meaning of
-any other item(s) of the payload depends on the packet tag.
-
-Packet definitions
-
- {wpt00Header int, typ int, s string}
- typ: Must be zero (ACIDFiler0 file).
- s: Any comment string, empty string is okay.
-
- This packet must be present only once - as the first packet of
- a WAL file.
-
- {wpt00WriteData int, b []byte, off int64}
- Write data (WriteAt(b, off)).
-
- {wpt00Checkpoint int, sz int64}
- Checkpoint (Truncate(sz)).
-
- This packet must be present only once - as the last packet of
- a WAL file.
-
- {wpt00Empty int}
- The WAL size is of non-zero size due to configured headroom,
- but empty otherwise.
-
-*/
-
-package lldb
-
-//TODO optimize bitfiler/wal/2pc data above final size
diff --git a/vendor/github.com/cznic/lldb/AUTHORS b/vendor/github.com/cznic/lldb/AUTHORS
deleted file mode 100644
index 0078f5f5b..000000000
--- a/vendor/github.com/cznic/lldb/AUTHORS
+++ /dev/null
@@ -1,11 +0,0 @@
-# This file lists authors for copyright purposes. This file is distinct from
-# the CONTRIBUTORS files. See the latter for an explanation.
-#
-# Names should be added to this file as:
-# Name or Organization
-#
-# The email address is not required for organizations.
-#
-# Please keep the list sorted.
-
-Jan Mercl <0xjnml@gmail.com>
diff --git a/vendor/github.com/cznic/lldb/CONTRIBUTORS b/vendor/github.com/cznic/lldb/CONTRIBUTORS
deleted file mode 100644
index 346ebe326..000000000
--- a/vendor/github.com/cznic/lldb/CONTRIBUTORS
+++ /dev/null
@@ -1,10 +0,0 @@
-# This file lists people who contributed code to this repository. The AUTHORS
-# file lists the copyright holders; this file lists people.
-#
-# Names should be added to this file like so:
-# Name
-#
-# Please keep the list sorted.
-
-Jan Mercl <0xjnml@gmail.com>
-Patrick Mézard
diff --git a/vendor/github.com/cznic/lldb/LICENSE b/vendor/github.com/cznic/lldb/LICENSE
deleted file mode 100644
index 27e4447a4..000000000
--- a/vendor/github.com/cznic/lldb/LICENSE
+++ /dev/null
@@ -1,27 +0,0 @@
-Copyright (c) 2014 The lldb Authors. All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are
-met:
-
- * Redistributions of source code must retain the above copyright
-notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above
-copyright notice, this list of conditions and the following disclaimer
-in the documentation and/or other materials provided with the
-distribution.
- * Neither the names of the authors nor the names of the
-contributors may be used to endorse or promote products derived from
-this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/github.com/cznic/lldb/Makefile b/vendor/github.com/cznic/lldb/Makefile
deleted file mode 100644
index b9f3b77e5..000000000
--- a/vendor/github.com/cznic/lldb/Makefile
+++ /dev/null
@@ -1,51 +0,0 @@
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
-
-clean:
- go clean
- rm -f *~ *.test *.out
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- @2>/dev/null gvim -p Makefile *.go
-
-editor:
- gofmt -l -s -w *.go
- go test 2>&1 | tee log
- go build
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench . -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * || true
- @grep -nr $(grep) TODO * || true
- @grep -nr $(grep) BUG * || true
- @grep -nr $(grep) [^[:alpha:]]println * || true
diff --git a/vendor/github.com/cznic/lldb/README.md b/vendor/github.com/cznic/lldb/README.md
deleted file mode 100644
index 261a49556..000000000
--- a/vendor/github.com/cznic/lldb/README.md
+++ /dev/null
@@ -1,8 +0,0 @@
-lldb
-====
-
-Package lldb implements a low level database engine.
-
-Installation: $ go get github.com/cznic/lldb
-
-Documentation: [godoc.org/github.com/cznic/lldb](http://godoc.org/github.com/cznic/lldb)
diff --git a/vendor/github.com/cznic/lldb/btree.go b/vendor/github.com/cznic/lldb/btree.go
deleted file mode 100644
index dcd671a8e..000000000
--- a/vendor/github.com/cznic/lldb/btree.go
+++ /dev/null
@@ -1,2346 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package lldb
-
-import (
- "bytes"
- "errors"
- "fmt"
- "io"
- "sort"
- "strings"
-
- "github.com/cznic/fileutil"
- "github.com/cznic/internal/buffer"
- "github.com/cznic/sortutil"
-)
-
-const (
- kData = 256 // [1, 512]
- kIndex = 256 // [2, 2048]
- kKV = 19 // Size of the key/value field in btreeDataPage
- kSz = kKV - 1 - 7 // Content prefix size
- kH = kKV - 7 // Content field offset for handle
- tagBTreeDataPage = 1
- tagBTreeIndexPage = 0
-)
-
-// BTree is a B+tree[1][2], i.e. a variant which speeds up
-// enumeration/iteration of the BTree. According to its origin it can be
-// volatile (backed only by memory) or non-volatile (backed by a non-volatile
-// Allocator).
-//
-// The specific implementation of BTrees in this package are B+trees with
-// delayed split/concatenation (discussed in e.g. [3]).
-//
-// Note: No BTree methods returns io.EOF for physical Filer reads/writes. The
-// io.EOF is returned only by bTreeEnumerator methods to indicate "no more K-V
-// pair".
-//
-// [1]: http://en.wikipedia.org/wiki/B+tree
-// [2]: http://zgking.com:8080/home/donghui/publications/books/dshandbook_BTree.pdf
-// [3]: http://people.cs.aau.dk/~simas/aalg06/UbiquitBtree.pdf
-type BTree struct {
- store btreeStore
- root btree
- collate func(a, b []byte) int
- serial uint64
-}
-
-// NewBTree returns a new, memory-only BTree.
-func NewBTree(collate func(a, b []byte) int) *BTree {
- store := newMemBTreeStore()
- root, err := newBTree(store)
- if err != nil { // should not happen
- panic(err.Error())
- }
-
- return &BTree{store, root, collate, 0}
-}
-
-// IsMem reports if t is a memory only BTree.
-func (t *BTree) IsMem() (r bool) {
- _, r = t.store.(*memBTreeStore)
- return
-}
-
-// Clear empties the tree.
-func (t *BTree) Clear() (err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- t.serial++
- return t.root.clear(t.store)
-}
-
-// Delete deletes key and its associated value from the tree.
-func (t *BTree) Delete(key []byte) (err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- t.serial++
- _, err = t.root.extract(t.store, nil, t.collate, key)
- return
-}
-
-// DeleteAny deletes one key and its associated value from the tree. If the
-// tree is empty on return then empty is true.
-func (t *BTree) DeleteAny() (empty bool, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- t.serial++
- return t.root.deleteAny(t.store)
-}
-
-func elem(v interface{}) string {
- switch x := v.(type) {
- default:
- panic("internal error")
- case nil:
- return "nil"
- case bool:
- if x {
- return "true"
- }
-
- return "false"
- case int64:
- return fmt.Sprint(x)
- case uint64:
- return fmt.Sprint(x)
- case float64:
- s := fmt.Sprintf("%g", x)
- if !strings.Contains(s, ".") {
- s += "."
- }
- return s
- case complex128:
- s := fmt.Sprint(x)
- return s[1 : len(s)-1]
- case []byte:
- return fmt.Sprintf("[]byte{% 02x}", x)
- case string:
- return fmt.Sprintf("%q", x)
- }
-}
-
-// Dump outputs a human readable dump of t to w. It is usable iff t keys and
-// values are encoded scalars (see EncodeScalars). Intended use is only for
-// examples or debugging. Some type information is lost in the rendering, for
-// example a float value '17.' and an integer value '17' may both output as
-// '17'.
-func (t *BTree) Dump(w io.Writer) (err error) {
- enum, err := t.seekFirst()
- if err != nil {
- return
- }
-
- for {
- bkey, bval, err := enum.current()
- if err != nil {
- return err
- }
-
- key, err := DecodeScalars(bkey)
- if err != nil {
- return err
- }
-
- val, err := DecodeScalars(bval)
- if err != nil {
- return err
- }
-
- kk := []string{}
- if key == nil {
- kk = []string{"null"}
- }
- for _, v := range key {
- kk = append(kk, elem(v))
- }
- vv := []string{}
- if val == nil {
- vv = []string{"null"}
- }
- for _, v := range val {
- vv = append(vv, elem(v))
- }
- skey := strings.Join(kk, ", ")
- sval := strings.Join(vv, ", ")
- if len(vv) > 1 {
- sval = fmt.Sprintf("[]interface{%s}", sval)
- }
- if _, err = fmt.Fprintf(w, "%s → %s\n", skey, sval); err != nil {
- return err
- }
-
- err = enum.next()
- if err != nil {
- if fileutil.IsEOF(err) {
- err = nil
- break
- }
-
- return err
- }
- }
- return
-}
-
-// Extract is a combination of Get and Delete. If the key exists in the tree,
-// it is returned (like Get) and also deleted from a tree in a more efficient
-// way which doesn't walk it twice. The returned slice may be a sub-slice of
-// buf if buf was large enough to hold the entire content. Otherwise, a newly
-// allocated slice will be returned. It is valid to pass a nil buf.
-func (t *BTree) Extract(buf, key []byte) (value []byte, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- t.serial++
- return t.root.extract(t.store, buf, t.collate, key)
-}
-
-// First returns the first KV pair of the tree, if it exists. Otherwise key == nil
-// and value == nil.
-func (t *BTree) First() (key, value []byte, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- var p btreeDataPage
- if _, p, err = t.root.first(t.store); err != nil || p == nil {
- return
- }
-
- if key, err = p.key(t.store, 0); err != nil {
- return
- }
-
- value, err = p.value(t.store, 0)
- return
-}
-
-// Get returns the value associated with key, or nil if no such value exists.
-// The returned slice may be a sub-slice of buf if buf was large enough to hold
-// the entire content. Otherwise, a newly allocated slice will be returned.
-// It is valid to pass a nil buf.
-//
-// Get is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (t *BTree) Get(buf, key []byte) (value []byte, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- pbuffer := buffer.Get(maxBuf)
- defer buffer.Put(pbuffer)
- buffer := *pbuffer
- if buffer, err = t.root.get(t.store, buffer, t.collate, key); buffer == nil || err != nil {
- return
- }
-
- if len(buffer) != 0 {
- // The buffer cache returns nil for empty buffers, bypass it
- value = need(len(buffer), buf)
- } else {
- value = []byte{}
- }
- copy(value, buffer)
- return
-}
-
-// Handle reports t's handle.
-func (t *BTree) Handle() int64 {
- return int64(t.root)
-}
-
-// Last returns the last KV pair of the tree, if it exists. Otherwise key == nil
-// and value == nil.
-func (t *BTree) Last() (key, value []byte, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- var p btreeDataPage
- if _, p, err = t.root.last(t.store); err != nil || p == nil {
- return
- }
-
- index := p.len() - 1
- if key, err = p.key(t.store, index); err != nil {
- return
- }
-
- value, err = p.value(t.store, index)
- return
-}
-
-// Put combines Get and Set in a more efficient way where the tree is walked
-// only once. The upd(ater) receives the current (key, old-value), if that
-// exists or (key, nil) otherwise. It can then return a (new-value, true, nil)
-// to create or overwrite the existing value in the KV pair, or (whatever,
-// false, nil) if it decides not to create or not to update the value of the KV
-// pair.
-//
-// tree.Set(k, v)
-//
-// conceptually equals
-//
-// tree.Put(k, func(k, v []byte){ return v, true }([]byte, bool))
-//
-// modulo the differing return values.
-//
-// The returned slice may be a sub-slice of buf if buf was large enough to hold
-// the entire content. Otherwise, a newly allocated slice will be returned.
-// It is valid to pass a nil buf.
-func (t *BTree) Put(buf, key []byte, upd func(key, old []byte) (new []byte, write bool, err error)) (old []byte, written bool, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- t.serial++
- return t.root.put2(buf, t.store, t.collate, key, upd)
-}
-
-// Seek returns an Enumerator with "position" or an error of any. Normally the
-// position is on a KV pair such that key >= KV.key. Then hit is key == KV.key.
-// The position is possibly "after" the last KV pair, but that is not an error.
-//
-// Seek is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (t *BTree) Seek(key []byte) (enum *BTreeEnumerator, hit bool, err error) {
- enum0, hit, err := t.seek(key)
- if err != nil {
- return
- }
-
- enum = &BTreeEnumerator{
- enum: enum0,
- firstHit: hit,
- key: append([]byte(nil), key...),
- }
- return
-}
-
-func (t *BTree) seek(key []byte) (enum *bTreeEnumerator, hit bool, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- r := &bTreeEnumerator{t: t, collate: t.collate, serial: t.serial}
- if r.p, r.index, hit, err = t.root.seek(t.store, r.collate, key); err != nil {
- return
- }
-
- enum = r
- return
-}
-
-// IndexSeek returns an Enumerator with "position" or an error of any. Normally
-// the position is on a KV pair such that key >= KV.key. Then hit is key ==
-// KV.key. The position is possibly "after" the last KV pair, but that is not
-// an error. The collate function originally passed to CreateBTree is used for
-// enumerating the tree but a custom collate function c is used for IndexSeek.
-//
-// IndexSeek is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (t *BTree) IndexSeek(key []byte, c func(a, b []byte) int) (enum *BTreeEnumerator, hit bool, err error) { //TODO +test
- enum0, hit, err := t.indexSeek(key, c)
- if err != nil {
- return
- }
-
- enum = &BTreeEnumerator{
- enum: enum0,
- firstHit: hit,
- key: append([]byte(nil), key...),
- }
- return
-}
-
-func (t *BTree) indexSeek(key []byte, c func(a, b []byte) int) (enum *bTreeEnumerator, hit bool, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- r := &bTreeEnumerator{t: t, collate: t.collate, serial: t.serial}
- if r.p, r.index, hit, err = t.root.seek(t.store, c, key); err != nil {
- return
- }
-
- enum = r
- return
-}
-
-// seekFirst returns an enumerator positioned on the first KV pair in the tree,
-// if any. For an empty tree, err == io.EOF is returend.
-//
-// SeekFirst is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (t *BTree) SeekFirst() (enum *BTreeEnumerator, err error) {
- enum0, err := t.seekFirst()
- if err != nil {
- return
- }
-
- var key []byte
- if key, _, err = enum0.current(); err != nil {
- return
- }
-
- enum = &BTreeEnumerator{
- enum: enum0,
- firstHit: true,
- key: append([]byte(nil), key...),
- }
- return
-}
-
-func (t *BTree) seekFirst() (enum *bTreeEnumerator, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- var p btreeDataPage
- if _, p, err = t.root.first(t.store); err == nil && p == nil {
- err = io.EOF
- }
- if err != nil {
- return
- }
-
- return &bTreeEnumerator{t: t, collate: t.collate, p: p, index: 0, serial: t.serial}, nil
-}
-
-// seekLast returns an enumerator positioned on the last KV pair in the tree,
-// if any. For an empty tree, err == io.EOF is returend.
-//
-// SeekLast is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (t *BTree) SeekLast() (enum *BTreeEnumerator, err error) {
- enum0, err := t.seekLast()
- if err != nil {
- return
- }
-
- var key []byte
- if key, _, err = enum0.current(); err != nil {
- return
- }
-
- enum = &BTreeEnumerator{
- enum: enum0,
- firstHit: true,
- key: append([]byte(nil), key...),
- }
- return
-}
-
-func (t *BTree) seekLast() (enum *bTreeEnumerator, err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- var p btreeDataPage
- if _, p, err = t.root.last(t.store); err == nil && p == nil {
- err = io.EOF
- }
- if err != nil {
- return
- }
-
- return &bTreeEnumerator{t: t, collate: t.collate, p: p, index: p.len() - 1, serial: t.serial}, nil
-}
-
-// Set sets the value associated with key. Any previous value, if existed, is
-// overwritten by the new one.
-func (t *BTree) Set(key, value []byte) (err error) {
- if t == nil {
- err = errors.New("BTree method invoked on nil receiver")
- return
- }
-
- t.serial++
- pdst := buffer.Get(maxBuf)
- dst := *pdst
- _, err = t.root.put(dst, t.store, t.collate, key, value, true)
- buffer.Put(pdst)
- return
-}
-
-// bTreeEnumerator is a closure of a BTree and a position. It is returned from
-// BTree.seek.
-//
-// NOTE: bTreeEnumerator cannot be used after its BTree was mutated after the
-// bTreeEnumerator was acquired from any of the seek, seekFirst, seekLast
-// methods.
-type bTreeEnumerator struct {
- t *BTree
- collate func(a, b []byte) int
- p btreeDataPage
- index int
- serial uint64
-}
-
-// Current returns the KV pair the enumerator is currently positioned on. If
-// the position is before the first KV pair in the tree or after the last KV
-// pair in the tree then err == io.EOF is returned.
-//
-// If the enumerator has been invalidated by updating the tree, ErrINVAL is
-// returned.
-func (e *bTreeEnumerator) current() (key, value []byte, err error) {
- if e == nil {
- err = errors.New("bTreeEnumerator method invoked on nil receiver")
- return
- }
-
- if e.serial != e.t.serial {
- err = &ErrINVAL{Src: "bTreeEnumerator invalidated by updating the tree"}
- return
- }
-
- if e.p == nil || e.index == e.p.len() {
- return nil, nil, io.EOF
- }
-
- if key, err = e.p.key(e.t.store, e.index); err != nil {
- return
- }
-
- value, err = e.p.value(e.t.store, e.index)
- return
-}
-
-// Next attempts to position the enumerator onto the next KV pair wrt the
-// current position. If there is no "next" KV pair, io.EOF is returned.
-//
-// If the enumerator has been invalidated by updating the tree, ErrINVAL is
-// returned.
-func (e *bTreeEnumerator) next() (err error) {
- if e == nil {
- err = errors.New("bTreeEnumerator method invoked on nil receiver")
- return
- }
-
- if e.serial != e.t.serial {
- err = &ErrINVAL{Src: "bTreeEnumerator invalidated by updating the tree"}
- return
- }
-
- if e.p == nil {
- return io.EOF
- }
-
- switch {
- case e.index < e.p.len()-1:
- e.index++
- default:
- ph := e.p.next()
- if ph == 0 {
- err = io.EOF
- break
- }
-
- if e.p, err = e.t.store.Get(e.p, ph); err != nil {
- e.p = nil
- return
- }
- e.index = 0
- }
- return
-}
-
-// Prev attempts to position the enumerator onto the previous KV pair wrt the
-// current position. If there is no "previous" KV pair, io.EOF is returned.
-//
-// If the enumerator has been invalidated by updating the tree, ErrINVAL is
-// returned.
-func (e *bTreeEnumerator) prev() (err error) {
- if e == nil {
- err = errors.New("bTreeEnumerator method invoked on nil receiver")
- return
- }
-
- if e.serial != e.t.serial {
- err = &ErrINVAL{Src: "bTreeEnumerator invalidated by updating the tree"}
- return
- }
-
- if e.p == nil {
- return io.EOF
- }
-
- switch {
- case e.index > 0:
- e.index--
- default:
- ph := e.p.prev()
- if ph == 0 {
- err = io.EOF
- break
- }
-
- if e.p, err = e.t.store.Get(e.p, ph); err != nil {
- e.p = nil
- return
- }
- e.index = e.p.len() - 1
- }
- return
-}
-
-// BTreeEnumerator captures the state of enumerating a tree. It is returned
-// from the Seek* methods. The enumerator is aware of any mutations made to
-// the tree in the process of enumerating it and automatically resumes the
-// enumeration.
-type BTreeEnumerator struct {
- enum *bTreeEnumerator
- err error
- key []byte
- firstHit bool
-}
-
-// Next returns the currently enumerated KV pair, if it exists and moves to the
-// next KV in the key collation order. If there is no KV pair to return, err ==
-// io.EOF is returned.
-//
-// Next is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (e *BTreeEnumerator) Next() (key, value []byte, err error) {
- if err = e.err; err != nil {
- return
- }
-
- canRetry := true
-retry:
- if e.enum.p == nil {
- e.err = io.EOF
- return nil, nil, e.err
- }
-
- if e.enum.index == e.enum.p.len() && e.enum.serial == e.enum.t.serial {
- if err = e.enum.next(); err != nil {
- e.err = err
- return nil, nil, e.err
- }
- }
-
- if key, value, err = e.enum.current(); err != nil {
- if _, ok := err.(*ErrINVAL); !ok || !canRetry {
- e.err = err
- return
- }
-
- canRetry = false
- var hit bool
- if e.enum, hit, err = e.enum.t.seek(e.key); err != nil {
- e.err = err
- return
- }
-
- if !e.firstHit && hit {
- err = e.enum.next()
- if err != nil {
- e.err = err
- return
- }
- }
-
- goto retry
- }
-
- e.firstHit = false
- e.key = append([]byte(nil), key...)
- e.err = e.enum.next()
- return
-}
-
-// Prev returns the currently enumerated KV pair, if it exists and moves to the
-// previous KV in the key collation order. If there is no KV pair to return,
-// err == io.EOF is returned.
-//
-// Prev is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the tree.
-func (e *BTreeEnumerator) Prev() (key, value []byte, err error) {
- if err = e.err; err != nil {
- return
- }
-
- canRetry := true
-retry:
- if key, value, err = e.enum.current(); err != nil {
- if _, ok := err.(*ErrINVAL); !ok || !canRetry {
- e.err = err
- return
- }
-
- canRetry = false
- var hit bool
- if e.enum, hit, err = e.enum.t.seek(e.key); err != nil {
- e.err = err
- return
- }
-
- if !e.firstHit && hit {
- err = e.enum.prev()
- if err != nil {
- e.err = err
- return
- }
- }
-
- goto retry
- }
-
- e.firstHit = false
- e.key = append([]byte(nil), key...)
- e.err = e.enum.prev()
- return
-}
-
-// CreateBTree creates a new BTree in store. It returns the tree, its (freshly
-// assigned) handle (for OpenBTree or RemoveBTree) or an error, if any.
-func CreateBTree(store *Allocator, collate func(a, b []byte) int) (bt *BTree, handle int64, err error) {
- r := &BTree{store: store, collate: collate}
- if r.root, err = newBTree(store); err != nil {
- return
- }
-
- return r, int64(r.root), nil
-}
-
-// OpenBTree opens a store's BTree using handle. It returns the tree or an
-// error, if any. The same tree may be opened more than once, but operations on
-// the separate instances should not ever overlap or void the other instances.
-// However, the intended API usage is to open the same tree handle only once
-// (handled by some upper layer "dispatcher").
-func OpenBTree(store *Allocator, collate func(a, b []byte) int, handle int64) (bt *BTree, err error) {
- r := &BTree{store: store, root: btree(handle), collate: collate}
- pb := buffer.Get(7)
- defer buffer.Put(pb)
- b := *pb
- if b, err = store.Get(b, handle); err != nil {
- return
- }
-
- if len(b) != 7 {
- return nil, &ErrILSEQ{Off: h2off(handle), More: "btree.go:671"}
- }
-
- return r, nil
-}
-
-// RemoveBTree removes tree, represented by handle from store. Empty trees are
-// cheap, each uses only few bytes of the store. If there's a chance that a
-// tree will eventually get reused (non empty again), it's recommended to
-// not/never remove it. One advantage of such approach is a stable handle of
-// such tree.
-func RemoveBTree(store *Allocator, handle int64) (err error) {
- tree, err := OpenBTree(store, nil, handle)
- if err != nil {
- return
- }
-
- if err = tree.Clear(); err != nil {
- return
- }
-
- return store.Free(handle)
-}
-
-type btreeStore interface {
- Alloc(b []byte) (handle int64, err error)
- Free(handle int64) (err error)
- Get(dst []byte, handle int64) (b []byte, err error)
- Realloc(handle int64, b []byte) (err error)
-}
-
-// Read only zero bytes
-var zeros [2 * kKV]byte
-
-func init() {
- if kData < 1 || kData > 512 {
- panic(fmt.Errorf("kData %d: out of limits", kData))
- }
-
- if kIndex < 2 || kIndex > 2048 {
- panic(fmt.Errorf("kIndex %d: out of limits", kIndex))
- }
-
- if kKV < 8 || kKV > 23 {
- panic(fmt.Errorf("kKV %d: out of limits", kKV))
- }
-
- if n := len(zeros); n < 15 {
- panic(fmt.Errorf("not enough zeros: %d", n))
- }
-}
-
-type memBTreeStore struct {
- h int64
- m map[int64][]byte
-}
-
-func newMemBTreeStore() *memBTreeStore {
- return &memBTreeStore{h: 0, m: map[int64][]byte{}}
-}
-
-func (s *memBTreeStore) String() string {
- var a sortutil.Int64Slice
- for k := range s.m {
- a = append(a, k)
- }
- sort.Sort(a)
- var sa []string
- for _, k := range a {
- sa = append(sa, fmt.Sprintf("%#x:|% x|", k, s.m[k]))
- }
- return strings.Join(sa, "\n")
-}
-
-func (s *memBTreeStore) Alloc(b []byte) (handle int64, err error) {
- s.h++
- handle = s.h
- s.m[handle] = bpack(b)
- return
-}
-
-func (s *memBTreeStore) Free(handle int64) (err error) {
- if _, ok := s.m[handle]; !ok {
- return &ErrILSEQ{Type: ErrOther, Off: h2off(handle), More: "btree.go:754"}
- }
-
- delete(s.m, handle)
- return
-}
-
-func (s *memBTreeStore) Get(dst []byte, handle int64) (b []byte, err error) {
- r, ok := s.m[handle]
- if !ok {
- return nil, &ErrILSEQ{Type: ErrOther, Off: h2off(handle), More: "btree.go:764"}
- }
-
- b = need(len(r), dst)
- copy(b, r)
- return
-}
-
-func (s *memBTreeStore) Realloc(handle int64, b []byte) (err error) {
- if _, ok := s.m[handle]; !ok {
- return &ErrILSEQ{Type: ErrOther, Off: h2off(handle), More: "btree.go:774"}
- }
-
- s.m[handle] = bpack(b)
- return
-}
-
-/*
-
-0...0 (1 bytes):
-Flag
-
- 0
- +---+
- | 0 |
- +---+
-
-0 indicates an index page
-
-1...count*14-1
-"array" of items, 14 bytes each. Count of items in kIndex-1..2*kIndex+2
-
- Count = (len(raw) - 8) / 14
-
- 0..6 7..13
- +-------+----------+
- | Child | DataPage |
- +-------+----------+
-
- Child == handle of a child index page
- DataPage == handle of a data page
-
-Offsets into the raw []byte:
-Child[X] == 1+14*X
-DataPage[X] == 8+14*X
-
-*/
-type btreeIndexPage []byte
-
-func newBTreeIndexPage(leftmostChild int64) (p btreeIndexPage) {
- p = (*buffer.Get(1 + (kIndex+1)*2*7))[:8]
- p[0] = tagBTreeIndexPage
- h2b(p[1:], leftmostChild)
- return
-}
-
-func (p btreeIndexPage) len() int {
- return (len(p) - 8) / 14
-}
-
-func (p btreeIndexPage) child(index int) int64 {
- return b2h(p[1+14*index:])
-}
-
-func (p btreeIndexPage) setChild(index int, dp int64) {
- h2b(p[1+14*index:], dp)
-}
-
-func (p btreeIndexPage) dataPage(index int) int64 {
- return b2h(p[8+14*index:])
-}
-
-func (p btreeIndexPage) setDataPage(index int, dp int64) {
- h2b(p[8+14*index:], dp)
-}
-
-func (q btreeIndexPage) insert(index int) btreeIndexPage {
- switch len0 := q.len(); {
- case index < len0:
- has := len(q)
- need := has + 14
- switch {
- case cap(q) >= need:
- q = q[:need]
- default:
- q = append(q, zeros[:14]...)
- }
- copy(q[8+14*(index+1):8+14*(index+1)+2*(len0-index)*7], q[8+14*index:])
- case index == len0:
- has := len(q)
- need := has + 14
- switch {
- case cap(q) >= need:
- q = q[:need]
- default:
- q = append(q, zeros[:14]...)
- }
- }
- return q
-}
-
-func (p btreeIndexPage) insert3(index int, dataPage, child int64) btreeIndexPage {
- p = p.insert(index)
- p.setDataPage(index, dataPage)
- p.setChild(index+1, child)
- return p
-}
-
-func (p btreeIndexPage) cmp(a btreeStore, c func(a, b []byte) int, keyA []byte, keyBIndex int) (int, error) {
- pb := buffer.Get(maxBuf)
- defer buffer.Put(pb)
- b := *pb
- dp, err := a.Get(b, p.dataPage(keyBIndex))
- if err != nil {
- return 0, err
- }
-
- return btreeDataPage(dp).cmp(a, c, keyA, 0)
-}
-
-func (q btreeIndexPage) setLen(n int) btreeIndexPage {
- q = q[:cap(q)]
- need := 8 + 14*n
- if need < len(q) {
- return q[:need]
- }
- return append(q, make([]byte, need-len(q))...)
-}
-
-func (p btreeIndexPage) split(a btreeStore, root btree, ph *int64, parent int64, parentIndex int, index *int) (btreeIndexPage, error) {
- right := newBTreeIndexPage(0)
- right = right.setLen(kIndex)
- copy(right[1:1+(2*kIndex+1)*7], p[1+14*(kIndex+1):])
- p = p.setLen(kIndex)
- if err := a.Realloc(*ph, p); err != nil {
- return nil, err
- }
-
- rh, err := a.Alloc(right)
- if err != nil {
- return nil, err
- }
-
- if parentIndex >= 0 {
- ppp := buffer.Get(maxBuf)
- defer buffer.Put(ppp)
- pp := btreeIndexPage(*ppp)
- if pp, err = a.Get(pp, parent); err != nil {
- return nil, err
- }
- pp = pp.insert3(parentIndex, p.dataPage(kIndex), rh)
- if err = a.Realloc(parent, pp); err != nil {
- return nil, err
- }
-
- } else {
- nr := newBTreeIndexPage(*ph)
- nr = nr.insert3(0, p.dataPage(kIndex), rh)
- nrh, err := a.Alloc(nr)
- if err != nil {
- return nil, err
- }
-
- if err = a.Realloc(int64(root), h2b(make([]byte, 7), nrh)); err != nil {
- return nil, err
- }
- }
- if *index > kIndex {
- p = right
- *ph = rh
- *index -= kIndex + 1
- }
- return p, nil
-}
-
-// p is dirty on return
-func (p btreeIndexPage) extract(index int) btreeIndexPage {
- n := p.len() - 1
- if index < n {
- sz := (n-index)*14 + 7
- copy(p[1+14*index:1+14*index+sz], p[1+14*(index+1):])
- }
- return p.setLen(n)
-}
-
-// must persist all changes made
-func (p btreeIndexPage) underflow(a btreeStore, root, iroot, parent int64, ph *int64, parentIndex int, index *int) (btreeIndexPage, error) {
- lh, rh, err := checkSiblings(a, parent, parentIndex)
- if err != nil {
- return nil, err
- }
-
- pleft := buffer.Get(maxBuf)
- defer buffer.Put(pleft)
- left := btreeIndexPage(*pleft)
-
- if lh != 0 {
- if left, err = a.Get(left, lh); err != nil {
- return nil, err
- }
-
- if lc := left.len(); lc > kIndex {
- ppp := buffer.Get(maxBuf)
- defer buffer.Put(ppp)
- pp := *ppp
- if pp, err = a.Get(pp, parent); err != nil {
- return nil, err
- }
-
- pc := p.len()
- p = p.setLen(pc + 1)
- di, si, sz := 1+1*14, 1+0*14, (2*pc+1)*7
- copy(p[di:di+sz], p[si:])
- p.setChild(0, left.child(lc))
- p.setDataPage(0, btreeIndexPage(pp).dataPage(parentIndex-1))
- *index++
- btreeIndexPage(pp).setDataPage(parentIndex-1, left.dataPage(lc-1))
- left = left.setLen(lc - 1)
- if err = a.Realloc(parent, pp); err != nil {
- return nil, err
- }
-
- if err = a.Realloc(*ph, p); err != nil {
- return nil, err
- }
-
- return p, a.Realloc(lh, left)
- }
- }
-
- if rh != 0 {
- pright := buffer.Get(maxBuf)
- defer buffer.Put(pright)
- right := *pright
- if right, err = a.Get(right, rh); err != nil {
- return nil, err
- }
-
- if rc := btreeIndexPage(right).len(); rc > kIndex {
- ppp := buffer.Get(maxBuf)
- defer buffer.Put(ppp)
- pp := *ppp
- if pp, err = a.Get(pp, parent); err != nil {
- return nil, err
- }
-
- pc := p.len()
- p = p.setLen(pc + 1)
- p.setDataPage(pc, btreeIndexPage(pp).dataPage(parentIndex))
- pc++
- p.setChild(pc, btreeIndexPage(right).child(0))
- btreeIndexPage(pp).setDataPage(parentIndex, btreeIndexPage(right).dataPage(0))
- di, si, sz := 1+0*14, 1+1*14, (2*rc+1)*7
- copy(right[di:di+sz], right[si:])
- right = btreeIndexPage(right).setLen(rc - 1)
- if err = a.Realloc(parent, pp); err != nil {
- return nil, err
- }
-
- if err = a.Realloc(*ph, p); err != nil {
- return nil, err
- }
-
- return p, a.Realloc(rh, right)
- }
- }
-
- if lh != 0 {
- *index += left.len() + 1
- if left, err = left.concat(a, root, iroot, parent, lh, *ph, parentIndex-1); err != nil {
- return p, err
- }
-
- p, *ph = left, lh
- return p, nil
- }
-
- return p.concat(a, root, iroot, parent, *ph, rh, parentIndex)
-}
-
-// must persist all changes made
-func (p btreeIndexPage) concat(a btreeStore, root, iroot, parent, ph, rh int64, parentIndex int) (btreeIndexPage, error) {
- ppp := buffer.Get(maxBuf)
- defer buffer.Put(ppp)
- pp := *ppp
- pp, err := a.Get(pp, parent)
- if err != nil {
- return nil, err
- }
-
- pright := buffer.Get(maxBuf)
- defer buffer.Put(pright)
- right := *pright
- if right, err = a.Get(right, rh); err != nil {
- return nil, err
- }
-
- pc := p.len()
- rc := btreeIndexPage(right).len()
- p = p.setLen(pc + rc + 1)
- p.setDataPage(pc, btreeIndexPage(pp).dataPage(parentIndex))
- di, si, sz := 1+14*(pc+1), 1+0*14, (2*rc+1)*7
- copy(p[di:di+sz], right[si:])
- if err := a.Realloc(ph, p); err != nil {
- return nil, err
- }
-
- if err := a.Free(rh); err != nil {
- return nil, err
- }
-
- if pc := btreeIndexPage(pp).len(); pc > 1 {
- if parentIndex < pc-1 {
- di, si, sz := 8+parentIndex*14, 8+(parentIndex+1)*14, 2*(pc-1-parentIndex)*7
- copy(pp[di:si+sz], pp[si:])
- }
- pp = btreeIndexPage(pp).setLen(pc - 1)
- return p, a.Realloc(parent, pp)
- }
-
- if err := a.Free(iroot); err != nil {
- return nil, err
- }
-
- pb7 := buffer.Get(7)
- defer buffer.Put(pb7)
- b7 := *pb7
- return p, a.Realloc(root, h2b(b7[:7], ph))
-}
-
-/*
-
-0...0 (1 bytes):
-Flag
-
- 0
- +---+
- | 1 |
- +---+
-
-1 indicates a data page
-
-1...14 (14 bytes)
-
- 1..7 8..14
- +------+------+
- | Prev | Next |
- +------+------+
-
- Prev, Next == Handles of the data pages doubly linked list
-
- Count = (len(raw) - 15) / (2*kKV)
-
-15...count*2*kKV-1
-"array" of items, 2*kKV bytes each. Count of items in kData-1..2*kData
-
-Item
- 0..kKV-1 kKV..2*kKV-1
- +----------+--------------+
- | Key | Value |
- +----------+--------------+
-
-Key/Value encoding
-
-Length 0...kKV-1
-
- 0 1...N N+1...kKV-1
- +---+---------+-------------+
- | N | Data | Padding |
- +---+---------+-------------+
-
- N == content length
- Data == Key or Value content
- Padding == MUST be zero bytes
-
-Length >= kKV
-
- 0 1...kkV-8 kKV-7...kkV-1
- +------+-----------+--------------+
- | 0xFF | Data | H |
- +------+-----------+--------------+
-
- Data == Key or Value content, first kKV-7 bytes
- H == Handle to THE REST of the content, w/o the first bytes in Data.
-
-Offsets into the raw []byte:
-Key[X] == 15+2*kKV*X
-Value[X] == 15+kKV+2*kKV*X
-*/
-type btreeDataPage []byte
-
-func newBTreeDataPage() (p btreeDataPage) {
- p = (*buffer.CGet(1 + 2*7 + (kData+1)*2*kKV))[:1+2*7]
- p[0] = tagBTreeDataPage
- return
-}
-
-func newBTreeDataPageAlloc(a btreeStore) (p btreeDataPage, h int64, err error) {
- p = newBTreeDataPage()
- h, err = a.Alloc(p)
- return
-}
-
-func (p btreeDataPage) len() int {
- return (len(p) - 15) / (2 * kKV)
-}
-
-func (q btreeDataPage) setLen(n int) btreeDataPage {
- q = q[:cap(q)]
- need := 15 + 2*kKV*n
- if need < len(q) {
- return q[:need]
- }
- return append(q, make([]byte, need-len(q))...)
-}
-
-func (p btreeDataPage) prev() int64 {
- return b2h(p[1:])
-}
-
-func (p btreeDataPage) next() int64 {
- return b2h(p[8:])
-}
-
-func (p btreeDataPage) setPrev(h int64) {
- h2b(p[1:], h)
-}
-
-func (p btreeDataPage) setNext(h int64) {
- h2b(p[8:], h)
-}
-
-func (q btreeDataPage) insert(index int) btreeDataPage {
- switch len0 := q.len(); {
- case index < len0:
- has := len(q)
- need := has + 2*kKV
- switch {
- case cap(q) >= need:
- q = q[:need]
- default:
- q = append(q, zeros[:2*kKV]...)
- }
- q.copy(q, index+1, index, len0-index)
- return q
- case index == len0:
- has := len(q)
- need := has + 2*kKV
- switch {
- case cap(q) >= need:
- return q[:need]
- default:
- return append(q, zeros[:2*kKV]...)
- }
- }
- panic("internal error")
-}
-
-func (p btreeDataPage) contentField(off int) (b []byte, h int64) {
- p = p[off:]
- switch n := int(p[0]); {
- case n >= kKV: // content has a handle
- b = append([]byte(nil), p[1:1+kSz]...)
- h = b2h(p[kH:])
- default: // content is embedded
- b, h = append([]byte(nil), p[1:1+n]...), 0
- }
- return
-}
-
-func (p btreeDataPage) content(a btreeStore, off int) (b []byte, err error) {
- b, h := p.contentField(off)
- if h == 0 {
- return
- }
-
- // content has a handle
- b2, err := a.Get(nil, h) //TODO buffers: Later, not a public API
- if err != nil {
- return nil, err
- }
-
- return append(b, b2...), nil
-}
-
-func (p btreeDataPage) setContent(a btreeStore, off int, b []byte) (err error) {
- p = p[off:]
- switch {
- case p[0] >= kKV: // existing content has a handle
- switch n := len(b); {
- case n < kKV:
- p[0] = byte(n)
- if err = a.Free(b2h(p[kH:])); err != nil {
- return
- }
- copy(p[1:], b)
- default:
- // reuse handle
- copy(p[1:1+kSz], b)
- return a.Realloc(b2h(p[kH:]), b[kSz:])
- }
- default: // existing content is embedded
- switch n := len(b); {
- case n < kKV:
- p[0] = byte(n)
- copy(p[1:], b)
- default:
- p[0] = 0xff
- copy(p[1:1+kSz], b)
- h, err := a.Alloc(b[kSz:])
- if err != nil {
- return err
- }
-
- h2b(p[kH:], h)
- }
- }
- return
-}
-
-func (p btreeDataPage) keyField(index int) (b []byte, h int64) {
- return p.contentField(15 + 2*kKV*index)
-}
-
-func (p btreeDataPage) key(a btreeStore, index int) (b []byte, err error) {
- return p.content(a, 15+2*kKV*index)
-}
-
-func (p btreeDataPage) valueField(index int) (b []byte, h int64) {
- return p.contentField(15 + kKV + 2*kKV*index)
-}
-
-func (p btreeDataPage) value(a btreeStore, index int) (b []byte, err error) {
- value, err := p.content(a, 15+kKV+2*kKV*index)
- if err == nil && value == nil {
- // We have a valid page, no fetch error, the key is valid so return
- // non-nil data
- return []byte{}, nil
- }
- return value, err
-}
-
-func (p btreeDataPage) valueCopy(a btreeStore, index int) (b []byte, err error) {
- if b, err = p.content(a, 15+kKV+2*kKV*index); err != nil {
- return
- }
-
- return append([]byte(nil), b...), nil
-}
-
-func (p btreeDataPage) setKey(a btreeStore, index int, key []byte) (err error) {
- return p.setContent(a, 15+2*kKV*index, key)
-}
-
-func (p btreeDataPage) setValue(a btreeStore, index int, value []byte) (err error) {
- return p.setContent(a, 15+kKV+2*kKV*index, value)
-}
-
-func (p btreeDataPage) cmp(a btreeStore, c func(a, b []byte) int, keyA []byte, keyBIndex int) (y int, err error) {
- var keyB []byte
- if keyB, err = p.content(a, 15+2*kKV*keyBIndex); err != nil {
- return
- }
-
- return c(keyA, keyB), nil
-}
-
-func (p btreeDataPage) copy(src btreeDataPage, di, si, n int) {
- do, so := 15+2*kKV*di, 15+2*kKV*si
- copy(p[do:do+2*kKV*n], src[so:])
-}
-
-// {p,left} dirty on exit
-func (p btreeDataPage) moveLeft(left btreeDataPage, n int) (btreeDataPage, btreeDataPage) {
- nl, np := left.len(), p.len()
- left = left.setLen(nl + n)
- left.copy(p, nl, 0, n)
- p.copy(p, 0, n, np-n)
- return p.setLen(np - n), left
-}
-
-func (p btreeDataPage) moveRight(right btreeDataPage, n int) (btreeDataPage, btreeDataPage) {
- nr, np := right.len(), p.len()
- right = right.setLen(nr + n)
- right.copy(right, n, 0, nr)
- right.copy(p, 0, np-n, n)
- return p.setLen(np - n), right
-}
-
-func (p btreeDataPage) insertItem(a btreeStore, index int, key, value []byte) (btreeDataPage, error) {
- p = p.insert(index)
- di, sz := 15+2*kKV*index, 2*kKV
- copy(p[di:di+sz], zeros[:sz])
- if err := p.setKey(a, index, key); err != nil {
- return nil, err
- }
- return p, p.setValue(a, index, value)
-}
-
-func (p btreeDataPage) split(a btreeStore, root, ph, parent int64, parentIndex, index int, key, value []byte) (btreeDataPage, error) {
- right, rh, err := newBTreeDataPageAlloc(a)
- if err != nil {
- return nil, err
- }
-
- if next := p.next(); next != 0 {
- right.setNext(p.next())
- nxh := right.next()
- pnx := buffer.Get(maxBuf)
- defer buffer.Put(pnx)
- nx := *pnx
- if nx, err = a.Get(nx, nxh); err != nil {
- return nil, err
- }
-
- btreeDataPage(nx).setPrev(rh)
- if err = a.Realloc(nxh, nx); err != nil {
- return nil, err
- }
- }
-
- p.setNext(rh)
- right.setPrev(ph)
- right = right.setLen(kData)
- right.copy(p, 0, kData, kData)
- p = p.setLen(kData)
-
- if parentIndex >= 0 {
- ppp := buffer.Get(maxBuf)
- defer buffer.Put(ppp)
- pp := btreeIndexPage(*ppp)
- if pp, err = a.Get(pp, parent); err != nil {
- return nil, err
- }
-
- pp = pp.insert3(parentIndex, rh, rh)
- if err = a.Realloc(parent, pp); err != nil {
- return nil, err
- }
-
- } else {
- nr := newBTreeIndexPage(ph)
- nr = nr.insert3(0, rh, rh)
-
- var nrh int64
- if nrh, err = a.Alloc(nr); err != nil {
- return nil, err
- }
-
- if err = a.Realloc(root, h2b(make([]byte, 7), nrh)); err != nil {
- return nil, err
- }
-
- }
- if index > kData {
- if right, err = right.insertItem(a, index-kData, key, value); err != nil {
- return nil, err
- }
- } else {
- if p, err = p.insertItem(a, index, key, value); err != nil {
- return nil, err
- }
- }
- if err = a.Realloc(ph, p); err != nil {
- return nil, err
- }
-
- return p, a.Realloc(rh, right)
-}
-
-func (p btreeDataPage) overflow(a btreeStore, root, ph, parent int64, parentIndex, index int, key, value []byte) (btreeDataPage, error) {
- leftH, rightH, err := checkSiblings(a, parent, parentIndex)
- if err != nil {
- return nil, err
- }
-
- if leftH != 0 {
- pleft := buffer.Get(maxBuf)
- defer buffer.Put(pleft)
- left := btreeDataPage(*pleft)
- if left, err = a.Get(left, leftH); err != nil {
- return nil, err
- }
-
- if left.len() < 2*kData && index > 0 {
-
- p, left = p.moveLeft(left, 1)
- if err = a.Realloc(leftH, left); err != nil {
- return nil, err
- }
-
- if p, err = p.insertItem(a, index-1, key, value); err != nil {
- return nil, err
- }
-
- return p, a.Realloc(ph, p)
- }
- }
-
- if rightH != 0 {
- pright := buffer.Get(maxBuf)
- defer buffer.Put(pright)
- right := btreeDataPage(*pright)
- if right, err = a.Get(right, rightH); err != nil {
- return nil, err
- }
-
- if right.len() < 2*kData {
- if index < 2*kData {
- p, right = p.moveRight(right, 1)
- if err = a.Realloc(rightH, right); err != nil {
- return nil, err
- }
-
- if p, err = p.insertItem(a, index, key, value); err != nil {
- return nil, err
- }
-
- return p, a.Realloc(ph, p)
- } else {
- if right, err = right.insertItem(a, 0, key, value); err != nil {
- return nil, err
- }
-
- return p, a.Realloc(rightH, right)
- }
- }
- }
- return p.split(a, root, ph, parent, parentIndex, index, key, value)
-}
-
-func (p btreeDataPage) swap(a btreeStore, di int, value []byte, canOverwrite bool) (oldValue []byte, err error) {
- if oldValue, err = p.value(a, di); err != nil {
- return
- }
-
- if !canOverwrite {
- return
- }
-
- oldValue = append([]byte(nil), oldValue...)
- err = p.setValue(a, di, value)
- return
-}
-
-type btreePage []byte
-
-func (p btreePage) isIndex() bool {
- return p[0] == tagBTreeIndexPage
-}
-
-func (p btreePage) len() int {
- if p.isIndex() {
- return btreeIndexPage(p).len()
- }
-
- return btreeDataPage(p).len()
-}
-
-func (p btreePage) find(a btreeStore, c func(a, b []byte) int, key []byte) (index int, ok bool, err error) {
- l := 0
- h := p.len() - 1
- isIndex := p.isIndex()
- if c == nil {
- c = bytes.Compare
- }
- for l <= h {
- index = (l + h) >> 1
- var cmp int
- if isIndex {
- if cmp, err = btreeIndexPage(p).cmp(a, c, key, index); err != nil {
- return
- }
- } else {
- if cmp, err = btreeDataPage(p).cmp(a, c, key, index); err != nil {
- return
- }
- }
- switch ok = cmp == 0; {
- case cmp > 0:
- l = index + 1
- case ok:
- return
- default:
- h = index - 1
- }
- }
- return l, false, nil
-}
-
-// p is dirty after extract!
-func (p btreeDataPage) extract(a btreeStore, index int) (btreeDataPage, []byte, error) {
- value, err := p.valueCopy(a, index)
- if err != nil {
- return nil, nil, err
- }
-
- if _, h := p.keyField(index); h != 0 {
- if err = a.Free(h); err != nil {
- return nil, nil, err
- }
- }
-
- if _, h := p.valueField(index); h != 0 {
- if err = a.Free(h); err != nil {
- return nil, nil, err
- }
- }
-
- n := p.len() - 1
- if index < n {
- p.copy(p, index, index+1, n-index)
- }
- return p.setLen(n), value, nil
-}
-
-func checkSiblings(a btreeStore, parent int64, parentIndex int) (left, right int64, err error) {
- if parentIndex >= 0 {
- pp := buffer.Get(maxBuf)
- defer buffer.Put(pp)
- p := btreeIndexPage(*pp)
- if p, err = a.Get(p, parent); err != nil {
- return
- }
-
- if parentIndex > 0 {
- left = p.child(parentIndex - 1)
- }
- if parentIndex < p.len() {
- right = p.child(parentIndex + 1)
- }
- }
- return
-}
-
-// underflow must persist all changes made.
-func (p btreeDataPage) underflow(a btreeStore, root, iroot, parent, ph int64, parentIndex int) (err error) {
- lh, rh, err := checkSiblings(a, parent, parentIndex)
- if err != nil {
- return err
- }
-
- if lh != 0 {
- pleft := buffer.Get(maxBuf)
- defer buffer.Put(pleft)
- left := *pleft
- if left, err = a.Get(left, lh); err != nil {
- return err
- }
-
- if btreeDataPage(left).len()+p.len() >= 2*kData {
- left, p = btreeDataPage(left).moveRight(p, 1)
- if err = a.Realloc(lh, left); err != nil {
- return err
- }
-
- return a.Realloc(ph, p)
- }
- }
-
- if rh != 0 {
- pright := buffer.Get(maxBuf)
- defer buffer.Put(pright)
- right := *pright
- if right, err = a.Get(right, rh); err != nil {
- return err
- }
-
- if p.len()+btreeDataPage(right).len() > 2*kData {
- right, p = btreeDataPage(right).moveLeft(p, 1)
- if err = a.Realloc(rh, right); err != nil {
- return err
- }
-
- return a.Realloc(ph, p)
- }
- }
-
- if lh != 0 {
- pleft := buffer.Get(maxBuf)
- defer buffer.Put(pleft)
- left := *pleft
- if left, err = a.Get(left, lh); err != nil {
- return err
- }
-
- if err = a.Realloc(ph, p); err != nil {
- return err
- }
-
- return btreeDataPage(left).concat(a, root, iroot, parent, lh, ph, parentIndex-1)
- }
-
- return p.concat(a, root, iroot, parent, ph, rh, parentIndex)
-}
-
-// concat must persist all changes made.
-func (p btreeDataPage) concat(a btreeStore, root, iroot, parent, ph, rh int64, parentIndex int) (err error) {
- pright := buffer.Get(maxBuf)
- defer buffer.Put(pright)
- right := *pright
- if right, err = a.Get(right, rh); err != nil {
- return err
- }
-
- right, p = btreeDataPage(right).moveLeft(p, btreeDataPage(right).len())
- nxh := btreeDataPage(right).next()
- if nxh != 0 {
- pnx := buffer.Get(maxBuf)
- defer buffer.Put(pnx)
- nx := *pnx
- if nx, err = a.Get(nx, nxh); err != nil {
- return err
- }
-
- btreeDataPage(nx).setPrev(ph)
- if err = a.Realloc(nxh, nx); err != nil {
- return err
- }
- }
- p.setNext(nxh)
- if err = a.Free(rh); err != nil {
- return err
- }
-
- ppp := buffer.Get(maxBuf)
- defer buffer.Put(ppp)
- pp := *ppp
- if pp, err = a.Get(pp, parent); err != nil {
- return err
- }
-
- if btreeIndexPage(pp).len() > 1 {
- pp = btreeIndexPage(pp).extract(parentIndex)
- btreeIndexPage(pp).setChild(parentIndex, ph)
- if err = a.Realloc(parent, pp); err != nil {
- return err
- }
-
- return a.Realloc(ph, p)
- }
-
- if err = a.Free(iroot); err != nil {
- return err
- }
-
- if err = a.Realloc(ph, p); err != nil {
- return err
- }
-
- var b7 [7]byte
- return a.Realloc(root, h2b(b7[:], ph))
-}
-
-// external "root" is stable and contains the real root.
-type btree int64
-
-func newBTree(a btreeStore) (btree, error) {
- r, err := a.Alloc(zeros[:7])
- return btree(r), err
-}
-
-func (root btree) String(a btreeStore) string {
- pr := buffer.Get(16)
- defer buffer.Put(pr)
- r := *pr
- r, err := a.Get(r, int64(root))
- if err != nil {
- panic(err)
- }
-
- iroot := b2h(r)
- m := map[int64]bool{int64(root): true}
-
- s := []string{fmt.Sprintf("tree %#x -> %#x\n====", root, iroot)}
- if iroot == 0 {
- return s[0]
- }
-
- var f func(int64, string)
- f = func(h int64, ind string) {
- if m[h] {
- return
- }
-
- m[h] = true
- pb := buffer.Get(maxBuf)
- defer buffer.Put(pb)
- b := btreePage(*pb)
- var err error
- if b, err = a.Get(b, h); err != nil {
- panic(err)
- }
-
- s = append(s, fmt.Sprintf("%s@%#x", ind, h))
- switch b.isIndex() {
- case true:
- da := []int64{}
- b := btreeIndexPage(b)
- for i := 0; i < b.len(); i++ {
- c, d := b.child(i), b.dataPage(i)
- s = append(s, fmt.Sprintf("%schild[%d] %#x dataPage[%d] %#x", ind, i, c, i, d))
- da = append(da, c)
- da = append(da, d)
- }
- i := b.len()
- c := b.child(i)
- s = append(s, fmt.Sprintf("%schild[%d] %#x", ind, i, c))
- for _, c := range da {
- f(c, ind+" ")
- }
- f(c, ind+" ")
- case false:
- b := btreeDataPage(b)
- s = append(s, fmt.Sprintf("%sprev %#x next %#x", ind, b.prev(), b.next()))
- for i := 0; i < b.len(); i++ {
- k, err := b.key(a, i)
- if err != nil {
- panic(err)
- }
-
- v, err := b.value(a, i)
- if err != nil {
- panic(err)
- }
-
- s = append(s, fmt.Sprintf("%sK[%d]|% x| V[%d]|% x|", ind, i, k, i, v))
- }
- }
- }
-
- f(iroot, "")
- return strings.Join(s, "\n")
-}
-
-func (root btree) put(dst []byte, a btreeStore, c func(a, b []byte) int, key, value []byte, canOverwrite bool) (prev []byte, err error) {
- prev, _, err = root.put2(dst, a, c, key, func(key, old []byte) (new []byte, write bool, err error) {
- new, write = value, true
- return
- })
- return
-}
-
-func (root btree) put2(dst []byte, a btreeStore, c func(a, b []byte) int, key []byte, upd func(key, old []byte) (new []byte, write bool, err error)) (old []byte, written bool, err error) {
- var r, value []byte
- if r, err = a.Get(dst, int64(root)); err != nil {
- return
- }
-
- iroot := b2h(r)
- var h int64
- if iroot == 0 {
- p := newBTreeDataPage()
- if value, written, err = upd(key, nil); err != nil || !written {
- return
- }
-
- if p, err = p.insertItem(a, 0, key, value); err != nil {
- return
- }
-
- h, err = a.Alloc(p)
- if err != nil {
- return nil, true, err
- }
-
- err = a.Realloc(int64(root), h2b(r, h)[:7])
- return
- }
-
- parentIndex := -1
- var parent int64
- ph := iroot
-
- pp := buffer.Get(maxBuf)
- defer buffer.Put(pp)
- p := *pp
-
- for {
- if p, err = a.Get(p[:cap(p)], ph); err != nil {
- return
- }
-
- var index int
- var ok bool
-
- if index, ok, err = btreePage(p).find(a, c, key); err != nil {
- return
- }
-
- switch {
- case ok: // Key found
- if btreePage(p).isIndex() {
- ph = btreeIndexPage(p).dataPage(index)
- if p, err = a.Get(p, ph); err != nil {
- return
- }
-
- if old, err = btreeDataPage(p).valueCopy(a, 0); err != nil {
- return
- }
-
- if value, written, err = upd(key, old); err != nil || !written {
- return
- }
-
- if _, err = btreeDataPage(p).swap(a, 0, value, true); err != nil {
- return
- }
-
- err = a.Realloc(ph, p)
- return
- }
-
- if old, err = btreeDataPage(p).valueCopy(a, index); err != nil {
- return
- }
-
- if value, written, err = upd(key, old); err != nil || !written {
- return
- }
-
- if _, err = btreeDataPage(p).swap(a, index, value, true); err != nil {
- return
- }
-
- err = a.Realloc(ph, p)
- return
- case btreePage(p).isIndex():
- if btreePage(p).len() > 2*kIndex {
- if p, err = btreeIndexPage(p).split(a, root, &ph, parent, parentIndex, &index); err != nil {
- return
- }
- }
- parentIndex = index
- parent = ph
- ph = btreeIndexPage(p).child(index)
- default:
- if value, written, err = upd(key, nil); err != nil || !written {
- return
- }
-
- if btreePage(p).len() < 2*kData { // page is not full
- if p, err = btreeDataPage(p).insertItem(a, index, key, value); err != nil {
- return
- }
-
- err = a.Realloc(ph, p)
- return
- }
-
- // page is full
- p, err = btreeDataPage(p).overflow(a, int64(root), ph, parent, parentIndex, index, key, value)
- return
- }
- }
-}
-
-//TODO actually use 'dst' to return 'value'
-func (root btree) get(a btreeStore, dst []byte, c func(a, b []byte) int, key []byte) (b []byte, err error) {
- var r []byte
- if r, err = a.Get(dst, int64(root)); err != nil {
- return
- }
-
- iroot := b2h(r)
- if iroot == 0 {
- return
- }
-
- ph := iroot
-
- for {
- var p btreePage
- if p, err = a.Get(p, ph); err != nil {
- return
- }
-
- var index int
- var ok bool
- if index, ok, err = p.find(a, c, key); err != nil {
- return
- }
-
- switch {
- case ok:
- if p.isIndex() {
- dh := btreeIndexPage(p).dataPage(index)
- dp, err := a.Get(dst, dh)
- if err != nil {
- return nil, err
- }
-
- return btreeDataPage(dp).value(a, 0)
- }
-
- return btreeDataPage(p).value(a, index)
- case p.isIndex():
- ph = btreeIndexPage(p).child(index)
- default:
- return
- }
- }
-}
-
-//TODO actually use 'dst' to return 'value'
-func (root btree) extract(a btreeStore, dst []byte, c func(a, b []byte) int, key []byte) (value []byte, err error) {
- var r []byte
- if r, err = a.Get(dst, int64(root)); err != nil {
- return
- }
-
- iroot := b2h(r)
- if iroot == 0 {
- return
- }
-
- ph := iroot
- parentIndex := -1
- var parent int64
-
- pp := buffer.Get(maxBuf)
- defer buffer.Put(pp)
- p := *pp
-
- for {
- if p, err = a.Get(p[:cap(p)], ph); err != nil {
- return
- }
-
- var index int
- var ok bool
- if index, ok, err = btreePage(p).find(a, c, key); err != nil {
- return
- }
-
- if ok {
- if btreePage(p).isIndex() {
- dph := btreeIndexPage(p).dataPage(index)
-
- var dp []byte
- if dp, err = a.Get(dst, dph); err != nil {
- return nil, err
- }
-
- if btreeDataPage(dp).len() > kData {
- if dp, value, err = btreeDataPage(dp).extract(a, 0); err != nil {
- return nil, err
- }
-
- return value, a.Realloc(dph, dp)
- }
-
- if btreeIndexPage(p).len() < kIndex && ph != iroot {
- if p, err = btreeIndexPage(p).underflow(a, int64(root), iroot, parent, &ph, parentIndex, &index); err != nil {
- return nil, err
- }
- }
- parentIndex = index + 1
- parent = ph
- ph = btreeIndexPage(p).child(parentIndex)
- continue
- }
-
- p, value, err = btreeDataPage(p).extract(a, index)
- if btreePage(p).len() >= kData {
- err = a.Realloc(ph, p)
- return
- }
-
- if ph != iroot {
- err = btreeDataPage(p).underflow(a, int64(root), iroot, parent, ph, parentIndex)
- return
- }
-
- if btreePage(p).len() == 0 {
- if err = a.Free(ph); err != nil {
- return
- }
-
- err = a.Realloc(int64(root), zeros[:7])
- return
- }
- err = a.Realloc(ph, p)
- return
- }
-
- if !btreePage(p).isIndex() {
- return
- }
-
- if btreePage(p).len() < kIndex && ph != iroot {
- if p, err = btreeIndexPage(p).underflow(a, int64(root), iroot, parent, &ph, parentIndex, &index); err != nil {
- return nil, err
- }
- }
- parentIndex = index
- parent = ph
- ph = btreeIndexPage(p).child(index)
- }
-}
-
-func (root btree) deleteAny(a btreeStore) (bool, error) {
- pr := buffer.Get(7)
- defer buffer.Put(pr)
- r := *pr
- var err error
- if r, err = a.Get(r, int64(root)); err != nil {
- return false, err
- }
-
- iroot := b2h(r)
- if iroot == 0 {
- return true, nil
- }
-
- ph := iroot
- parentIndex := -1
- var parent int64
- pp := buffer.Get(maxBuf)
- defer buffer.Put(pp)
- p := *pp
-
- for {
- if p, err = a.Get(p, ph); err != nil {
- return false, err
- }
-
- index := btreePage(p).len() / 2
- if btreePage(p).isIndex() {
- dph := btreeIndexPage(p).dataPage(index)
- pdp := buffer.Get(maxBuf)
- defer buffer.Put(pdp)
- dp := *pdp
- if dp, err = a.Get(dp, dph); err != nil {
- return false, err
- }
-
- if btreeDataPage(dp).len() > kData {
- if dp, _, err = btreeDataPage(dp).extract(a, 0); err != nil {
- return false, err
- }
-
- return false, a.Realloc(dph, dp)
- }
-
- if btreeIndexPage(p).len() < kIndex && ph != iroot {
- if p, err = btreeIndexPage(p).underflow(a, int64(root), iroot, parent, &ph, parentIndex, &index); err != nil {
- return false, err
- }
- }
- parentIndex = index + 1
- parent = ph
- ph = btreeIndexPage(p).child(parentIndex)
- continue
- }
-
- p, _, err = btreeDataPage(p).extract(a, index)
- if btreePage(p).len() >= kData {
- err = a.Realloc(ph, p)
- return false, err
- }
-
- if ph != iroot {
- err = btreeDataPage(p).underflow(a, int64(root), iroot, parent, ph, parentIndex)
- return false, err
- }
-
- if btreePage(p).len() == 0 {
- if err = a.Free(ph); err != nil {
- return true, err
- }
-
- return true, a.Realloc(int64(root), zeros[:7])
- }
-
- return false, a.Realloc(ph, p)
- }
-}
-
-func (root btree) first(a btreeStore) (ph int64, p btreeDataPage, err error) {
- pr := buffer.Get(7)
- defer buffer.Put(pr)
- r := *pr
- if r, err = a.Get(r, int64(root)); err != nil {
- return
- }
-
- for ph = b2h(r); ph != 0; ph = btreeIndexPage(p).child(0) {
- if p, err = a.Get(p, ph); err != nil {
- return
- }
-
- if !btreePage(p).isIndex() {
- break
- }
- }
-
- return
-}
-
-func (root btree) last(a btreeStore) (ph int64, p btreeDataPage, err error) {
- pr := buffer.Get(7)
- defer buffer.Put(pr)
- r := *pr
- if r, err = a.Get(r, int64(root)); err != nil {
- return
- }
-
- for ph = b2h(r); ph != 0; ph = btreeIndexPage(p).child(btreeIndexPage(p).len()) {
- if p, err = a.Get(p, ph); err != nil {
- return
- }
-
- if !btreePage(p).isIndex() {
- break
- }
- }
-
- return
-}
-
-// key >= p[index].key
-func (root btree) seek(a btreeStore, c func(a, b []byte) int, key []byte) (p btreeDataPage, index int, equal bool, err error) {
- pr := buffer.Get(7)
- defer buffer.Put(pr)
- r := *pr
- if r, err = a.Get(r, int64(root)); err != nil {
- return
- }
-
- for ph := b2h(r); ph != 0; ph = btreeIndexPage(p).child(index) {
- if p, err = a.Get(p, ph); err != nil {
- break
- }
-
- if index, equal, err = btreePage(p).find(a, c, key); err != nil {
- break
- }
-
- if equal {
- if !btreePage(p).isIndex() {
- break
- }
-
- p, err = a.Get(p, btreeIndexPage(p).dataPage(index))
- index = 0
- break
- }
-
- if !btreePage(p).isIndex() {
- break
- }
- }
- return
-}
-
-func (root btree) clear(a btreeStore) (err error) {
- pr := buffer.Get(7)
- defer buffer.Put(pr)
- r := *pr
- if r, err = a.Get(r, int64(root)); err != nil {
- return
- }
-
- iroot := b2h(r)
- if iroot == 0 {
- return
- }
-
- if err = root.clear2(a, iroot); err != nil {
- return
- }
-
- var b [7]byte
- return a.Realloc(int64(root), b[:])
-}
-
-func (root btree) clear2(a btreeStore, ph int64) (err error) {
- pp := buffer.Get(maxBuf)
- defer buffer.Put(pp)
- p := *pp
- if p, err = a.Get(p, ph); err != nil {
- return
- }
-
- switch btreePage(p).isIndex() {
- case true:
- ip := btreeIndexPage(p)
- for i := 0; i <= ip.len(); i++ {
- if err = root.clear2(a, ip.child(i)); err != nil {
- return err
- }
- }
- case false:
- dp := btreeDataPage(p)
- for i := 0; i < dp.len(); i++ {
- if err = dp.setKey(a, i, nil); err != nil {
- return
- }
-
- if err = dp.setValue(a, i, nil); err != nil {
- return
- }
- }
- }
- return a.Free(ph)
-}
diff --git a/vendor/github.com/cznic/lldb/errors.go b/vendor/github.com/cznic/lldb/errors.go
deleted file mode 100644
index de4de8766..000000000
--- a/vendor/github.com/cznic/lldb/errors.go
+++ /dev/null
@@ -1,170 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Some errors returned by this package.
-//
-// Note that this package can return more errors than declared here, for
-// example io.EOF from Filer.ReadAt().
-
-package lldb
-
-import (
- "fmt"
-)
-
-// ErrDecodeScalars is possibly returned from DecodeScalars
-type ErrDecodeScalars struct {
- B []byte // Data being decoded
- I int // offending offset
-}
-
-// Error implements the built in error type.
-func (e *ErrDecodeScalars) Error() string {
- return fmt.Sprintf("DecodeScalars: corrupted data @ %d/%d", e.I, len(e.B))
-}
-
-// ErrINVAL reports invalid values passed as parameters, for example negative
-// offsets where only non-negative ones are allowed or read from the DB.
-type ErrINVAL struct {
- Src string
- Val interface{}
-}
-
-// Error implements the built in error type.
-func (e *ErrINVAL) Error() string {
- return fmt.Sprintf("%s: %+v", e.Src, e.Val)
-}
-
-// ErrPERM is for example reported when a Filer is closed while BeginUpdate(s)
-// are not balanced with EndUpdate(s)/Rollback(s) or when EndUpdate or Rollback
-// is invoked which is not paired with a BeginUpdate.
-type ErrPERM struct {
- Src string
-}
-
-// Error implements the built in error type.
-func (e *ErrPERM) Error() string {
- return fmt.Sprintf("%s: Operation not permitted", e.Src)
-}
-
-// ErrTag represents an ErrILSEQ kind.
-type ErrType int
-
-// ErrILSEQ types
-const (
- ErrOther ErrType = iota
-
- ErrAdjacentFree // Adjacent free blocks (.Off and .Arg)
- ErrDecompress // Used compressed block: corrupted compression
- ErrExpFreeTag // Expected a free block tag, got .Arg
- ErrExpUsedTag // Expected a used block tag, got .Arg
- ErrFLT // Free block is invalid or referenced multiple times
- ErrFLTLoad // FLT truncated to .Off, need size >= .Arg
- ErrFLTSize // Free block size (.Arg) doesn't belong to its list min size: .Arg2
- ErrFileSize // File .Name size (.Arg) != 0 (mod 16)
- ErrFreeChaining // Free block, .prev.next doesn't point back to this block
- ErrFreeTailBlock // Last block is free
- ErrHead // Head of a free block list has non zero Prev (.Arg)
- ErrInvalidRelocTarget // Reloc doesn't target (.Arg) a short or long used block
- ErrInvalidWAL // Corrupted write ahead log. .Name: file name, .More: more
- ErrLongFreeBlkTooLong // Long free block spans beyond EOF, size .Arg
- ErrLongFreeBlkTooShort // Long free block must have at least 2 atoms, got only .Arg
- ErrLongFreeNextBeyondEOF // Long free block .Next (.Arg) spans beyond EOF
- ErrLongFreePrevBeyondEOF // Long free block .Prev (.Arg) spans beyond EOF
- ErrLongFreeTailTag // Expected a long free block tail tag, got .Arg
- ErrLostFreeBlock // Free block is not in any FLT list
- ErrNullReloc // Used reloc block with nil target
- ErrRelocBeyondEOF // Used reloc points (.Arg) beyond EOF
- ErrShortFreeTailTag // Expected a short free block tail tag, got .Arg
- ErrSmall // Request for a free block (.Arg) returned a too small one (.Arg2) at .Off
- ErrTailTag // Block at .Off has invalid tail CC (compression code) tag, got .Arg
- ErrUnexpReloc // Unexpected reloc block referred to from reloc block .Arg
- ErrVerifyPadding // Used block has nonzero padding
- ErrVerifyTailSize // Long free block size .Arg but tail size .Arg2
- ErrVerifyUsedSpan // Used block size (.Arg) spans beyond EOF
-)
-
-// ErrILSEQ reports a corrupted file format. Details in fields according to Type.
-type ErrILSEQ struct {
- Type ErrType
- Off int64
- Arg int64
- Arg2 int64
- Arg3 int64
- Name string
- More interface{}
-}
-
-// Error implements the built in error type.
-func (e *ErrILSEQ) Error() string {
- switch e.Type {
- case ErrAdjacentFree:
- return fmt.Sprintf("Adjacent free blocks at offset %#x and %#x", e.Off, e.Arg)
- case ErrDecompress:
- return fmt.Sprintf("Compressed block at offset %#x: Corrupted compressed content", e.Off)
- case ErrExpFreeTag:
- return fmt.Sprintf("Block at offset %#x: Expected a free block tag, got %#2x", e.Off, e.Arg)
- case ErrExpUsedTag:
- return fmt.Sprintf("Block at ofset %#x: Expected a used block tag, got %#2x", e.Off, e.Arg)
- case ErrFLT:
- return fmt.Sprintf("Free block at offset %#x is invalid or referenced multiple times", e.Off)
- case ErrFLTLoad:
- return fmt.Sprintf("FLT truncated to size %d, expected at least %d", e.Off, e.Arg)
- case ErrFLTSize:
- return fmt.Sprintf("Free block at offset %#x has size (%#x) should be at least (%#x)", e.Off, e.Arg, e.Arg2)
- case ErrFileSize:
- return fmt.Sprintf("File %q size (%#x) != 0 (mod 16)", e.Name, e.Arg)
- case ErrFreeChaining:
- return fmt.Sprintf("Free block at offset %#x: .prev.next doesn point back here.", e.Off)
- case ErrFreeTailBlock:
- return fmt.Sprintf("Free block at offset %#x: Cannot be last file block", e.Off)
- case ErrHead:
- return fmt.Sprintf("Block at offset %#x: Head of free block list has non zero .prev %#x", e.Off, e.Arg)
- case ErrInvalidRelocTarget:
- return fmt.Sprintf("Used reloc block at offset %#x: Target (%#x) is not a short or long used block", e.Off, e.Arg)
- case ErrInvalidWAL:
- return fmt.Sprintf("Corrupted write ahead log file: %q %v", e.Name, e.More)
- case ErrLongFreeBlkTooLong:
- return fmt.Sprintf("Long free block at offset %#x: Size (%#x) beyond EOF", e.Off, e.Arg)
- case ErrLongFreeBlkTooShort:
- return fmt.Sprintf("Long free block at offset %#x: Size (%#x) too small", e.Off, e.Arg)
- case ErrLongFreeNextBeyondEOF:
- return fmt.Sprintf("Long free block at offset %#x: Next (%#x) points beyond EOF", e.Off, e.Arg)
- case ErrLongFreePrevBeyondEOF:
- return fmt.Sprintf("Long free block at offset %#x: Prev (%#x) points beyond EOF", e.Off, e.Arg)
- case ErrLongFreeTailTag:
- return fmt.Sprintf("Block at offset %#x: Expected long free tail tag, got %#2x", e.Off, e.Arg)
- case ErrLostFreeBlock:
- return fmt.Sprintf("Free block at offset %#x: not in any FLT list", e.Off)
- case ErrNullReloc:
- return fmt.Sprintf("Used reloc block at offset %#x: Nil target", e.Off)
- case ErrRelocBeyondEOF:
- return fmt.Sprintf("Used reloc block at offset %#x: Link (%#x) points beyond EOF", e.Off, e.Arg)
- case ErrShortFreeTailTag:
- return fmt.Sprintf("Block at offset %#x: Expected short free tail tag, got %#2x", e.Off, e.Arg)
- case ErrSmall:
- return fmt.Sprintf("Request for of free block of size %d returned a too small (%d) one at offset %#x", e.Arg, e.Arg2, e.Off)
- case ErrTailTag:
- return fmt.Sprintf("Block at offset %#x: Invalid tail CC tag, got %#2x", e.Off, e.Arg)
- case ErrUnexpReloc:
- return fmt.Sprintf("Block at offset %#x: Unexpected reloc block. Referred to from reloc block at offset %#x", e.Off, e.Arg)
- case ErrVerifyPadding:
- return fmt.Sprintf("Used block at offset %#x: Nonzero padding", e.Off)
- case ErrVerifyTailSize:
- return fmt.Sprintf("Long free block at offset %#x: Size %#x, but tail size %#x", e.Off, e.Arg, e.Arg2)
- case ErrVerifyUsedSpan:
- return fmt.Sprintf("Used block at offset %#x: Size %#x spans beyond EOF", e.Off, e.Arg)
- }
-
- more := ""
- if e.More != nil {
- more = fmt.Sprintf(", %v", e.More)
- }
- off := ""
- if e.Off != 0 {
- off = fmt.Sprintf(", off: %#x", e.Off)
- }
-
- return fmt.Sprintf("Error%s%s", off, more)
-}
diff --git a/vendor/github.com/cznic/lldb/falloc.go b/vendor/github.com/cznic/lldb/falloc.go
deleted file mode 100644
index 87687a767..000000000
--- a/vendor/github.com/cznic/lldb/falloc.go
+++ /dev/null
@@ -1,1999 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// The storage space management.
-
-package lldb
-
-import (
- "bytes"
- "errors"
- "fmt"
- "io"
- "sort"
- "strings"
- "sync"
-
- "github.com/cznic/internal/buffer"
- "github.com/cznic/mathutil"
- "github.com/cznic/zappy"
-)
-
-const (
- maxBuf = maxRq + 20
-)
-
-// Options are passed to the NewAllocator to amend some configuration. The
-// compatibility promise is the same as of struct types in the Go standard
-// library - introducing changes can be made only by adding new exported
-// fields, which is backward compatible as long as client code uses field names
-// to assign values of imported struct types literals.
-//
-// NOTE: No options are currently defined.
-type Options struct{}
-
-// AllocStats record statistics about a Filer. It can be optionally filled by
-// Allocator.Verify, if successful.
-type AllocStats struct {
- Handles int64 // total valid handles in use
- Compression int64 // number of compressed blocks
- TotalAtoms int64 // total number of atoms == AllocAtoms + FreeAtoms
- AllocBytes int64 // bytes allocated (after decompression, if/where used)
- AllocAtoms int64 // atoms allocated/used, including relocation atoms
- Relocations int64 // number of relocated used blocks
- FreeAtoms int64 // atoms unused
- AllocMap map[int64]int64 // allocated block size in atoms -> count of such blocks
- FreeMap map[int64]int64 // free block size in atoms -> count of such blocks
-}
-
-/*
-
-Allocator implements "raw" storage space management (allocation and
-deallocation) for a low level of a DB engine. The storage is an abstraction
-provided by a Filer.
-
-The terms MUST or MUST NOT, if/where used in the documentation of Allocator,
-written in all caps as seen here, are a requirement for any possible
-alternative implementations aiming for compatibility with this one.
-
-Filer file
-
-A Filer file, or simply 'file', is a linear, contiguous sequence of blocks.
-Blocks may be either free (currently unused) or allocated (currently used).
-Some blocks may eventually become virtual in a sense as they may not be
-realized in the storage (sparse files).
-
-Free Lists Table
-
-File starts with a FLT. This table records heads of 14 doubly linked free
-lists. The zero based index (I) vs minimal size of free blocks in that list,
-except the last one which registers free blocks of size 4112+ atoms:
-
- MinSize == 2^I
-
- For example 0 -> 1, 1 -> 2, ... 12 -> 4096.
-
-Each entry in the FLT is 8 bytes in netwtork order, MSB MUST be zero, ie. the
-slot value is effectively only 7 bytes. The value is the handle of the head of
-the respective doubly linked free list. The FLT size is 14*8 == 112(0x70)
-bytes. If the free blocks list for any particular size is empty, the respective
-FLT slot is zero. Sizes of free blocks in one list MUST NOT overlap with sizes
-of free lists in other list. For example, even though a free block of size 2
-technically is of minimal size >= 1, it MUST NOT be put to the list for slot 0
-(minimal size 1), but in slot 1( minimal size 2).
-
- slot 0: sizes [1, 2)
- slot 1: sizes [2, 4)
- slot 2: sizes [4, 8)
- ...
- slot 11: sizes [2048, 4096)
- slot 12: sizes [4096, 4112)
- slot 13: sizes [4112, inf)
-
-The last FLT slot collects all free blocks bigger than its minimal size. That
-still respects the 'no overlap' invariant.
-
-File blocks
-
-A block is a linear, contiguous sequence of atoms. The first and last atoms of
-a block provide information about, for example, whether the block is free or
-used, what is the size of the block, etc. Details are discussed elsewhere. The
-first block of a file starts immediately after FLT, ie. at file offset
-112(0x70).
-
-Block atoms
-
-An atom is a fixed size piece of a block (and thus of a file too); it is 16
-bytes long. A consequence is that for a valid file:
-
- filesize == 0 (mod 16)
-
-The first atom of the first block is considered to be atom #1.
-
-Block handles
-
-A handle is an integer referring to a block. The reference is the number of the
-atom the block starts with. Put in other way:
-
- handle == offset/16 - 6
- offset == 16 * (handle + 6)
-
-`offset` is the offset of the first byte of the block, measured in bytes
-- as in fseek(3). Handle has type `int64`, but only the lower 7 bytes may be
-nonzero while referring to a block, both in code as well as when persisted in
-the the file's internal bookkeeping structures - see 'Block types' bellow. So a
-handle is effectively only `uint56`. This also means that the maximum usable
-size of a file is 2^56 atoms. That is 2^60 bytes == 1 exabyte (10^18 bytes).
-
-Nil handles
-
-A handle with numeric value of '0' refers to no block.
-
-Zero padding
-
-A padding is used to round-up a block size to be a whole number of atoms. Any
-padding, if present, MUST be all zero bytes. Note that the size of padding is
-in [0, 15].
-
-Content wiping
-
-When a block is deallocated, its data content is not wiped as the added
-overhead may be substantial while not necessarily needed. Client code should
-however overwrite the content of any block having sensitive data with eg. zeros
-(good compression) - before deallocating the block.
-
-Block tags
-
-Every block is tagged in its first byte (a head tag) and last byte (tail tag).
-Block types are:
-
- 1. Short content used block (head tags 0x00-0xFB)
- 2. Long content used block (head tag 0xFC)
- 3. Relocated used block (head tag 0xFD)
- 4. Short, single atom, free block (head tag 0xFE)
- 5. Long free block (head tag 0xFF)
-
-Note: Relocated used block, 3. above (head tag 0xFD) MUST NOT refer to blocks
-other then 1. or 2. above (head tags 0x00-0xFC).
-
-Content blocks
-
-Used blocks (head tags 0x00-0xFC) tail tag distinguish used/unused block and if
-content is compressed or not.
-
-Content compression
-
-The tail flag of an used block is one of
-
- CC == 0 // Content is not compressed.
- CC == 1 // Content is in zappy compression format.
-
-If compression of written content is enabled, there are two cases: If
-compressed size < original size then the compressed content should be written
-if it will save at least one atom of the block. If compressed size >= original
-size then the compressed content should not be used.
-
-It's recommended to use compression. For example the BTrees implementation
-assumes compression is used. Using compression may cause a slowdown in some
-cases while it may as well cause a speedup.
-
-Short content block
-
-Short content block carries content of length between N == 0(0x00) and N ==
-251(0xFB) bytes.
-
- |<-first atom start ... last atom end->|
- +---++-- ... --+-- ... --++------+
- | 0 || 1... | 0x*...0x*E || 0x*F |
- +---++-- ... --+-- ... --++------+
- | N || content | padding || CC |
- +---++-- ... --+-- ... --++------+
-
- A == (N+1)/16 + 1 // The number of atoms in the block [1, 16]
- padding == 15 - (N+1)%16 // Length of the zero padding
-
-Long content block
-
-Long content block carries content of length between N == 252(0xFC) and N ==
-65787(0x100FB) bytes.
-
- |<-first atom start ... last atom end->|
- +------++------+-- ... --+-- ... --++------+
- | 0 || 1..2 | 3... | 0x*...0x*E || 0x*F |
- +------++------+-- ... --+-- ... --++------+
- | 0xFC || M | content | padding || CC |
- +------++------+-- ... --+-- ... --++------+
-
- A == (N+3)/16 + 1 // The number of atoms in the block [16, 4112]
- M == N % 0x10000 // Stored as 2 bytes in network byte order
- padding == 15 - (N+3)%16 // Length of the zero padding
-
-Relocated used block
-
-Relocated block allows to permanently assign a handle to some content and
-resize the content anytime afterwards without having to update all the possible
-existing references; the handle can be constant while the content size may be
-dynamic. When relocating a block, any space left by the original block content,
-above this single atom block, MUST be reclaimed.
-
-Relocations MUST point only to a used short or long block == blocks with tags
-0x00...0xFC.
-
- +------++------+---------++----+
- | 0 || 1..7 | 8...14 || 15 |
- +------++------+---------++----+
- | 0xFD || H | padding || 0 |
- +------++------+---------++----+
-
-H is the handle of the relocated block in network byte order.
-
-Free blocks
-
-Free blocks are the result of space deallocation. Free blocks are organized in
-one or more doubly linked lists, abstracted by the FLT interface. Free blocks
-MUST be "registered" by putting them in such list. Allocator MUST reuse a big
-enough free block, if such exists, before growing the file size. When a free
-block is created by deallocation or reallocation it MUST be joined with any
-adjacently existing free blocks before "registering". If the resulting free
-block is now a last block of a file, the free block MUST be discarded and the
-file size MUST be truncated accordingly instead. Put differently, there MUST
-NOT ever be a free block at the file end.
-
-A single free atom
-
-Is an unused block of size 1 atom.
-
- +------++------+--------++------+
- | 0 || 1..7 | 8...14 || 15 |
- +------++------+--------++------+
- | 0xFE || P | N || 0xFE |
- +------++------+--------++------+
-
-P and N, stored in network byte order, are the previous and next free block
-handles in the doubly linked list to which this free block belongs.
-
-A long unused block
-
-Is an unused block of size > 1 atom.
-
- +------++------+-------+---------+- ... -+----------++------+
- | 0 || 1..7 | 8..14 | 15...21 | | Z-7..Z-1 || Z |
- +------++------+-------+---------+- ... -+----------++------+
- | 0xFF || S | P | N | Leak | S || 0xFF |
- +------++------+-------+---------+- ... -+----------++------+
-
- Z == 16 * S - 1
-
-S is the size of this unused block in atoms. P and N are the previous and next
-free block handles in the doubly linked list to which this free block belongs.
-Leak contains any data the block had before deallocating this block. See also
-the subtitle 'Content wiping' above. S, P and N are stored in network byte
-order. Large free blocks may trigger a consideration of file hole punching of
-the Leak field - for some value of 'large'.
-
-Note: Allocator methods vs CRUD[1]:
-
- Alloc [C]reate
- Get [R]ead
- Realloc [U]pdate
- Free [D]elete
-
-Note: No Allocator method returns io.EOF.
-
- [1]: http://en.wikipedia.org/wiki/Create,_read,_update_and_delete
-
-*/
-type Allocator struct {
- f Filer
- flt flt
- cache cache
- m map[int64]*node
- lru lst
- mu sync.Mutex
- expHit int64
- expMiss int64
- cacheSz int
- hit uint16
- miss uint16
- Compress bool // enables content compression
-}
-
-// NewAllocator returns a new Allocator. To open an existing file, pass its
-// Filer. To create a "new" file, pass a Filer which file is of zero size.
-func NewAllocator(f Filer, opts *Options) (a *Allocator, err error) {
- if opts == nil { // Enforce *Options is always passed
- return nil, errors.New("NewAllocator: nil opts passed")
- }
-
- a = &Allocator{
- f: f,
- cacheSz: 10,
- }
-
- a.cinit()
- switch x := f.(type) {
- case *RollbackFiler:
- x.afterRollback = func() error {
- a.cinit()
- return a.flt.load(a.f, 0)
- }
- case *ACIDFiler0:
- x.RollbackFiler.afterRollback = func() error {
- a.cinit()
- return a.flt.load(a.f, 0)
- }
- }
-
- sz, err := f.Size()
- if err != nil {
- return
- }
-
- a.flt.init()
- if sz == 0 {
- var b [fltSz]byte
- if err = a.f.BeginUpdate(); err != nil {
- return
- }
-
- if _, err = f.WriteAt(b[:], 0); err != nil {
- _ = a.f.Rollback()
- return
- }
-
- return a, a.f.EndUpdate()
- }
-
- return a, a.flt.load(f, 0)
-}
-
-// CacheStats reports cache statistics.
-//
-//TODO return a struct perhaps.
-func (a *Allocator) CacheStats() (buffersUsed, buffersTotal int, bytesUsed, bytesTotal, hits, misses int64) {
- buffersUsed = len(a.m)
- buffersTotal = buffersUsed + len(a.cache)
- bytesUsed = a.lru.size()
- bytesTotal = bytesUsed + a.cache.size()
- hits = a.expHit
- misses = a.expMiss
- return
-}
-
-func (a *Allocator) cinit() {
- for h, n := range a.m {
- a.cache.put(a.lru.remove(n))
- delete(a.m, h)
- }
- if a.m == nil {
- a.m = map[int64]*node{}
- }
-}
-
-func (a *Allocator) cadd(b []byte, h int64) {
- if len(a.m) < a.cacheSz {
- n := a.cache.get(len(b))
- n.h = h
- copy(n.b, b)
- a.m[h] = a.lru.pushFront(n)
- return
- }
-
- // cache full
- delete(a.m, a.cache.put(a.lru.removeBack()).h)
- n := a.cache.get(len(b))
- n.h = h
- copy(n.b, b)
- a.m[h] = a.lru.pushFront(n)
- return
-}
-
-func (a *Allocator) cfree(h int64) {
- n, ok := a.m[h]
- if !ok { // must have been evicted
- return
- }
-
- a.cache.put(a.lru.remove(n))
- delete(a.m, h)
-}
-
-// Alloc allocates storage space for b and returns the handle of the new block
-// with content set to b or an error, if any. The returned handle is valid only
-// while the block is used - until the block is deallocated. No two valid
-// handles share the same value within the same Filer, but any value of a
-// handle not referring to any used block may become valid any time as a result
-// of Alloc.
-//
-// Invoking Alloc on an empty Allocator is guaranteed to return handle with
-// value 1. The intended use of content of handle 1 is a root "directory" of
-// other data held by an Allocator.
-//
-// Passing handles not obtained initially from Alloc or not anymore valid to
-// any other Allocator methods can result in an irreparably corrupted database.
-func (a *Allocator) Alloc(b []byte) (handle int64, err error) {
- pbuf := buffer.Get(zappy.MaxEncodedLen(len(b)))
- defer buffer.Put(pbuf)
- buf := *pbuf
- buf, _, cc, err := a.makeUsedBlock(buf, b)
- if err != nil {
- return
- }
-
- if handle, err = a.alloc(buf, cc); err == nil {
- a.cadd(b, handle)
- }
- return
-}
-
-func (a *Allocator) alloc(b []byte, cc byte) (h int64, err error) {
- rqAtoms := n2atoms(len(b))
- if h = a.flt.find(rqAtoms); h == 0 { // must grow
- var sz int64
- if sz, err = a.f.Size(); err != nil {
- return
- }
-
- h = off2h(sz)
- err = a.writeUsedBlock(h, cc, b)
- return
- }
-
- // Handle is the first item of a free blocks list.
- tag, s, prev, next, err := a.nfo(h)
- if err != nil {
- return
- }
-
- if tag != tagFreeShort && tag != tagFreeLong {
- err = &ErrILSEQ{Type: ErrExpFreeTag, Off: h2off(h), Arg: int64(tag)}
- return
- }
-
- if prev != 0 {
- err = &ErrILSEQ{Type: ErrHead, Off: h2off(h), Arg: prev}
- return
- }
-
- if s < int64(rqAtoms) {
- err = &ErrILSEQ{Type: ErrSmall, Arg: int64(rqAtoms), Arg2: s, Off: h2off(h)}
- return
- }
-
- if err = a.unlink(h, s, prev, next); err != nil {
- return
- }
-
- if s > int64(rqAtoms) {
- freeH := h + int64(rqAtoms)
- freeAtoms := s - int64(rqAtoms)
- if err = a.link(freeH, freeAtoms); err != nil {
- return
- }
- }
- return h, a.writeUsedBlock(h, cc, b)
-}
-
-// Free deallocates the block referred to by handle or returns an error, if
-// any.
-//
-// After Free succeeds, handle is invalid and must not be used.
-//
-// Handle must have been obtained initially from Alloc and must be still valid,
-// otherwise a database may get irreparably corrupted.
-func (a *Allocator) Free(handle int64) (err error) {
- if handle <= 0 || handle > maxHandle {
- return &ErrINVAL{"Allocator.Free: handle out of limits", handle}
- }
-
- a.cfree(handle)
- return a.free(handle, 0, true)
-}
-
-func (a *Allocator) free(h, from int64, acceptRelocs bool) (err error) {
- tag, atoms, _, n, err := a.nfo(h)
- if err != nil {
- return
- }
-
- switch tag {
- default:
- // nop
- case tagUsedLong:
- // nop
- case tagUsedRelocated:
- if !acceptRelocs {
- return &ErrILSEQ{Type: ErrUnexpReloc, Off: h2off(h), Arg: h2off(from)}
- }
-
- if err = a.free(n, h, false); err != nil {
- return
- }
- case tagFreeShort, tagFreeLong:
- return &ErrINVAL{"Allocator.Free: attempt to free a free block at off", h2off(h)}
- }
-
- return a.free2(h, atoms)
-}
-
-func (a *Allocator) free2(h, atoms int64) (err error) {
- sz, err := a.f.Size()
- if err != nil {
- return
- }
-
- ltag, latoms, lp, ln, err := a.leftNfo(h)
- if err != nil {
- return
- }
-
- if ltag != tagFreeShort && ltag != tagFreeLong {
- latoms = 0
- }
-
- var rtag byte
- var ratoms, rp, rn int64
-
- isTail := h2off(h)+atoms*16 == sz
- if !isTail {
- if rtag, ratoms, rp, rn, err = a.nfo(h + atoms); err != nil {
- return
- }
- }
-
- if rtag != tagFreeShort && rtag != tagFreeLong {
- ratoms = 0
- }
-
- switch {
- case latoms == 0 && ratoms == 0:
- // -> isolated <-
- if isTail { // cut tail
- return a.f.Truncate(h2off(h))
- }
-
- return a.link(h, atoms)
- case latoms == 0 && ratoms != 0:
- // right join ->
- if err = a.unlink(h+atoms, ratoms, rp, rn); err != nil {
- return
- }
-
- return a.link(h, atoms+ratoms)
- case latoms != 0 && ratoms == 0:
- // <- left join
- if err = a.unlink(h-latoms, latoms, lp, ln); err != nil {
- return
- }
-
- if isTail {
- return a.f.Truncate(h2off(h - latoms))
- }
-
- return a.link(h-latoms, latoms+atoms)
- }
-
- // case latoms != 0 && ratoms != 0:
- // <- middle join ->
- lh, rh := h-latoms, h+atoms
- if err = a.unlink(lh, latoms, lp, ln); err != nil {
- return
- }
-
- // Prev unlink may have invalidated rp or rn
- if _, _, rp, rn, err = a.nfo(rh); err != nil {
- return
- }
-
- if err = a.unlink(rh, ratoms, rp, rn); err != nil {
- return
- }
-
- return a.link(h-latoms, latoms+atoms+ratoms)
-}
-
-// Add a free block h to the appropriate free list
-func (a *Allocator) link(h, atoms int64) (err error) {
- if err = a.makeFree(h, atoms, 0, a.flt.head(atoms)); err != nil {
- return
- }
-
- return a.flt.setHead(h, atoms, a.f)
-}
-
-// Remove free block h from the free list
-func (a *Allocator) unlink(h, atoms, p, n int64) (err error) {
- switch {
- case p == 0 && n == 0:
- // single item list, must be head
- return a.flt.setHead(0, atoms, a.f)
- case p == 0 && n != 0:
- // head of list (has next item[s])
- if err = a.prev(n, 0); err != nil {
- return
- }
-
- // new head
- return a.flt.setHead(n, atoms, a.f)
- case p != 0 && n == 0:
- // last item in list
- return a.next(p, 0)
- }
- // case p != 0 && n != 0:
- // intermediate item in a list
- if err = a.next(p, n); err != nil {
- return
- }
-
- return a.prev(n, p)
-}
-
-//TODO remove ?
-// Return len(slice) == n, reuse src if possible.
-func need(n int, src []byte) []byte {
- if cap(src) < n {
- return *buffer.Get(n)
- }
-
- return src[:n]
-}
-
-// Get returns the data content of a block referred to by handle or an error if
-// any. The returned slice may be a sub-slice of buf if buf was large enough
-// to hold the entire content. Otherwise, a newly allocated slice will be
-// returned. It is valid to pass a nil buf.
-//
-// If the content was stored using compression then it is transparently
-// returned decompressed.
-//
-// Handle must have been obtained initially from Alloc and must be still valid,
-// otherwise invalid data may be returned without detecting the error.
-//
-// Get is safe for concurrent access by multiple goroutines iff no other
-// goroutine mutates the DB.
-func (a *Allocator) Get(buf []byte, handle int64) (b []byte, err error) {
- buf = buf[:cap(buf)]
- a.mu.Lock() // X1+
- if n, ok := a.m[handle]; ok {
- a.lru.moveToFront(n)
- b = need(len(n.b), buf)
- copy(b, n.b)
- a.expHit++
- a.hit++
- a.mu.Unlock() // X1-
- return
- }
-
- a.expMiss++
- a.miss++
- if a.miss > 10 && len(a.m) < 500 {
- if 100*a.hit/a.miss < 95 {
- a.cacheSz++
- }
- a.hit, a.miss = 0, 0
- }
- a.mu.Unlock() // X1-
-
- defer func(h int64) {
- if err == nil {
- a.mu.Lock() // X2+
- a.cadd(b, h)
- a.mu.Unlock() // X2-
- }
- }(handle)
-
- pfirst := buffer.Get(16)
- defer buffer.Put(pfirst)
- first := *pfirst
- relocated := false
- relocSrc := handle
-reloc:
- if handle <= 0 || handle > maxHandle {
- return nil, &ErrINVAL{"Allocator.Get: handle out of limits", handle}
- }
-
- off := h2off(handle)
- if err = a.read(first, off); err != nil {
- return
- }
-
- switch tag := first[0]; tag {
- default:
- dlen := int(tag)
- atoms := n2atoms(dlen)
- switch atoms {
- case 1:
- switch tag = first[15]; tag {
- default:
- return nil, &ErrILSEQ{Type: ErrTailTag, Off: off, Arg: int64(tag)}
- case tagNotCompressed:
- b = need(dlen, buf)
- copy(b, first[1:])
- return
- case tagCompressed:
- return zappy.Decode(buf, first[1:dlen+1])
- }
- default:
- pcc := buffer.Get(1)
- defer buffer.Put(pcc)
- cc := *pcc
- dlen := int(tag)
- atoms := n2atoms(dlen)
- tailOff := off + 16*int64(atoms) - 1
- if err = a.read(cc, tailOff); err != nil {
- return
- }
-
- switch tag = cc[0]; tag {
- default:
- return nil, &ErrILSEQ{Type: ErrTailTag, Off: off, Arg: int64(tag)}
- case tagNotCompressed:
- b = need(dlen, buf)
- off += 1
- if err = a.read(b, off); err != nil {
- b = buf[:0]
- }
- return
- case tagCompressed:
- pzbuf := buffer.Get(dlen)
- defer buffer.Put(pzbuf)
- zbuf := *pzbuf
- off += 1
- if err = a.read(zbuf, off); err != nil {
- return buf[:0], err
- }
-
- return zappy.Decode(buf, zbuf)
- }
- }
- case 0:
- return buf[:0], nil
- case tagUsedLong:
- pcc := buffer.Get(1)
- defer buffer.Put(pcc)
- cc := *pcc
- dlen := m2n(int(first[1])<<8 | int(first[2]))
- atoms := n2atoms(dlen)
- tailOff := off + 16*int64(atoms) - 1
- if err = a.read(cc, tailOff); err != nil {
- return
- }
-
- switch tag = cc[0]; tag {
- default:
- return nil, &ErrILSEQ{Type: ErrTailTag, Off: off, Arg: int64(tag)}
- case tagNotCompressed:
- b = need(dlen, buf)
- off += 3
- if err = a.read(b, off); err != nil {
- b = buf[:0]
- }
- return
- case tagCompressed:
- pzbuf := buffer.Get(dlen)
- defer buffer.Put(pzbuf)
- zbuf := *pzbuf
- off += 3
- if err = a.read(zbuf, off); err != nil {
- return buf[:0], err
- }
-
- return zappy.Decode(buf, zbuf)
- }
- case tagFreeShort, tagFreeLong:
- return nil, &ErrILSEQ{Type: ErrExpUsedTag, Off: off, Arg: int64(tag)}
- case tagUsedRelocated:
- if relocated {
- return nil, &ErrILSEQ{Type: ErrUnexpReloc, Off: off, Arg: relocSrc}
- }
-
- handle = b2h(first[1:])
- relocated = true
- goto reloc
- }
-}
-
-var reallocTestHook bool
-
-// Realloc sets the content of a block referred to by handle or returns an
-// error, if any.
-//
-// Handle must have been obtained initially from Alloc and must be still valid,
-// otherwise a database may get irreparably corrupted.
-func (a *Allocator) Realloc(handle int64, b []byte) (err error) {
- if handle <= 0 || handle > maxHandle {
- return &ErrINVAL{"Realloc: handle out of limits", handle}
- }
-
- a.cfree(handle)
- if err = a.realloc(handle, b); err != nil {
- return
- }
-
- if reallocTestHook {
- if err = cacheAudit(a.m, &a.lru); err != nil {
- return
- }
- }
-
- a.cadd(b, handle)
- return
-}
-
-func (a *Allocator) realloc(handle int64, b []byte) (err error) {
- var dlen, needAtoms0 int
-
- pb8 := buffer.Get(8)
- defer buffer.Put(pb8)
- b8 := *pb8
- pdst := buffer.Get(zappy.MaxEncodedLen(len(b)))
- defer buffer.Put(pdst)
- dst := *pdst
- b, needAtoms0, cc, err := a.makeUsedBlock(dst, b)
- if err != nil {
- return
- }
-
- needAtoms := int64(needAtoms0)
- off := h2off(handle)
- if err = a.read(b8[:], off); err != nil {
- return
- }
-
- switch tag := b8[0]; tag {
- default:
- dlen = int(b8[0])
- case tagUsedLong:
- dlen = m2n(int(b8[1])<<8 | int(b8[2]))
- case tagUsedRelocated:
- if err = a.free(b2h(b8[1:]), handle, false); err != nil {
- return err
- }
-
- dlen = 0
- case tagFreeShort, tagFreeLong:
- return &ErrINVAL{"Allocator.Realloc: invalid handle", handle}
- }
-
- atoms := int64(n2atoms(dlen))
-retry:
- switch {
- case needAtoms < atoms:
- // in place shrink
- if err = a.writeUsedBlock(handle, cc, b); err != nil {
- return
- }
-
- fh, fa := handle+needAtoms, atoms-needAtoms
- var sz int64
- if sz, err = a.f.Size(); err != nil {
- return err
- }
-
- if h2off(fh)+16*fa == sz {
- return a.f.Truncate(h2off(fh))
- }
-
- return a.free2(fh, fa)
- case needAtoms == atoms:
- // in place replace
- return a.writeUsedBlock(handle, cc, b)
- }
-
- // case needAtoms > atoms:
- // in place extend or relocate
- var sz int64
- if sz, err = a.f.Size(); err != nil {
- return
- }
-
- off = h2off(handle)
- switch {
- case off+atoms*16 == sz:
- // relocating tail block - shortcut
- return a.writeUsedBlock(handle, cc, b)
- default:
- if off+atoms*16 < sz {
- // handle is not a tail block, check right neighbour
- rh := handle + atoms
- rtag, ratoms, p, n, e := a.nfo(rh)
- if e != nil {
- return e
- }
-
- if rtag == tagFreeShort || rtag == tagFreeLong {
- // Right neighbour is a free block
- if needAtoms <= atoms+ratoms {
- // can expand in place
- if err = a.unlink(rh, ratoms, p, n); err != nil {
- return
- }
-
- atoms += ratoms
- goto retry
-
- }
- }
- }
- }
-
- if atoms > 1 {
- if err = a.realloc(handle, nil); err != nil {
- return
- }
- }
-
- var newH int64
- if newH, err = a.alloc(b, cc); err != nil {
- return err
- }
-
- prb := buffer.CGet(16)
- defer buffer.Put(prb)
- rb := *prb
- rb[0] = tagUsedRelocated
- h2b(rb[1:], newH)
- if err = a.writeAt(rb[:], h2off(handle)); err != nil {
- return
- }
-
- return a.writeUsedBlock(newH, cc, b)
-}
-
-func (a *Allocator) writeAt(b []byte, off int64) (err error) {
- var n int
- if n, err = a.f.WriteAt(b, off); err != nil {
- return
- }
-
- if n != len(b) {
- err = io.ErrShortWrite
- }
- return
-}
-
-func (a *Allocator) write(off int64, b ...[]byte) (err error) {
- rq := 0
- for _, part := range b {
- rq += len(part)
- }
- pbuf := buffer.Get(rq)
- defer buffer.Put(pbuf)
- buf := *pbuf
- buf = buf[:0]
- for _, part := range b {
- buf = append(buf, part...)
- }
- return a.writeAt(buf, off)
-}
-
-func (a *Allocator) read(b []byte, off int64) (err error) {
- var rn int
- if rn, err = a.f.ReadAt(b, off); rn != len(b) {
- return &ErrILSEQ{Type: ErrOther, Off: off, More: err}
- }
-
- return nil
-}
-
-// nfo returns h's tag. If it's a free block then return also (s)ize (in
-// atoms), (p)rev and (n)ext. If it's a used block then only (s)ize is returned
-// (again in atoms). If it's a used relocate block then (n)ext is set to the
-// relocation target handle.
-func (a *Allocator) nfo(h int64) (tag byte, s, p, n int64, err error) {
- off := h2off(h)
- rq := int64(22)
- sz, err := a.f.Size()
- if err != nil {
- return
- }
-
- if off+rq >= sz {
- if rq = sz - off; rq < 15 {
- err = io.ErrUnexpectedEOF
- return
- }
- }
-
- pbuf := buffer.Get(22)
- defer buffer.Put(pbuf)
- buf := *pbuf
- if err = a.read(buf[:rq], off); err != nil {
- return
- }
-
- switch tag = buf[0]; tag {
- default:
- s = int64(n2atoms(int(tag)))
- case tagUsedLong:
- s = int64(n2atoms(m2n(int(buf[1])<<8 | int(buf[2]))))
- case tagFreeLong:
- if rq < 22 {
- err = io.ErrUnexpectedEOF
- return
- }
-
- s, p, n = b2h(buf[1:]), b2h(buf[8:]), b2h(buf[15:])
- case tagUsedRelocated:
- s, n = 1, b2h(buf[1:])
- case tagFreeShort:
- s, p, n = 1, b2h(buf[1:]), b2h(buf[8:])
- }
- return
-}
-
-// leftNfo returns nfo for h's left neighbor if h > 1 and the left neighbor is
-// a free block. Otherwise all zero values are returned instead.
-func (a *Allocator) leftNfo(h int64) (tag byte, s, p, n int64, err error) {
- if !(h > 1) {
- return
- }
-
- pbuf := buffer.Get(8)
- defer buffer.Put(pbuf)
- buf := *pbuf
- off := h2off(h)
- if err = a.read(buf[:], off-8); err != nil {
- return
- }
-
- switch tag := buf[7]; tag {
- case tagFreeShort:
- return a.nfo(h - 1)
- case tagFreeLong:
- return a.nfo(h - b2h(buf[:]))
- }
- return
-}
-
-// Set h.prev = p
-func (a *Allocator) prev(h, p int64) (err error) {
- pb := buffer.Get(7)
- defer buffer.Put(pb)
- b := *pb
- off := h2off(h)
- if err = a.read(b[:1], off); err != nil {
- return
- }
-
- switch tag := b[0]; tag {
- default:
- return &ErrILSEQ{Type: ErrExpFreeTag, Off: off, Arg: int64(tag)}
- case tagFreeShort:
- off += 1
- case tagFreeLong:
- off += 8
- }
- return a.writeAt(h2b(b[:7], p), off)
-}
-
-// Set h.next = n
-func (a *Allocator) next(h, n int64) (err error) {
- pb := buffer.Get(7)
- defer buffer.Put(pb)
- b := *pb
- off := h2off(h)
- if err = a.read(b[:1], off); err != nil {
- return
- }
-
- switch tag := b[0]; tag {
- default:
- return &ErrILSEQ{Type: ErrExpFreeTag, Off: off, Arg: int64(tag)}
- case tagFreeShort:
- off += 8
- case tagFreeLong:
- off += 15
- }
- return a.writeAt(h2b(b[:7], n), off)
-}
-
-// Make the filer image @h a free block.
-func (a *Allocator) makeFree(h, atoms, prev, next int64) (err error) {
- pbuf := buffer.Get(22)
- defer buffer.Put(pbuf)
- buf := *pbuf
- switch {
- case atoms == 1:
- buf[0], buf[15] = tagFreeShort, tagFreeShort
- h2b(buf[1:], prev)
- h2b(buf[8:], next)
- if err = a.write(h2off(h), buf[:16]); err != nil {
- return
- }
- default:
-
- buf[0] = tagFreeLong
- h2b(buf[1:], atoms)
- h2b(buf[8:], prev)
- h2b(buf[15:], next)
- if err = a.write(h2off(h), buf[:22]); err != nil {
- return
- }
-
- h2b(buf[:], atoms)
- buf[7] = tagFreeLong
- if err = a.write(h2off(h+atoms)-8, buf[:8]); err != nil {
- return
- }
- }
- if prev != 0 {
- if err = a.next(prev, h); err != nil {
- return
- }
- }
-
- if next != 0 {
- err = a.prev(next, h)
- }
- return
-}
-
-func (a *Allocator) makeUsedBlock(dst []byte, b []byte) (w []byte, rqAtoms int, cc byte, err error) {
- cc = tagNotCompressed
- w = b
-
- var n int
- if n = len(b); n > maxRq {
- return nil, 0, 0, &ErrINVAL{"Allocator.makeUsedBlock: content size out of limits", n}
- }
-
- rqAtoms = n2atoms(n)
- if a.Compress && n > 14 { // attempt compression
- if dst, err = zappy.Encode(dst, b); err != nil {
- return
- }
-
- n2 := len(dst)
- if rqAtoms2 := n2atoms(n2); rqAtoms2 < rqAtoms { // compression saved at least a single atom
- w, rqAtoms, cc = dst, rqAtoms2, tagCompressed
- }
- }
- return
-}
-
-func (a *Allocator) writeUsedBlock(h int64, cc byte, b []byte) (err error) {
- n := len(b)
- rq := n2atoms(n) << 4
- pbuf := buffer.Get(rq)
- defer buffer.Put(pbuf)
- buf := *pbuf
- switch n <= maxShort {
- case true:
- buf[0] = byte(n)
- copy(buf[1:], b)
- case false:
- m := n2m(n)
- buf[0], buf[1], buf[2] = tagUsedLong, byte(m>>8), byte(m)
- copy(buf[3:], b)
- }
- if p := n2padding(n); p != 0 {
- copy(buf[rq-1-p:], zeros[:])
- }
- buf[rq-1] = cc
- return a.writeAt(buf, h2off(h))
-}
-
-func (a *Allocator) verifyUnused(h, totalAtoms int64, tag byte, log func(error) bool, fast bool) (atoms, prev, next int64, err error) {
- switch tag {
- default:
- panic("internal error")
- case tagFreeShort:
- var b [16]byte
- off := h2off(h)
- if err = a.read(b[:], off); err != nil {
- return
- }
-
- if b[15] != tagFreeShort {
- err = &ErrILSEQ{Type: ErrShortFreeTailTag, Off: off, Arg: int64(b[15])}
- log(err)
- return
- }
-
- atoms, prev, next = 1, b2h(b[1:]), b2h(b[8:])
- case tagFreeLong:
- var b [22]byte
- off := h2off(h)
- if err = a.read(b[:], off); err != nil {
- return
- }
-
- atoms, prev, next = b2h(b[1:]), b2h(b[8:]), b2h(b[15:])
- if fast {
- return
- }
-
- if atoms < 2 {
- err = &ErrILSEQ{Type: ErrLongFreeBlkTooShort, Off: off, Arg: atoms}
- break
- }
-
- if h+atoms-1 > totalAtoms {
- err = &ErrILSEQ{Type: ErrLongFreeBlkTooLong, Off: off, Arg: atoms}
- break
- }
-
- if prev > totalAtoms {
- err = &ErrILSEQ{Type: ErrLongFreePrevBeyondEOF, Off: off, Arg: next}
- break
- }
-
- if next > totalAtoms {
- err = &ErrILSEQ{Type: ErrLongFreeNextBeyondEOF, Off: off, Arg: next}
- break
- }
-
- toff := h2off(h+atoms) - 8
- if err = a.read(b[:8], toff); err != nil {
- return
- }
-
- if b[7] != tag {
- err = &ErrILSEQ{Type: ErrLongFreeTailTag, Off: off, Arg: int64(b[7])}
- break
- }
-
- if s2 := b2h(b[:]); s2 != atoms {
- err = &ErrILSEQ{Type: ErrVerifyTailSize, Off: off, Arg: atoms, Arg2: s2}
- break
- }
-
- }
- if err != nil {
- log(err)
- }
- return
-}
-
-func (a *Allocator) verifyUsed(h, totalAtoms int64, tag byte, buf, ubuf []byte, log func(error) bool, fast bool) (compressed bool, dlen int, atoms, link int64, err error) {
- var (
- padding int
- doff int64
- padZeros [15]byte
- tailBuf [16]byte
- )
-
- switch tag {
- default: // Short used
- dlen = int(tag)
- atoms = int64((dlen+1)/16) + 1
- padding = 15 - (dlen+1)%16
- doff = h2off(h) + 1
- case tagUsedLong:
- off := h2off(h) + 1
- var b2 [2]byte
- if err = a.read(b2[:], off); err != nil {
- return
- }
-
- dlen = m2n(int(b2[0])<<8 | int(b2[1]))
- atoms = int64((dlen+3)/16) + 1
- padding = 15 - (dlen+3)%16
- doff = h2off(h) + 3
- case tagUsedRelocated:
- dlen = 7
- atoms = 1
- padding = 7
- doff = h2off(h) + 1
- case tagFreeShort, tagFreeLong:
- panic("internal error")
- }
-
- if fast {
- if tag == tagUsedRelocated {
- dlen = 0
- if err = a.read(buf[:7], doff); err != nil {
- return
- }
-
- link = b2h(buf)
- }
-
- return false, dlen, atoms, link, nil
- }
-
- if ok := h+atoms-1 <= totalAtoms; !ok { // invalid last block
- err = &ErrILSEQ{Type: ErrVerifyUsedSpan, Off: h2off(h), Arg: atoms}
- log(err)
- return
- }
-
- tailsz := 1 + padding
- off := h2off(h) + 16*atoms - int64(tailsz)
- if err = a.read(tailBuf[:tailsz], off); err != nil {
- return false, 0, 0, 0, err
- }
-
- if ok := bytes.Equal(padZeros[:padding], tailBuf[:padding]); !ok {
- err = &ErrILSEQ{Type: ErrVerifyPadding, Off: h2off(h)}
- log(err)
- return
- }
-
- var cc byte
- switch cc = tailBuf[padding]; cc {
- default:
- err = &ErrILSEQ{Type: ErrTailTag, Off: h2off(h)}
- log(err)
- return
- case tagCompressed:
- compressed = true
- if tag == tagUsedRelocated {
- err = &ErrILSEQ{Type: ErrTailTag, Off: h2off(h)}
- log(err)
- return
- }
-
- fallthrough
- case tagNotCompressed:
- if err = a.read(buf[:dlen], doff); err != nil {
- return false, 0, 0, 0, err
- }
- }
-
- if cc == tagCompressed {
- if ubuf, err = zappy.Decode(ubuf, buf[:dlen]); err != nil || len(ubuf) > maxRq {
- err = &ErrILSEQ{Type: ErrDecompress, Off: h2off(h)}
- log(err)
- return
- }
-
- dlen = len(ubuf)
- }
-
- if tag == tagUsedRelocated {
- link = b2h(buf)
- if link == 0 {
- err = &ErrILSEQ{Type: ErrNullReloc, Off: h2off(h)}
- log(err)
- return
- }
-
- if link > totalAtoms { // invalid last block
- err = &ErrILSEQ{Type: ErrRelocBeyondEOF, Off: h2off(h), Arg: link}
- log(err)
- return
- }
- }
-
- return
-}
-
-var nolog = func(error) bool { return false }
-
-// Verify attempts to find any structural errors in a Filer wrt the
-// organization of it as defined by Allocator. 'bitmap' is a scratch pad for
-// necessary bookkeeping and will grow to at most to Allocator's
-// Filer.Size()/128 (0,78%). Any problems found are reported to 'log' except
-// non verify related errors like disk read fails etc. If 'log' returns false
-// or the error doesn't allow to (reliably) continue, the verification process
-// is stopped and an error is returned from the Verify function. Passing a nil
-// log works like providing a log function always returning false. Any
-// non-structural errors, like for instance Filer read errors, are NOT reported
-// to 'log', but returned as the Verify's return value, because Verify cannot
-// proceed in such cases. Verify returns nil only if it fully completed
-// verifying Allocator's Filer without detecting any error.
-//
-// It is recommended to limit the number reported problems by returning false
-// from 'log' after reaching some limit. Huge and corrupted DB can produce an
-// overwhelming error report dataset.
-//
-// The verifying process will scan the whole DB at least 3 times (a trade
-// between processing space and time consumed). It doesn't read the content of
-// free blocks above the head/tail info bytes. If the 3rd phase detects lost
-// free space, then a 4th scan (a faster one) is performed to precisely report
-// all of them.
-//
-// If the DB/Filer to be verified is reasonably small, respective if its
-// size/128 can comfortably fit within process's free memory, then it is
-// recommended to consider using a MemFiler for the bit map.
-//
-// Statistics are returned via 'stats' if non nil. The statistics are valid
-// only if Verify succeeded, ie. it didn't reported anything to log and it
-// returned a nil error.
-func (a *Allocator) Verify(bitmap Filer, log func(error) bool, stats *AllocStats) (err error) {
- if log == nil {
- log = nolog
- }
-
- n, err := bitmap.Size()
- if err != nil {
- return
- }
-
- if n != 0 {
- return &ErrINVAL{"Allocator.Verify: bit map initial size non zero (%d)", n}
- }
-
- var bits int64
- bitMask := [8]byte{1, 2, 4, 8, 16, 32, 64, 128}
- byteBuf := []byte{0}
-
- //DONE
- // +performance, this implementation is hopefully correct but _very_
- // naive, probably good as a prototype only. Use maybe a MemFiler
- // "cache" etc.
- // ----
- // Turns out the OS caching is as effective as it can probably get.
- bit := func(on bool, h int64) (wasOn bool, err error) {
- m := bitMask[h&7]
- off := h >> 3
- var v byte
- sz, err := bitmap.Size()
- if err != nil {
- return
- }
-
- if off < sz {
- if n, err := bitmap.ReadAt(byteBuf, off); n != 1 {
- return false, &ErrILSEQ{Type: ErrOther, Off: off, More: fmt.Errorf("Allocator.Verify - reading bitmap: %s", err)}
- }
-
- v = byteBuf[0]
- }
- switch wasOn = v&m != 0; on {
- case true:
- if !wasOn {
- v |= m
- bits++
- }
- case false:
- if wasOn {
- v ^= m
- bits--
- }
- }
- byteBuf[0] = v
- if n, err := bitmap.WriteAt(byteBuf, off); n != 1 || err != nil {
- return false, &ErrILSEQ{Type: ErrOther, Off: off, More: fmt.Errorf("Allocator.Verify - writing bitmap: %s", err)}
- }
-
- return
- }
-
- // Phase 1 - sequentially scan a.f to reliably determine block
- // boundaries. Set a bit for every block start.
- var (
- buf, ubuf [maxRq]byte
- prevH, h, atoms int64
- wasOn bool
- tag byte
- st = AllocStats{
- AllocMap: map[int64]int64{},
- FreeMap: map[int64]int64{},
- }
- dlen int
- )
-
- fsz, err := a.f.Size()
- if err != nil {
- return
- }
-
- ok := fsz%16 == 0
- totalAtoms := (fsz - fltSz) / atomLen
- if !ok {
- err = &ErrILSEQ{Type: ErrFileSize, Name: a.f.Name(), Arg: fsz}
- log(err)
- return
- }
-
- st.TotalAtoms = totalAtoms
- prevTag := -1
- lastH := int64(-1)
-
- for h = 1; h <= totalAtoms; h += atoms {
- prevH = h // For checking last block == used
-
- off := h2off(h)
- if err = a.read(buf[:1], off); err != nil {
- return
- }
-
- switch tag = buf[0]; tag {
- default: // Short used
- fallthrough
- case tagUsedLong, tagUsedRelocated:
- var compressed bool
- if compressed, dlen, atoms, _, err = a.verifyUsed(h, totalAtoms, tag, buf[:], ubuf[:], log, false); err != nil {
- return
- }
-
- if compressed {
- st.Compression++
- }
- st.AllocAtoms += atoms
- switch {
- case tag == tagUsedRelocated:
- st.AllocMap[1]++
- st.Relocations++
- default:
- st.AllocMap[atoms]++
- st.AllocBytes += int64(dlen)
- st.Handles++
- }
- case tagFreeShort, tagFreeLong:
- if prevTag == tagFreeShort || prevTag == tagFreeLong {
- err = &ErrILSEQ{Type: ErrAdjacentFree, Off: h2off(lastH), Arg: off}
- log(err)
- return
- }
-
- if atoms, _, _, err = a.verifyUnused(h, totalAtoms, tag, log, false); err != nil {
- return
- }
-
- st.FreeMap[atoms]++
- st.FreeAtoms += atoms
- }
-
- if wasOn, err = bit(true, h); err != nil {
- return
- }
-
- if wasOn {
- panic("internal error")
- }
-
- prevTag = int(tag)
- lastH = h
- }
-
- if totalAtoms != 0 && (tag == tagFreeShort || tag == tagFreeLong) {
- err = &ErrILSEQ{Type: ErrFreeTailBlock, Off: h2off(prevH)}
- log(err)
- return
- }
-
- // Phase 2 - check used blocks, turn off the map bit for every used
- // block.
- for h = 1; h <= totalAtoms; h += atoms {
- off := h2off(h)
- if err = a.read(buf[:1], off); err != nil {
- return
- }
-
- var link int64
- switch tag = buf[0]; tag {
- default: // Short used
- fallthrough
- case tagUsedLong, tagUsedRelocated:
- if _, _, atoms, link, err = a.verifyUsed(h, totalAtoms, tag, buf[:], ubuf[:], log, true); err != nil {
- return
- }
- case tagFreeShort, tagFreeLong:
- if atoms, _, _, err = a.verifyUnused(h, totalAtoms, tag, log, true); err != nil {
- return
- }
- }
-
- turnoff := true
- switch tag {
- case tagUsedRelocated:
- if err = a.read(buf[:1], h2off(link)); err != nil {
- return
- }
-
- switch linkedTag := buf[0]; linkedTag {
- case tagFreeShort, tagFreeLong, tagUsedRelocated:
- err = &ErrILSEQ{Type: ErrInvalidRelocTarget, Off: off, Arg: link}
- log(err)
- return
- }
-
- case tagFreeShort, tagFreeLong:
- turnoff = false
- }
-
- if !turnoff {
- continue
- }
-
- if wasOn, err = bit(false, h); err != nil {
- return
- }
-
- if !wasOn {
- panic("internal error")
- }
-
- }
-
- // Phase 3 - using the flt check heads link to proper free blocks. For
- // every free block, walk the list, verify the {next, prev} links and
- // turn the respective map bit off. After processing all free lists,
- // the map bits count should be zero. Otherwise there are "lost" free
- // blocks.
-
- var prev, next, fprev, fnext int64
- rep := a.flt
-
- for _, list := range rep {
- prev, next = 0, list.head
- for ; next != 0; prev, next = next, fnext {
- if wasOn, err = bit(false, next); err != nil {
- return
- }
-
- if !wasOn {
- err = &ErrILSEQ{Type: ErrFLT, Off: h2off(next), Arg: h}
- log(err)
- return
- }
-
- off := h2off(next)
- if err = a.read(buf[:1], off); err != nil {
- return
- }
-
- switch tag = buf[0]; tag {
- default:
- panic("internal error")
- case tagFreeShort, tagFreeLong:
- if atoms, fprev, fnext, err = a.verifyUnused(next, totalAtoms, tag, log, true); err != nil {
- return
- }
-
- if min := list.minSize; atoms < min {
- err = &ErrILSEQ{Type: ErrFLTSize, Off: h2off(next), Arg: atoms, Arg2: min}
- log(err)
- return
- }
-
- if fprev != prev {
- err = &ErrILSEQ{Type: ErrFreeChaining, Off: h2off(next)}
- log(err)
- return
- }
- }
- }
-
- }
-
- if bits == 0 { // Verify succeeded
- if stats != nil {
- *stats = st
- }
- return
- }
-
- // Phase 4 - if after phase 3 there are lost free blocks, report all of
- // them to 'log'
- for i := range ubuf { // setup zeros for compares
- ubuf[i] = 0
- }
-
- var off, lh int64
- rem, err := bitmap.Size()
- if err != nil {
- return err
- }
-
- for rem != 0 {
- rq := int(mathutil.MinInt64(64*1024, rem))
- var n int
- if n, err = bitmap.ReadAt(buf[:rq], off); n != rq {
- return &ErrILSEQ{Type: ErrOther, Off: off, More: fmt.Errorf("bitmap ReadAt(size %d, off %#x): %s", rq, off, err)}
- }
-
- if !bytes.Equal(buf[:rq], ubuf[:rq]) {
- for d, v := range buf[:rq] {
- if v != 0 {
- for i, m := range bitMask {
- if v&m != 0 {
- lh = 8*(off+int64(d)) + int64(i)
- err = &ErrILSEQ{Type: ErrLostFreeBlock, Off: h2off(lh)}
- log(err)
- return
- }
- }
- }
- }
- }
-
- off += int64(rq)
- rem -= int64(rq)
- }
-
- return
-}
-
-type fltSlot struct {
- head int64
- minSize int64
-}
-
-func (f fltSlot) String() string {
- return fmt.Sprintf("head %#x, minSize %#x\n", f.head, f.minSize)
-}
-
-type flt [14]fltSlot
-
-func (f *flt) init() {
- sz := 1
- for i := range *f {
- f[i].minSize, f[i].head = int64(sz), 0
- sz <<= 1
- }
- f[13].minSize = 4112
-}
-
-func (f *flt) load(fi Filer, off int64) (err error) {
- pb := buffer.Get(fltSz)
- defer buffer.Put(pb)
- b := *pb
- if _, err = fi.ReadAt(b[:], off); err != nil {
- return
- }
-
- for i := range *f {
- off := 8*i + 1
- f[i].head = b2h(b[off:])
- }
- return
-}
-
-func (f *flt) find(rq int) (h int64) {
- switch {
- case rq < 1:
- panic(rq)
- case rq >= maxFLTRq:
- h, f[13].head = f[13].head, 0
- return
- default:
- g := f[mathutil.Log2Uint16(uint16(rq)):]
- for i := range g {
- p := &g[i]
- if rq <= int(p.minSize) {
- if h = p.head; h != 0 {
- p.head = 0
- return
- }
- }
- }
- return
- }
-}
-
-func (f *flt) head(atoms int64) (h int64) {
- switch {
- case atoms < 1:
- panic(atoms)
- case atoms >= maxFLTRq:
- return f[13].head
- default:
- lg := mathutil.Log2Uint16(uint16(atoms))
- g := f[lg:]
- for i := range g {
- if atoms < g[i+1].minSize {
- return g[i].head
- }
- }
- panic("internal error")
- }
-}
-
-func (f *flt) setHead(h, atoms int64, fi Filer) (err error) {
- switch {
- case atoms < 1:
- panic(atoms)
- case atoms >= maxFLTRq:
- pb := buffer.Get(7)
- defer buffer.Put(pb)
- b := *pb
- if _, err = fi.WriteAt(h2b(b[:], h), 8*13+1); err != nil {
- return
- }
-
- f[13].head = h
- return
- default:
- lg := mathutil.Log2Uint16(uint16(atoms))
- g := f[lg:]
- for i := range f {
- if atoms < g[i+1].minSize {
- pb := buffer.Get(7)
- defer buffer.Put(pb)
- b := *pb
- if _, err = fi.WriteAt(h2b(b[:], h), 8*int64(i+lg)+1); err != nil {
- return
- }
-
- g[i].head = h
- return
- }
- }
- panic("internal error")
- }
-}
-
-func (f *flt) String() string {
- a := []string{}
- for i, v := range *f {
- a = append(a, fmt.Sprintf("[%2d] %s", i, v))
- }
- return strings.Join(a, "")
-}
-
-type node struct {
- b []byte
- h int64
- prev, next *node
-}
-
-type cache []*node
-
-func (c *cache) get(n int) *node {
- r, _ := c.get2(n)
- return r
-}
-
-func (c *cache) get2(n int) (r *node, isZeroed bool) {
- s := *c
- lens := len(s)
- if lens == 0 {
- return &node{b: make([]byte, n, mathutil.Min(2*n, maxBuf))}, true
- }
-
- i := sort.Search(lens, func(x int) bool { return len(s[x].b) >= n })
- if i == lens {
- i--
- s[i].b, isZeroed = make([]byte, n, mathutil.Min(2*n, maxBuf)), true
- }
-
- r = s[i]
- r.b = r.b[:n]
- copy(s[i:], s[i+1:])
- s = s[:lens-1]
- *c = s
- return
-}
-
-func (c *cache) cget(n int) (r *node) {
- r, ok := c.get2(n)
- if ok {
- return
- }
-
- for i := range r.b {
- r.b[i] = 0
- }
- return
-}
-
-func (c *cache) size() (sz int64) {
- for _, n := range *c {
- sz += int64(cap(n.b))
- }
- return
-}
-
-func (c *cache) put(n *node) *node {
- s := *c
- n.b = n.b[:cap(n.b)]
- lenb := len(n.b)
- lens := len(s)
- i := sort.Search(lens, func(x int) bool { return len(s[x].b) >= lenb })
- s = append(s, nil)
- copy(s[i+1:], s[i:])
- s[i] = n
- *c = s
- return n
-}
-
-type lst struct {
- front, back *node
-}
-
-func (l *lst) pushFront(n *node) *node {
- if l.front == nil {
- l.front, l.back, n.prev, n.next = n, n, nil, nil
- return n
- }
-
- n.prev, n.next, l.front.prev, l.front = nil, l.front, n, n
- return n
-}
-
-func (l *lst) remove(n *node) *node {
- if n.prev == nil {
- l.front = n.next
- } else {
- n.prev.next = n.next
- }
- if n.next == nil {
- l.back = n.prev
- } else {
- n.next.prev = n.prev
- }
- n.prev, n.next = nil, nil
- return n
-}
-
-func (l *lst) removeBack() *node {
- return l.remove(l.back)
-}
-
-func (l *lst) moveToFront(n *node) *node {
- return l.pushFront(l.remove(n))
-}
-
-func (l *lst) size() (sz int64) {
- for n := l.front; n != nil; n = n.next {
- sz += int64(cap(n.b))
- }
- return
-}
-
-func cacheAudit(m map[int64]*node, l *lst) (err error) {
- cnt := 0
- for h, n := range m {
- if g, e := n.h, h; g != e {
- return fmt.Errorf("cacheAudit: invalid node handle %d != %d", g, e)
- }
-
- if cnt, err = l.audit(n, true); err != nil {
- return
- }
- }
-
- if g, e := cnt, len(m); g != e {
- return fmt.Errorf("cacheAudit: invalid cache size %d != %d", g, e)
- }
-
- return
-}
-
-func (l *lst) audit(n *node, onList bool) (cnt int, err error) {
- if !onList && (n.prev != nil || n.next != nil) {
- return -1, fmt.Errorf("lst.audit: free node with non nil linkage")
- }
-
- if l.front == nil && l.back != nil || l.back == nil && l.front != nil {
- return -1, fmt.Errorf("lst.audit: one of .front/.back is nil while the other is non nil")
- }
-
- if l.front == l.back && l.front != nil {
- x := l.front
- if x.prev != nil || x.next != nil {
- return -1, fmt.Errorf("lst.audit: single node has non nil linkage")
- }
-
- if onList && x != n {
- return -1, fmt.Errorf("lst.audit: single node is alien")
- }
- }
-
- seen := false
- var prev *node
- x := l.front
- for x != nil {
- cnt++
- if x.prev != prev {
- return -1, fmt.Errorf("lst.audit: broken .prev linkage")
- }
-
- if x == n {
- seen = true
- }
-
- prev = x
- x = x.next
- }
-
- if prev != l.back {
- return -1, fmt.Errorf("lst.audit: broken .back linkage")
- }
-
- if onList && !seen {
- return -1, fmt.Errorf("lst.audit: node missing in list")
- }
-
- if !onList && seen {
- return -1, fmt.Errorf("lst.audit: node should not be on the list")
- }
-
- return
-}
diff --git a/vendor/github.com/cznic/lldb/filer.go b/vendor/github.com/cznic/lldb/filer.go
deleted file mode 100644
index f7793ed9c..000000000
--- a/vendor/github.com/cznic/lldb/filer.go
+++ /dev/null
@@ -1,184 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// An abstraction of file like (persistent) storage with optional (abstracted)
-// support for structural integrity.
-
-package lldb
-
-import "github.com/cznic/mathutil"
-
-// A Filer is a []byte-like model of a file or similar entity. It may
-// optionally implement support for structural transaction safety. In contrast
-// to a file stream, a Filer is not sequentially accessible. ReadAt and WriteAt
-// are always "addressed" by an offset and are assumed to perform atomically.
-// A Filer is not safe for concurrent access, it's designed for consumption by
-// the other objects in package, which should use a Filer from one goroutine
-// only or via a mutex. BeginUpdate, EndUpdate and Rollback must be either all
-// implemented by a Filer for structural integrity - or they should be all
-// no-ops; where/if that requirement is relaxed.
-//
-// If a Filer wraps another Filer implementation, it usually invokes the same
-// methods on the "inner" one, after some possible argument translations etc.
-// If a Filer implements the structural transactions handling methods
-// (BeginUpdate, EndUpdate and Rollback) as no-ops _and_ wraps another Filer:
-// it then still MUST invoke those methods on the inner Filer. This is
-// important for the case where a RollbackFiler exists somewhere down the
-// chain. It's also important for an Allocator - to know when it must
-// invalidate its FLT cache.
-type Filer interface {
- // BeginUpdate increments the "nesting" counter (initially zero). Every
- // call to BeginUpdate must be eventually "balanced" by exactly one of
- // EndUpdate or Rollback. Calls to BeginUpdate may nest.
- BeginUpdate() error
-
- // Analogous to os.File.Close().
- Close() error
-
- // EndUpdate decrements the "nesting" counter. If it's zero after that
- // then assume the "storage" has reached structural integrity (after a
- // batch of partial updates). If a Filer implements some support for
- // that (write ahead log, journal, etc.) then the appropriate actions
- // are to be taken for nesting == 0. Invocation of an unbalanced
- // EndUpdate is an error.
- EndUpdate() error
-
- // Analogous to os.File.Name().
- Name() string
-
- // PunchHole deallocates space inside a "file" in the byte range
- // starting at off and continuing for size bytes. The actual hole
- // created by PunchHole may be smaller than requested. The Filer size
- // (as reported by `Size()` does not change when hole punching, even
- // when punching the end of a file off. In contrast to the Linux
- // implementation of FALLOC_FL_PUNCH_HOLE in `fallocate`(2); a Filer is
- // free not only to ignore `PunchHole()` (implement it as a nop), but
- // additionally no guarantees about the content of the hole, when
- // eventually read back, are required, i.e. any data, not only zeros,
- // can be read from the "hole", including just anything what was left
- // there - with all of the possible security problems.
- PunchHole(off, size int64) error
-
- // As os.File.ReadAt. Note: `off` is an absolute "file pointer"
- // address and cannot be negative even when a Filer is a InnerFiler.
- ReadAt(b []byte, off int64) (n int, err error)
-
- // Rollback cancels and undoes the innermost pending update level.
- // Rollback decrements the "nesting" counter. If a Filer implements
- // some support for keeping structural integrity (write ahead log,
- // journal, etc.) then the appropriate actions are to be taken.
- // Invocation of an unbalanced Rollback is an error.
- Rollback() error
-
- // Analogous to os.File.FileInfo().Size().
- Size() (int64, error)
-
- // Analogous to os.Sync().
- Sync() (err error)
-
- // Analogous to os.File.Truncate().
- Truncate(size int64) error
-
- // Analogous to os.File.WriteAt(). Note: `off` is an absolute "file
- // pointer" address and cannot be negative even when a Filer is a
- // InnerFiler.
- WriteAt(b []byte, off int64) (n int, err error)
-}
-
-var _ Filer = &InnerFiler{} // Ensure InnerFiler is a Filer.
-
-// A InnerFiler is a Filer with added addressing/size translation.
-type InnerFiler struct {
- outer Filer
- off int64
-}
-
-// NewInnerFiler returns a new InnerFiler wrapped by `outer` in a way which
-// adds `off` to every access.
-//
-// For example, considering:
-//
-// inner := NewInnerFiler(outer, 10)
-//
-// then
-//
-// inner.WriteAt([]byte{42}, 4)
-//
-// translates to
-//
-// outer.WriteAt([]byte{42}, 14)
-//
-// But an attempt to emulate
-//
-// outer.WriteAt([]byte{17}, 9)
-//
-// by
-//
-// inner.WriteAt([]byte{17}, -1)
-//
-// will fail as the `off` parameter can never be < 0. Also note that
-//
-// inner.Size() == outer.Size() - off,
-//
-// i.e. `inner` pretends no `outer` exists. Finally, after e.g.
-//
-// inner.Truncate(7)
-// outer.Size() == 17
-//
-// will be true.
-func NewInnerFiler(outer Filer, off int64) *InnerFiler { return &InnerFiler{outer, off} }
-
-// BeginUpdate implements Filer.
-func (f *InnerFiler) BeginUpdate() error { return f.outer.BeginUpdate() }
-
-// Close implements Filer.
-func (f *InnerFiler) Close() (err error) { return f.outer.Close() }
-
-// EndUpdate implements Filer.
-func (f *InnerFiler) EndUpdate() error { return f.outer.EndUpdate() }
-
-// Name implements Filer.
-func (f *InnerFiler) Name() string { return f.outer.Name() }
-
-// PunchHole implements Filer. `off`, `size` must be >= 0.
-func (f *InnerFiler) PunchHole(off, size int64) error { return f.outer.PunchHole(f.off+off, size) }
-
-// ReadAt implements Filer. `off` must be >= 0.
-func (f *InnerFiler) ReadAt(b []byte, off int64) (n int, err error) {
- if off < 0 {
- return 0, &ErrINVAL{f.outer.Name() + ":ReadAt invalid off", off}
- }
-
- return f.outer.ReadAt(b, f.off+off)
-}
-
-// Rollback implements Filer.
-func (f *InnerFiler) Rollback() error { return f.outer.Rollback() }
-
-// Size implements Filer.
-func (f *InnerFiler) Size() (int64, error) {
- sz, err := f.outer.Size()
- if err != nil {
- return 0, err
- }
-
- return mathutil.MaxInt64(sz-f.off, 0), nil
-}
-
-// Sync() implements Filer.
-func (f *InnerFiler) Sync() (err error) {
- return f.outer.Sync()
-}
-
-// Truncate implements Filer.
-func (f *InnerFiler) Truncate(size int64) error { return f.outer.Truncate(size + f.off) }
-
-// WriteAt implements Filer. `off` must be >= 0.
-func (f *InnerFiler) WriteAt(b []byte, off int64) (n int, err error) {
- if off < 0 {
- return 0, &ErrINVAL{f.outer.Name() + ":WriteAt invalid off", off}
- }
-
- return f.outer.WriteAt(b, f.off+off)
-}
diff --git a/vendor/github.com/cznic/lldb/gb.go b/vendor/github.com/cznic/lldb/gb.go
deleted file mode 100644
index 5bc3e404e..000000000
--- a/vendor/github.com/cznic/lldb/gb.go
+++ /dev/null
@@ -1,812 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Utilities to encode/decode and collate Go predeclared scalar types (and the
-// typeless nil and []byte). The encoding format is a variation of the one
-// used by the "encoding/gob" package.
-
-package lldb
-
-import (
- "bytes"
- "fmt"
- "math"
-
- "github.com/cznic/mathutil"
-)
-
-const (
- gbNull = iota // 0x00
- gbFalse // 0x01
- gbTrue // 0x02
- gbFloat0 // 0x03
- gbFloat1 // 0x04
- gbFloat2 // 0x05
- gbFloat3 // 0x06
- gbFloat4 // 0x07
- gbFloat5 // 0x08
- gbFloat6 // 0x09
- gbFloat7 // 0x0a
- gbFloat8 // 0x0b
- gbComplex0 // 0x0c
- gbComplex1 // 0x0d
- gbComplex2 // 0x0e
- gbComplex3 // 0x0f
- gbComplex4 // 0x10
- gbComplex5 // 0x11
- gbComplex6 // 0x12
- gbComplex7 // 0x13
- gbComplex8 // 0x14
- gbBytes00 // 0x15
- gbBytes01 // 0x16
- gbBytes02 // 0x17
- gbBytes03 // 0x18
- gbBytes04 // 0x19
- gbBytes05 // 0x1a
- gbBytes06 // 0x1b
- gbBytes07 // 0x1c
- gbBytes08 // 0x1d
- gbBytes09 // 0x1e
- gbBytes10 // 0x1f
- gbBytes11 // 0x20
- gbBytes12 // 0x21
- gbBytes13 // 0x22
- gbBytes14 // 0x23
- gbBytes15 // 0x24
- gbBytes16 // 0x25
- gbBytes17 // Ox26
- gbBytes1 // 0x27
- gbBytes2 // 0x28: Offset by one to allow 64kB sized []byte.
- gbString00 // 0x29
- gbString01 // 0x2a
- gbString02 // 0x2b
- gbString03 // 0x2c
- gbString04 // 0x2d
- gbString05 // 0x2e
- gbString06 // 0x2f
- gbString07 // 0x30
- gbString08 // 0x31
- gbString09 // 0x32
- gbString10 // 0x33
- gbString11 // 0x34
- gbString12 // 0x35
- gbString13 // 0x36
- gbString14 // 0x37
- gbString15 // 0x38
- gbString16 // 0x39
- gbString17 // 0x3a
- gbString1 // 0x3b
- gbString2 // 0x3c
- gbUintP1 // 0x3d
- gbUintP2 // 0x3e
- gbUintP3 // 0x3f
- gbUintP4 // 0x40
- gbUintP5 // 0x41
- gbUintP6 // 0x42
- gbUintP7 // 0x43
- gbUintP8 // 0x44
- gbIntM8 // 0x45
- gbIntM7 // 0x46
- gbIntM6 // 0x47
- gbIntM5 // 0x48
- gbIntM4 // 0x49
- gbIntM3 // 0x4a
- gbIntM2 // 0x4b
- gbIntM1 // 0x4c
- gbIntP1 // 0x4d
- gbIntP2 // 0x4e
- gbIntP3 // 0x4f
- gbIntP4 // 0x50
- gbIntP5 // 0x51
- gbIntP6 // 0x52
- gbIntP7 // 0x53
- gbIntP8 // 0x54
- gbInt0 // 0x55
-
- gbIntMax = 255 - gbInt0 // 0xff == 170
-)
-
-// EncodeScalars encodes a vector of predeclared scalar type values to a
-// []byte, making it suitable to store it as a "record" in a DB or to use it as
-// a key of a BTree.
-func EncodeScalars(scalars ...interface{}) (b []byte, err error) {
- for _, scalar := range scalars {
- switch x := scalar.(type) {
- default:
- return nil, &ErrINVAL{"EncodeScalars: unsupported type", fmt.Sprintf("%T in `%#v`", x, scalars)}
-
- case nil:
- b = append(b, gbNull)
-
- case bool:
- switch x {
- case false:
- b = append(b, gbFalse)
- case true:
- b = append(b, gbTrue)
- }
-
- case float32:
- encFloat(float64(x), &b)
- case float64:
- encFloat(x, &b)
-
- case complex64:
- encComplex(complex128(x), &b)
- case complex128:
- encComplex(x, &b)
-
- case string:
- n := len(x)
- if n <= 17 {
- b = append(b, byte(gbString00+n))
- b = append(b, []byte(x)...)
- break
- }
-
- if n > 65535 {
- return nil, fmt.Errorf("EncodeScalars: cannot encode string of length %d (limit 65536)", n)
- }
-
- pref := byte(gbString1)
- if n > 255 {
- pref++
- }
- b = append(b, pref)
- encUint0(uint64(n), &b)
- b = append(b, []byte(x)...)
-
- case int8:
- encInt(int64(x), &b)
- case int16:
- encInt(int64(x), &b)
- case int32:
- encInt(int64(x), &b)
- case int64:
- encInt(x, &b)
- case int:
- encInt(int64(x), &b)
-
- case uint8:
- encUint(uint64(x), &b)
- case uint16:
- encUint(uint64(x), &b)
- case uint32:
- encUint(uint64(x), &b)
- case uint64:
- encUint(x, &b)
- case uint:
- encUint(uint64(x), &b)
- case []byte:
- n := len(x)
- if n <= 17 {
- b = append(b, byte(gbBytes00+n))
- b = append(b, x...)
- break
- }
-
- if n > 655356 {
- return nil, fmt.Errorf("EncodeScalars: cannot encode []byte of length %d (limit 65536)", n)
- }
-
- pref := byte(gbBytes1)
- if n > 255 {
- pref++
- }
- b = append(b, pref)
- if n <= 255 {
- b = append(b, byte(n))
- } else {
- n--
- b = append(b, byte(n>>8), byte(n))
- }
- b = append(b, x...)
- }
- }
- return
-}
-
-func encComplex(f complex128, b *[]byte) {
- encFloatPrefix(gbComplex0, real(f), b)
- encFloatPrefix(gbComplex0, imag(f), b)
-}
-
-func encFloatPrefix(prefix byte, f float64, b *[]byte) {
- u := math.Float64bits(f)
- var n uint64
- for i := 0; i < 8; i++ {
- n <<= 8
- n |= u & 0xFF
- u >>= 8
- }
- bits := mathutil.BitLenUint64(n)
- if bits == 0 {
- *b = append(*b, prefix)
- return
- }
-
- // 0 1 2 3 4 5 6 7 8 9
- // . 1 1 1 1 1 1 1 1 2
- encUintPrefix(prefix+1+byte((bits-1)>>3), n, b)
-}
-
-func encFloat(f float64, b *[]byte) {
- encFloatPrefix(gbFloat0, f, b)
-}
-
-func encUint0(n uint64, b *[]byte) {
- switch {
- case n <= 0xff:
- *b = append(*b, byte(n))
- case n <= 0xffff:
- *b = append(*b, byte(n>>8), byte(n))
- case n <= 0xffffff:
- *b = append(*b, byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffff:
- *b = append(*b, byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffffff:
- *b = append(*b, byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffffffff:
- *b = append(*b, byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffffffffff:
- *b = append(*b, byte(n>>48), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= math.MaxUint64:
- *b = append(*b, byte(n>>56), byte(n>>48), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- }
-}
-
-func encUintPrefix(prefix byte, n uint64, b *[]byte) {
- *b = append(*b, prefix)
- encUint0(n, b)
-}
-
-func encUint(n uint64, b *[]byte) {
- bits := mathutil.Max(1, mathutil.BitLenUint64(n))
- encUintPrefix(gbUintP1+byte((bits-1)>>3), n, b)
-}
-
-func encInt(n int64, b *[]byte) {
- switch {
- case n < -0x100000000000000:
- *b = append(*b, byte(gbIntM8), byte(n>>56), byte(n>>48), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n < -0x1000000000000:
- *b = append(*b, byte(gbIntM7), byte(n>>48), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n < -0x10000000000:
- *b = append(*b, byte(gbIntM6), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n < -0x100000000:
- *b = append(*b, byte(gbIntM5), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n < -0x1000000:
- *b = append(*b, byte(gbIntM4), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n < -0x10000:
- *b = append(*b, byte(gbIntM3), byte(n>>16), byte(n>>8), byte(n))
- case n < -0x100:
- *b = append(*b, byte(gbIntM2), byte(n>>8), byte(n))
- case n < 0:
- *b = append(*b, byte(gbIntM1), byte(n))
- case n <= gbIntMax:
- *b = append(*b, byte(gbInt0+n))
- case n <= 0xff:
- *b = append(*b, gbIntP1, byte(n))
- case n <= 0xffff:
- *b = append(*b, gbIntP2, byte(n>>8), byte(n))
- case n <= 0xffffff:
- *b = append(*b, gbIntP3, byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffff:
- *b = append(*b, gbIntP4, byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffffff:
- *b = append(*b, gbIntP5, byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffffffff:
- *b = append(*b, gbIntP6, byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0xffffffffffffff:
- *b = append(*b, gbIntP7, byte(n>>48), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- case n <= 0x7fffffffffffffff:
- *b = append(*b, gbIntP8, byte(n>>56), byte(n>>48), byte(n>>40), byte(n>>32), byte(n>>24), byte(n>>16), byte(n>>8), byte(n))
- }
-}
-
-func decodeFloat(b []byte) float64 {
- var u uint64
- for i, v := range b {
- u |= uint64(v) << uint((i+8-len(b))*8)
- }
- return math.Float64frombits(u)
-}
-
-// DecodeScalars decodes a []byte produced by EncodeScalars.
-func DecodeScalars(b []byte) (scalars []interface{}, err error) {
- b0 := b
- for len(b) != 0 {
- switch tag := b[0]; tag {
- //default:
- //return nil, fmt.Errorf("tag %d(%#x) not supported", b[0], b[0])
- case gbNull:
- scalars = append(scalars, nil)
- b = b[1:]
- case gbFalse:
- scalars = append(scalars, false)
- b = b[1:]
- case gbTrue:
- scalars = append(scalars, true)
- b = b[1:]
- case gbFloat0:
- scalars = append(scalars, 0.0)
- b = b[1:]
- case gbFloat1, gbFloat2, gbFloat3, gbFloat4, gbFloat5, gbFloat6, gbFloat7, gbFloat8:
- n := 1 + int(tag) - gbFloat0
- if len(b) < n-1 {
- goto corrupted
- }
-
- scalars = append(scalars, decodeFloat(b[1:n]))
- b = b[n:]
- case gbComplex0, gbComplex1, gbComplex2, gbComplex3, gbComplex4, gbComplex5, gbComplex6, gbComplex7, gbComplex8:
- n := 1 + int(tag) - gbComplex0
- if len(b) < n-1 {
- goto corrupted
- }
-
- re := decodeFloat(b[1:n])
- b = b[n:]
-
- if len(b) == 0 {
- goto corrupted
- }
-
- tag = b[0]
- if tag < gbComplex0 || tag > gbComplex8 {
- goto corrupted
- }
-
- n = 1 + int(tag) - gbComplex0
- if len(b) < n-1 {
- goto corrupted
- }
-
- scalars = append(scalars, complex(re, decodeFloat(b[1:n])))
- b = b[n:]
- case gbBytes00, gbBytes01, gbBytes02, gbBytes03, gbBytes04,
- gbBytes05, gbBytes06, gbBytes07, gbBytes08, gbBytes09,
- gbBytes10, gbBytes11, gbBytes12, gbBytes13, gbBytes14,
- gbBytes15, gbBytes16, gbBytes17:
- n := int(tag - gbBytes00)
- if len(b) < n+1 {
- goto corrupted
- }
-
- scalars = append(scalars, append([]byte(nil), b[1:n+1]...))
- b = b[n+1:]
- case gbBytes1:
- if len(b) < 2 {
- goto corrupted
- }
-
- n := int(b[1])
- b = b[2:]
- if len(b) < n {
- goto corrupted
- }
-
- scalars = append(scalars, append([]byte(nil), b[:n]...))
- b = b[n:]
- case gbBytes2:
- if len(b) < 3 {
- goto corrupted
- }
-
- n := int(b[1])<<8 | int(b[2]) + 1
- b = b[3:]
- if len(b) < n {
- goto corrupted
- }
-
- scalars = append(scalars, append([]byte(nil), b[:n]...))
- b = b[n:]
- case gbString00, gbString01, gbString02, gbString03, gbString04,
- gbString05, gbString06, gbString07, gbString08, gbString09,
- gbString10, gbString11, gbString12, gbString13, gbString14,
- gbString15, gbString16, gbString17:
- n := int(tag - gbString00)
- if len(b) < n+1 {
- goto corrupted
- }
-
- scalars = append(scalars, string(b[1:n+1]))
- b = b[n+1:]
- case gbString1:
- if len(b) < 2 {
- goto corrupted
- }
-
- n := int(b[1])
- b = b[2:]
- if len(b) < n {
- goto corrupted
- }
-
- scalars = append(scalars, string(b[:n]))
- b = b[n:]
- case gbString2:
- if len(b) < 3 {
- goto corrupted
- }
-
- n := int(b[1])<<8 | int(b[2])
- b = b[3:]
- if len(b) < n {
- goto corrupted
- }
-
- scalars = append(scalars, string(b[:n]))
- b = b[n:]
- case gbUintP1, gbUintP2, gbUintP3, gbUintP4, gbUintP5, gbUintP6, gbUintP7, gbUintP8:
- b = b[1:]
- n := 1 + int(tag) - gbUintP1
- if len(b) < n {
- goto corrupted
- }
-
- var u uint64
- for _, v := range b[:n] {
- u = u<<8 | uint64(v)
- }
- scalars = append(scalars, u)
- b = b[n:]
- case gbIntM8, gbIntM7, gbIntM6, gbIntM5, gbIntM4, gbIntM3, gbIntM2, gbIntM1:
- b = b[1:]
- n := 8 - (int(tag) - gbIntM8)
- if len(b) < n {
- goto corrupted
- }
- u := uint64(math.MaxUint64)
- for _, v := range b[:n] {
- u = u<<8 | uint64(v)
- }
- scalars = append(scalars, int64(u))
- b = b[n:]
- case gbIntP1, gbIntP2, gbIntP3, gbIntP4, gbIntP5, gbIntP6, gbIntP7, gbIntP8:
- b = b[1:]
- n := 1 + int(tag) - gbIntP1
- if len(b) < n {
- goto corrupted
- }
-
- i := int64(0)
- for _, v := range b[:n] {
- i = i<<8 | int64(v)
- }
- scalars = append(scalars, i)
- b = b[n:]
- default:
- scalars = append(scalars, int64(b[0])-gbInt0)
- b = b[1:]
- }
- }
- return append([]interface{}(nil), scalars...), nil
-
-corrupted:
- return nil, &ErrDecodeScalars{append([]byte(nil), b0...), len(b0) - len(b)}
-}
-
-func collateComplex(x, y complex128) int {
- switch rx, ry := real(x), real(y); {
- case rx < ry:
- return -1
- case rx == ry:
- switch ix, iy := imag(x), imag(y); {
- case ix < iy:
- return -1
- case ix == iy:
- return 0
- case ix > iy:
- return 1
- }
- }
- //case rx > ry:
- return 1
-}
-
-func collateFloat(x, y float64) int {
- switch {
- case x < y:
- return -1
- case x == y:
- return 0
- }
- //case x > y:
- return 1
-}
-
-func collateInt(x, y int64) int {
- switch {
- case x < y:
- return -1
- case x == y:
- return 0
- }
- //case x > y:
- return 1
-}
-
-func collateUint(x, y uint64) int {
- switch {
- case x < y:
- return -1
- case x == y:
- return 0
- }
- //case x > y:
- return 1
-}
-
-func collateIntUint(x int64, y uint64) int {
- if y > math.MaxInt64 {
- return -1
- }
-
- return collateInt(x, int64(y))
-}
-
-func collateUintInt(x uint64, y int64) int {
- return -collateIntUint(y, x)
-}
-
-func collateType(i interface{}) (r interface{}, err error) {
- switch x := i.(type) {
- default:
- return nil, fmt.Errorf("invalid collate type %T", x)
- case nil:
- return i, nil
- case bool:
- return i, nil
- case int8:
- return int64(x), nil
- case int16:
- return int64(x), nil
- case int32:
- return int64(x), nil
- case int64:
- return i, nil
- case int:
- return int64(x), nil
- case uint8:
- return uint64(x), nil
- case uint16:
- return uint64(x), nil
- case uint32:
- return uint64(x), nil
- case uint64:
- return i, nil
- case uint:
- return uint64(x), nil
- case float32:
- return float64(x), nil
- case float64:
- return i, nil
- case complex64:
- return complex128(x), nil
- case complex128:
- return i, nil
- case []byte:
- return i, nil
- case string:
- return i, nil
- }
-}
-
-// Collate collates two arrays of Go predeclared scalar types (and the typeless
-// nil or []byte). If any other type appears in x or y, Collate will return a
-// non nil error. String items are collated using strCollate or lexically
-// byte-wise (as when using Go comparison operators) when strCollate is nil.
-// []byte items are collated using bytes.Compare.
-//
-// Collate returns:
-//
-// -1 if x < y
-// 0 if x == y
-// +1 if x > y
-//
-// The same value as defined above must be returned from strCollate.
-//
-// The "outer" ordering is: nil, bool, number, []byte, string. IOW, nil is
-// "smaller" than anything else except other nil, numbers collate before
-// []byte, []byte collate before strings, etc.
-//
-// Integers and real numbers collate as expected in math. However, complex
-// numbers are not ordered in Go. Here the ordering is defined: Complex numbers
-// are in comparison considered first only by their real part. Iff the result
-// is equality then the imaginary part is used to determine the ordering. In
-// this "second order" comparing, integers and real numbers are considered as
-// complex numbers with a zero imaginary part.
-func Collate(x, y []interface{}, strCollate func(string, string) int) (r int, err error) {
- nx, ny := len(x), len(y)
-
- switch {
- case nx == 0 && ny != 0:
- return -1, nil
- case nx == 0 && ny == 0:
- return 0, nil
- case nx != 0 && ny == 0:
- return 1, nil
- }
-
- r = 1
- if nx > ny {
- x, y, r = y, x, -r
- }
-
- var c int
- for i, xi0 := range x {
- yi0 := y[i]
- xi, err := collateType(xi0)
- if err != nil {
- return 0, err
- }
-
- yi, err := collateType(yi0)
- if err != nil {
- return 0, err
- }
-
- switch x := xi.(type) {
- default:
- panic(fmt.Errorf("internal error: %T", x))
-
- case nil:
- switch yi.(type) {
- case nil:
- // nop
- default:
- return -r, nil
- }
-
- case bool:
- switch y := yi.(type) {
- case nil:
- return r, nil
- case bool:
- switch {
- case !x && y:
- return -r, nil
- case x == y:
- // nop
- case x && !y:
- return r, nil
- }
- default:
- return -r, nil
- }
-
- case int64:
- switch y := yi.(type) {
- case nil, bool:
- return r, nil
- case int64:
- c = collateInt(x, y)
- case uint64:
- c = collateIntUint(x, y)
- case float64:
- c = collateFloat(float64(x), y)
- case complex128:
- c = collateComplex(complex(float64(x), 0), y)
- case []byte:
- return -r, nil
- case string:
- return -r, nil
- }
-
- if c != 0 {
- return c * r, nil
- }
-
- case uint64:
- switch y := yi.(type) {
- case nil, bool:
- return r, nil
- case int64:
- c = collateUintInt(x, y)
- case uint64:
- c = collateUint(x, y)
- case float64:
- c = collateFloat(float64(x), y)
- case complex128:
- c = collateComplex(complex(float64(x), 0), y)
- case []byte:
- return -r, nil
- case string:
- return -r, nil
- }
-
- if c != 0 {
- return c * r, nil
- }
-
- case float64:
- switch y := yi.(type) {
- case nil, bool:
- return r, nil
- case int64:
- c = collateFloat(x, float64(y))
- case uint64:
- c = collateFloat(x, float64(y))
- case float64:
- c = collateFloat(x, y)
- case complex128:
- c = collateComplex(complex(x, 0), y)
- case []byte:
- return -r, nil
- case string:
- return -r, nil
- }
-
- if c != 0 {
- return c * r, nil
- }
-
- case complex128:
- switch y := yi.(type) {
- case nil, bool:
- return r, nil
- case int64:
- c = collateComplex(x, complex(float64(y), 0))
- case uint64:
- c = collateComplex(x, complex(float64(y), 0))
- case float64:
- c = collateComplex(x, complex(y, 0))
- case complex128:
- c = collateComplex(x, y)
- case []byte:
- return -r, nil
- case string:
- return -r, nil
- }
-
- if c != 0 {
- return c * r, nil
- }
-
- case []byte:
- switch y := yi.(type) {
- case nil, bool, int64, uint64, float64, complex128:
- return r, nil
- case []byte:
- c = bytes.Compare(x, y)
- case string:
- return -r, nil
- }
-
- if c != 0 {
- return c * r, nil
- }
-
- case string:
- switch y := yi.(type) {
- case nil, bool, int64, uint64, float64, complex128:
- return r, nil
- case []byte:
- return r, nil
- case string:
- switch {
- case strCollate != nil:
- c = strCollate(x, y)
- case x < y:
- return -r, nil
- case x == y:
- c = 0
- case x > y:
- return r, nil
- }
- }
-
- if c != 0 {
- return c * r, nil
- }
- }
- }
-
- if nx == ny {
- return 0, nil
- }
-
- return -r, nil
-}
diff --git a/vendor/github.com/cznic/lldb/lldb.go b/vendor/github.com/cznic/lldb/lldb.go
deleted file mode 100644
index 670fffd48..000000000
--- a/vendor/github.com/cznic/lldb/lldb.go
+++ /dev/null
@@ -1,160 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package lldb implements a low level database engine. The database model used
-// could be considered a specific implementation of some small(est)
-// intersection of models listed in [1]. As a settled term is lacking, it'll be
-// called here a 'Virtual memory model' (VMM).
-//
-// Changelog
-//
-// 2016-07-24: v1.0.4 brings some performance improvements.
-//
-// 2016-07-22: v1.0.3 brings some small performance improvements.
-//
-// 2016-07-12: v1.0.2 now uses packages from cznic/internal.
-//
-// 2016-07-12: v1.0.1 adds a license for testdata/fortunes.txt.
-//
-// 2016-07-11: First standalone release v1.0.0 of the package previously
-// published as experimental (github.com/cznic/exp/lldb).
-//
-// Filers
-//
-// A Filer is an abstraction of storage. A Filer may be a part of some process'
-// virtual address space, an OS file, a networked, remote file etc. Persistence
-// of the storage is optional, opaque to VMM and it is specific to a concrete
-// Filer implementation.
-//
-// Space management
-//
-// Mechanism to allocate, reallocate (resize), deallocate (and later reclaim
-// the unused) contiguous parts of a Filer, called blocks. Blocks are
-// identified and referred to by a handle, an int64.
-//
-// BTrees
-//
-// In addition to the VMM like services, lldb provides volatile and
-// non-volatile BTrees. Keys and values of a BTree are limited in size to 64kB
-// each (a bit more actually). Support for larger keys/values, if desired, can
-// be built atop a BTree to certain limits.
-//
-// Handles vs pointers
-//
-// A handle is the abstracted storage counterpart of a memory address. There
-// is one fundamental difference, though. Resizing a block never results in a
-// change to the handle which refers to the resized block, so a handle is more
-// akin to an unique numeric id/key. Yet it shares one property of pointers -
-// handles can be associated again with blocks after the original handle block
-// was deallocated. In other words, a handle uniqueness domain is the state of
-// the database and is not something comparable to e.g. an ever growing
-// numbering sequence.
-//
-// Also, as with memory pointers, dangling handles can be created and blocks
-// overwritten when such handles are used. Using a zero handle to refer to a
-// block will not panic; however, the resulting error is effectively the same
-// exceptional situation as dereferencing a nil pointer.
-//
-// Blocks
-//
-// Allocated/used blocks, are limited in size to only a little bit more than
-// 64kB. Bigger semantic entities/structures must be built in lldb's client
-// code. The content of a block has no semantics attached, it's only a fully
-// opaque `[]byte`.
-//
-// Scalars
-//
-// Use of "scalars" applies to EncodeScalars, DecodeScalars and Collate. Those
-// first two "to bytes" and "from bytes" functions are suggested for handling
-// multi-valued Allocator content items and/or keys/values of BTrees (using
-// Collate for keys). Types called "scalar" are:
-//
-// nil (the typeless one)
-// bool
-// all integral types: [u]int8, [u]int16, [u]int32, [u]int, [u]int64
-// all floating point types: float32, float64
-// all complex types: complex64, complex128
-// []byte (64kB max)
-// string (64kb max)
-//
-// Specific implementations
-//
-// Included are concrete implementations of some of the VMM interfaces included
-// to ease serving simple client code or for testing and possibly as an
-// example. More details in the documentation of such implementations.
-//
-// [1]: http://en.wikipedia.org/wiki/Database_model
-package lldb
-
-const (
- fltSz = 0x70 // size of the FLT
- maxShort = 251
- maxRq = 65787
- maxFLTRq = 4112
- maxHandle = 1<<56 - 1
- atomLen = 16
- tagUsedLong = 0xfc
- tagUsedRelocated = 0xfd
- tagFreeShort = 0xfe
- tagFreeLong = 0xff
- tagNotCompressed = 0
- tagCompressed = 1
-)
-
-// Content size n -> blocksize in atoms.
-func n2atoms(n int) int {
- if n > maxShort {
- n += 2
- }
- return (n+1)/16 + 1
-}
-
-// Content size n -> number of padding zeros.
-func n2padding(n int) int {
- if n > maxShort {
- n += 2
- }
- return 15 - (n+1)&15
-}
-
-// Handle <-> offset
-func h2off(h int64) int64 { return (h + 6) * 16 }
-func off2h(off int64) int64 { return off/16 - 6 }
-
-// Get a 7B int64 from b
-func b2h(b []byte) (h int64) {
- for _, v := range b[:7] {
- h = h<<8 | int64(v)
- }
- return
-}
-
-// Put a 7B int64 into b
-func h2b(b []byte, h int64) []byte {
- for i := range b[:7] {
- b[i], h = byte(h>>48), h<<8
- }
- return b
-}
-
-// Content length N (must be in [252, 65787]) to long used block M field.
-func n2m(n int) (m int) {
- return n % 0x10000
-}
-
-// Long used block M (must be in [0, 65535]) field to content length N.
-func m2n(m int) (n int) {
- if m <= maxShort {
- m += 0x10000
- }
- return m
-}
-
-func bpack(a []byte) []byte {
- if cap(a) > len(a) {
- return append([]byte(nil), a...)
- }
-
- return a
-}
diff --git a/vendor/github.com/cznic/lldb/memfiler.go b/vendor/github.com/cznic/lldb/memfiler.go
deleted file mode 100644
index 3085d4e9b..000000000
--- a/vendor/github.com/cznic/lldb/memfiler.go
+++ /dev/null
@@ -1,101 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// A memory-only implementation of Filer.
-
-package lldb
-
-import (
- "fmt"
- "io"
-
- "github.com/cznic/internal/file"
-)
-
-var _ Filer = &MemFiler{}
-
-// MemFiler is a memory backed Filer. It implements BeginUpdate, EndUpdate and
-// Rollback as no-ops. MemFiler is not automatically persistent, but it has
-// ReadFrom and WriteTo methods.
-type MemFiler struct {
- fi file.Interface
- nest int
-}
-
-// NewMemFiler returns a new MemFiler.
-func NewMemFiler() *MemFiler {
- fi, err := file.OpenMem("")
- if err != nil {
- return nil
- }
-
- return &MemFiler{fi: fi}
-}
-
-// BeginUpdate implements Filer.
-func (f *MemFiler) BeginUpdate() error {
- f.nest++
- return nil
-}
-
-// Close implements Filer.
-func (f *MemFiler) Close() (err error) {
- if f.nest != 0 {
- return &ErrPERM{(f.Name() + ":Close")}
- }
-
- return f.fi.Close()
-}
-
-// EndUpdate implements Filer.
-func (f *MemFiler) EndUpdate() (err error) {
- if f.nest == 0 {
- return &ErrPERM{(f.Name() + ": EndUpdate")}
- }
-
- f.nest--
- return
-}
-
-// Name implements Filer.
-func (f *MemFiler) Name() string { return fmt.Sprintf("%p.memfiler", f) }
-
-// PunchHole implements Filer.
-func (f *MemFiler) PunchHole(off, size int64) (err error) { return nil }
-
-// ReadAt implements Filer.
-func (f *MemFiler) ReadAt(b []byte, off int64) (n int, err error) { return f.fi.ReadAt(b, off) }
-
-// ReadFrom is a helper to populate MemFiler's content from r. 'n' reports the
-// number of bytes read from 'r'.
-func (f *MemFiler) ReadFrom(r io.Reader) (n int64, err error) { return f.fi.ReadFrom(r) }
-
-// Rollback implements Filer.
-func (f *MemFiler) Rollback() (err error) { return nil }
-
-// Size implements Filer.
-func (f *MemFiler) Size() (int64, error) {
- info, err := f.fi.Stat()
- if err != nil {
- return 0, err
- }
-
- return info.Size(), nil
-}
-
-// Sync implements Filer.
-func (f *MemFiler) Sync() error { return nil }
-
-// Truncate implements Filer.
-func (f *MemFiler) Truncate(size int64) (err error) { return f.fi.Truncate(size) }
-
-// WriteAt implements Filer.
-func (f *MemFiler) WriteAt(b []byte, off int64) (n int, err error) { return f.fi.WriteAt(b, off) }
-
-// WriteTo is a helper to copy/persist MemFiler's content to w. If w is also
-// an io.WriterAt then WriteTo may attempt to _not_ write any big, for some
-// value of big, runs of zeros, i.e. it will attempt to punch holes, where
-// possible, in `w` if that happens to be a freshly created or to zero length
-// truncated OS file. 'n' reports the number of bytes written to 'w'.
-func (f *MemFiler) WriteTo(w io.Writer) (n int64, err error) { return f.fi.WriteTo(w) }
diff --git a/vendor/github.com/cznic/lldb/osfiler.go b/vendor/github.com/cznic/lldb/osfiler.go
deleted file mode 100644
index d6e189a18..000000000
--- a/vendor/github.com/cznic/lldb/osfiler.go
+++ /dev/null
@@ -1,130 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package lldb
-
-import (
- "io"
- "os"
-
- "github.com/cznic/mathutil"
-)
-
-var _ Filer = (*OSFiler)(nil)
-
-// OSFile is an os.File like minimal set of methods allowing to construct a
-// Filer.
-type OSFile interface {
- Name() string
- Stat() (fi os.FileInfo, err error)
- Sync() (err error)
- Truncate(size int64) (err error)
- io.Closer
- io.Reader
- io.ReaderAt
- io.Seeker
- io.Writer
- io.WriterAt
-}
-
-// OSFiler is like a SimpleFileFiler but based on an OSFile.
-type OSFiler struct {
- f OSFile
- nest int
- size int64 // not set if < 0
-}
-
-// NewOSFiler returns a Filer from an OSFile. This Filer is like the
-// SimpleFileFiler, it does not implement the transaction related methods.
-func NewOSFiler(f OSFile) (r *OSFiler) {
- return &OSFiler{
- f: f,
- size: -1,
- }
-}
-
-// BeginUpdate implements Filer.
-func (f *OSFiler) BeginUpdate() (err error) {
- f.nest++
- return nil
-}
-
-// Close implements Filer.
-func (f *OSFiler) Close() (err error) {
- if f.nest != 0 {
- return &ErrPERM{(f.Name() + ":Close")}
- }
-
- return f.f.Close()
-}
-
-// EndUpdate implements Filer.
-func (f *OSFiler) EndUpdate() (err error) {
- if f.nest == 0 {
- return &ErrPERM{(f.Name() + ":EndUpdate")}
- }
-
- f.nest--
- return
-}
-
-// Name implements Filer.
-func (f *OSFiler) Name() string {
- return f.f.Name()
-}
-
-// PunchHole implements Filer.
-func (f *OSFiler) PunchHole(off, size int64) (err error) {
- return
-}
-
-// ReadAt implements Filer.
-func (f *OSFiler) ReadAt(b []byte, off int64) (n int, err error) {
- return f.f.ReadAt(b, off)
-}
-
-// Rollback implements Filer.
-func (f *OSFiler) Rollback() (err error) { return }
-
-// Size implements Filer.
-func (f *OSFiler) Size() (n int64, err error) {
- if f.size < 0 { // boot
- fi, err := f.f.Stat()
- if err != nil {
- return 0, err
- }
-
- f.size = fi.Size()
- }
- return f.size, nil
-}
-
-// Sync implements Filer.
-func (f *OSFiler) Sync() (err error) {
- return f.f.Sync()
-}
-
-// Truncate implements Filer.
-func (f *OSFiler) Truncate(size int64) (err error) {
- if size < 0 {
- return &ErrINVAL{"Truncate size", size}
- }
-
- f.size = size
- return f.f.Truncate(size)
-}
-
-// WriteAt implements Filer.
-func (f *OSFiler) WriteAt(b []byte, off int64) (n int, err error) {
- if f.size < 0 { // boot
- fi, err := os.Stat(f.f.Name())
- if err != nil {
- return 0, err
- }
-
- f.size = fi.Size()
- }
- f.size = mathutil.MaxInt64(f.size, int64(len(b))+off)
- return f.f.WriteAt(b, off)
-}
diff --git a/vendor/github.com/cznic/lldb/perf-4670.log b/vendor/github.com/cznic/lldb/perf-4670.log
deleted file mode 100644
index bae4adfda..000000000
--- a/vendor/github.com/cznic/lldb/perf-4670.log
+++ /dev/null
@@ -1,192 +0,0 @@
-$ benchcmp -mag -changed log-bench-2016-07-11-1221-e572829f log-bench-2016-07-24-1458-74c3b196
-benchmark old ns/op new ns/op delta
-BenchmarkBTreePut1-4 18052 666 -96.31%
-BenchmarkBTreePut8-4 18069 678 -96.25%
-BenchmarkBTreePut16-4 17939 724 -95.96%
-BenchmarkBTreePut32-4 18523 1353 -92.70%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e1-4 6973 3415 -51.03%
-BenchmarkAllocatorRndFreeRollbackFiler0-4 1453839 717344 -50.66%
-BenchmarkAllocatorRndFreeSimpleFileFiler0-4 6806 3407 -49.94%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e3-4 7942 3997 -49.67%
-BenchmarkAllocatorAllocRollbackFiler1e1-4 1279565 651636 -49.07%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e2-4 7411 3812 -48.56%
-BenchmarkAllocatorRndGetSimpleFileFiler1e3-4 2080 1095 -47.36%
-BenchmarkAllocatorRndFreeRollbackFiler1e1-4 1364247 719511 -47.26%
-BenchmarkAllocatorRndGetSimpleFileFiler1e2-4 1641 868 -47.11%
-BenchmarkBTreeGet32-4 350 652 +86.29%
-BenchmarkAllocatorAllocRollbackFiler0-4 1226959 660623 -46.16%
-BenchmarkBTreeGet1-4 306 567 +85.29%
-BenchmarkAllocatorRndFreeRollbackFiler1e2-4 1372538 761810 -44.50%
-BenchmarkBTreeSetSimpleFileFiler1e2-4 43789 24569 -43.89%
-BenchmarkAllocatorAllocRollbackFiler1e2-4 1255146 714241 -43.09%
-BenchmarkBTreeSetRollbackFiler1e3-4 1974529 1144561 -42.03%
-BenchmarkBTreeSetSimpleFileFiler1e3-4 43770 25663 -41.37%
-BenchmarkBTreeGet8-4 207 352 +70.05%
-BenchmarkBTreeSetSimpleFileFiler0-4 38033 22635 -40.49%
-BenchmarkBTreeSetSimpleFileFiler1e1-4 38035 22708 -40.30%
-BenchmarkAllocatorRndFreeRollbackFiler1e3-4 1486691 893780 -39.88%
-BenchmarkBTreeSetRollbackFiler1e1-4 1470871 892358 -39.33%
-BenchmarkBTreeGet16-4 223 363 +62.78%
-BenchmarkBTreeSetRollbackFiler1e2-4 1589581 982970 -38.16%
-BenchmarkAllocatorAllocRollbackFiler1e3-4 1375172 859304 -37.51%
-BenchmarkBTreeSetRollbackFiler0-4 1455317 921016 -36.71%
-BenchmarkAllocatorAllocSimpleFileFiler1e1-4 1302 829 -36.33%
-BenchmarkAllocatorAllocSimpleFileFiler1e2-4 1364 882 -35.34%
-BenchmarkAllocatorAllocSimpleFileFiler0-4 1281 866 -32.40%
-BenchmarkAllocatorRndGetRollbackFiler1e3-4 4440 3057 -31.15%
-BenchmarkAllocatorRndGetSimpleFileFiler1e1-4 810 565 -30.25%
-BenchmarkAllocatorRndGetSimpleFileFiler0-4 802 574 -28.43%
-BenchmarkAllocatorAllocSimpleFileFiler1e3-4 1812 1306 -27.92%
-BenchmarkAllocatorRndGetACIDFiler1e3-4 4158 3047 -26.72%
-BenchmarkBTreeSetMemFiler1e2-4 25093 20683 -17.57%
-BenchmarkAllocatorAllocACIDFiler1e1-4 4300146 3666822 -14.73%
-BenchmarkBTreeSetMemFiler0-4 22518 19238 -14.57%
-BenchmarkAllocatorRndFreeACIDFiler1e1-4 4384437 3766451 -14.09%
-BenchmarkBTreeSetMemFiler1e1-4 22682 19498 -14.04%
-BenchmarkMemFilerRdSeq-4 1888 2169 +14.88%
-BenchmarkBTreeSetMemFiler1e3-4 24512 21377 -12.79%
-BenchmarkAllocatorAllocMemFiler1e2-4 584 510 -12.67%
-BenchmarkAllocatorRndGetRollbackFiler1e1-4 1959 2212 +12.91%
-BenchmarkAllocatorAllocACIDFiler1e2-4 4088780 3626368 -11.31%
-BenchmarkAllocatorRndFreeMemFiler1e1-4 2502 2246 -10.23%
-BenchmarkAllocatorRndFreeMemFiler0-4 2489 2244 -9.84%
-BenchmarkAllocatorRndFreeMemFiler1e2-4 2764 2507 -9.30%
-BenchmarkAllocatorAllocMemFiler1e1-4 530 483 -8.87%
-BenchmarkBTreeSetACIDFiler0-4 4061680 3705069 -8.78%
-BenchmarkAllocatorAllocACIDFiler0-4 4048443 3710996 -8.34%
-BenchmarkAllocatorRndFreeMemFiler1e3-4 2923 2699 -7.66%
-BenchmarkAllocatorRndGetMemFiler1e2-4 941 872 -7.33%
-BenchmarkAllocatorRndGetACIDFiler1e1-4 1993 2142 +7.48%
-BenchmarkAllocatorRndGetRollbackFiler0-4 2002 2151 +7.44%
-BenchmarkAllocatorRndGetACIDFiler0-4 1985 2129 +7.25%
-BenchmarkBTreeSetACIDFiler1e2-4 4119577 3846159 -6.64%
-BenchmarkAllocatorRndGetMemFiler1e1-4 598 562 -6.02%
-BenchmarkAllocatorRndFreeACIDFiler1e2-4 4038721 3814214 -5.56%
-BenchmarkAllocatorRndFreeACIDFiler0-4 3787035 3583356 -5.38%
-BenchmarkRollbackFiler-4 4.40 4.65 +5.68%
-BenchmarkMemFilerWrRand-4 5448 5755 +5.64%
-BenchmarkAllocatorRndGetMemFiler0-4 586 557 -4.95%
-BenchmarkAllocatorRndGetMemFiler1e3-4 1156 1100 -4.84%
-BenchmarkBTreeSetACIDFiler1e1-4 3994640 3801252 -4.84%
-BenchmarkAllocatorAllocMemFiler1e0-4 532 507 -4.70%
-BenchmarkAllocatorAllocACIDFiler1e3-4 3809395 3634900 -4.58%
-BenchmarkAllocatorAllocMemFiler1e3-4 769 736 -4.29%
-BenchmarkBTreeSetACIDFiler1e3-4 4076971 3936825 -3.44%
-BenchmarkAllocatorRndFreeACIDFiler1e3-4 3943185 4047580 +2.65%
-BenchmarkMemFilerRdRand-4 10183 9980 -1.99%
-BenchmarkMemFilerWrSeq-4 1494 1473 -1.41%
-BenchmarkAllocatorRndGetRollbackFiler1e2-4 2726 2753 +0.99%
-BenchmarkAllocatorRndGetACIDFiler1e2-4 2757 2754 -0.11%
-
-benchmark old allocs new allocs delta
-BenchmarkBTreeSetACIDFiler0-4 203 53 -73.89%
-BenchmarkBTreeSetACIDFiler1e2-4 241 71 -70.54%
-BenchmarkBTreeSetACIDFiler1e3-4 263 78 -70.34%
-BenchmarkBTreeSetSimpleFileFiler1e3-4 14 36 +157.14%
-BenchmarkBTreeSetACIDFiler1e1-4 135 53 -60.74%
-BenchmarkBTreeSetSimpleFileFiler1e2-4 15 36 +140.00%
-BenchmarkBTreeSetRollbackFiler0-4 49 22 -55.10%
-BenchmarkBTreeSetRollbackFiler1e1-4 49 22 -55.10%
-BenchmarkBTreeSetSimpleFileFiler0-4 15 33 +120.00%
-BenchmarkBTreeSetSimpleFileFiler1e1-4 15 33 +120.00%
-BenchmarkBTreeSetRollbackFiler1e2-4 53 25 -52.83%
-BenchmarkBTreeSetRollbackFiler1e3-4 56 27 -51.79%
-BenchmarkAllocatorRndFreeACIDFiler0-4 63 35 -44.44%
-BenchmarkAllocatorRndFreeACIDFiler1e1-4 62 36 -41.94%
-BenchmarkAllocatorAllocACIDFiler1e3-4 45 30 -33.33%
-BenchmarkAllocatorAllocRollbackFiler0-4 4 6 +50.00%
-BenchmarkAllocatorAllocRollbackFiler1e1-4 4 6 +50.00%
-BenchmarkAllocatorAllocRollbackFiler1e2-4 4 6 +50.00%
-BenchmarkAllocatorRndGetACIDFiler0-4 4 6 +50.00%
-BenchmarkAllocatorRndGetACIDFiler1e1-4 4 6 +50.00%
-BenchmarkAllocatorRndGetACIDFiler1e2-4 4 6 +50.00%
-BenchmarkAllocatorRndGetRollbackFiler0-4 4 6 +50.00%
-BenchmarkAllocatorRndGetRollbackFiler1e1-4 4 6 +50.00%
-BenchmarkAllocatorRndGetRollbackFiler1e2-4 4 6 +50.00%
-BenchmarkBTreeGet1-4 4 6 +50.00%
-BenchmarkBTreeGet32-4 5 7 +40.00%
-BenchmarkBTreeGet16-4 3 4 +33.33%
-BenchmarkBTreeGet8-4 3 4 +33.33%
-BenchmarkBTreePut32-4 11 14 +27.27%
-BenchmarkAllocatorAllocRollbackFiler1e3-4 5 6 +20.00%
-BenchmarkAllocatorRndGetACIDFiler1e3-4 5 6 +20.00%
-BenchmarkAllocatorRndGetRollbackFiler1e3-4 5 6 +20.00%
-BenchmarkAllocatorRndFreeACIDFiler1e2-4 67 56 -16.42%
-BenchmarkAllocatorRndFreeRollbackFiler0-4 7 8 +14.29%
-BenchmarkAllocatorRndFreeRollbackFiler1e1-4 7 8 +14.29%
-BenchmarkBTreePut1-4 7 8 +14.29%
-BenchmarkBTreePut16-4 7 8 +14.29%
-BenchmarkBTreePut8-4 7 8 +14.29%
-BenchmarkAllocatorRndFreeRollbackFiler1e2-4 8 9 +12.50%
-BenchmarkAllocatorRndFreeACIDFiler1e3-4 71 66 -7.04%
-BenchmarkAllocatorAllocACIDFiler1e2-4 29 28 -3.45%
-BenchmarkAllocatorAllocSimpleFileFiler0-4 0 2 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e1-4 0 2 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e2-4 0 2 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e3-4 0 2 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler0-4 0 7 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e1-4 0 7 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e2-4 0 7 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e3-4 0 7 +Inf%
-
-benchmark old bytes new bytes delta
-BenchmarkBTreePut1-4 139367 145 -99.90%
-BenchmarkBTreePut8-4 139367 145 -99.90%
-BenchmarkBTreePut16-4 139399 177 -99.87%
-BenchmarkBTreePut32-4 139592 402 -99.71%
-BenchmarkBTreeSetMemFiler1e2-4 19275 319 -98.35%
-BenchmarkBTreeSetMemFiler0-4 12928 256 -98.02%
-BenchmarkBTreeSetMemFiler1e1-4 12928 259 -98.00%
-BenchmarkBTreeSetSimpleFileFiler1e3-4 168 2836 +1588.10%
-BenchmarkBTreeSetSimpleFileFiler1e2-4 170 2840 +1570.59%
-BenchmarkBTreeSetRollbackFiler0-4 24242 1566 -93.54%
-BenchmarkBTreeSetRollbackFiler1e1-4 24243 1567 -93.54%
-BenchmarkBTreeSetMemFiler1e3-4 18734 1282 -93.16%
-BenchmarkBTreeSetSimpleFileFiler0-4 169 2436 +1341.42%
-BenchmarkBTreeSetSimpleFileFiler1e1-4 169 2433 +1339.64%
-BenchmarkBTreeSetRollbackFiler1e2-4 26831 1929 -92.81%
-BenchmarkBTreeSetRollbackFiler1e3-4 28710 2161 -92.47%
-BenchmarkAllocatorRndFreeRollbackFiler1e3-4 4781 897 -81.24%
-BenchmarkAllocatorRndFreeRollbackFiler1e2-4 3861 800 -79.28%
-BenchmarkAllocatorRndFreeRollbackFiler1e1-4 3421 725 -78.81%
-BenchmarkAllocatorRndFreeRollbackFiler0-4 3308 725 -78.08%
-BenchmarkRollbackFiler-4 2 9 +350.00%
-BenchmarkAllocatorRndGetACIDFiler1e3-4 2123 545 -74.33%
-BenchmarkAllocatorRndGetRollbackFiler1e3-4 2123 546 -74.28%
-BenchmarkAllocatorAllocRollbackFiler1e3-4 2148 565 -73.70%
-BenchmarkAllocatorRndFreeACIDFiler1e3-4 10040 25877 +157.74%
-BenchmarkAllocatorRndFreeACIDFiler1e2-4 9123 20659 +126.45%
-BenchmarkAllocatorRndGetACIDFiler1e2-4 1000 529 -47.10%
-BenchmarkAllocatorRndGetRollbackFiler1e2-4 1000 530 -47.00%
-BenchmarkBTreeSetACIDFiler0-4 31790 17014 -46.48%
-BenchmarkAllocatorAllocRollbackFiler1e2-4 1005 540 -46.27%
-BenchmarkAllocatorRndGetACIDFiler0-4 880 528 -40.00%
-BenchmarkAllocatorRndGetACIDFiler1e1-4 880 528 -40.00%
-BenchmarkAllocatorRndGetRollbackFiler0-4 880 528 -40.00%
-BenchmarkAllocatorRndGetRollbackFiler1e1-4 880 528 -40.00%
-BenchmarkAllocatorAllocRollbackFiler1e1-4 889 536 -39.71%
-BenchmarkAllocatorAllocRollbackFiler0-4 884 535 -39.48%
-BenchmarkBTreeSetACIDFiler1e2-4 34393 27331 -20.53%
-BenchmarkBTreeSetACIDFiler1e1-4 21319 17022 -20.16%
-BenchmarkAllocatorRndFreeACIDFiler1e1-4 8030 9898 +23.26%
-BenchmarkBTreeSetACIDFiler1e3-4 38350 31566 -17.69%
-BenchmarkAllocatorAllocACIDFiler1e3-4 8229 6912 -16.00%
-BenchmarkAllocatorRndFreeACIDFiler0-4 8330 9867 +18.45%
-BenchmarkBTreeGet8-4 128 112 -12.50%
-BenchmarkBTreeGet16-4 136 120 -11.76%
-BenchmarkBTreeGet1-4 136 152 +11.76%
-BenchmarkAllocatorAllocMemFiler1e0-4 16 15 -6.25%
-BenchmarkAllocatorAllocACIDFiler0-4 5618 5693 +1.33%
-BenchmarkAllocatorAllocACIDFiler1e1-4 5632 5696 +1.14%
-BenchmarkAllocatorAllocACIDFiler1e2-4 5880 5824 -0.95%
-BenchmarkAllocatorAllocMemFiler1e2-4 112 111 -0.89%
-BenchmarkAllocatorAllocMemFiler1e3-4 1009 1008 -0.10%
-BenchmarkMemFilerWrRand-4 10750 10743 -0.07%
-BenchmarkAllocatorAllocSimpleFileFiler0-4 0 240 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e1-4 0 240 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e2-4 0 240 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e3-4 0 240 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler0-4 0 920 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e1-4 0 920 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e2-4 0 920 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e3-4 0 920 +Inf%
diff --git a/vendor/github.com/cznic/lldb/perf-r550.log b/vendor/github.com/cznic/lldb/perf-r550.log
deleted file mode 100644
index 4422a6206..000000000
--- a/vendor/github.com/cznic/lldb/perf-r550.log
+++ /dev/null
@@ -1,196 +0,0 @@
-$ benchcmp -mag -changed log-bench-2016-07-11-1221-e572829f log-bench-2016-07-24-1458-74c3b196
-benchmark old ns/op new ns/op delta
-BenchmarkBTreePut1-4 62389 1282 -97.95%
-BenchmarkBTreePut8-4 61530 1329 -97.84%
-BenchmarkBTreePut16-4 61696 1373 -97.77%
-BenchmarkBTreePut32-4 58387 2625 -95.50%
-BenchmarkAllocatorRndFreeSimpleFileFiler0-4 15873 6442 -59.42%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e1-4 15909 6607 -58.47%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e2-4 16737 7348 -56.10%
-BenchmarkAllocatorRndGetSimpleFileFiler1e2-4 3413 1561 -54.26%
-BenchmarkMemFilerWrRand-4 66220 129632 +95.76%
-BenchmarkAllocatorAllocSimpleFileFiler1e1-4 3269 1719 -47.42%
-BenchmarkAllocatorRndGetSimpleFileFiler1e3-4 4132 2243 -45.72%
-BenchmarkAllocatorAllocSimpleFileFiler0-4 3271 1810 -44.67%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e3-4 17774 9951 -44.01%
-BenchmarkAllocatorAllocSimpleFileFiler1e2-4 3416 1918 -43.85%
-BenchmarkBTreeGet1-4 614 1082 +76.22%
-BenchmarkBTreeGet32-4 727 1255 +72.63%
-BenchmarkBTreeSetSimpleFileFiler1e2-4 115600 71576 -38.08%
-BenchmarkAllocatorRndGetSimpleFileFiler1e1-4 1688 1048 -37.91%
-BenchmarkAllocatorRndGetSimpleFileFiler0-4 1646 1022 -37.91%
-BenchmarkBTreeSetSimpleFileFiler1e3-4 118683 73793 -37.82%
-BenchmarkBTreeGet8-4 427 676 +58.31%
-BenchmarkBTreeGet16-4 441 691 +56.69%
-BenchmarkBTreeSetSimpleFileFiler0-4 101189 66921 -33.87%
-BenchmarkBTreeSetSimpleFileFiler1e1-4 101753 67350 -33.81%
-BenchmarkRollbackFiler-4 9.25 13.2 +42.70%
-BenchmarkAllocatorRndFreeACIDFiler1e3-4 154155028 113354887 -26.47%
-BenchmarkAllocatorRndGetRollbackFiler1e3-4 10973 8301 -24.35%
-BenchmarkAllocatorRndGetACIDFiler1e3-4 10032 7893 -21.32%
-BenchmarkBTreeSetMemFiler1e2-4 81878 64427 -21.31%
-BenchmarkMemFilerRdRand-4 48540 61167 +26.01%
-BenchmarkAllocatorAllocMemFiler1e1-4 1005 800 -20.40%
-BenchmarkBTreeSetRollbackFiler1e1-4 53542893 42893017 -19.89%
-BenchmarkAllocatorRndFreeMemFiler1e1-4 4560 3697 -18.93%
-BenchmarkAllocatorRndFreeMemFiler0-4 4536 3679 -18.89%
-BenchmarkBTreeSetMemFiler1e3-4 80012 65171 -18.55%
-BenchmarkBTreeSetRollbackFiler1e2-4 55207335 45530525 -17.53%
-BenchmarkAllocatorRndFreeMemFiler1e2-4 5046 4202 -16.73%
-BenchmarkAllocatorRndFreeMemFiler1e3-4 5346 4472 -16.35%
-BenchmarkBTreeSetMemFiler0-4 69735 59058 -15.31%
-BenchmarkAllocatorAllocSimpleFileFiler1e3-4 7935 9344 +17.76%
-BenchmarkAllocatorAllocMemFiler1e2-4 1110 944 -14.95%
-BenchmarkAllocatorAllocACIDFiler1e2-4 109752059 128224956 +16.83%
-BenchmarkAllocatorRndFreeACIDFiler1e2-4 124974458 109609716 -12.29%
-BenchmarkAllocatorRndFreeRollbackFiler1e3-4 84862180 74626566 -12.06%
-BenchmarkBTreeSetMemFiler1e1-4 66802 59168 -11.43%
-BenchmarkAllocatorRndGetRollbackFiler0-4 4616 5158 +11.74%
-BenchmarkAllocatorRndFreeRollbackFiler1e2-4 57052848 51130276 -10.38%
-BenchmarkAllocatorRndGetMemFiler1e3-4 2520 2270 -9.92%
-BenchmarkAllocatorRndGetMemFiler0-4 1097 1003 -8.57%
-BenchmarkAllocatorAllocMemFiler1e0-4 964 883 -8.40%
-BenchmarkAllocatorRndGetRollbackFiler1e2-4 6504 7097 +9.12%
-BenchmarkAllocatorRndGetRollbackFiler1e1-4 4761 5188 +8.97%
-BenchmarkAllocatorRndGetMemFiler1e2-4 1715 1577 -8.05%
-BenchmarkAllocatorRndGetMemFiler1e1-4 1095 1018 -7.03%
-BenchmarkAllocatorRndFreeACIDFiler1e1-4 116914490 108760132 -6.97%
-BenchmarkAllocatorRndGetACIDFiler1e1-4 4813 5153 +7.06%
-BenchmarkAllocatorAllocMemFiler1e3-4 2132 1992 -6.57%
-BenchmarkAllocatorRndGetACIDFiler0-4 4728 4998 +5.71%
-BenchmarkBTreeSetACIDFiler1e1-4 109770670 104029058 -5.23%
-BenchmarkAllocatorRndGetACIDFiler1e2-4 6461 6808 +5.37%
-BenchmarkAllocatorAllocRollbackFiler1e2-4 42659658 44885965 +5.22%
-BenchmarkAllocatorRndFreeRollbackFiler0-4 46103955 48326779 +4.82%
-BenchmarkAllocatorAllocRollbackFiler0-4 44100144 46221286 +4.81%
-BenchmarkBTreeSetACIDFiler0-4 107413862 103212528 -3.91%
-BenchmarkBTreeSetRollbackFiler0-4 47988451 46221843 -3.68%
-BenchmarkAllocatorRndFreeRollbackFiler1e1-4 43687222 45317995 +3.73%
-BenchmarkMemFilerRdSeq-4 10945 11280 +3.06%
-BenchmarkAllocatorAllocACIDFiler0-4 108243596 105692910 -2.36%
-BenchmarkBTreeSetACIDFiler1e2-4 103100307 105549334 +2.38%
-BenchmarkBTreeSetRollbackFiler1e3-4 47756563 46862983 -1.87%
-BenchmarkAllocatorRndFreeACIDFiler0-4 107960640 110014433 +1.90%
-BenchmarkAllocatorAllocACIDFiler1e1-4 109079753 110713125 +1.50%
-BenchmarkBTreeSetACIDFiler1e3-4 105766500 107238849 +1.39%
-BenchmarkAllocatorAllocRollbackFiler1e3-4 44952236 45424491 +1.05%
-BenchmarkMemFilerWrSeq-4 9855 9770 -0.86%
-BenchmarkAllocatorAllocACIDFiler1e3-4 114116546 114886042 +0.67%
-BenchmarkAllocatorAllocRollbackFiler1e1-4 43817840 44063415 +0.56%
-
-benchmark old allocs new allocs delta
-BenchmarkBTreeSetSimpleFileFiler1e2-4 12 33 +175.00%
-BenchmarkBTreeSetSimpleFileFiler1e3-4 12 33 +175.00%
-BenchmarkBTreeSetSimpleFileFiler0-4 13 30 +130.77%
-BenchmarkBTreeSetSimpleFileFiler1e1-4 13 30 +130.77%
-BenchmarkAllocatorRndFreeACIDFiler0-4 59 28 -52.54%
-BenchmarkAllocatorRndFreeACIDFiler1e1-4 58 28 -51.72%
-BenchmarkBTreeSetACIDFiler1e2-4 70 41 -41.43%
-BenchmarkBTreeSetACIDFiler1e3-4 83 52 -37.35%
-BenchmarkAllocatorRndFreeACIDFiler1e2-4 63 40 -36.51%
-BenchmarkAllocatorRndGetACIDFiler0-4 4 6 +50.00%
-BenchmarkAllocatorRndGetACIDFiler1e1-4 4 6 +50.00%
-BenchmarkAllocatorRndGetACIDFiler1e2-4 4 6 +50.00%
-BenchmarkAllocatorRndGetRollbackFiler0-4 4 6 +50.00%
-BenchmarkAllocatorRndGetRollbackFiler1e1-4 4 6 +50.00%
-BenchmarkAllocatorRndGetRollbackFiler1e2-4 4 6 +50.00%
-BenchmarkBTreeGet1-4 4 6 +50.00%
-BenchmarkAllocatorAllocRollbackFiler0-4 5 7 +40.00%
-BenchmarkAllocatorAllocRollbackFiler1e1-4 5 7 +40.00%
-BenchmarkAllocatorAllocRollbackFiler1e2-4 5 7 +40.00%
-BenchmarkBTreeGet32-4 5 7 +40.00%
-BenchmarkAllocatorAllocACIDFiler1e3-4 49 36 -26.53%
-BenchmarkBTreeGet16-4 3 4 +33.33%
-BenchmarkBTreeGet8-4 3 4 +33.33%
-BenchmarkBTreePut32-4 11 14 +27.27%
-BenchmarkAllocatorRndFreeRollbackFiler0-4 5 6 +20.00%
-BenchmarkAllocatorRndFreeRollbackFiler1e1-4 5 6 +20.00%
-BenchmarkAllocatorRndGetACIDFiler1e3-4 5 6 +20.00%
-BenchmarkAllocatorRndGetRollbackFiler1e3-4 5 6 +20.00%
-BenchmarkBTreeSetRollbackFiler0-4 10 12 +20.00%
-BenchmarkBTreeSetRollbackFiler1e1-4 10 12 +20.00%
-BenchmarkBTreeSetRollbackFiler1e2-4 12 14 +16.67%
-BenchmarkAllocatorAllocRollbackFiler1e3-4 7 8 +14.29%
-BenchmarkBTreePut1-4 7 8 +14.29%
-BenchmarkBTreePut16-4 7 8 +14.29%
-BenchmarkBTreePut8-4 7 8 +14.29%
-BenchmarkAllocatorRndFreeACIDFiler1e3-4 65 58 -10.77%
-BenchmarkAllocatorRndFreeRollbackFiler1e3-4 9 10 +11.11%
-BenchmarkBTreeSetACIDFiler0-4 35 38 +8.57%
-BenchmarkBTreeSetACIDFiler1e1-4 35 38 +8.57%
-BenchmarkBTreeSetMemFiler1e3-4 14 13 -7.14%
-BenchmarkBTreeSetRollbackFiler1e3-4 16 15 -6.25%
-BenchmarkAllocatorAllocACIDFiler1e1-4 32 34 +6.25%
-BenchmarkAllocatorAllocACIDFiler0-4 31 32 +3.23%
-BenchmarkAllocatorAllocACIDFiler1e2-4 34 33 -2.94%
-BenchmarkAllocatorAllocSimpleFileFiler0-4 0 2 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e1-4 0 2 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e2-4 0 2 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e3-4 0 2 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler0-4 0 7 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e1-4 0 7 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e2-4 0 7 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e3-4 0 7 +Inf%
-
-benchmark old bytes new bytes delta
-BenchmarkBTreePut1-4 139363 145 -99.90%
-BenchmarkBTreePut8-4 139363 146 -99.90%
-BenchmarkBTreePut16-4 139397 178 -99.87%
-BenchmarkBTreePut32-4 139587 408 -99.71%
-BenchmarkBTreeSetMemFiler1e2-4 20202 348 -98.28%
-BenchmarkBTreeSetMemFiler0-4 12286 247 -97.99%
-BenchmarkBTreeSetMemFiler1e1-4 10617 247 -97.67%
-BenchmarkBTreeSetMemFiler1e3-4 20591 1343 -93.48%
-BenchmarkBTreeSetSimpleFileFiler1e1-4 164 2299 +1301.83%
-BenchmarkBTreeSetSimpleFileFiler0-4 164 2293 +1298.17%
-BenchmarkBTreeSetSimpleFileFiler1e2-4 215 2757 +1182.33%
-BenchmarkBTreeSetSimpleFileFiler1e3-4 223 2756 +1135.87%
-BenchmarkRollbackFiler-4 2 9 +350.00%
-BenchmarkAllocatorRndFreeRollbackFiler1e2-4 3273 840 -74.34%
-BenchmarkAllocatorRndGetACIDFiler1e3-4 2125 549 -74.16%
-BenchmarkAllocatorRndGetRollbackFiler1e3-4 2125 550 -74.12%
-BenchmarkAllocatorRndFreeRollbackFiler1e3-4 4182 1248 -70.16%
-BenchmarkAllocatorRndFreeRollbackFiler0-4 2026 683 -66.29%
-BenchmarkAllocatorRndFreeRollbackFiler1e1-4 1904 683 -64.13%
-BenchmarkAllocatorRndFreeACIDFiler1e3-4 9449 21867 +131.42%
-BenchmarkMemFilerWrRand-4 76195 168878 +121.64%
-BenchmarkAllocatorRndGetSimpleFileFiler1e3-4 2 1 -50.00%
-BenchmarkAllocatorRndGetACIDFiler1e2-4 1000 530 -47.00%
-BenchmarkAllocatorRndGetRollbackFiler1e2-4 1000 532 -46.80%
-BenchmarkBTreeSetACIDFiler1e1-4 21011 36013 +71.40%
-BenchmarkBTreeSetACIDFiler0-4 21011 36007 +71.37%
-BenchmarkAllocatorRndGetACIDFiler0-4 880 528 -40.00%
-BenchmarkAllocatorRndGetACIDFiler1e1-4 880 528 -40.00%
-BenchmarkAllocatorRndGetRollbackFiler1e1-4 880 528 -40.00%
-BenchmarkAllocatorRndGetRollbackFiler0-4 880 529 -39.89%
-BenchmarkBTreeSetRollbackFiler0-4 6690 10904 +62.99%
-BenchmarkBTreeSetRollbackFiler1e1-4 6696 10904 +62.84%
-BenchmarkBTreeSetACIDFiler1e3-4 27500 44167 +60.61%
-BenchmarkBTreeSetACIDFiler1e2-4 22726 36274 +59.61%
-BenchmarkAllocatorAllocRollbackFiler1e3-4 3100 1978 -36.19%
-BenchmarkAllocatorRndFreeACIDFiler1e2-4 8440 12086 +43.20%
-BenchmarkBTreeSetRollbackFiler1e2-4 8116 11223 +38.28%
-BenchmarkAllocatorRndFreeACIDFiler1e1-4 7266 5823 -19.86%
-BenchmarkAllocatorRndFreeACIDFiler0-4 7168 5769 -19.52%
-BenchmarkAllocatorAllocRollbackFiler1e2-4 1382 1122 -18.81%
-BenchmarkAllocatorAllocRollbackFiler0-4 1185 1022 -13.76%
-BenchmarkAllocatorAllocRollbackFiler1e1-4 1196 1053 -11.96%
-BenchmarkBTreeGet8-4 127 112 -11.81%
-BenchmarkBTreeGet16-4 136 120 -11.76%
-BenchmarkBTreeGet1-4 136 152 +11.76%
-BenchmarkBTreeSetRollbackFiler1e3-4 10761 12007 +11.58%
-BenchmarkAllocatorAllocACIDFiler1e1-4 6544 7264 +11.00%
-BenchmarkAllocatorAllocACIDFiler0-4 6512 7144 +9.71%
-BenchmarkAllocatorAllocACIDFiler1e2-4 6980 7459 +6.86%
-BenchmarkMemFilerWrSeq-4 50 51 +2.00%
-BenchmarkAllocatorAllocACIDFiler1e3-4 11037 10948 -0.81%
-BenchmarkAllocatorAllocMemFiler1e3-4 1009 1008 -0.10%
-BenchmarkAllocatorAllocSimpleFileFiler0-4 0 240 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e1-4 0 240 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e2-4 0 240 +Inf%
-BenchmarkAllocatorAllocSimpleFileFiler1e3-4 0 240 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler0-4 0 920 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e1-4 0 920 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e2-4 0 920 +Inf%
-BenchmarkAllocatorRndFreeSimpleFileFiler1e3-4 0 920 +Inf%
-BenchmarkMemFilerRdRand-4 0 8 +Inf%
diff --git a/vendor/github.com/cznic/lldb/simplefilefiler.go b/vendor/github.com/cznic/lldb/simplefilefiler.go
deleted file mode 100644
index 71ee67417..000000000
--- a/vendor/github.com/cznic/lldb/simplefilefiler.go
+++ /dev/null
@@ -1,99 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// A basic os.File backed Filer.
-
-package lldb
-
-import (
- "os"
-
- "github.com/cznic/internal/file"
-)
-
-var _ Filer = &SimpleFileFiler{}
-
-// SimpleFileFiler is an os.File backed Filer intended for use where structural
-// consistency can be reached by other means (SimpleFileFiler is for example
-// wrapped in eg. an RollbackFiler or ACIDFiler0) or where persistence is not
-// required (temporary/working data sets).
-//
-// SimpleFileFiler is the most simple os.File backed Filer implementation as it
-// does not really implement BeginUpdate and EndUpdate/Rollback in any way
-// which would protect the structural integrity of data. If misused e.g. as a
-// real database storage w/o other measures, it can easily cause data loss
-// when, for example, a power outage occurs or the updating process terminates
-// abruptly.
-type SimpleFileFiler struct {
- fi file.Interface
- name string
- nest int
-}
-
-// NewSimpleFileFiler returns a new SimpleFileFiler.
-func NewSimpleFileFiler(f *os.File) *SimpleFileFiler {
- fi, err := file.Open(f)
- if err != nil {
- return nil
- }
-
- sf := &SimpleFileFiler{fi: fi, name: f.Name()}
- return sf
-}
-
-// BeginUpdate implements Filer.
-func (f *SimpleFileFiler) BeginUpdate() error {
- f.nest++
- return nil
-}
-
-// Close implements Filer.
-func (f *SimpleFileFiler) Close() (err error) {
- if f.nest != 0 {
- return &ErrPERM{(f.Name() + ":Close")}
- }
-
- return f.fi.Close()
-}
-
-// EndUpdate implements Filer.
-func (f *SimpleFileFiler) EndUpdate() (err error) {
- if f.nest == 0 {
- return &ErrPERM{(f.Name() + ":EndUpdate")}
- }
-
- f.nest--
- return
-}
-
-// Name implements Filer.
-func (f *SimpleFileFiler) Name() string { return f.name }
-
-// PunchHole implements Filer.
-func (f *SimpleFileFiler) PunchHole(off, size int64) (err error) { return nil }
-
-// ReadAt implements Filer.
-func (f *SimpleFileFiler) ReadAt(b []byte, off int64) (n int, err error) { return f.fi.ReadAt(b, off) }
-
-// Rollback implements Filer.
-func (f *SimpleFileFiler) Rollback() (err error) { return nil }
-
-// Size implements Filer.
-func (f *SimpleFileFiler) Size() (int64, error) {
- info, err := f.fi.Stat()
- if err != nil {
- return 0, err
- }
-
- return info.Size(), nil
-}
-
-// Sync implements Filer.
-func (f *SimpleFileFiler) Sync() error { return f.fi.Sync() }
-
-// Truncate implements Filer.
-func (f *SimpleFileFiler) Truncate(size int64) (err error) { return f.fi.Truncate(size) }
-
-// WriteAt implements Filer.
-func (f *SimpleFileFiler) WriteAt(b []byte, off int64) (n int, err error) { return f.fi.WriteAt(b, off) }
diff --git a/vendor/github.com/cznic/lldb/xact.go b/vendor/github.com/cznic/lldb/xact.go
deleted file mode 100644
index 70887ec2a..000000000
--- a/vendor/github.com/cznic/lldb/xact.go
+++ /dev/null
@@ -1,615 +0,0 @@
-// Copyright 2014 The lldb Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Structural transactions.
-
-package lldb
-
-//DONE+ TransactionalMemoryFiler
-// ----
-// Use NewRollbackFiler(myMemFiler, ...)
-
-/*
-
-bfBits: 3
-BenchmarkRollbackFiler 20000000 102 ns/op 9.73 MB/s
-
-bfBits: 4
-BenchmarkRollbackFiler 50000000 55.7 ns/op 17.95 MB/s
-
-bfBits: 5
-BenchmarkRollbackFiler 100000000 32.2 ns/op 31.06 MB/s
-
-bfBits: 6
-BenchmarkRollbackFiler 100000000 20.6 ns/op 48.46 MB/s
-
-bfBits: 7
-BenchmarkRollbackFiler 100000000 15.1 ns/op 66.12 MB/s
-
-bfBits: 8
-BenchmarkRollbackFiler 100000000 10.5 ns/op 95.66 MB/s
-
-bfBits: 9
-BenchmarkRollbackFiler 200000000 8.02 ns/op 124.74 MB/s
-
-bfBits: 10
-BenchmarkRollbackFiler 200000000 9.25 ns/op 108.09 MB/s
-
-bfBits: 11
-BenchmarkRollbackFiler 100000000 11.7 ns/op 85.47 MB/s
-
-bfBits: 12
-BenchmarkRollbackFiler 100000000 17.2 ns/op 57.99 MB/s
-
-bfBits: 13
-BenchmarkRollbackFiler 100000000 32.7 ns/op 30.58 MB/s
-
-bfBits: 14
-BenchmarkRollbackFiler 50000000 39.6 ns/op 25.27 MB/s
-
-*/
-
-import (
- "fmt"
- "io"
- "sync"
-
- "github.com/cznic/fileutil"
- "github.com/cznic/internal/buffer"
- "github.com/cznic/mathutil"
-)
-
-var (
- _ Filer = &bitFiler{} // Ensure bitFiler is a Filer.
- _ Filer = &RollbackFiler{} // ditto
-)
-
-const (
- bfBits = 12
- bfSize = 1 << bfBits
- bfMask = bfSize - 1
-)
-
-type (
- bitPage struct {
- prev, next *bitPage
- pdata *[]byte
- data []byte
- dirty bool
- }
-
- bitFilerMap map[int64]*bitPage
-
- bitFiler struct {
- parent Filer
- m bitFilerMap
- size int64
- }
-)
-
-func newBitFiler(parent Filer) (f *bitFiler, err error) {
- sz, err := parent.Size()
- if err != nil {
- return
- }
-
- return &bitFiler{parent: parent, m: bitFilerMap{}, size: sz}, nil
-}
-
-func (f *bitFiler) BeginUpdate() error { panic("internal error") }
-func (f *bitFiler) EndUpdate() error { panic("internal error") }
-func (f *bitFiler) Rollback() error { panic("internal error") }
-func (f *bitFiler) Sync() error { panic("internal error") }
-
-func (f *bitFiler) Close() (err error) { return }
-func (f *bitFiler) Name() string { return fmt.Sprintf("%p.bitfiler", f) }
-func (f *bitFiler) Size() (int64, error) { return f.size, nil }
-
-func (f *bitFiler) free() {
- for _, pg := range f.m {
- buffer.Put(pg.pdata)
- }
-}
-
-func (f *bitFiler) PunchHole(off, size int64) (err error) {
- first := off >> bfBits
- if off&bfMask != 0 {
- first++
- }
- off += size - 1
- last := off >> bfBits
- if off&bfMask != 0 {
- last--
- }
- if limit := f.size >> bfBits; last > limit {
- last = limit
- }
- for pgI := first; pgI <= last; pgI++ {
- pg := &bitPage{}
- pg.pdata = buffer.CGet(bfSize)
- pg.data = *pg.pdata
- pg.dirty = true
- f.m[pgI] = pg
- }
- return
-}
-
-func (f *bitFiler) ReadAt(b []byte, off int64) (n int, err error) {
- avail := f.size - off
- pgI := off >> bfBits
- pgO := int(off & bfMask)
- rem := len(b)
- if int64(rem) >= avail {
- rem = int(avail)
- err = io.EOF
- }
- for rem != 0 && avail > 0 {
- pg := f.m[pgI]
- if pg == nil {
- pg = &bitPage{}
- pg.pdata = buffer.CGet(bfSize)
- pg.data = *pg.pdata
- if f.parent != nil {
- _, err = f.parent.ReadAt(pg.data, off&^bfMask)
- if err != nil && !fileutil.IsEOF(err) {
- return
- }
-
- err = nil
- }
- f.m[pgI] = pg
- }
- nc := copy(b[:mathutil.Min(rem, bfSize)], pg.data[pgO:])
- pgI++
- pgO = 0
- rem -= nc
- n += nc
- b = b[nc:]
- off += int64(nc)
- }
- return
-}
-
-func (f *bitFiler) Truncate(size int64) (err error) {
- switch {
- case size < 0:
- return &ErrINVAL{"Truncate size", size}
- case size == 0:
- f.m = bitFilerMap{}
- f.size = 0
- return
- }
-
- first := size >> bfBits
- if size&bfMask != 0 {
- first++
- }
- last := f.size >> bfBits
- if f.size&bfMask != 0 {
- last++
- }
- for ; first < last; first++ {
- if bp, ok := f.m[first]; ok {
- buffer.Put(bp.pdata)
- }
- delete(f.m, first)
- }
-
- f.size = size
- return
-}
-
-func (f *bitFiler) WriteAt(b []byte, off int64) (n int, err error) {
- off0 := off
- pgI := off >> bfBits
- pgO := int(off & bfMask)
- n = len(b)
- rem := n
- var nc int
- for rem != 0 {
- pg := f.m[pgI]
- if pg == nil {
- pg = &bitPage{}
- pg.pdata = buffer.CGet(bfSize)
- pg.data = *pg.pdata
- if f.parent != nil {
- _, err = f.parent.ReadAt(pg.data, off&^bfMask)
- if err != nil && !fileutil.IsEOF(err) {
- return
- }
-
- err = nil
- }
- f.m[pgI] = pg
- }
- nc = copy(pg.data[pgO:], b)
- pgI++
- pg.dirty = true
- pgO = 0
- rem -= nc
- b = b[nc:]
- off += int64(nc)
- }
- f.size = mathutil.MaxInt64(f.size, off0+int64(n))
- return
-}
-
-func (f *bitFiler) link() {
- for pgI, pg := range f.m {
- nx, ok := f.m[pgI+1]
- if !ok || !nx.dirty {
- continue
- }
-
- nx.prev, pg.next = pg, nx
- }
-}
-
-func (f *bitFiler) dumpDirty(w io.WriterAt) (nwr int, err error) {
- f.link()
- for pgI, pg := range f.m {
- if !pg.dirty {
- continue
- }
-
- for pg.prev != nil && pg.prev.dirty {
- pg = pg.prev
- pgI--
- }
-
- for pg != nil && pg.dirty {
- if _, err := w.WriteAt(pg.data, pgI< deadlock
- if err != nil {
- return
- }
-
- r.tlevel--
- bf := r.bitFiler
- parent := bf.parent
- w := r.writerAt
- if r.tlevel != 0 {
- w = parent
- }
- nwr, err := bf.dumpDirty(w)
- if err != nil {
- return
- }
-
- switch {
- case r.tlevel == 0:
- defer func() {
- r.bitFiler.free()
- r.bitFiler = nil
- }()
-
- if nwr == 0 {
- return
- }
-
- return r.checkpoint(sz)
- default:
- r.bitFiler.free()
- r.bitFiler = parent.(*bitFiler)
- sz, _ := bf.Size() // bitFiler.Size() never returns err != nil
- return parent.Truncate(sz)
- }
-}
-
-// Implements Filer.
-func (r *RollbackFiler) Name() string {
- r.mu.RLock()
- defer r.mu.RUnlock()
-
- return r.f.Name()
-}
-
-// Implements Filer.
-func (r *RollbackFiler) PunchHole(off, size int64) error {
- r.mu.Lock()
- defer r.mu.Unlock()
-
- if r.tlevel == 0 {
- return &ErrPERM{r.f.Name() + ": PunchHole outside of a transaction"}
- }
-
- if off < 0 {
- return &ErrINVAL{r.f.Name() + ": PunchHole off", off}
- }
-
- if size < 0 || off+size > r.bitFiler.size {
- return &ErrINVAL{r.f.Name() + ": PunchHole size", size}
- }
-
- return r.bitFiler.PunchHole(off, size)
-}
-
-// Implements Filer.
-func (r *RollbackFiler) ReadAt(b []byte, off int64) (n int, err error) {
- r.inCallbackMu.RLock()
- defer r.inCallbackMu.RUnlock()
- if !r.inCallback {
- r.mu.RLock()
- defer r.mu.RUnlock()
- }
- if r.tlevel == 0 {
- return r.f.ReadAt(b, off)
- }
-
- return r.bitFiler.ReadAt(b, off)
-}
-
-// Implements Filer.
-func (r *RollbackFiler) Rollback() (err error) {
- r.mu.Lock()
- defer r.mu.Unlock()
-
- if r.tlevel == 0 {
- return &ErrPERM{r.f.Name() + ": Rollback outside of a transaction"}
- }
-
- if r.tlevel > 1 {
- r.bitFiler.free()
- r.bitFiler = r.bitFiler.parent.(*bitFiler)
- }
- r.tlevel--
- if f := r.afterRollback; f != nil {
- r.inCallbackMu.Lock()
- r.inCallback = true
- r.inCallbackMu.Unlock()
- defer func() {
- r.inCallbackMu.Lock()
- r.inCallback = false
- r.inCallbackMu.Unlock()
- }()
- return f()
- }
- return
-}
-
-func (r *RollbackFiler) size() (sz int64, err error) {
- if r.tlevel == 0 {
- return r.f.Size()
- }
-
- return r.bitFiler.Size()
-}
-
-// Implements Filer.
-func (r *RollbackFiler) Size() (sz int64, err error) {
- r.mu.Lock()
- defer r.mu.Unlock()
-
- return r.size()
-}
-
-// Implements Filer.
-func (r *RollbackFiler) Sync() error {
- r.mu.Lock()
- defer r.mu.Unlock()
-
- return r.f.Sync()
-}
-
-// Implements Filer.
-func (r *RollbackFiler) Truncate(size int64) error {
- r.mu.Lock()
- defer r.mu.Unlock()
-
- if r.tlevel == 0 {
- return &ErrPERM{r.f.Name() + ": Truncate outside of a transaction"}
- }
-
- return r.bitFiler.Truncate(size)
-}
-
-// Implements Filer.
-func (r *RollbackFiler) WriteAt(b []byte, off int64) (n int, err error) {
- r.mu.Lock()
- defer r.mu.Unlock()
-
- if r.tlevel == 0 {
- return 0, &ErrPERM{r.f.Name() + ": WriteAt outside of a transaction"}
- }
-
- return r.bitFiler.WriteAt(b, off)
-}
diff --git a/vendor/github.com/cznic/mathutil/AUTHORS b/vendor/github.com/cznic/mathutil/AUTHORS
deleted file mode 100644
index d04c45011..000000000
--- a/vendor/github.com/cznic/mathutil/AUTHORS
+++ /dev/null
@@ -1,12 +0,0 @@
-# This file lists authors for copyright purposes. This file is distinct from
-# the CONTRIBUTORS files. See the latter for an explanation.
-#
-# Names should be added to this file as:
-# Name or Organization
-#
-# The email address is not required for organizations.
-#
-# Please keep the list sorted.
-
-CZ.NIC z.s.p.o.
-Jan Mercl <0xjnml@gmail.com>
diff --git a/vendor/github.com/cznic/mathutil/CONTRIBUTORS b/vendor/github.com/cznic/mathutil/CONTRIBUTORS
deleted file mode 100644
index 9c9a5dd84..000000000
--- a/vendor/github.com/cznic/mathutil/CONTRIBUTORS
+++ /dev/null
@@ -1,10 +0,0 @@
-# This file lists people who contributed code to this repository. The AUTHORS
-# file lists the copyright holders; this file lists people.
-#
-# Names should be added to this file like so:
-# Name
-#
-# Please keep the list sorted.
-
-Gary Burd
-Jan Mercl <0xjnml@gmail.com>
diff --git a/vendor/github.com/cznic/mathutil/LICENSE b/vendor/github.com/cznic/mathutil/LICENSE
deleted file mode 100644
index 128a1b64a..000000000
--- a/vendor/github.com/cznic/mathutil/LICENSE
+++ /dev/null
@@ -1,27 +0,0 @@
-Copyright (c) 2014 The mathutil Authors. All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are
-met:
-
- * Redistributions of source code must retain the above copyright
-notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above
-copyright notice, this list of conditions and the following disclaimer
-in the documentation and/or other materials provided with the
-distribution.
- * Neither the names of the authors nor the names of the
-contributors may be used to endorse or promote products derived from
-this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/github.com/cznic/mathutil/Makefile b/vendor/github.com/cznic/mathutil/Makefile
deleted file mode 100644
index ba50e2243..000000000
--- a/vendor/github.com/cznic/mathutil/Makefile
+++ /dev/null
@@ -1,58 +0,0 @@
-# Copyright (c) 2016 The mathutil Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
- codesweep || true
- unconvert || true
- maligned || true
-
-clean:
- go clean
- rm -f *~ *.test *.out
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- @ 1>/dev/null 2>/dev/null gvim -p Makefile *.go
-
-editor:
- gofmt -l -s -w *.go
- go test
- go build
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench . -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * | grep -v $(ngrep) || true
- @grep -nr $(grep) TODO * | grep -v $(ngrep) || true
- @grep -nr $(grep) BUG * | grep -v $(ngrep) || true
- @grep -nr $(grep) [^[:alpha:]]println * | grep -v $(ngrep) || true
diff --git a/vendor/github.com/cznic/mathutil/README b/vendor/github.com/cznic/mathutil/README
deleted file mode 100644
index a9ee59c40..000000000
--- a/vendor/github.com/cznic/mathutil/README
+++ /dev/null
@@ -1,10 +0,0 @@
-This is a goinstall-able mirror of modified code already published at:
-http://git.nic.cz/redmine/projects/gornd/repository
-
-Packages in this repository:
-
-Install: $ go get github.com/cznic/mathutil
-Godocs: http://godoc.org/github.com/cznic/mathutil
-
-Install: $ go get github.com/cznic/mathutil/mersenne
-Godocs: http://godoc.org/github.com/cznic/mathutil/mersenne
diff --git a/vendor/github.com/cznic/mathutil/bits.go b/vendor/github.com/cznic/mathutil/bits.go
deleted file mode 100644
index fee4c0363..000000000
--- a/vendor/github.com/cznic/mathutil/bits.go
+++ /dev/null
@@ -1,207 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-import (
- "math/big"
-)
-
-// BitLenByte returns the bit width of the non zero part of n.
-func BitLenByte(n byte) int {
- return log2[n] + 1
-}
-
-// BitLenUint16 returns the bit width of the non zero part of n.
-func BitLenUint16(n uint16) int {
- if b := n >> 8; b != 0 {
- return log2[b] + 8 + 1
- }
-
- return log2[n] + 1
-}
-
-// BitLenUint32 returns the bit width of the non zero part of n.
-func BitLenUint32(n uint32) int {
- if b := n >> 24; b != 0 {
- return log2[b] + 24 + 1
- }
-
- if b := n >> 16; b != 0 {
- return log2[b] + 16 + 1
- }
-
- if b := n >> 8; b != 0 {
- return log2[b] + 8 + 1
- }
-
- return log2[n] + 1
-}
-
-// BitLen returns the bit width of the non zero part of n.
-func BitLen(n int) int { // Should handle correctly [future] 64 bit Go ints
- if IntBits == 64 {
- return BitLenUint64(uint64(n))
- }
-
- if b := byte(n >> 24); b != 0 {
- return log2[b] + 24 + 1
- }
-
- if b := byte(n >> 16); b != 0 {
- return log2[b] + 16 + 1
- }
-
- if b := byte(n >> 8); b != 0 {
- return log2[b] + 8 + 1
- }
-
- return log2[byte(n)] + 1
-}
-
-// BitLenUint returns the bit width of the non zero part of n.
-func BitLenUint(n uint) int { // Should handle correctly [future] 64 bit Go uints
- if IntBits == 64 {
- return BitLenUint64(uint64(n))
- }
-
- if b := n >> 24; b != 0 {
- return log2[b] + 24 + 1
- }
-
- if b := n >> 16; b != 0 {
- return log2[b] + 16 + 1
- }
-
- if b := n >> 8; b != 0 {
- return log2[b] + 8 + 1
- }
-
- return log2[n] + 1
-}
-
-// BitLenUint64 returns the bit width of the non zero part of n.
-func BitLenUint64(n uint64) int {
- if b := n >> 56; b != 0 {
- return log2[b] + 56 + 1
- }
-
- if b := n >> 48; b != 0 {
- return log2[b] + 48 + 1
- }
-
- if b := n >> 40; b != 0 {
- return log2[b] + 40 + 1
- }
-
- if b := n >> 32; b != 0 {
- return log2[b] + 32 + 1
- }
-
- if b := n >> 24; b != 0 {
- return log2[b] + 24 + 1
- }
-
- if b := n >> 16; b != 0 {
- return log2[b] + 16 + 1
- }
-
- if b := n >> 8; b != 0 {
- return log2[b] + 8 + 1
- }
-
- return log2[n] + 1
-}
-
-// BitLenUintptr returns the bit width of the non zero part of n.
-func BitLenUintptr(n uintptr) int {
- if b := n >> 56; b != 0 {
- return log2[b] + 56 + 1
- }
-
- if b := n >> 48; b != 0 {
- return log2[b] + 48 + 1
- }
-
- if b := n >> 40; b != 0 {
- return log2[b] + 40 + 1
- }
-
- if b := n >> 32; b != 0 {
- return log2[b] + 32 + 1
- }
-
- if b := n >> 24; b != 0 {
- return log2[b] + 24 + 1
- }
-
- if b := n >> 16; b != 0 {
- return log2[b] + 16 + 1
- }
-
- if b := n >> 8; b != 0 {
- return log2[b] + 8 + 1
- }
-
- return log2[n] + 1
-}
-
-// PopCountByte returns population count of n (number of bits set in n).
-func PopCountByte(n byte) int {
- return int(popcnt[n])
-}
-
-// PopCountUint16 returns population count of n (number of bits set in n).
-func PopCountUint16(n uint16) int {
- return int(popcnt[byte(n>>8)]) + int(popcnt[byte(n)])
-}
-
-// PopCountUint32 returns population count of n (number of bits set in n).
-func PopCountUint32(n uint32) int {
- return int(popcnt[byte(n>>24)]) + int(popcnt[byte(n>>16)]) +
- int(popcnt[byte(n>>8)]) + int(popcnt[byte(n)])
-}
-
-// PopCount returns population count of n (number of bits set in n).
-func PopCount(n int) int { // Should handle correctly [future] 64 bit Go ints
- if IntBits == 64 {
- return PopCountUint64(uint64(n))
- }
-
- return PopCountUint32(uint32(n))
-}
-
-// PopCountUint returns population count of n (number of bits set in n).
-func PopCountUint(n uint) int { // Should handle correctly [future] 64 bit Go uints
- if IntBits == 64 {
- return PopCountUint64(uint64(n))
- }
-
- return PopCountUint32(uint32(n))
-}
-
-// PopCountUintptr returns population count of n (number of bits set in n).
-func PopCountUintptr(n uintptr) int {
- if UintPtrBits == 64 {
- return PopCountUint64(uint64(n))
- }
-
- return PopCountUint32(uint32(n))
-}
-
-// PopCountUint64 returns population count of n (number of bits set in n).
-func PopCountUint64(n uint64) int {
- return int(popcnt[byte(n>>56)]) + int(popcnt[byte(n>>48)]) +
- int(popcnt[byte(n>>40)]) + int(popcnt[byte(n>>32)]) +
- int(popcnt[byte(n>>24)]) + int(popcnt[byte(n>>16)]) +
- int(popcnt[byte(n>>8)]) + int(popcnt[byte(n)])
-}
-
-// PopCountBigInt returns population count of |n| (number of bits set in |n|).
-func PopCountBigInt(n *big.Int) (r int) {
- for _, v := range n.Bits() {
- r += PopCountUintptr(uintptr(v))
- }
- return
-}
diff --git a/vendor/github.com/cznic/mathutil/envelope.go b/vendor/github.com/cznic/mathutil/envelope.go
deleted file mode 100644
index ff8e6012a..000000000
--- a/vendor/github.com/cznic/mathutil/envelope.go
+++ /dev/null
@@ -1,46 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-import (
- "math"
-)
-
-// Approximation type determines approximation methods used by e.g. Envelope.
-type Approximation int
-
-// Specific approximation method tags
-const (
- _ Approximation = iota
- Linear // As named
- Sinusoidal // Smooth for all derivations
-)
-
-// Envelope is an utility for defining simple curves using a small (usually)
-// set of data points. Envelope returns a value defined by x, points and
-// approximation. The value of x must be in [0,1) otherwise the result is
-// undefined or the function may panic. Points are interpreted as dividing the
-// [0,1) interval in len(points)-1 sections, so len(points) must be > 1 or the
-// function may panic. According to the left and right points closing/adjacent
-// to the section the resulting value is interpolated using the chosen
-// approximation method. Unsupported values of approximation are silently
-// interpreted as 'Linear'.
-func Envelope(x float64, points []float64, approximation Approximation) float64 {
- step := 1 / float64(len(points)-1)
- fslot := math.Floor(x / step)
- mod := x - fslot*step
- slot := int(fslot)
- l, r := points[slot], points[slot+1]
- rmod := mod / step
- switch approximation {
- case Sinusoidal:
- k := (math.Sin(math.Pi*(rmod-0.5)) + 1) / 2
- return l + (r-l)*k
- case Linear:
- fallthrough
- default:
- return l + (r-l)*rmod
- }
-}
diff --git a/vendor/github.com/cznic/mathutil/mathutil.go b/vendor/github.com/cznic/mathutil/mathutil.go
deleted file mode 100644
index ecf94b1ba..000000000
--- a/vendor/github.com/cznic/mathutil/mathutil.go
+++ /dev/null
@@ -1,831 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package mathutil provides utilities supplementing the standard 'math' and
-// 'math/rand' packages.
-//
-// Release history and compatibility issues
-//
-// 2016-10-10: New functions QuadPolyDiscriminant and QuadPolyFactors.
-//
-// 2013-12-13: The following functions have been REMOVED
-//
-// func Uint64ToBigInt(n uint64) *big.Int
-// func Uint64FromBigInt(n *big.Int) (uint64, bool)
-//
-// 2013-05-13: The following functions are now DEPRECATED
-//
-// func Uint64ToBigInt(n uint64) *big.Int
-// func Uint64FromBigInt(n *big.Int) (uint64, bool)
-//
-// These functions will be REMOVED with Go release 1.1+1.
-//
-// 2013-01-21: The following functions have been REMOVED
-//
-// func MaxInt() int
-// func MinInt() int
-// func MaxUint() uint
-// func UintPtrBits() int
-//
-// They are now replaced by untyped constants
-//
-// MaxInt
-// MinInt
-// MaxUint
-// UintPtrBits
-//
-// Additionally one more untyped constant was added
-//
-// IntBits
-//
-// This change breaks any existing code depending on the above removed
-// functions. They should have not been published in the first place, that was
-// unfortunate. Instead, defining such architecture and/or implementation
-// specific integer limits and bit widths as untyped constants improves
-// performance and allows for static dead code elimination if it depends on
-// these values. Thanks to minux for pointing it out in the mail list
-// (https://groups.google.com/d/msg/golang-nuts/tlPpLW6aJw8/NT3mpToH-a4J).
-//
-// 2012-12-12: The following functions will be DEPRECATED with Go release
-// 1.0.3+1 and REMOVED with Go release 1.0.3+2, b/c of
-// http://code.google.com/p/go/source/detail?r=954a79ee3ea8
-//
-// func Uint64ToBigInt(n uint64) *big.Int
-// func Uint64FromBigInt(n *big.Int) (uint64, bool)
-package mathutil
-
-import (
- "math"
- "math/big"
-)
-
-// Architecture and/or implementation specific integer limits and bit widths.
-const (
- MaxInt = 1<<(IntBits-1) - 1
- MinInt = -MaxInt - 1
- MaxUint = 1<>32&1 + ^uint(0)>>16&1 + ^uint(0)>>8&1 + 3)
- UintPtrBits = 1 << (^uintptr(0)>>32&1 + ^uintptr(0)>>16&1 + ^uintptr(0)>>8&1 + 3)
-)
-
-var (
- _1 = big.NewInt(1)
- _2 = big.NewInt(2)
-)
-
-// GCDByte returns the greatest common divisor of a and b. Based on:
-// http://en.wikipedia.org/wiki/Euclidean_algorithm#Implementations
-func GCDByte(a, b byte) byte {
- for b != 0 {
- a, b = b, a%b
- }
- return a
-}
-
-// GCDUint16 returns the greatest common divisor of a and b.
-func GCDUint16(a, b uint16) uint16 {
- for b != 0 {
- a, b = b, a%b
- }
- return a
-}
-
-// GCDUint32 returns the greatest common divisor of a and b.
-func GCDUint32(a, b uint32) uint32 {
- for b != 0 {
- a, b = b, a%b
- }
- return a
-}
-
-// GCDUint64 returns the greatest common divisor of a and b.
-func GCDUint64(a, b uint64) uint64 {
- for b != 0 {
- a, b = b, a%b
- }
- return a
-}
-
-// ISqrt returns floor(sqrt(n)). Typical run time is few hundreds of ns.
-func ISqrt(n uint32) (x uint32) {
- if n == 0 {
- return
- }
-
- if n >= math.MaxUint16*math.MaxUint16 {
- return math.MaxUint16
- }
-
- var px, nx uint32
- for x = n; ; px, x = x, nx {
- nx = (x + n/x) / 2
- if nx == x || nx == px {
- break
- }
- }
- return
-}
-
-// SqrtUint64 returns floor(sqrt(n)). Typical run time is about 0.5 µs.
-func SqrtUint64(n uint64) (x uint64) {
- if n == 0 {
- return
- }
-
- if n >= math.MaxUint32*math.MaxUint32 {
- return math.MaxUint32
- }
-
- var px, nx uint64
- for x = n; ; px, x = x, nx {
- nx = (x + n/x) / 2
- if nx == x || nx == px {
- break
- }
- }
- return
-}
-
-// SqrtBig returns floor(sqrt(n)). It panics on n < 0.
-func SqrtBig(n *big.Int) (x *big.Int) {
- switch n.Sign() {
- case -1:
- panic(-1)
- case 0:
- return big.NewInt(0)
- }
-
- var px, nx big.Int
- x = big.NewInt(0)
- x.SetBit(x, n.BitLen()/2+1, 1)
- for {
- nx.Rsh(nx.Add(x, nx.Div(n, x)), 1)
- if nx.Cmp(x) == 0 || nx.Cmp(&px) == 0 {
- break
- }
- px.Set(x)
- x.Set(&nx)
- }
- return
-}
-
-// Log2Byte returns log base 2 of n. It's the same as index of the highest
-// bit set in n. For n == 0 -1 is returned.
-func Log2Byte(n byte) int {
- return log2[n]
-}
-
-// Log2Uint16 returns log base 2 of n. It's the same as index of the highest
-// bit set in n. For n == 0 -1 is returned.
-func Log2Uint16(n uint16) int {
- if b := n >> 8; b != 0 {
- return log2[b] + 8
- }
-
- return log2[n]
-}
-
-// Log2Uint32 returns log base 2 of n. It's the same as index of the highest
-// bit set in n. For n == 0 -1 is returned.
-func Log2Uint32(n uint32) int {
- if b := n >> 24; b != 0 {
- return log2[b] + 24
- }
-
- if b := n >> 16; b != 0 {
- return log2[b] + 16
- }
-
- if b := n >> 8; b != 0 {
- return log2[b] + 8
- }
-
- return log2[n]
-}
-
-// Log2Uint64 returns log base 2 of n. It's the same as index of the highest
-// bit set in n. For n == 0 -1 is returned.
-func Log2Uint64(n uint64) int {
- if b := n >> 56; b != 0 {
- return log2[b] + 56
- }
-
- if b := n >> 48; b != 0 {
- return log2[b] + 48
- }
-
- if b := n >> 40; b != 0 {
- return log2[b] + 40
- }
-
- if b := n >> 32; b != 0 {
- return log2[b] + 32
- }
-
- if b := n >> 24; b != 0 {
- return log2[b] + 24
- }
-
- if b := n >> 16; b != 0 {
- return log2[b] + 16
- }
-
- if b := n >> 8; b != 0 {
- return log2[b] + 8
- }
-
- return log2[n]
-}
-
-// ModPowByte computes (b^e)%m. It panics for m == 0 || b == e == 0.
-//
-// See also: http://en.wikipedia.org/wiki/Modular_exponentiation#Right-to-left_binary_method
-func ModPowByte(b, e, m byte) byte {
- if b == 0 && e == 0 {
- panic(0)
- }
-
- if m == 1 {
- return 0
- }
-
- r := uint16(1)
- for b, m := uint16(b), uint16(m); e > 0; b, e = b*b%m, e>>1 {
- if e&1 == 1 {
- r = r * b % m
- }
- }
- return byte(r)
-}
-
-// ModPowUint16 computes (b^e)%m. It panics for m == 0 || b == e == 0.
-func ModPowUint16(b, e, m uint16) uint16 {
- if b == 0 && e == 0 {
- panic(0)
- }
-
- if m == 1 {
- return 0
- }
-
- r := uint32(1)
- for b, m := uint32(b), uint32(m); e > 0; b, e = b*b%m, e>>1 {
- if e&1 == 1 {
- r = r * b % m
- }
- }
- return uint16(r)
-}
-
-// ModPowUint32 computes (b^e)%m. It panics for m == 0 || b == e == 0.
-func ModPowUint32(b, e, m uint32) uint32 {
- if b == 0 && e == 0 {
- panic(0)
- }
-
- if m == 1 {
- return 0
- }
-
- r := uint64(1)
- for b, m := uint64(b), uint64(m); e > 0; b, e = b*b%m, e>>1 {
- if e&1 == 1 {
- r = r * b % m
- }
- }
- return uint32(r)
-}
-
-// ModPowUint64 computes (b^e)%m. It panics for m == 0 || b == e == 0.
-func ModPowUint64(b, e, m uint64) (r uint64) {
- if b == 0 && e == 0 {
- panic(0)
- }
-
- if m == 1 {
- return 0
- }
-
- return modPowBigInt(big.NewInt(0).SetUint64(b), big.NewInt(0).SetUint64(e), big.NewInt(0).SetUint64(m)).Uint64()
-}
-
-func modPowBigInt(b, e, m *big.Int) (r *big.Int) {
- r = big.NewInt(1)
- for i, n := 0, e.BitLen(); i < n; i++ {
- if e.Bit(i) != 0 {
- r.Mod(r.Mul(r, b), m)
- }
- b.Mod(b.Mul(b, b), m)
- }
- return
-}
-
-// ModPowBigInt computes (b^e)%m. Returns nil for e < 0. It panics for m == 0 || b == e == 0.
-func ModPowBigInt(b, e, m *big.Int) (r *big.Int) {
- if b.Sign() == 0 && e.Sign() == 0 {
- panic(0)
- }
-
- if m.Cmp(_1) == 0 {
- return big.NewInt(0)
- }
-
- if e.Sign() < 0 {
- return
- }
-
- return modPowBigInt(big.NewInt(0).Set(b), big.NewInt(0).Set(e), m)
-}
-
-var uint64ToBigIntDelta big.Int
-
-func init() {
- uint64ToBigIntDelta.SetBit(&uint64ToBigIntDelta, 63, 1)
-}
-
-var uintptrBits int
-
-func init() {
- x := uint64(math.MaxUint64)
- uintptrBits = BitLenUintptr(uintptr(x))
-}
-
-// UintptrBits returns the bit width of an uintptr at the executing machine.
-func UintptrBits() int {
- return uintptrBits
-}
-
-// AddUint128_64 returns the uint128 sum of uint64 a and b.
-func AddUint128_64(a, b uint64) (hi uint64, lo uint64) {
- lo = a + b
- if lo < a {
- hi = 1
- }
- return
-}
-
-// MulUint128_64 returns the uint128 bit product of uint64 a and b.
-func MulUint128_64(a, b uint64) (hi, lo uint64) {
- /*
- 2^(2 W) ahi bhi + 2^W alo bhi + 2^W ahi blo + alo blo
-
- FEDCBA98 76543210 FEDCBA98 76543210
- ---- alo*blo ----
- ---- alo*bhi ----
- ---- ahi*blo ----
- ---- ahi*bhi ----
- */
- const w = 32
- const m = 1<>w, b>>w, a&m, b&m
- lo = alo * blo
- mid1 := alo * bhi
- mid2 := ahi * blo
- c1, lo := AddUint128_64(lo, mid1<>w+mid2>>w+c1+c2)
- return
-}
-
-// PowerizeBigInt returns (e, p) such that e is the smallest number for which p
-// == b^e is greater or equal n. For n < 0 or b < 2 (0, nil) is returned.
-//
-// NOTE: Run time for large values of n (above about 2^1e6 ~= 1e300000) can be
-// significant and/or unacceptabe. For any smaller values of n the function
-// typically performs in sub second time. For "small" values of n (cca bellow
-// 2^1e3 ~= 1e300) the same can be easily below 10 µs.
-//
-// A special (and trivial) case of b == 2 is handled separately and performs
-// much faster.
-func PowerizeBigInt(b, n *big.Int) (e uint32, p *big.Int) {
- switch {
- case b.Cmp(_2) < 0 || n.Sign() < 0:
- return
- case n.Sign() == 0 || n.Cmp(_1) == 0:
- return 0, big.NewInt(1)
- case b.Cmp(_2) == 0:
- p = big.NewInt(0)
- e = uint32(n.BitLen() - 1)
- p.SetBit(p, int(e), 1)
- if p.Cmp(n) < 0 {
- p.Mul(p, _2)
- e++
- }
- return
- }
-
- bw := b.BitLen()
- nw := n.BitLen()
- p = big.NewInt(1)
- var bb, r big.Int
- for {
- switch p.Cmp(n) {
- case -1:
- x := uint32((nw - p.BitLen()) / bw)
- if x == 0 {
- x = 1
- }
- e += x
- switch x {
- case 1:
- p.Mul(p, b)
- default:
- r.Set(_1)
- bb.Set(b)
- e := x
- for {
- if e&1 != 0 {
- r.Mul(&r, &bb)
- }
- if e >>= 1; e == 0 {
- break
- }
-
- bb.Mul(&bb, &bb)
- }
- p.Mul(p, &r)
- }
- case 0, 1:
- return
- }
- }
-}
-
-// PowerizeUint32BigInt returns (e, p) such that e is the smallest number for
-// which p == b^e is greater or equal n. For n < 0 or b < 2 (0, nil) is
-// returned.
-//
-// More info: see PowerizeBigInt.
-func PowerizeUint32BigInt(b uint32, n *big.Int) (e uint32, p *big.Int) {
- switch {
- case b < 2 || n.Sign() < 0:
- return
- case n.Sign() == 0 || n.Cmp(_1) == 0:
- return 0, big.NewInt(1)
- case b == 2:
- p = big.NewInt(0)
- e = uint32(n.BitLen() - 1)
- p.SetBit(p, int(e), 1)
- if p.Cmp(n) < 0 {
- p.Mul(p, _2)
- e++
- }
- return
- }
-
- var bb big.Int
- bb.SetInt64(int64(b))
- return PowerizeBigInt(&bb, n)
-}
-
-/*
-ProbablyPrimeUint32 returns true if n is prime or n is a pseudoprime to base a.
-It implements the Miller-Rabin primality test for one specific value of 'a' and
-k == 1.
-
-Wrt pseudocode shown at
-http://en.wikipedia.org/wiki/Miller-Rabin_primality_test#Algorithm_and_running_time
-
- Input: n > 3, an odd integer to be tested for primality;
- Input: k, a parameter that determines the accuracy of the test
- Output: composite if n is composite, otherwise probably prime
- write n − 1 as 2^s·d with d odd by factoring powers of 2 from n − 1
- LOOP: repeat k times:
- pick a random integer a in the range [2, n − 2]
- x ← a^d mod n
- if x = 1 or x = n − 1 then do next LOOP
- for r = 1 .. s − 1
- x ← x^2 mod n
- if x = 1 then return composite
- if x = n − 1 then do next LOOP
- return composite
- return probably prime
-
-... this function behaves like passing 1 for 'k' and additionally a
-fixed/non-random 'a'. Otherwise it's the same algorithm.
-
-See also: http://mathworld.wolfram.com/Rabin-MillerStrongPseudoprimeTest.html
-*/
-func ProbablyPrimeUint32(n, a uint32) bool {
- d, s := n-1, 0
- for ; d&1 == 0; d, s = d>>1, s+1 {
- }
- x := uint64(ModPowUint32(a, d, n))
- if x == 1 || uint32(x) == n-1 {
- return true
- }
-
- for ; s > 1; s-- {
- if x = x * x % uint64(n); x == 1 {
- return false
- }
-
- if uint32(x) == n-1 {
- return true
- }
- }
- return false
-}
-
-// ProbablyPrimeUint64_32 returns true if n is prime or n is a pseudoprime to
-// base a. It implements the Miller-Rabin primality test for one specific value
-// of 'a' and k == 1. See also ProbablyPrimeUint32.
-func ProbablyPrimeUint64_32(n uint64, a uint32) bool {
- d, s := n-1, 0
- for ; d&1 == 0; d, s = d>>1, s+1 {
- }
- x := ModPowUint64(uint64(a), d, n)
- if x == 1 || x == n-1 {
- return true
- }
-
- bx, bn := big.NewInt(0).SetUint64(x), big.NewInt(0).SetUint64(n)
- for ; s > 1; s-- {
- if x = bx.Mod(bx.Mul(bx, bx), bn).Uint64(); x == 1 {
- return false
- }
-
- if x == n-1 {
- return true
- }
- }
- return false
-}
-
-// ProbablyPrimeBigInt_32 returns true if n is prime or n is a pseudoprime to
-// base a. It implements the Miller-Rabin primality test for one specific value
-// of 'a' and k == 1. See also ProbablyPrimeUint32.
-func ProbablyPrimeBigInt_32(n *big.Int, a uint32) bool {
- var d big.Int
- d.Set(n)
- d.Sub(&d, _1) // d <- n-1
- s := 0
- for ; d.Bit(s) == 0; s++ {
- }
- nMinus1 := big.NewInt(0).Set(&d)
- d.Rsh(&d, uint(s))
-
- x := ModPowBigInt(big.NewInt(int64(a)), &d, n)
- if x.Cmp(_1) == 0 || x.Cmp(nMinus1) == 0 {
- return true
- }
-
- for ; s > 1; s-- {
- if x = x.Mod(x.Mul(x, x), n); x.Cmp(_1) == 0 {
- return false
- }
-
- if x.Cmp(nMinus1) == 0 {
- return true
- }
- }
- return false
-}
-
-// ProbablyPrimeBigInt returns true if n is prime or n is a pseudoprime to base
-// a. It implements the Miller-Rabin primality test for one specific value of
-// 'a' and k == 1. See also ProbablyPrimeUint32.
-func ProbablyPrimeBigInt(n, a *big.Int) bool {
- var d big.Int
- d.Set(n)
- d.Sub(&d, _1) // d <- n-1
- s := 0
- for ; d.Bit(s) == 0; s++ {
- }
- nMinus1 := big.NewInt(0).Set(&d)
- d.Rsh(&d, uint(s))
-
- x := ModPowBigInt(a, &d, n)
- if x.Cmp(_1) == 0 || x.Cmp(nMinus1) == 0 {
- return true
- }
-
- for ; s > 1; s-- {
- if x = x.Mod(x.Mul(x, x), n); x.Cmp(_1) == 0 {
- return false
- }
-
- if x.Cmp(nMinus1) == 0 {
- return true
- }
- }
- return false
-}
-
-// Max returns the larger of a and b.
-func Max(a, b int) int {
- if a > b {
- return a
- }
-
- return b
-}
-
-// Min returns the smaller of a and b.
-func Min(a, b int) int {
- if a < b {
- return a
- }
-
- return b
-}
-
-// UMax returns the larger of a and b.
-func UMax(a, b uint) uint {
- if a > b {
- return a
- }
-
- return b
-}
-
-// UMin returns the smaller of a and b.
-func UMin(a, b uint) uint {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxByte returns the larger of a and b.
-func MaxByte(a, b byte) byte {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinByte returns the smaller of a and b.
-func MinByte(a, b byte) byte {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxInt8 returns the larger of a and b.
-func MaxInt8(a, b int8) int8 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinInt8 returns the smaller of a and b.
-func MinInt8(a, b int8) int8 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxUint16 returns the larger of a and b.
-func MaxUint16(a, b uint16) uint16 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinUint16 returns the smaller of a and b.
-func MinUint16(a, b uint16) uint16 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxInt16 returns the larger of a and b.
-func MaxInt16(a, b int16) int16 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinInt16 returns the smaller of a and b.
-func MinInt16(a, b int16) int16 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxUint32 returns the larger of a and b.
-func MaxUint32(a, b uint32) uint32 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinUint32 returns the smaller of a and b.
-func MinUint32(a, b uint32) uint32 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxInt32 returns the larger of a and b.
-func MaxInt32(a, b int32) int32 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinInt32 returns the smaller of a and b.
-func MinInt32(a, b int32) int32 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxUint64 returns the larger of a and b.
-func MaxUint64(a, b uint64) uint64 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinUint64 returns the smaller of a and b.
-func MinUint64(a, b uint64) uint64 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// MaxInt64 returns the larger of a and b.
-func MaxInt64(a, b int64) int64 {
- if a > b {
- return a
- }
-
- return b
-}
-
-// MinInt64 returns the smaller of a and b.
-func MinInt64(a, b int64) int64 {
- if a < b {
- return a
- }
-
- return b
-}
-
-// ToBase produces n in base b. For example
-//
-// ToBase(2047, 22) -> [1, 5, 4]
-//
-// 1 * 22^0 1
-// 5 * 22^1 110
-// 4 * 22^2 1936
-// ----
-// 2047
-//
-// ToBase panics for bases < 2.
-func ToBase(n *big.Int, b int) []int {
- var nn big.Int
- nn.Set(n)
- if b < 2 {
- panic("invalid base")
- }
-
- k := 1
- switch nn.Sign() {
- case -1:
- nn.Neg(&nn)
- k = -1
- case 0:
- return []int{0}
- }
-
- bb := big.NewInt(int64(b))
- var r []int
- rem := big.NewInt(0)
- for nn.Sign() != 0 {
- nn.QuoRem(&nn, bb, rem)
- r = append(r, k*int(rem.Int64()))
- }
- return r
-}
diff --git a/vendor/github.com/cznic/mathutil/nist-sts-2-1-1-report b/vendor/github.com/cznic/mathutil/nist-sts-2-1-1-report
deleted file mode 100644
index 20e686c61..000000000
--- a/vendor/github.com/cznic/mathutil/nist-sts-2-1-1-report
+++ /dev/null
@@ -1,267 +0,0 @@
-$ ./example -max 100000000 > rnd.dat
-$ ./assess 1000000
- G E N E R A T O R S E L E C T I O N
- ______________________________________
-
- [0] Input File [1] Linear Congruential
- [2] Quadratic Congruential I [3] Quadratic Congruential II
- [4] Cubic Congruential [5] XOR
- [6] Modular Exponentiation [7] Blum-Blum-Shub
- [8] Micali-Schnorr [9] G Using SHA-1
-
- Enter Choice: 0
-
-
- User Prescribed Input File: rnd.dat
-
- S T A T I S T I C A L T E S T S
- _________________________________
-
- [01] Frequency [02] Block Frequency
- [03] Cumulative Sums [04] Runs
- [05] Longest Run of Ones [06] Rank
- [07] Discrete Fourier Transform [08] Nonperiodic Template Matchings
- [09] Overlapping Template Matchings [10] Universal Statistical
- [11] Approximate Entropy [12] Random Excursions
- [13] Random Excursions Variant [14] Serial
- [15] Linear Complexity
-
- INSTRUCTIONS
- Enter 0 if you DO NOT want to apply all of the
- statistical tests to each sequence and 1 if you DO.
-
- Enter Choice: 1
-
- P a r a m e t e r A d j u s t m e n t s
- -----------------------------------------
- [1] Block Frequency Test - block length(M): 128
- [2] NonOverlapping Template Test - block length(m): 9
- [3] Overlapping Template Test - block length(m): 9
- [4] Approximate Entropy Test - block length(m): 10
- [5] Serial Test - block length(m): 16
- [6] Linear Complexity Test - block length(M): 500
-
- Select Test (0 to continue): 0
-
- How many bitstreams? 200
-
- Input File Format:
- [0] ASCII - A sequence of ASCII 0's and 1's
- [1] Binary - Each byte in data file contains 8 bits of data
-
- Select input mode: 1
-
- Statistical Testing In Progress.........
-
- Statistical Testing Complete!!!!!!!!!!!!
-
-$ cat experiments/AlgorithmTesting/finalAnalysisReport.txt
-------------------------------------------------------------------------------
-RESULTS FOR THE UNIFORMITY OF P-VALUES AND THE PROPORTION OF PASSING SEQUENCES
-------------------------------------------------------------------------------
- generator is
-------------------------------------------------------------------------------
- C1 C2 C3 C4 C5 C6 C7 C8 C9 C10 P-VALUE PROPORTION STATISTICAL TEST
-------------------------------------------------------------------------------
- 28 22 17 19 15 8 24 23 19 25 0.093720 198/200 Frequency
- 20 18 24 14 18 17 16 28 21 24 0.504219 199/200 BlockFrequency
- 25 22 17 24 19 21 22 15 16 19 0.825505 197/200 CumulativeSums
- 27 17 16 22 14 26 14 25 19 20 0.304126 199/200 CumulativeSums
- 22 19 14 23 22 22 13 28 13 24 0.224821 199/200 Runs
- 20 24 18 21 15 13 22 23 24 20 0.719747 197/200 LongestRun
- 22 26 18 22 26 15 17 22 20 12 0.410055 199/200 Rank
- 25 22 26 22 20 16 20 20 16 13 0.585209 195/200 FFT
- 22 11 15 26 33 24 21 13 14 21 0.013102 197/200 NonOverlappingTemplate
- 17 11 16 27 19 24 19 20 28 19 0.219006 200/200 NonOverlappingTemplate
- 23 27 24 15 21 11 18 27 15 19 0.162606 197/200 NonOverlappingTemplate
- 21 18 13 20 19 23 20 17 26 23 0.749884 197/200 NonOverlappingTemplate
- 24 22 24 24 24 21 13 15 17 16 0.494392 196/200 NonOverlappingTemplate
- 24 16 23 15 23 18 25 16 18 22 0.699313 199/200 NonOverlappingTemplate
- 19 23 21 16 27 18 17 20 18 21 0.859637 198/200 NonOverlappingTemplate
- 12 20 16 19 26 14 30 20 24 19 0.141256 198/200 NonOverlappingTemplate
- 18 21 17 21 20 14 25 19 24 21 0.859637 198/200 NonOverlappingTemplate
- 24 25 21 18 23 15 23 17 16 18 0.749884 199/200 NonOverlappingTemplate
- 20 22 22 18 16 22 28 16 14 22 0.574903 198/200 NonOverlappingTemplate
- 18 23 22 17 24 25 19 16 23 13 0.626709 199/200 NonOverlappingTemplate
- 17 22 14 19 21 21 18 19 24 25 0.842937 198/200 NonOverlappingTemplate
- 18 17 26 21 22 15 22 18 21 20 0.883171 197/200 NonOverlappingTemplate
- 19 25 16 32 15 19 20 18 16 20 0.236810 199/200 NonOverlappingTemplate
- 19 18 15 21 24 22 18 21 20 22 0.964295 200/200 NonOverlappingTemplate
- 21 14 17 23 26 19 20 22 20 18 0.834308 196/200 NonOverlappingTemplate
- 15 21 17 27 26 23 21 17 24 9 0.129620 198/200 NonOverlappingTemplate
- 25 17 19 19 18 22 21 22 21 16 0.951205 196/200 NonOverlappingTemplate
- 20 19 24 21 19 24 16 18 17 22 0.946308 197/200 NonOverlappingTemplate
- 27 16 19 18 23 19 22 17 22 17 0.807412 197/200 NonOverlappingTemplate
- 14 18 21 23 23 20 14 22 20 25 0.719747 198/200 NonOverlappingTemplate
- 18 22 19 12 24 25 25 22 18 15 0.474986 198/200 NonOverlappingTemplate
- 21 18 23 17 19 18 28 19 20 17 0.825505 198/200 NonOverlappingTemplate
- 20 19 15 16 27 20 26 17 20 20 0.657933 198/200 NonOverlappingTemplate
- 17 25 21 21 11 19 22 16 27 21 0.401199 198/200 NonOverlappingTemplate
- 19 16 15 18 24 19 25 25 19 20 0.769527 199/200 NonOverlappingTemplate
- 18 20 20 26 20 12 24 25 19 16 0.524101 198/200 NonOverlappingTemplate
- 14 16 18 23 21 21 19 19 28 21 0.668321 197/200 NonOverlappingTemplate
- 21 20 23 25 21 22 19 17 14 18 0.875539 197/200 NonOverlappingTemplate
- 14 16 29 22 23 13 20 29 17 17 0.099513 197/200 NonOverlappingTemplate
- 14 19 27 19 17 23 18 24 20 19 0.709558 199/200 NonOverlappingTemplate
- 18 15 21 19 27 22 21 23 17 17 0.779188 198/200 NonOverlappingTemplate
- 13 23 13 22 22 23 22 21 21 20 0.689019 199/200 NonOverlappingTemplate
- 17 14 26 26 16 21 30 15 21 14 0.096578 199/200 NonOverlappingTemplate
- 18 21 24 23 21 13 23 23 19 15 0.719747 197/200 NonOverlappingTemplate
- 19 21 14 32 20 15 16 18 24 21 0.202268 199/200 NonOverlappingTemplate
- 27 22 20 21 21 14 15 22 14 24 0.474986 196/200 NonOverlappingTemplate
- 31 12 25 11 21 18 19 16 24 23 0.050305 197/200 NonOverlappingTemplate
- 17 26 20 22 15 27 22 19 12 20 0.383827 199/200 NonOverlappingTemplate
- 15 22 14 14 31 15 27 18 23 21 0.078086 194/200 NonOverlappingTemplate
- 19 19 14 15 24 21 25 21 20 22 0.788728 197/200 NonOverlappingTemplate
- 20 21 19 22 25 18 13 24 28 10 0.153763 195/200 NonOverlappingTemplate
- 23 17 21 25 21 20 13 30 14 16 0.196920 196/200 NonOverlappingTemplate
- 17 31 17 22 16 15 28 23 11 20 0.050305 197/200 NonOverlappingTemplate
- 15 21 26 27 15 18 19 21 18 20 0.605916 198/200 NonOverlappingTemplate
- 23 18 15 14 20 21 20 20 20 29 0.554420 200/200 NonOverlappingTemplate
- 22 19 19 18 19 17 22 21 31 12 0.311542 199/200 NonOverlappingTemplate
- 16 22 23 21 19 19 18 24 21 17 0.960198 197/200 NonOverlappingTemplate
- 21 21 17 20 16 23 25 22 18 17 0.917870 200/200 NonOverlappingTemplate
- 27 17 17 16 21 20 22 18 21 21 0.859637 197/200 NonOverlappingTemplate
- 18 24 15 27 18 21 18 16 24 19 0.657933 199/200 NonOverlappingTemplate
- 13 16 21 21 15 25 18 22 29 20 0.326749 198/200 NonOverlappingTemplate
- 18 17 23 23 15 19 26 30 11 18 0.125927 198/200 NonOverlappingTemplate
- 30 21 18 22 17 21 15 17 21 18 0.544254 195/200 NonOverlappingTemplate
- 12 18 19 24 16 24 18 24 28 17 0.311542 199/200 NonOverlappingTemplate
- 20 15 23 15 18 30 23 18 17 21 0.410055 196/200 NonOverlappingTemplate
- 15 18 23 16 29 21 22 16 19 21 0.544254 200/200 NonOverlappingTemplate
- 18 16 27 13 21 22 22 21 16 24 0.534146 199/200 NonOverlappingTemplate
- 20 25 18 21 16 21 17 28 21 13 0.484646 200/200 NonOverlappingTemplate
- 23 22 13 22 14 20 26 18 19 23 0.574903 197/200 NonOverlappingTemplate
- 21 24 25 13 19 22 18 13 24 21 0.504219 199/200 NonOverlappingTemplate
- 19 13 18 25 22 15 23 28 19 18 0.410055 195/200 NonOverlappingTemplate
- 20 15 27 22 26 26 14 13 21 16 0.181557 198/200 NonOverlappingTemplate
- 18 18 19 23 18 20 19 21 24 20 0.991468 200/200 NonOverlappingTemplate
- 18 23 17 14 20 25 22 22 22 17 0.816537 198/200 NonOverlappingTemplate
- 26 15 15 11 23 21 21 16 36 16 0.005557 196/200 NonOverlappingTemplate
- 27 13 21 23 21 16 19 20 16 24 0.544254 198/200 NonOverlappingTemplate
- 16 15 32 17 20 23 22 19 20 16 0.262249 200/200 NonOverlappingTemplate
- 26 19 24 13 24 16 18 18 13 29 0.137282 199/200 NonOverlappingTemplate
- 15 18 14 27 32 21 15 20 19 19 0.112047 198/200 NonOverlappingTemplate
- 22 23 22 18 20 23 19 22 16 15 0.924076 196/200 NonOverlappingTemplate
- 18 17 21 22 14 17 22 24 20 25 0.798139 199/200 NonOverlappingTemplate
- 15 17 19 24 21 23 17 25 23 16 0.739918 196/200 NonOverlappingTemplate
- 22 11 15 26 32 25 21 13 14 21 0.017305 197/200 NonOverlappingTemplate
- 22 16 19 23 22 21 21 19 17 20 0.985788 200/200 NonOverlappingTemplate
- 22 28 18 24 14 20 23 21 20 10 0.230755 198/200 NonOverlappingTemplate
- 14 13 22 28 14 28 17 22 23 19 0.129620 197/200 NonOverlappingTemplate
- 22 16 22 20 21 21 16 19 18 25 0.935716 198/200 NonOverlappingTemplate
- 15 20 23 17 19 22 21 23 18 22 0.951205 200/200 NonOverlappingTemplate
- 20 24 21 19 17 19 19 24 15 22 0.930026 198/200 NonOverlappingTemplate
- 18 21 15 21 17 28 24 22 20 14 0.534146 200/200 NonOverlappingTemplate
- 19 15 19 19 20 20 15 25 23 25 0.779188 198/200 NonOverlappingTemplate
- 17 24 25 16 15 21 18 19 23 22 0.788728 198/200 NonOverlappingTemplate
- 15 20 18 25 24 15 21 31 18 13 0.141256 200/200 NonOverlappingTemplate
- 24 17 19 20 18 21 15 22 24 20 0.924076 196/200 NonOverlappingTemplate
- 23 18 17 21 17 28 23 21 18 14 0.605916 197/200 NonOverlappingTemplate
- 21 19 22 23 16 17 20 21 22 19 0.985788 200/200 NonOverlappingTemplate
- 27 17 21 27 24 15 15 17 15 22 0.304126 199/200 NonOverlappingTemplate
- 25 28 20 24 13 14 16 22 19 19 0.304126 197/200 NonOverlappingTemplate
- 27 16 14 24 22 18 24 20 18 17 0.564639 196/200 NonOverlappingTemplate
- 18 18 24 19 19 19 26 11 27 19 0.375313 195/200 NonOverlappingTemplate
- 20 15 29 19 26 16 21 11 18 25 0.141256 197/200 NonOverlappingTemplate
- 19 14 21 25 11 23 22 25 26 14 0.176657 199/200 NonOverlappingTemplate
- 18 23 20 17 19 18 29 22 26 8 0.102526 199/200 NonOverlappingTemplate
- 22 17 18 16 18 20 19 19 25 26 0.834308 198/200 NonOverlappingTemplate
- 25 18 14 16 16 24 18 18 30 21 0.268917 198/200 NonOverlappingTemplate
- 24 21 23 13 12 22 20 23 20 22 0.554420 196/200 NonOverlappingTemplate
- 18 21 21 30 22 17 19 14 18 20 0.534146 197/200 NonOverlappingTemplate
- 25 20 22 21 15 18 17 20 17 25 0.825505 199/200 NonOverlappingTemplate
- 18 21 22 21 18 20 26 16 20 18 0.941144 197/200 NonOverlappingTemplate
- 23 18 22 25 12 16 17 19 26 22 0.474986 198/200 NonOverlappingTemplate
- 22 18 29 23 19 23 17 17 15 17 0.534146 198/200 NonOverlappingTemplate
- 19 21 17 26 18 15 22 26 15 21 0.626709 197/200 NonOverlappingTemplate
- 16 20 20 23 18 21 18 18 25 21 0.955835 199/200 NonOverlappingTemplate
- 23 21 20 21 22 10 15 27 15 26 0.186566 198/200 NonOverlappingTemplate
- 18 26 20 26 26 18 17 17 20 12 0.358641 198/200 NonOverlappingTemplate
- 24 20 21 18 24 12 19 27 14 21 0.401199 195/200 NonOverlappingTemplate
- 16 25 15 21 24 18 18 25 22 16 0.657933 199/200 NonOverlappingTemplate
- 24 14 17 26 15 17 17 25 21 24 0.428095 200/200 NonOverlappingTemplate
- 22 24 11 20 22 24 19 18 12 28 0.176657 196/200 NonOverlappingTemplate
- 27 16 27 18 27 14 13 16 21 21 0.141256 197/200 NonOverlappingTemplate
- 23 25 20 18 23 17 15 23 19 17 0.834308 196/200 NonOverlappingTemplate
- 19 21 20 27 16 16 18 25 16 22 0.678686 199/200 NonOverlappingTemplate
- 25 22 21 19 15 19 22 19 25 13 0.657933 197/200 NonOverlappingTemplate
- 19 28 21 25 20 12 18 13 29 15 0.073417 198/200 NonOverlappingTemplate
- 20 24 21 19 21 15 17 24 20 19 0.941144 198/200 NonOverlappingTemplate
- 18 29 23 17 24 19 17 18 16 19 0.585209 200/200 NonOverlappingTemplate
- 18 28 18 16 25 21 18 20 14 22 0.544254 198/200 NonOverlappingTemplate
- 22 19 23 22 22 21 21 26 12 12 0.401199 199/200 NonOverlappingTemplate
- 22 15 25 16 21 27 14 22 21 17 0.484646 199/200 NonOverlappingTemplate
- 18 25 20 23 30 17 13 22 18 14 0.213309 200/200 NonOverlappingTemplate
- 20 23 21 21 23 29 16 13 16 18 0.410055 199/200 NonOverlappingTemplate
- 21 19 16 22 31 18 20 17 18 18 0.514124 198/200 NonOverlappingTemplate
- 26 22 12 14 23 17 21 24 21 20 0.455937 197/200 NonOverlappingTemplate
- 21 17 18 17 14 32 21 26 18 16 0.162606 197/200 NonOverlappingTemplate
- 22 24 22 23 11 15 17 18 29 19 0.230755 198/200 NonOverlappingTemplate
- 19 27 20 19 23 15 24 15 21 17 0.657933 198/200 NonOverlappingTemplate
- 20 25 16 10 24 13 23 21 21 27 0.149495 200/200 NonOverlappingTemplate
- 19 21 21 27 17 17 19 21 21 17 0.904708 200/200 NonOverlappingTemplate
- 18 23 15 19 24 21 23 21 13 23 0.719747 198/200 NonOverlappingTemplate
- 26 16 28 19 19 18 17 17 16 24 0.474986 199/200 NonOverlappingTemplate
- 24 32 17 18 20 13 18 18 19 21 0.236810 195/200 NonOverlappingTemplate
- 26 25 18 17 12 19 20 23 21 19 0.585209 196/200 NonOverlappingTemplate
- 18 26 25 12 18 16 24 19 18 24 0.410055 199/200 NonOverlappingTemplate
- 27 21 22 27 21 14 18 14 23 13 0.219006 197/200 NonOverlappingTemplate
- 18 23 24 16 19 21 16 26 20 17 0.798139 199/200 NonOverlappingTemplate
- 19 30 15 27 14 19 24 11 22 19 0.073417 198/200 NonOverlappingTemplate
- 20 23 22 20 22 15 22 21 18 17 0.964295 198/200 NonOverlappingTemplate
- 22 31 16 26 13 19 17 22 24 10 0.037566 197/200 NonOverlappingTemplate
- 18 24 22 14 23 19 16 18 19 27 0.637119 197/200 NonOverlappingTemplate
- 19 20 21 22 21 18 19 22 20 18 0.999438 198/200 NonOverlappingTemplate
- 27 15 21 18 28 18 15 23 18 17 0.375313 195/200 NonOverlappingTemplate
- 26 23 20 20 23 19 20 23 14 12 0.514124 199/200 NonOverlappingTemplate
- 18 19 11 15 21 24 20 26 23 23 0.428095 198/200 NonOverlappingTemplate
- 19 16 21 25 19 21 15 24 24 16 0.749884 197/200 NonOverlappingTemplate
- 17 26 23 18 20 26 23 14 18 15 0.494392 198/200 NonOverlappingTemplate
- 15 17 19 24 21 23 17 25 23 16 0.739918 196/200 NonOverlappingTemplate
- 26 19 20 20 24 22 22 13 14 20 0.605916 198/200 OverlappingTemplate
- 29 24 17 21 18 13 18 21 17 22 0.446556 196/200 Universal
- 22 18 22 20 20 21 22 21 18 16 0.992952 198/200 ApproximateEntropy
- 14 8 13 9 11 13 13 8 7 10 0.719747 106/106 RandomExcursions
- 13 18 9 7 12 12 9 6 12 8 0.236810 104/106 RandomExcursions
- 11 15 10 7 11 14 9 6 12 11 0.595549 106/106 RandomExcursions
- 15 7 12 12 9 11 16 8 10 6 0.350485 106/106 RandomExcursions
- 10 10 12 16 10 12 10 7 13 6 0.554420 106/106 RandomExcursions
- 8 7 12 10 11 16 11 13 10 8 0.657933 106/106 RandomExcursions
- 9 6 12 12 14 9 11 13 10 10 0.816537 104/106 RandomExcursions
- 10 10 7 12 11 9 10 13 14 10 0.911413 105/106 RandomExcursions
- 8 8 12 9 10 5 13 12 17 12 0.319084 104/106 RandomExcursionsVariant
- 5 11 10 11 7 11 10 15 11 15 0.455937 104/106 RandomExcursionsVariant
- 6 12 11 8 12 12 12 13 13 7 0.699313 104/106 RandomExcursionsVariant
- 14 10 11 6 12 9 8 12 11 13 0.779188 104/106 RandomExcursionsVariant
- 12 12 10 7 17 6 6 12 13 11 0.262249 103/106 RandomExcursionsVariant
- 13 8 14 13 7 6 6 13 15 11 0.249284 102/106 RandomExcursionsVariant
- 12 12 12 13 7 9 6 13 12 10 0.739918 105/106 RandomExcursionsVariant
- 13 15 12 8 9 10 6 9 14 10 0.574903 106/106 RandomExcursionsVariant
- 10 15 9 12 14 10 8 11 7 10 0.739918 105/106 RandomExcursionsVariant
- 13 12 8 11 12 11 9 10 11 9 0.978072 103/106 RandomExcursionsVariant
- 10 13 12 12 8 13 8 9 14 7 0.739918 104/106 RandomExcursionsVariant
- 12 10 10 14 7 8 7 13 14 11 0.657933 106/106 RandomExcursionsVariant
- 10 13 10 10 13 10 12 6 10 12 0.897763 106/106 RandomExcursionsVariant
- 9 12 15 8 13 8 12 8 11 10 0.779188 106/106 RandomExcursionsVariant
- 9 13 15 10 10 10 8 14 6 11 0.616305 106/106 RandomExcursionsVariant
- 7 17 9 12 9 11 10 16 4 11 0.129620 106/106 RandomExcursionsVariant
- 10 9 10 15 7 12 7 8 12 16 0.419021 106/106 RandomExcursionsVariant
- 9 12 11 8 8 9 15 12 9 13 0.798139 106/106 RandomExcursionsVariant
- 17 34 11 22 22 17 19 20 13 25 0.026057 199/200 Serial
- 22 20 16 22 20 18 20 18 23 21 0.989786 199/200 Serial
- 12 33 25 29 21 11 21 15 14 19 0.003996 199/200 LinearComplexity
-
-
-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
-The minimum pass rate for each statistical test with the exception of the
-random excursion (variant) test is approximately = 193 for a
-sample size = 200 binary sequences.
-
-The minimum pass rate for the random excursion (variant) test
-is approximately = 101 for a sample size = 106 binary sequences.
-
-For further guidelines construct a probability table using the MAPLE program
-provided in the addendum section of the documentation.
-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
-$
diff --git a/vendor/github.com/cznic/mathutil/permute.go b/vendor/github.com/cznic/mathutil/permute.go
deleted file mode 100644
index 82ad791fd..000000000
--- a/vendor/github.com/cznic/mathutil/permute.go
+++ /dev/null
@@ -1,39 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-import (
- "sort"
-)
-
-// PermutationFirst generates the first permutation of data.
-func PermutationFirst(data sort.Interface) {
- sort.Sort(data)
-}
-
-// PermutationNext generates the next permutation of data if possible and
-// return true. Return false if there is no more permutation left. Based on
-// the algorithm described here:
-// http://en.wikipedia.org/wiki/Permutation#Generation_in_lexicographic_order
-func PermutationNext(data sort.Interface) bool {
- var k, l int
- for k = data.Len() - 2; ; k-- { // 1.
- if k < 0 {
- return false
- }
-
- if data.Less(k, k+1) {
- break
- }
- }
- for l = data.Len() - 1; !data.Less(k, l); l-- { // 2.
- }
- data.Swap(k, l) // 3.
- for i, j := k+1, data.Len()-1; i < j; i++ { // 4.
- data.Swap(i, j)
- j--
- }
- return true
-}
diff --git a/vendor/github.com/cznic/mathutil/poly.go b/vendor/github.com/cznic/mathutil/poly.go
deleted file mode 100644
index 98fed28d7..000000000
--- a/vendor/github.com/cznic/mathutil/poly.go
+++ /dev/null
@@ -1,111 +0,0 @@
-// Copyright (c) 2016 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-import (
- "fmt"
-)
-
-func abs(n int) uint64 {
- if n >= 0 {
- return uint64(n)
- }
-
- return uint64(-n)
-}
-
-// QuadPolyDiscriminant returns the discriminant of a quadratic polynomial in
-// one variable of the form a*x^2+b*x+c with integer coefficients a, b, c, or
-// an error on overflow.
-//
-// ds is the square of the discriminant. If |ds| is a square number, d is set
-// to sqrt(|ds|), otherwise d is < 0.
-func QuadPolyDiscriminant(a, b, c int) (ds, d int, _ error) {
- if 2*BitLenUint64(abs(b)) > IntBits-1 ||
- 2+BitLenUint64(abs(a))+BitLenUint64(abs(c)) > IntBits-1 {
- return 0, 0, fmt.Errorf("overflow")
- }
-
- ds = b*b - 4*a*c
- s := ds
- if s < 0 {
- s = -s
- }
- d64 := SqrtUint64(uint64(s))
- if d64*d64 != uint64(s) {
- return ds, -1, nil
- }
-
- return ds, int(d64), nil
-}
-
-// PolyFactor describes an irreducible factor of a polynomial in one variable
-// with integer coefficients P, Q of the form P*x+Q.
-type PolyFactor struct {
- P, Q int
-}
-
-// QuadPolyFactors returns the content and the irreducible factors of the
-// primitive part of a quadratic polynomial in one variable with integer
-// coefficients a, b, c of the form a*x^2+b*x+c in integers, or an error on
-// overflow.
-//
-// If the factorization in integers does not exists, the return value is (nil,
-// nil).
-//
-// See also:
-// https://en.wikipedia.org/wiki/Factorization_of_polynomials#Primitive_part.E2.80.93content_factorization
-func QuadPolyFactors(a, b, c int) (content int, primitivePart []PolyFactor, _ error) {
- content = int(GCDUint64(abs(a), GCDUint64(abs(b), abs(c))))
- switch {
- case content == 0:
- content = 1
- case content > 0:
- if a < 0 || a == 0 && b < 0 {
- content = -content
- }
- }
- a /= content
- b /= content
- c /= content
- if a == 0 {
- if b == 0 {
- return content, []PolyFactor{{0, c}}, nil
- }
-
- if b < 0 && c < 0 {
- b = -b
- c = -c
- }
- if b < 0 {
- b = -b
- c = -c
- }
- return content, []PolyFactor{{b, c}}, nil
- }
-
- ds, d, err := QuadPolyDiscriminant(a, b, c)
- if err != nil {
- return 0, nil, err
- }
-
- if ds < 0 || d < 0 {
- return 0, nil, nil
- }
-
- x1num := -b + d
- x1denom := 2 * a
- gcd := int(GCDUint64(abs(x1num), abs(x1denom)))
- x1num /= gcd
- x1denom /= gcd
-
- x2num := -b - d
- x2denom := 2 * a
- gcd = int(GCDUint64(abs(x2num), abs(x2denom)))
- x2num /= gcd
- x2denom /= gcd
-
- return content, []PolyFactor{{x1denom, -x1num}, {x2denom, -x2num}}, nil
-}
diff --git a/vendor/github.com/cznic/mathutil/primes.go b/vendor/github.com/cznic/mathutil/primes.go
deleted file mode 100644
index bd10fe6d3..000000000
--- a/vendor/github.com/cznic/mathutil/primes.go
+++ /dev/null
@@ -1,335 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-import (
- "math"
-)
-
-// IsPrimeUint16 returns true if n is prime. Typical run time is few ns.
-func IsPrimeUint16(n uint16) bool {
- return n > 0 && primes16[n-1] == 1
-}
-
-// NextPrimeUint16 returns first prime > n and true if successful or an
-// undefined value and false if there is no next prime in the uint16 limits.
-// Typical run time is few ns.
-func NextPrimeUint16(n uint16) (p uint16, ok bool) {
- return n + uint16(primes16[n]), n < 65521
-}
-
-// IsPrime returns true if n is prime. Typical run time is about 100 ns.
-//
-//TODO rename to IsPrimeUint32
-func IsPrime(n uint32) bool {
- switch {
- case n&1 == 0:
- return n == 2
- case n%3 == 0:
- return n == 3
- case n%5 == 0:
- return n == 5
- case n%7 == 0:
- return n == 7
- case n%11 == 0:
- return n == 11
- case n%13 == 0:
- return n == 13
- case n%17 == 0:
- return n == 17
- case n%19 == 0:
- return n == 19
- case n%23 == 0:
- return n == 23
- case n%29 == 0:
- return n == 29
- case n%31 == 0:
- return n == 31
- case n%37 == 0:
- return n == 37
- case n%41 == 0:
- return n == 41
- case n%43 == 0:
- return n == 43
- case n%47 == 0:
- return n == 47
- case n%53 == 0:
- return n == 53 // Benchmarked optimum
- case n < 65536:
- // use table data
- return IsPrimeUint16(uint16(n))
- default:
- mod := ModPowUint32(2, (n+1)/2, n)
- if mod != 2 && mod != n-2 {
- return false
- }
- blk := &lohi[n>>24]
- lo, hi := blk.lo, blk.hi
- for lo <= hi {
- index := (lo + hi) >> 1
- liar := liars[index]
- switch {
- case n > liar:
- lo = index + 1
- case n < liar:
- hi = index - 1
- default:
- return false
- }
- }
- return true
- }
-}
-
-// IsPrimeUint64 returns true if n is prime. Typical run time is few tens of µs.
-//
-// SPRP bases: http://miller-rabin.appspot.com
-func IsPrimeUint64(n uint64) bool {
- switch {
- case n%2 == 0:
- return n == 2
- case n%3 == 0:
- return n == 3
- case n%5 == 0:
- return n == 5
- case n%7 == 0:
- return n == 7
- case n%11 == 0:
- return n == 11
- case n%13 == 0:
- return n == 13
- case n%17 == 0:
- return n == 17
- case n%19 == 0:
- return n == 19
- case n%23 == 0:
- return n == 23
- case n%29 == 0:
- return n == 29
- case n%31 == 0:
- return n == 31
- case n%37 == 0:
- return n == 37
- case n%41 == 0:
- return n == 41
- case n%43 == 0:
- return n == 43
- case n%47 == 0:
- return n == 47
- case n%53 == 0:
- return n == 53
- case n%59 == 0:
- return n == 59
- case n%61 == 0:
- return n == 61
- case n%67 == 0:
- return n == 67
- case n%71 == 0:
- return n == 71
- case n%73 == 0:
- return n == 73
- case n%79 == 0:
- return n == 79
- case n%83 == 0:
- return n == 83
- case n%89 == 0:
- return n == 89 // Benchmarked optimum
- case n <= math.MaxUint16:
- return IsPrimeUint16(uint16(n))
- case n <= math.MaxUint32:
- return ProbablyPrimeUint32(uint32(n), 11000544) &&
- ProbablyPrimeUint32(uint32(n), 31481107)
- case n < 105936894253:
- return ProbablyPrimeUint64_32(n, 2) &&
- ProbablyPrimeUint64_32(n, 1005905886) &&
- ProbablyPrimeUint64_32(n, 1340600841)
- case n < 31858317218647:
- return ProbablyPrimeUint64_32(n, 2) &&
- ProbablyPrimeUint64_32(n, 642735) &&
- ProbablyPrimeUint64_32(n, 553174392) &&
- ProbablyPrimeUint64_32(n, 3046413974)
- case n < 3071837692357849:
- return ProbablyPrimeUint64_32(n, 2) &&
- ProbablyPrimeUint64_32(n, 75088) &&
- ProbablyPrimeUint64_32(n, 642735) &&
- ProbablyPrimeUint64_32(n, 203659041) &&
- ProbablyPrimeUint64_32(n, 3613982119)
- default:
- return ProbablyPrimeUint64_32(n, 2) &&
- ProbablyPrimeUint64_32(n, 325) &&
- ProbablyPrimeUint64_32(n, 9375) &&
- ProbablyPrimeUint64_32(n, 28178) &&
- ProbablyPrimeUint64_32(n, 450775) &&
- ProbablyPrimeUint64_32(n, 9780504) &&
- ProbablyPrimeUint64_32(n, 1795265022)
- }
-}
-
-// NextPrime returns first prime > n and true if successful or an undefined value and false if there
-// is no next prime in the uint32 limits. Typical run time is about 2 µs.
-//
-//TODO rename to NextPrimeUint32
-func NextPrime(n uint32) (p uint32, ok bool) {
- switch {
- case n < 65521:
- p16, _ := NextPrimeUint16(uint16(n))
- return uint32(p16), true
- case n >= math.MaxUint32-4:
- return
- }
-
- n++
- var d0, d uint32
- switch mod := n % 6; mod {
- case 0:
- d0, d = 1, 4
- case 1:
- d = 4
- case 2, 3, 4:
- d0, d = 5-mod, 2
- case 5:
- d = 2
- }
-
- p = n + d0
- if p < n { // overflow
- return
- }
-
- for {
- if IsPrime(p) {
- return p, true
- }
-
- p0 := p
- p += d
- if p < p0 { // overflow
- break
- }
-
- d ^= 6
- }
- return
-}
-
-// NextPrimeUint64 returns first prime > n and true if successful or an undefined value and false if there
-// is no next prime in the uint64 limits. Typical run time is in hundreds of µs.
-func NextPrimeUint64(n uint64) (p uint64, ok bool) {
- switch {
- case n < 65521:
- p16, _ := NextPrimeUint16(uint16(n))
- return uint64(p16), true
- case n >= 18446744073709551557: // last uint64 prime
- return
- }
-
- n++
- var d0, d uint64
- switch mod := n % 6; mod {
- case 0:
- d0, d = 1, 4
- case 1:
- d = 4
- case 2, 3, 4:
- d0, d = 5-mod, 2
- case 5:
- d = 2
- }
-
- p = n + d0
- if p < n { // overflow
- return
- }
-
- for {
- if ok = IsPrimeUint64(p); ok {
- break
- }
-
- p0 := p
- p += d
- if p < p0 { // overflow
- break
- }
-
- d ^= 6
- }
- return
-}
-
-// FactorTerm is one term of an integer factorization.
-type FactorTerm struct {
- Prime uint32 // The divisor
- Power uint32 // Term == Prime^Power
-}
-
-// FactorTerms represent a factorization of an integer
-type FactorTerms []FactorTerm
-
-// FactorInt returns prime factorization of n > 1 or nil otherwise.
-// Resulting factors are ordered by Prime. Typical run time is few µs.
-func FactorInt(n uint32) (f FactorTerms) {
- switch {
- case n < 2:
- return
- case IsPrime(n):
- return []FactorTerm{{n, 1}}
- }
-
- f, w := make([]FactorTerm, 9), 0
- for p := 2; p < len(primes16); p += int(primes16[p]) {
- if uint(p*p) > uint(n) {
- break
- }
-
- power := uint32(0)
- for n%uint32(p) == 0 {
- n /= uint32(p)
- power++
- }
- if power != 0 {
- f[w] = FactorTerm{uint32(p), power}
- w++
- }
- if n == 1 {
- break
- }
- }
- if n != 1 {
- f[w] = FactorTerm{n, 1}
- w++
- }
- return f[:w]
-}
-
-// PrimorialProductsUint32 returns a slice of numbers in [lo, hi] which are a
-// product of max 'max' primorials. The slice is not sorted.
-//
-// See also: http://en.wikipedia.org/wiki/Primorial
-func PrimorialProductsUint32(lo, hi, max uint32) (r []uint32) {
- lo64, hi64 := int64(lo), int64(hi)
- if max > 31 { // N/A
- max = 31
- }
-
- var f func(int64, int64, uint32)
- f = func(n, p int64, emax uint32) {
- e := uint32(1)
- for n <= hi64 && e <= emax {
- n *= p
- if n >= lo64 && n <= hi64 {
- r = append(r, uint32(n))
- }
- if n < hi64 {
- p, _ := NextPrime(uint32(p))
- f(n, int64(p), e)
- }
- e++
- }
- }
-
- f(1, 2, max)
- return
-}
diff --git a/vendor/github.com/cznic/mathutil/rat.go b/vendor/github.com/cznic/mathutil/rat.go
deleted file mode 100644
index 91b1c6fb1..000000000
--- a/vendor/github.com/cznic/mathutil/rat.go
+++ /dev/null
@@ -1,27 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-// QCmpUint32 compares a/b and c/d and returns:
-//
-// -1 if a/b < c/d
-// 0 if a/b == c/d
-// +1 if a/b > c/d
-//
-func QCmpUint32(a, b, c, d uint32) int {
- switch x, y := uint64(a)*uint64(d), uint64(b)*uint64(c); {
- case x < y:
- return -1
- case x == y:
- return 0
- default: // x > y
- return 1
- }
-}
-
-// QScaleUint32 returns a such that a/b >= c/d.
-func QScaleUint32(b, c, d uint32) (a uint64) {
- return 1 + (uint64(b)*uint64(c))/uint64(d)
-}
diff --git a/vendor/github.com/cznic/mathutil/rnd.go b/vendor/github.com/cznic/mathutil/rnd.go
deleted file mode 100644
index 9132dc0d5..000000000
--- a/vendor/github.com/cznic/mathutil/rnd.go
+++ /dev/null
@@ -1,383 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-import (
- "fmt"
- "math"
- "math/big"
-)
-
-// FC32 is a full cycle PRNG covering the 32 bit signed integer range.
-// In contrast to full cycle generators shown at e.g. http://en.wikipedia.org/wiki/Full_cycle,
-// this code doesn't produce values at constant delta (mod cycle length).
-// The 32 bit limit is per this implementation, the algorithm used has no intrinsic limit on the cycle size.
-// Properties include:
-// - Adjustable limits on creation (hi, lo).
-// - Positionable/randomly accessible (Pos, Seek).
-// - Repeatable (deterministic).
-// - Can run forward or backward (Next, Prev).
-// - For a billion numbers cycle the Next/Prev PRN can be produced in cca 100-150ns.
-// That's like 5-10 times slower compared to PRNs generated using the (non FC) rand package.
-type FC32 struct {
- cycle int64 // On average: 3 * delta / 2, (HQ: 2 * delta)
- delta int64 // hi - lo
- factors [][]int64 // This trades some space for hopefully a bit of speed (multiple adding vs multiplying).
- lo int
- mods []int // pos % set
- pos int64 // Within cycle.
- primes []int64 // Ordered. ∏ primes == cycle.
- set []int64 // Reordered primes (magnitude order bases) according to seed.
-}
-
-// NewFC32 returns a newly created FC32 adjusted for the closed interval [lo, hi] or an Error if any.
-// If hq == true then trade some generation time for improved (pseudo)randomness.
-func NewFC32(lo, hi int, hq bool) (r *FC32, err error) {
- if lo > hi {
- return nil, fmt.Errorf("invalid range %d > %d", lo, hi)
- }
-
- if uint64(hi)-uint64(lo) > math.MaxUint32 {
- return nil, fmt.Errorf("range out of int32 limits %d, %d", lo, hi)
- }
-
- delta := int64(hi) - int64(lo)
- // Find the primorial covering whole delta
- n, set, p := int64(1), []int64{}, uint32(2)
- if hq {
- p++
- }
- for {
- set = append(set, int64(p))
- n *= int64(p)
- if n > delta {
- break
- }
- p, _ = NextPrime(p)
- }
-
- // Adjust the set so n ∊ [delta, 2 * delta] (HQ: [delta, 3 * delta])
- // while keeping the cardinality of the set (correlates with the statistic "randomness quality")
- // at max, i.e. discard atmost one member.
- i := -1 // no candidate prime
- if n > 2*(delta+1) {
- for j, p := range set {
- q := n / p
- if q < delta+1 {
- break
- }
-
- i = j // mark the highest candidate prime set index
- }
- }
- if i >= 0 { // shrink the inner cycle
- n = n / set[i]
- set = delete(set, i)
- }
- r = &FC32{
- cycle: n,
- delta: delta,
- factors: make([][]int64, len(set)),
- lo: lo,
- mods: make([]int, len(set)),
- primes: set,
- }
- r.Seed(1) // the default seed should be always non zero
- return
-}
-
-// Cycle reports the length of the inner FCPRNG cycle.
-// Cycle is atmost the double (HQ: triple) of the generator period (hi - lo + 1).
-func (r *FC32) Cycle() int64 {
- return r.cycle
-}
-
-// Next returns the first PRN after Pos.
-func (r *FC32) Next() int {
- return r.step(1)
-}
-
-// Pos reports the current position within the inner cycle.
-func (r *FC32) Pos() int64 {
- return r.pos
-}
-
-// Prev return the first PRN before Pos.
-func (r *FC32) Prev() int {
- return r.step(-1)
-}
-
-// Seed uses the provided seed value to initialize the generator to a deterministic state.
-// A zero seed produces a "canonical" generator with worse randomness than for most non zero seeds.
-// Still, the FC property holds for any seed value.
-func (r *FC32) Seed(seed int64) {
- u := uint64(seed)
- r.set = mix(r.primes, &u)
- n := int64(1)
- for i, p := range r.set {
- k := make([]int64, p)
- v := int64(0)
- for j := range k {
- k[j] = v
- v += n
- }
- n *= p
- r.factors[i] = mix(k, &u)
- }
-}
-
-// Seek sets Pos to |pos| % Cycle.
-func (r *FC32) Seek(pos int64) { //vet:ignore
- if pos < 0 {
- pos = -pos
- }
- pos %= r.cycle
- r.pos = pos
- for i, p := range r.set {
- r.mods[i] = int(pos % p)
- }
-}
-
-func (r *FC32) step(dir int) int {
- for { // avg loops per step: 3/2 (HQ: 2)
- y := int64(0)
- pos := r.pos
- pos += int64(dir)
- switch {
- case pos < 0:
- pos = r.cycle - 1
- case pos >= r.cycle:
- pos = 0
- }
- r.pos = pos
- for i, mod := range r.mods {
- mod += dir
- p := int(r.set[i])
- switch {
- case mod < 0:
- mod = p - 1
- case mod >= p:
- mod = 0
- }
- r.mods[i] = mod
- y += r.factors[i][mod]
- }
- if y <= r.delta {
- return int(y) + r.lo
- }
- }
-}
-
-func delete(set []int64, i int) (y []int64) {
- for j, v := range set {
- if j != i {
- y = append(y, v)
- }
- }
- return
-}
-
-func mix(set []int64, seed *uint64) (y []int64) {
- for len(set) != 0 {
- *seed = rol(*seed)
- i := int(*seed % uint64(len(set)))
- y = append(y, set[i])
- set = delete(set, i)
- }
- return
-}
-
-func rol(u uint64) (y uint64) {
- y = u << 1
- if int64(u) < 0 {
- y |= 1
- }
- return
-}
-
-// FCBig is a full cycle PRNG covering ranges outside of the int32 limits.
-// For more info see the FC32 docs.
-// Next/Prev PRN on a 1e15 cycle can be produced in about 2 µsec.
-type FCBig struct {
- cycle *big.Int // On average: 3 * delta / 2, (HQ: 2 * delta)
- delta *big.Int // hi - lo
- factors [][]*big.Int // This trades some space for hopefully a bit of speed (multiple adding vs multiplying).
- lo *big.Int
- mods []int // pos % set
- pos *big.Int // Within cycle.
- primes []int64 // Ordered. ∏ primes == cycle.
- set []int64 // Reordered primes (magnitude order bases) according to seed.
-}
-
-// NewFCBig returns a newly created FCBig adjusted for the closed interval [lo, hi] or an Error if any.
-// If hq == true then trade some generation time for improved (pseudo)randomness.
-func NewFCBig(lo, hi *big.Int, hq bool) (r *FCBig, err error) {
- if lo.Cmp(hi) > 0 {
- return nil, fmt.Errorf("invalid range %d > %d", lo, hi)
- }
-
- delta := big.NewInt(0)
- delta.Add(delta, hi).Sub(delta, lo)
-
- // Find the primorial covering whole delta
- n, set, pp, p := big.NewInt(1), []int64{}, big.NewInt(0), uint32(2)
- if hq {
- p++
- }
- for {
- set = append(set, int64(p))
- pp.SetInt64(int64(p))
- n.Mul(n, pp)
- if n.Cmp(delta) > 0 {
- break
- }
- p, _ = NextPrime(p)
- }
-
- // Adjust the set so n ∊ [delta, 2 * delta] (HQ: [delta, 3 * delta])
- // while keeping the cardinality of the set (correlates with the statistic "randomness quality")
- // at max, i.e. discard atmost one member.
- dd1 := big.NewInt(1)
- dd1.Add(dd1, delta)
- dd2 := big.NewInt(0)
- dd2.Lsh(dd1, 1)
- i := -1 // no candidate prime
- if n.Cmp(dd2) > 0 {
- q := big.NewInt(0)
- for j, p := range set {
- pp.SetInt64(p)
- q.Set(n)
- q.Div(q, pp)
- if q.Cmp(dd1) < 0 {
- break
- }
-
- i = j // mark the highest candidate prime set index
- }
- }
- if i >= 0 { // shrink the inner cycle
- pp.SetInt64(set[i])
- n.Div(n, pp)
- set = delete(set, i)
- }
- r = &FCBig{
- cycle: n,
- delta: delta,
- factors: make([][]*big.Int, len(set)),
- lo: lo,
- mods: make([]int, len(set)),
- pos: big.NewInt(0),
- primes: set,
- }
- r.Seed(1) // the default seed should be always non zero
- return
-}
-
-// Cycle reports the length of the inner FCPRNG cycle.
-// Cycle is atmost the double (HQ: triple) of the generator period (hi - lo + 1).
-func (r *FCBig) Cycle() *big.Int {
- return r.cycle
-}
-
-// Next returns the first PRN after Pos.
-func (r *FCBig) Next() *big.Int {
- return r.step(1)
-}
-
-// Pos reports the current position within the inner cycle.
-func (r *FCBig) Pos() *big.Int {
- return r.pos
-}
-
-// Prev return the first PRN before Pos.
-func (r *FCBig) Prev() *big.Int {
- return r.step(-1)
-}
-
-// Seed uses the provided seed value to initialize the generator to a deterministic state.
-// A zero seed produces a "canonical" generator with worse randomness than for most non zero seeds.
-// Still, the FC property holds for any seed value.
-func (r *FCBig) Seed(seed int64) {
- u := uint64(seed)
- r.set = mix(r.primes, &u)
- n := big.NewInt(1)
- v := big.NewInt(0)
- pp := big.NewInt(0)
- for i, p := range r.set {
- k := make([]*big.Int, p)
- v.SetInt64(0)
- for j := range k {
- k[j] = big.NewInt(0)
- k[j].Set(v)
- v.Add(v, n)
- }
- pp.SetInt64(p)
- n.Mul(n, pp)
- r.factors[i] = mixBig(k, &u)
- }
-}
-
-// Seek sets Pos to |pos| % Cycle.
-func (r *FCBig) Seek(pos *big.Int) {
- r.pos.Set(pos)
- r.pos.Abs(r.pos)
- r.pos.Mod(r.pos, r.cycle)
- mod := big.NewInt(0)
- pp := big.NewInt(0)
- for i, p := range r.set {
- pp.SetInt64(p)
- r.mods[i] = int(mod.Mod(r.pos, pp).Int64())
- }
-}
-
-func (r *FCBig) step(dir int) (y *big.Int) {
- y = big.NewInt(0)
- d := big.NewInt(int64(dir))
- for { // avg loops per step: 3/2 (HQ: 2)
- r.pos.Add(r.pos, d)
- switch {
- case r.pos.Sign() < 0:
- r.pos.Add(r.pos, r.cycle)
- case r.pos.Cmp(r.cycle) >= 0:
- r.pos.SetInt64(0)
- }
- for i, mod := range r.mods {
- mod += dir
- p := int(r.set[i])
- switch {
- case mod < 0:
- mod = p - 1
- case mod >= p:
- mod = 0
- }
- r.mods[i] = mod
- y.Add(y, r.factors[i][mod])
- }
- if y.Cmp(r.delta) <= 0 {
- y.Add(y, r.lo)
- return
- }
- y.SetInt64(0)
- }
-}
-
-func deleteBig(set []*big.Int, i int) (y []*big.Int) {
- for j, v := range set {
- if j != i {
- y = append(y, v)
- }
- }
- return
-}
-
-func mixBig(set []*big.Int, seed *uint64) (y []*big.Int) {
- for len(set) != 0 {
- *seed = rol(*seed)
- i := int(*seed % uint64(len(set)))
- y = append(y, set[i])
- set = deleteBig(set, i)
- }
- return
-}
diff --git a/vendor/github.com/cznic/mathutil/tables.go b/vendor/github.com/cznic/mathutil/tables.go
deleted file mode 100644
index f32952c00..000000000
--- a/vendor/github.com/cznic/mathutil/tables.go
+++ /dev/null
@@ -1,6995 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// "Static" data
-
-package mathutil
-
-var (
- // Set bits count in a byte
- popcnt = [256]byte{
- 0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4, // 0
- 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, // 1
- 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, // 2
- 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, // 3
- 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, // 4
- 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, // 5
- 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, // 6
- 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, // 7
- 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, // 8
- 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, // 9
- 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, // 10
- 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, // 11
- 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, // 12
- 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, // 13
- 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, // 14
- 4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8, // 15
- }
-
- // Highest set bit index in a byte
- log2 = [256]int{
- -1, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, // 0
-
- 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, // 1
-
- 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, // 2
- 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, // 3
-
- 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, // 4
- 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, // 5
- 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, // 6
- 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, // 7
-
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 8
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 9
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 10
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 11
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 12
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 13
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 14
- 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // 15
- }
-
- // "Predivisors": 2-53
- liars = [3660]uint32{
- 31621, 42799, 49141, 49981, 65077, 65281, 80581, 83333, 88357, 90751,
- 104653, 130561, 164737, 188057, 194221, 196093, 215749, 219781, 220729, 253241,
- 256999, 271951, 280601, 282133, 357761, 390937, 458989, 486737, 489997, 514447,
- 580337, 587861, 611701, 647089, 653333, 657901, 665281, 665333, 688213, 710533,
- 721801, 722261, 738541, 741751, 742813, 745889, 769757, 818201, 838861, 873181,
- 877099, 916327, 976873, 983401, 1016801, 1018921, 1053761, 1064053, 1073021, 1082401,
- 1109461, 1132657, 1145257, 1168513, 1194649, 1207361, 1251949, 1252697, 1302451, 1325843,
- 1357441, 1373653, 1397419, 1441091, 1493857, 1507963, 1509709, 1530787, 1584133, 1678541,
- 1690501, 1730977, 1735841, 1811573, 1876393, 1969417, 1987021, 2004403, 2081713, 2163001,
- 2181961, 2205967, 2261953, 2264369, 2269093, 2284453, 2304167, 2387797, 2487941, 2510569,
- 2670361, 2746477, 2748023, 2757241, 2811271, 2909197, 2944261, 2976487, 3048841, 3090091,
- 3116107, 3125281, 3225601, 3363121, 3375041, 3400013, 3413533, 3429037, 3539101, 3542533,
- 3567481, 3568661, 3605429, 3656449, 3763801, 3828001, 3898129, 3911197, 3985921, 4072729,
- 4181921, 4188889, 4209661, 4360621, 4469471, 4480477, 4513841, 4835209, 4863127, 4869313,
- 4877641, 4922413, 5016191, 5044033, 5095177, 5173169, 5173601, 5176153, 5256091, 5271841,
- 5284333, 5351537, 5489641, 5590621, 5672041, 5919187, 6027193, 6118141, 6140161, 6159301,
- 6189121, 6226193, 6233977, 6236257, 6278533, 6334351, 6368689, 6386993, 6631549, 6658669,
- 6779137, 6787327, 6836233, 6952037, 6955541, 6998881, 7017193, 7232321, 7306261, 7306561,
- 7429117, 7462001, 7674967, 7725901, 7759937, 7820201, 7883731, 8036033, 8095447, 8239477,
- 8384513, 8534233, 8725753, 8727391, 8902741, 9006401, 9056501, 9073513, 9131401, 9345541,
- 9371251, 9439201, 9480461, 9533701, 9564169, 9567673, 9588151, 9591661, 9729301, 9774181,
- 9863461, 10024561, 10084177, 10323769, 10331141, 10386241, 10425511, 10610063, 10700761, 10712857,
- 10763653, 10974881, 11081459, 11115037, 11335501, 11541307, 11585293, 11592397, 11777599, 12032021,
- 12096613, 12263131, 12322133, 12327121, 12599233, 12854437, 13057787, 13338371, 13446253, 13500313,
- 13635289, 13694761, 13747361, 13773061, 14026897, 14154337, 14179537, 14324473, 14469841, 14671801,
- 14676481, 14709241, 14794081, 14796289, 14865121, 15101893, 15139199, 15162941, 15188557, 15220951,
- 15247621, 15479777, 15525241, 15603391, 15621409, 15700301, 15802681, 15976747, 15978007, 16070429,
- 16132321, 16149169, 16153633, 16324001, 16349477, 16360381, 16705021, 16773121, 16822081, 16843009,
- 16853077, 16879501, 16973393, 17098369, 17116837, 17134043, 17208601, 17236801, 17327773, 17375249,
- 17405537, 17585969, 17870561, 18067501, 18073817, 18366937, 18443701, 18454921, 18535177, 18653353,
- 18740971, 19328653, 19384289, 19404139, 19471033, 19607561, 20261251, 20417311, 20647621, 20968501,
- 21042001, 21303343, 21306157, 21359521, 21397381, 21400481, 21623659, 21654533, 22075579, 22087477,
- 22369621, 22591301, 22669501, 22711873, 22849481, 22953673, 23247901, 23382529, 23464033, 23577497,
- 23634181, 23734901, 23828017, 23872213, 23963869, 24214051, 24356377, 25080101, 25150501, 25276421,
- 25326001, 25457833, 25629913, 25696133, 25768261, 25909453, 26280073, 26377921, 26821601, 26840269,
- 26877421, 26886817, 27108397, 27118601, 27219697, 27271151, 27279409, 27331921, 27380831, 27392041,
- 27409541, 27491237, 27509653, 27664033, 27798461, 27808463, 28325881, 28527049, 28572961, 29111881,
- 29214541, 29581501, 30022129, 30090817, 30185569, 30219757, 30295141, 30338593, 30388753, 30418957,
- 30576151, 30662497, 30740417, 30881551, 30894307, 31040833, 31166803, 31436123, 31735621, 31759121,
- 32091781, 32095057, 32168117, 32285041, 32497921, 32676481, 33146717, 33298337, 33600533, 33627301,
- 33704101, 33872593, 34003061, 34043101, 34124641, 34540801, 34856167, 34944001, 35576599, 35703361,
- 35820937, 35851037, 36291193, 36307981, 36861901, 36919681, 36974341, 37109467, 37376509, 37439201,
- 37964809, 37988497, 38010307, 38046817, 38118763, 38210323, 39465091, 39512773, 39655153, 39684157,
- 40165093, 40238797, 40315441, 40361197, 40629601, 40782589, 40827473, 40987201, 41121433, 41568101,
- 41604109, 41642681, 41662297, 41840809, 42009217, 42485119, 42623017, 42984589, 43224397, 43363601,
- 43661257, 44070841, 44314129, 44465221, 44482901, 45100177, 45175201, 45219329, 45414433, 45819541,
- 45879941, 46094401, 46325029, 46386589, 46469809, 46517857, 46679761, 46860001, 47220367, 47903701,
- 47918581, 48064021, 48191653, 48269761, 48316969, 48400753, 48448661, 48551161, 48563089, 49075417,
- 49303801, 49411801, 49459801, 50155733, 50201089, 50443201, 50523661, 51030601, 51129781, 51302353,
- 51500521, 52072021, 52119289, 52204237, 53283169, 53399449, 53656021, 53675623, 53695721, 53711113,
- 54029741, 54449431, 55109401, 55176097, 55318957, 55729957, 56052361, 56420033, 56479897, 56810137,
- 57762433, 58003213, 58422409, 58449847, 58509977, 58679941, 58755877, 59631211, 59840537, 59913157,
- 59953741, 60155201, 60352921, 60547831, 60566431, 60581401, 60696661, 60738257, 60957361, 61201009,
- 61219789, 61377109, 61832377, 62756641, 63001801, 63002501, 63065281, 63167743, 63318169, 63328469,
- 63346999, 63388033, 64148717, 64605041, 64735897, 65144501, 65254393, 65301013, 65350801, 65359477,
- 66096253, 67194401, 67642513, 67928221, 68102641, 68154001, 68165761, 68512867, 68621701, 68839597,
- 69030901, 69128641, 69176647, 69228967, 69231061, 69485281, 69612061, 69885649, 70149631, 70463489,
- 70593931, 70728121, 71079661, 71734417, 72498253, 72543547, 73562833, 73645001, 74411131, 74927161,
- 75140137, 75565873, 76725091, 76745101, 77533123, 77648941, 77812153, 77817979, 78939089, 79398901,
- 79411201, 79417801, 79464533, 79786523, 80142761, 80146909, 80375707, 80556337, 80687881, 80891009,
- 81433591, 81954133, 82273201, 82506439, 82870517, 82929001, 83083001, 83103329, 83204801, 84164033,
- 84350561, 84421081, 84487457, 84998503, 85328717, 85519337, 85823401, 86027329, 86438857, 86530621,
- 86999837, 87499651, 87694261, 88256449, 88368853, 88661861, 89308771, 89784581, 90270613, 90278161,
- 90341197, 90665789, 90698401, 91433281, 91659283, 92438581, 92625121, 93431521, 93541537, 93571633,
- 93643201, 93677761, 93926197, 94316401, 94502701, 95451361, 95452781, 96135601, 96618397, 96791881,
- 96888641, 96895441, 96904081, 96925921, 97255801, 97496449, 97796953, 97863529, 97924217, 99036001,
- 99115297, 99486889, 99789673, 99898801, 100463443, 100618933, 100943201, 101152133, 101218921, 101270251,
- 101276579, 101649241, 102004421, 102678031, 102690677, 102690901, 103301633, 104078857, 104524421, 104988673,
- 105305443, 105919633, 106485121, 106622353, 106743073, 107360641, 107543333, 108596953, 109231229, 109437751,
- 109541461, 109879837, 110135821, 110139499, 110312773, 110413333, 110717861, 111370141, 111654401, 112032001,
- 112402981, 112828801, 113589601, 113605201, 113730481, 113892589, 114305441, 114329881, 114701341, 114842677,
- 114910489, 115039081, 115174681, 115497901, 115804501, 115873801, 116090081, 116321617, 116617289, 116682721,
- 116696161, 116998669, 117987841, 118466401, 118901521, 119092801, 119204809, 119261113, 119327041, 119558011,
- 119743537, 119940853, 120296677, 120517021, 120838609, 121062001, 121374241, 121472359, 121609489, 122166307,
- 122396737, 122941981, 123481777, 123671671, 123877081, 123987793, 124145473, 124630273, 124818601, 125284141,
- 125686241, 125848577, 126132553, 127050067, 128079409, 128124151, 128396921, 128468957, 128665319, 128987429,
- 129205781, 129256273, 129357061, 129461617, 129524669, 130556329, 130693393, 130944133, 131023201, 131567929,
- 131938561, 132332201, 132338881, 132440521, 132575071, 133216381, 133302781, 133467517, 133800661, 134696801,
- 134767153, 134868029, 135263269, 135296053, 135308881, 135945853, 135969401, 136043641, 136661201, 136722433,
- 137415821, 137763037, 138030721, 138403981, 138828821, 139295701, 139487041, 140197051, 142525333, 142922413,
- 143106133, 143168581, 145348529, 146156617, 146272901, 146659801, 146843929, 146884393, 147028001, 147287141,
- 148109473, 148171769, 148910653, 149389633, 150379693, 150960239, 150988753, 151533377, 151589881, 152716537,
- 152922001, 152991841, 153369061, 153589801, 153754873, 153928133, 154287451, 154513633, 154944533, 155203361,
- 156114061, 156532799, 157069189, 157368661, 157405249, 157725829, 158068153, 158192317, 158397247, 158496911,
- 158544401, 158895281, 160348189, 160378861, 160491329, 160587841, 160672201, 160730389, 161184013, 161216021,
- 161289649, 161304001, 161423377, 162026869, 162067441, 162690481, 162771337, 162776041, 163442551, 163954561,
- 164111281, 165061909, 165224321, 165938653, 166082309, 166339057, 166406561, 166827943, 167579497, 167582377,
- 167692141, 167881121, 168566501, 169655641, 170640961, 170782921, 170856533, 171454321, 172116181, 172436713,
- 172947529, 173401621, 174479729, 176030977, 176597821, 176609441, 176977921, 177167233, 177254533, 177693521,
- 177927641, 177951973, 178837201, 178956971, 179083601, 179285137, 179820257, 180115489, 180497633, 180703451,
- 181285001, 181285537, 181542601, 181647497, 182383111, 183677341, 184411567, 185653333, 186183469, 186393481,
- 186983521, 187050529, 187667969, 187761241, 188516329, 188985961, 189714193, 189738361, 189941761, 190212181,
- 190382161, 190913297, 191233813, 191648161, 191981609, 192346153, 192857761, 193330237, 193638337, 193949641,
- 194556451, 196035001, 196049701, 196231393, 198982759, 199674721, 200143351, 200753281, 201261061, 202130197,
- 202156813, 202538857, 203505697, 204280501, 204582457, 204766381, 205057561, 206304961, 206453509, 206504033,
- 206529737, 207008569, 207030541, 207132481, 207477001, 207618781, 208051201, 208969223, 209246701, 209404369,
- 209990881, 210592873, 210842113, 213035761, 214038533, 214110541, 214852609, 214858717, 215436241, 216821881,
- 217123069, 217875571, 218603617, 218642029, 218947121, 219621781, 220531501, 220883521, 221368153, 221415781,
- 221884001, 222010721, 222630193, 223449463, 223625851, 223782263, 224074369, 224136013, 224769241, 224957893,
- 225853633, 226359547, 226450297, 227132641, 227444101, 227475481, 228652201, 228842209, 228988033, 229589413,
- 230357761, 231383461, 231405701, 231927781, 232114433, 232460821, 232771501, 233110081, 234869009, 235426913,
- 235928071, 237791143, 238001653, 238833421, 240068041, 240371713, 240694513, 240785047, 241505377, 242067841,
- 242650717, 242860069, 243583201, 243955141, 244883981, 245006623, 245950561, 246099317, 246282511, 246434761,
- 246658441, 247318957, 247321301, 247416101, 249582481, 250436033, 250958401, 250988173, 251528401, 251663837,
- 251855893, 252853921, 253610281, 253893397, 255416897, 256831433, 257590661, 258020473, 258043229, 258234401,
- 258944401, 259763093, 259765747, 260156101, 260518801, 260736341, 260963389, 261186001, 261703417, 262979501,
- 263428181, 264269449, 264384469, 265020001, 265584133, 265735969, 265836161, 266790481, 266925601, 270525737,
- 271272569, 271763467, 271826629, 271950829, 273361789, 273480637, 274701913, 274810241, 274919401, 275283401,
- 275619961, 276018913, 276131137, 276542401, 276638321, 277787141, 278943061, 279377281, 280885153, 282253141,
- 282471853, 282769771, 283900961, 284166877, 284301751, 284736091, 284834299, 285820501, 286316801, 287160301,
- 287449091, 287715121, 288099001, 288117721, 288735277, 290643601, 290706781, 290953921, 291088513, 291461633,
- 292153681, 292290181, 292433321, 292902481, 293346637, 293847721, 293938261, 295419097, 295743017, 297624961,
- 297798961, 298212601, 299367877, 299736181, 301413001, 302635351, 304080001, 307629401, 307694323, 307972801,
- 308483209, 309666361, 310474249, 310978027, 311177213, 311411629, 311655829, 311671361, 312408113, 312614021,
- 314184487, 315034513, 315351521, 317137969, 317365933, 317641171, 317796119, 319053281, 319374577, 319440769,
- 319726177, 320326003, 321324589, 321850849, 322469701, 322941881, 324477697, 325028089, 325352101, 325546873,
- 326266051, 326405713, 326469137, 326628721, 326694301, 326695141, 327073601, 327093409, 327398009, 328302901,
- 329153653, 329769721, 330198331, 330759617, 331658081, 331934989, 337135501, 337420679, 337665901, 337783981,
- 338125537, 338458807, 338914369, 339195097, 339492169, 339794641, 341958121, 341994131, 343017529, 343052833,
- 344201441, 344255551, 344776301, 346080391, 348989101, 349752913, 350031973, 350244577, 351058753, 351177769,
- 352802803, 352932337, 353815801, 353932801, 354062809, 356604421, 356836819, 357348601, 357872971, 358416577,
- 359394751, 359727073, 360145633, 360375181, 360787771, 361307521, 361312337, 362569201, 363170837, 363430637,
- 364550761, 365077373, 365231401, 366487201, 366532321, 366652201, 367559501, 367632301, 368016949, 368476501,
- 369667561, 371011801, 371611153, 372167101, 373012777, 373533617, 373669453, 373906513, 374346361, 374988661,
- 376957153, 377192353, 377334497, 377458849, 377806687, 377869031, 378792649, 379732501, 380137633, 382304161,
- 384100001, 385175113, 385319089, 387072661, 388695301, 390609941, 390612221, 391014937, 392679737, 393611653,
- 394723177, 396864469, 399156661, 399302581, 399647221, 400385701, 400557109, 401100881, 403095967, 403293313,
- 405739681, 405782623, 407737201, 407889161, 409302001, 409458241, 410613809, 410680357, 411618241, 411851389,
- 412836689, 413138881, 413429801, 413778817, 414216461, 414368641, 415200361, 415204501, 415476343, 416964241,
- 417767201, 417779909, 418044563, 418226581, 418616161, 418617281, 418667401, 419184481, 420607441, 421942951,
- 422429041, 422928101, 423384001, 423465001, 424175761, 424411501, 424431541, 425967301, 426174101, 426219649,
- 426770437, 426783811, 427294141, 428180191, 428758201, 429135841, 429509837, 430046857, 430381921, 430646401,
- 430733701, 432227449, 434042801, 435016187, 435358657, 435993301, 436465501, 437247841, 437462101, 437597101,
- 437866087, 439309261, 441354497, 441650591, 441758461, 442050577, 442181291, 442543553, 444660421, 445429693,
- 446414621, 446619617, 449501761, 450807481, 450866021, 450872573, 452990401, 453366029, 453967739, 454745773,
- 455198563, 457274161, 457320533, 459785089, 460251733, 460585861, 461151121, 461272267, 461329601, 462587329,
- 462639409, 462701513, 464012033, 464955857, 465505633, 466290949, 466758181, 467100937, 468410113, 468950021,
- 470120257, 470268137, 470644021, 471535373, 471664513, 472814413, 473581057, 474892741, 474970501, 474983881,
- 475723849, 478614067, 479962009, 480668347, 481153501, 481239361, 482488393, 482824669, 482921297, 483006889,
- 483029821, 483945601, 484200289, 486063001, 486902929, 487896601, 488104681, 488169289, 488585521, 488656981,
- 489994201, 490950461, 491738801, 493108481, 494288677, 495909871, 496109729, 496560349, 497148599, 497285713,
- 498662561, 498706651, 498905189, 500747293, 501172241, 501472333, 502686713, 504870241, 505473263, 505532773,
- 505798213, 506349421, 507142567, 507323521, 508606771, 509302873, 509551201, 510925609, 511098521, 511215521,
- 511611673, 512330281, 514738981, 516045197, 516259657, 516764063, 517662001, 518216201, 518548801, 521501473,
- 522390109, 522758233, 523756711, 526067821, 526359289, 526686889, 528013333, 528043753, 528220117, 530630701,
- 531095029, 531681281, 532126801, 532758241, 532800133, 533429881, 534782293, 535252867, 535428577, 535517581,
- 536003333, 536114197, 536342419, 536870911, 540207097, 540621181, 540654409, 540680141, 542497201, 542536457,
- 544861633, 545550433, 545622401, 546102481, 546117301, 546322201, 548080513, 548989561, 549308761, 550132741,
- 550230409, 550635373, 550853137, 551313001, 552573793, 553027201, 554487121, 554599051, 554964001, 555321007,
- 555465601, 556001377, 556069849, 556095433, 556114609, 557165209, 558235109, 558900821, 558977761, 561448487,
- 562367821, 563298061, 563947141, 564298489, 564689381, 565664761, 565707061, 567358513, 567596401, 568902001,
- 568967221, 569332177, 569495809, 570941881, 572123521, 572228929, 572430769, 572567353, 572936869, 573817861,
- 573862021, 574998841, 575326033, 576724219, 577210181, 577352641, 577613261, 579606301, 579956653, 581618143,
- 582389641, 582799951, 585261637, 586706821, 587343541, 588049001, 591242653, 591822001, 592467451, 592468777,
- 593682169, 593728489, 595405201, 595590841, 597537361, 597717121, 599135767, 599945293, 600893921, 601606487,
- 602379181, 604584221, 605454917, 605961049, 606872449, 607148653, 607750681, 608421637, 608917753, 609361567,
- 609813781, 611097401, 611374453, 611770513, 611812321, 611817421, 612006253, 613849601, 614742241, 615361183,
- 615760133, 615895897, 616280897, 617087701, 619239457, 619365121, 619480601, 620169409, 620544961, 620755537,
- 621769669, 622137601, 623735953, 624303241, 624732421, 625060801, 625482001, 626717471, 627886657, 628868467,
- 629134081, 630496621, 630622753, 630811513, 631767943, 631974613, 633289807, 635155291, 635291077, 635319361,
- 636287653, 636337073, 636936697, 638502913, 638837761, 639305921, 639807781, 640650931, 640977373, 643036321,
- 643316461, 643552909, 644004817, 644453633, 644457551, 644731357, 644900257, 645556481, 648056449, 648328801,
- 651011329, 651064681, 651151801, 651514753, 652469641, 653235841, 653260633, 655264369, 657732349, 659526601,
- 659846021, 660095641, 660754117, 661122881, 661207177, 662134201, 663760681, 665462081, 668498321, 670976641,
- 670987021, 671716921, 672103001, 672108193, 673778827, 675260477, 676359391, 678481693, 680983817, 681019921,
- 681124207, 681303241, 682528687, 683316001, 683362681, 684350833, 686059921, 687741401, 689537441, 690035713,
- 690562601, 691131349, 692535637, 693456521, 694116893, 696042901, 696321949, 696998251, 697821857, 698192041,
- 698819711, 702683101, 705303457, 705351583, 706728377, 707691601, 709409993, 710382401, 710617861, 710721001,
- 714490481, 717096641, 717653129, 717831211, 720767521, 722955773, 724160251, 724969087, 725508241, 731276521,
- 732805681, 734166217, 736668013, 739444021, 739576801, 740988151, 741182401, 741214237, 742017181, 742550401,
- 744500641, 745493761, 745745461, 746331041, 747406801, 748638001, 749172821, 749640161, 750632137, 751226401,
- 751705597, 752186593, 753233717, 753574537, 753594001, 754020361, 754874257, 756205633, 756271909, 756980137,
- 758581651, 758687581, 758901701, 759252367, 759266621, 759638881, 762699649, 763907741, 764033999, 764240611,
- 765378241, 766303693, 766823797, 770201221, 770909107, 770937931, 771043201, 771337891, 772495777, 773131927,
- 773807401, 775368901, 775896181, 776443769, 777218989, 781471001, 782823281, 784450393, 784777393, 784783477,
- 784966297, 787085857, 787209277, 788046901, 788931361, 789082001, 790453049, 791118043, 792144161, 792145729,
- 794201333, 794399041, 794937601, 795064909, 796072003, 796200901, 796560703, 797418997, 797834017, 799162561,
- 799630753, 799898833, 799916101, 801093011, 801227269, 801866647, 804978721, 805505957, 805771501, 807115753,
- 807218413, 808214161, 809790881, 810023881, 810455101, 811110301, 811478533, 811607777, 811730923, 815430533,
- 815796413, 816024161, 816215401, 816549121, 817832329, 818401321, 819466201, 819743233, 822018961, 822531841,
- 824389441, 826004467, 829512001, 830664451, 831933901, 832048447, 832127489, 832169857, 833610751, 837766217,
- 839268139, 839280691, 839908217, 840749761, 841217653, 841660961, 842785841, 842824981, 842960981, 843161887,
- 844545271, 845376533, 846961321, 848090377, 848755969, 849548671, 852432769, 854094781, 854868257, 855734401,
- 857100421, 857902861, 858687103, 859096477, 860334301, 862082677, 862678081, 863196181, 863609113, 863984881,
- 865242841, 867022747, 867110501, 867638201, 868088341, 868111597, 868691401, 870985223, 871157233, 871195561,
- 871908481, 876850801, 877542481, 878492941, 878940833, 879995689, 880870513, 880922657, 883276549, 884304037,
- 884952001, 886180429, 887795221, 888868441, 892740853, 893692819, 894264337, 896901461, 897087361, 897283213,
- 899019353, 900736411, 901848301, 902566501, 903108821, 903390643, 905040953, 907378669, 907670501, 907711561,
- 908005249, 910202509, 910867481, 911484421, 914348737, 914906539, 920375821, 920696653, 921858631, 922845241,
- 923437213, 926756881, 927106561, 927877001, 929159941, 930530701, 932148253, 933729421, 935794081, 936421141,
- 937675393, 938376181, 939947009, 940123801, 941056273, 941734657, 943271569, 944832533, 946034057, 946787377,
- 947878081, 949317217, 949697233, 952893881, 954924013, 957600541, 957631249, 958131157, 958735681, 960269377,
- 960946321, 962442001, 962489557, 962523169, 964412837, 965501857, 967266451, 967287751, 967790401, 968283247,
- 968413217, 968751241, 969528337, 970586713, 971975071, 974113601, 974471243, 974774401, 975576281, 976396961,
- 977483449, 979363153, 980056507, 980725201, 981484561, 983456377, 984133441, 984252001, 985052881, 985075681,
- 987842101, 994133479, 995586373, 995650921, 997836841, 998489017, 998590601, 998596741, 998724481, 999828727,
- 1002261781, 1003062061, 1005402133, 1005833971, 1006800829, 1008777001, 1008839999, 1009025263, 1009140161, 1011319501,
- 1011333061, 1011570457, 1011909271, 1012438391, 1013833153, 1015339441, 1015626151, 1017748057, 1020515761, 1021281301,
- 1022336611, 1024041853, 1024123501, 1024605121, 1025035129, 1026738161, 1027744453, 1028494429, 1034252929, 1034958601,
- 1040234231, 1049584313, 1050102901, 1050535501, 1054999441, 1055009117, 1056121453, 1057426651, 1063212481, 1065508321,
- 1065602281, 1066972301, 1069388497, 1070639389, 1070941987, 1071512749, 1071643249, 1072898711, 1073159281, 1073288581,
- 1073484823, 1075100041, 1077133397, 1078467589, 1081798061, 1082472553, 1084241341, 1084444481, 1090858081, 1093150081,
- 1093352833, 1093526353, 1094042321, 1097416321, 1098743563, 1100624857, 1101623381, 1101673501, 1102573501, 1102750013,
- 1104194521, 1105038871, 1106529761, 1106580817, 1106595493, 1107138961, 1108135381, 1109304913, 1110582947, 1111205873,
- 1111939201, 1112671603, 1114277221, 1116379301, 1117202557, 1117785881, 1117828001, 1117890019, 1119412321, 1120076281,
- 1120981021, 1121176981, 1123406047, 1123625501, 1123727617, 1124396521, 1125038377, 1127040769, 1130933429, 1134367777,
- 1138289041, 1138607233, 1139137057, 1140573601, 1142466151, 1147434289, 1148578201, 1150229761, 1151670001, 1153164097,
- 1153440289, 1154343961, 1154691409, 1154987209, 1155939709, 1156761911, 1156993373, 1157839381, 1159421509, 1160844821,
- 1163098249, 1163227759, 1164218641, 1165717129, 1166475601, 1166598217, 1168221121, 1168256953, 1168492417, 1173229201,
- 1173545533, 1174300093, 1180970407, 1181566219, 1183338241, 1184554801, 1186325981, 1187235193, 1191153937, 1191216133,
- 1192314817, 1192412033, 1192903531, 1193229577, 1193557093, 1195524181, 1196852273, 1198650961, 1198880261, 1200456577,
- 1200778753, 1202142061, 1204205449, 1205606533, 1205772499, 1209998077, 1210393801, 1210562701, 1210653541, 1213619761,
- 1217181061, 1217823517, 1217924159, 1219816261, 1219858921, 1220114377, 1221127013, 1222861271, 1223531677, 1223941657,
- 1225128829, 1226230297, 1226855293, 1227220801, 1229491063, 1229751667, 1230446653, 1231362793, 1232445677, 1234125721,
- 1234646533, 1235188597, 1235864033, 1236313501, 1236442421, 1238825569, 1242171349, 1242858317, 1249166881, 1249785941,
- 1250656621, 1252236421, 1254277909, 1255665613, 1257102001, 1258903981, 1260332137, 1263293281, 1264145401, 1265477791,
- 1266003461, 1266273793, 1266425101, 1267345081, 1269295201, 1269835201, 1270193401, 1270489621, 1270667353, 1272558739,
- 1272866167, 1282447477, 1282568741, 1285636801, 1286298133, 1286298263, 1296613501, 1297443913, 1299072721, 1299784141,
- 1299963601, 1301509249, 1301926081, 1302745481, 1306836001, 1307004641, 1307520469, 1307823661, 1308758533, 1308998741,
- 1309723213, 1309983901, 1310329567, 1311255661, 1311616153, 1312332001, 1312573123, 1313396221, 1315858381, 1316169541,
- 1318126321, 1318717531, 1319978701, 1319992181, 1320793813, 1321058213, 1323668917, 1325172421, 1325329297, 1328256247,
- 1329174601, 1329431689, 1331973329, 1341010577, 1341926401, 1343575381, 1344597577, 1344975721, 1345514101, 1345523401,
- 1347387361, 1348964401, 1350685001, 1351126261, 1352453257, 1353051517, 1356241321, 1356328121, 1357459183, 1362463807,
- 1362515701, 1362742561, 1365662917, 1366587661, 1366608377, 1368769681, 1371908137, 1372681861, 1375322101, 1376799577,
- 1378646179, 1379464633, 1382453333, 1383283129, 1385656829, 1386705433, 1388972353, 1389353941, 1389975149, 1391890033,
- 1393851553, 1394640941, 1394746081, 1394942473, 1397357851, 1398883201, 1400859847, 1401840833, 1404008369, 1404253369,
- 1406826241, 1406851249, 1409372779, 1413803197, 1414154827, 1414529533, 1415969101, 1417986901, 1421475031, 1424503849,
- 1425860101, 1426319563, 1426534201, 1427771089, 1428966001, 1432354901, 1435091377, 1438648993, 1440231941, 1440922891,
- 1441139641, 1441678411, 1442945689, 1443388481, 1443742273, 1446298309, 1446434677, 1446818651, 1448921633, 1451635201,
- 1454282449, 1454445413, 1456527461, 1457378449, 1461307717, 1463065501, 1463178817, 1463992661, 1464568381, 1465908193,
- 1465945417, 1468540477, 1468824787, 1469059481, 1469960377, 1470080501, 1470650851, 1471628401, 1472221921, 1473580001,
- 1477289941, 1481626513, 1482274513, 1482876673, 1483873861, 1483918801, 1485061471, 1486564301, 1493114149, 1495190699,
- 1497221281, 1497965713, 1499971457, 1499989177, 1500142001, 1501165097, 1502171117, 1502403121, 1503240559, 1503705601,
- 1504139521, 1504832033, 1507746241, 1509156013, 1510870241, 1511558533, 1515175087, 1515785041, 1517039371, 1518014689,
- 1518290707, 1520190341, 1521221473, 1522302121, 1526732803, 1529648231, 1529819971, 1530495289, 1532419099, 1532569681,
- 1532755369, 1533343261, 1534063081, 1535020133, 1536112001, 1536251047, 1536883357, 1537433899, 1537641691, 1538012449,
- 1539583921, 1539804001, 1540454761, 1540550413, 1541047813, 1541849761, 1541955409, 1544145121, 1545019813, 1545177581,
- 1546106773, 1546340401, 1546508057, 1547140841, 1547543161, 1547712601, 1550924873, 1554270481, 1557118081, 1560312001,
- 1560620041, 1561800833, 1565893201, 1566594551, 1567830241, 1568916311, 1574362441, 1574601601, 1577983489, 1578009401,
- 1580449201, 1581576641, 1581714481, 1582783777, 1583230241, 1583658649, 1586436193, 1587650401, 1590394313, 1593706201,
- 1595647351, 1595887921, 1598197201, 1602517949, 1603765021, 1603810561, 1603994701, 1609916491, 1609935913, 1612121473,
- 1614508267, 1617795181, 1617921667, 1619447741, 1620646177, 1627103521, 1627898401, 1628692201, 1630062253, 1630307617,
- 1631314609, 1632286673, 1632513601, 1633044241, 1636185601, 1637434657, 1637436457, 1637930893, 1638294661, 1639351981,
- 1639846391, 1641971701, 1642814653, 1644637051, 1645413001, 1647225529, 1648076041, 1649430889, 1650265549, 1650682153,
- 1654940509, 1655660761, 1656229921, 1656280033, 1656917377, 1659009601, 1661202113, 1668037621, 1668926629, 1669893661,
- 1671603667, 1671714241, 1672125131, 1674091141, 1674658133, 1675978193, 1678274581, 1679130641, 1680901381, 1683174533,
- 1685433413, 1686001861, 1687248001, 1691745821, 1692605041, 1694128129, 1695158921, 1696893101, 1698707377, 1699279441,
- 1700250049, 1709909293, 1710753001, 1712392321, 1714322377, 1716160321, 1716714793, 1716774481, 1718013133, 1718088301,
- 1719197621, 1721061497, 1721986313, 1722007169, 1722685777, 1725675451, 1726372441, 1731048937, 1731995497, 1732924001,
- 1734059291, 1734285601, 1735071913, 1736481601, 1738687469, 1740214841, 1742288881, 1742815621, 1743166441, 1744605097,
- 1746692641, 1746721681, 1749124829, 1750412161, 1754818561, 1757148121, 1760014561, 1766984389, 1767234613, 1769091241,
- 1769267761, 1770236893, 1771303801, 1772267281, 1773582977, 1776439261, 1776820033, 1779649381, 1779892577, 1784306273,
- 1784638309, 1785843547, 1786005521, 1787934881, 1790023861, 1791426787, 1792442737, 1792588813, 1794814103, 1801558201,
- 1801774081, 1802510669, 1803768091, 1804906517, 1805947313, 1809888967, 1816408273, 1817067169, 1819829749, 1820306953,
- 1821514633, 1828682101, 1828887061, 1831258601, 1835114401, 1837156049, 1837599769, 1839568981, 1841034961, 1841099261,
- 1841479501, 1844028961, 1846171781, 1847811673, 1849964117, 1850233897, 1850598961, 1852496761, 1853926777, 1854084649,
- 1854940231, 1856689453, 1857221281, 1858098497, 1858197961, 1860373241, 1861026133, 1861880689, 1862880401, 1866409861,
- 1867906721, 1868682241, 1871987041, 1872937057, 1873177693, 1874634721, 1874849929, 1878691753, 1879111697, 1879623157,
- 1879775501, 1883509633, 1883785681, 1885915841, 1894909141, 1894955311, 1897700113, 1899081757, 1899525601, 1900687381,
- 1903447841, 1904658913, 1905958891, 1908088001, 1909566073, 1910134309, 1911197947, 1912950241, 1914303841, 1915391521,
- 1916987593, 1917397637, 1920301951, 1921309633, 1922092567, 1922687293, 1923224689, 1923311317, 1923845801, 1924201501,
- 1925042737, 1928903971, 1929862849, 1930403333, 1930447501, 1930534453, 1930915169, 1934350351, 1938264241, 1940048881,
- 1943951041, 1944125633, 1945042181, 1950987193, 1952513369, 1952968753, 1957705177, 1959659857, 1960708261, 1963149553,
- 1965007601, 1968002149, 1970065681, 1974474049, 1977257441, 1982123893, 1982826961, 1988071801, 1988713189, 1988835713,
- 1988965861, 1989192277, 1991063449, 1995784961, 1995830761, 1996231189, 1996339649, 1997844157, 1998780001, 1999053601,
- 1999111801, 1999743661, 2004299641, 2007646961, 2013554869, 2013834961, 2016481477, 2017021333, 2017509601, 2019564769,
- 2021392369, 2021884343, 2027675701, 2028279793, 2028631361, 2028812399, 2029830409, 2030600833, 2036224321, 2043173273,
- 2049293401, 2050617713, 2052149221, 2054711381, 2055634561, 2057267941, 2057835781, 2058072041, 2059739221, 2062612033,
- 2068867841, 2070739441, 2072624761, 2076192007, 2081039297, 2081551753, 2082146617, 2083034113, 2083997441, 2085453649,
- 2085882661, 2086645009, 2093300401, 2095627153, 2096046457, 2097317377, 2100292841, 2101470541, 2101744837, 2104994449,
- 2106147457, 2107148761, 2114643217, 2115769633, 2115986557, 2116483027, 2116541221, 2117031263, 2117555641, 2118621097,
- 2120096161, 2123601751, 2124078653, 2124691213, 2127197489, 2128104001, 2129304997, 2130134533, 2131004737, 2131811501,
- 2140699681, 2140771609, 2141340833, 2144961253, 2147418113, 2147429509, 2152627801, 2154446641, 2155416251, 2156151313,
- 2164282177, 2168431201, 2170282969, 2172155819, 2173499329, 2173540951, 2173579801, 2175126601, 2175406201, 2175646177,
- 2177374321, 2177645557, 2178082901, 2178939221, 2180221201, 2182281601, 2182802689, 2185362233, 2187717761, 2193980881,
- 2199617701, 2200115713, 2201924341, 2202101761, 2202205897, 2203649197, 2203856497, 2206095589, 2210578759, 2213431729,
- 2216960929, 2217879901, 2219072017, 2224252801, 2229468697, 2231332357, 2233031701, 2240507821, 2241880033, 2241982009,
- 2244932281, 2245519981, 2246762899, 2248354153, 2251732033, 2254314241, 2254757077, 2256197761, 2256748777, 2256751837,
- 2262861901, 2269307587, 2274584089, 2283289681, 2284416181, 2289251669, 2289624793, 2290316377, 2290910257, 2291205461,
- 2292068143, 2295209281, 2296995121, 2299190401, 2300628601, 2300795353, 2301745249, 2304120001, 2308966661, 2309241601,
- 2309405617, 2311558021, 2311575001, 2315137261, 2320527613, 2323147201, 2324867399, 2329584217, 2330569541, 2331181621,
- 2335341601, 2338157597, 2338728001, 2340460487, 2345907961, 2347597981, 2352371251, 2354453561, 2355230749, 2355320101,
- 2355622721, 2355649921, 2355735089, 2358534361, 2360261989, 2370771181, 2370928337, 2371350101, 2372976563, 2374232977,
- 2375415841, 2377166401, 2378309041, 2381782597, 2382678101, 2383164577, 2385574201, 2389072321, 2389544977, 2393708761,
- 2394311233, 2398393661, 2404912501, 2411128441, 2412172153, 2412675721, 2413973071, 2422296241, 2423401681, 2425249601,
- 2428648967, 2428870753, 2428986913, 2429407961, 2430697513, 2431136401, 2431144801, 2432761633, 2432860273, 2433791593,
- 2434964321, 2434974433, 2435091221, 2436691321, 2437907779, 2438778413, 2442050353, 2442454561, 2443708961, 2444950561,
- 2448039497, 2448374689, 2453473049, 2454285751, 2456536681, 2457846161, 2463713281, 2471205361, 2473120961, 2473189441,
- 2473823353, 2474308069, 2474676949, 2476283239, 2477814193, 2478643907, 2480147521, 2480343553, 2482435981, 2482682131,
- 2484408301, 2486017249, 2488420801, 2488591117, 2492480233, 2494660033, 2494984321, 2495834329, 2499327041, 2501012599,
- 2501771329, 2502525637, 2504008609, 2506529257, 2506733189, 2507121037, 2508178843, 2513230891, 2516684801, 2519297089,
- 2525070241, 2526566041, 2528291341, 2529410281, 2529827821, 2529854713, 2530351561, 2532630787, 2533465661, 2533797017,
- 2535516173, 2537105761, 2539406281, 2539736257, 2540469901, 2541660367, 2542479481, 2544590161, 2545934077, 2548051801,
- 2550139253, 2550780277, 2551365769, 2552418761, 2553272929, 2555391481, 2561945401, 2564536201, 2565186137, 2570087521,
- 2571180247, 2575060949, 2575737361, 2577345541, 2582092189, 2582246701, 2582952769, 2583322381, 2584460701, 2588054401,
- 2588582089, 2590663681, 2593065721, 2595276353, 2597289241, 2597294701, 2598933481, 2600611861, 2602343521, 2602378721,
- 2604465013, 2604803701, 2611122229, 2611461529, 2613382201, 2614688801, 2616180821, 2617563031, 2621080741, 2621977627,
- 2622993661, 2624549929, 2625903601, 2626783921, 2627284987, 2630643401, 2632605049, 2634284801, 2634804481, 2634820813,
- 2638067881, 2639099233, 2642159809, 2642582251, 2646751249, 2646790033, 2648662777, 2649907201, 2650820329, 2651507713,
- 2654716321, 2656494271, 2658630913, 2658696301, 2659265701, 2668095181, 2668469431, 2670972949, 2672605657, 2672651521,
- 2676053333, 2677147201, 2677821121, 2678785621, 2681041843, 2682823681, 2683742491, 2684284441, 2687655169, 2688124001,
- 2689427281, 2690408533, 2690867401, 2693739751, 2695115473, 2700818017, 2700891839, 2701878941, 2704957909, 2706863833,
- 2707661501, 2716157989, 2716275007, 2717428033, 2719319513, 2721666817, 2721721939, 2723859001, 2725357249, 2733156029,
- 2736316301, 2738184697, 2740336561, 2744329909, 2746021741, 2753333227, 2753538001, 2759392633, 2765323397, 2766006253,
- 2767672189, 2769080161, 2769602333, 2774295577, 2777887297, 2778304273, 2779477741, 2781117721, 2781226477, 2786028337,
- 2787998641, 2789218909, 2800352011, 2805762961, 2809635901, 2812672981, 2814748201, 2823570433, 2824256377, 2824804693,
- 2824854913, 2828205397, 2832384133, 2832743713, 2837697773, 2837917633, 2840634109, 2840871041, 2841190381, 2847894377,
- 2848466281, 2848722131, 2855046421, 2855071801, 2855512909, 2862066481, 2865483601, 2866005139, 2866527841, 2870377309,
- 2871536561, 2872527733, 2872948321, 2874382853, 2877769501, 2881429741, 2882370481, 2885594497, 2887955533, 2890316801,
- 2890414873, 2892426029, 2894667781, 2895004927, 2899294889, 2903776129, 2915953633, 2916247819, 2918295451, 2920691161,
- 2923042141, 2924158001, 2929062533, 2929106753, 2930831641, 2931708097, 2932327549, 2936227603, 2936958181, 2941174897,
- 2941343633, 2944555681, 2944677961, 2945208001, 2945549881, 2951136343, 2956724317, 2957320351, 2965700233, 2967053953,
- 2968206601, 2974506841, 2975377429, 2976930001, 2978766341, 2980689601, 2986025677, 2987414977, 2990152901, 2993462713,
- 2993495041, 2994098281, 2994415201, 2998202353, 2998919873, 3000688381, 3001561441, 3002647829, 3004443679, 3009628301,
- 3011421841, 3014101261, 3015502181, 3016957381, 3017444761, 3018147217, 3018576689, 3019916461, 3025350343, 3026575553,
- 3028586471, 3030393901, 3033332641, 3034402681, 3034817209, 3035375047, 3036079729, 3037295801, 3037781251, 3038880473,
- 3039681457, 3041984353, 3042630533, 3048159841, 3050190163, 3056100623, 3056160929, 3057886591, 3058670677, 3059397793,
- 3063685633, 3065998717, 3076505209, 3077122133, 3079496551, 3082054697, 3082068013, 3083053387, 3083537689, 3083884651,
- 3088408429, 3089013313, 3091019777, 3094763851, 3099670657, 3103800701, 3112974481, 3114125071, 3115667521, 3120445697,
- 3122287981, 3129914881, 3133899409, 3135040133, 3143282221, 3145410761, 3150972917, 3156599161, 3156643141, 3157579861,
- 3163106953, 3166504273, 3167442721, 3170262409, 3172658653, 3175204531, 3175255717, 3178375201, 3181356263, 3181391641,
- 3182606857, 3182655361, 3182891401, 3185472001, 3187035113, 3187421077, 3187939921, 3196397821, 3196431829, 3197565001,
- 3197632441, 3197911001, 3197911741, 3199164901, 3205663921, 3207297773, 3208902491, 3212465437, 3215031751, 3217412881,
- 3219808411, 3221580281, 3222693421, 3224143441, 3225081473, 3227082823, 3227209057, 3229131137, 3233558021, 3237992101,
- 3242533897, 3248236309, 3250348417, 3250700737, 3252148621, 3257334541, 3258647809, 3258892801, 3261114601, 3263097641,
- 3263568901, 3263626957, 3264820001, 3265122451, 3267417677, 3268506541, 3268841941, 3270933121, 3271999249, 3272030401,
- 3272702497, 3274264033, 3275671969, 3276075709, 3277047649, 3278640289, 3280067129, 3282974857, 3287174129, 3288757249,
- 3295362727, 3296403601, 3299246833, 3302322241, 3304307341, 3305829073, 3306686659, 3306957593, 3310858777, 3312489577,
- 3312536569, 3313196881, 3315139717, 3320669437, 3323308501, 3323590463, 3323829169, 3328354801, 3332800021, 3334350781,
- 3340214413, 3342005633, 3344191241, 3346172189, 3347908801, 3349218881, 3350993969, 3352091557, 3355382857, 3355953001,
- 3357417181, 3359737921, 3360511981, 3369139201, 3371024521, 3371452921, 3371693063, 3372667121, 3373086601, 3381052177,
- 3381901921, 3385842877, 3386603221, 3387014401, 3387487351, 3389030261, 3395091311, 3399205591, 3399890413, 3402234749,
- 3407609221, 3407772817, 3407952169, 3408135121, 3409339393, 3411250081, 3411574801, 3411829693, 3412575097, 3415379701,
- 3415832137, 3417522841, 3420143941, 3421845001, 3423222757, 3423580481, 3427050673, 3428133103, 3429457921, 3429982081,
- 3430804297, 3432695921, 3432997537, 3433458073, 3434575327, 3435973837, 3440195713, 3443704261, 3449768513, 3450717901,
- 3453900913, 3458257741, 3461861761, 3463907761, 3464236901, 3466158361, 3470716657, 3474335437, 3480174001, 3482161261,
- 3485747521, 3489958697, 3491763493, 3492178873, 3492883081, 3493262761, 3497607433, 3504132113, 3512030497, 3512291021,
- 3512369857, 3513604657, 3516565057, 3519318721, 3524086333, 3525088961, 3529119361, 3529864391, 3532687201, 3533662129,
- 3533856913, 3538213381, 3542303047, 3543203333, 3548378341, 3549286001, 3549988261, 3552158521, 3553567057, 3557646401,
- 3562963973, 3563340457, 3566428301, 3574891757, 3582711841, 3583249921, 3583604161, 3584800801, 3586833253, 3587553971,
- 3589937261, 3590409439, 3593276353, 3594110081, 3596491907, 3596815169, 3598772761, 3602006101, 3605151241, 3611571121,
- 3612298321, 3612825221, 3614770573, 3616574081, 3620631169, 3628526287, 3630596257, 3631828481, 3632452741, 3635993089,
- 3649116277, 3649965281, 3650158849, 3651572609, 3656355841, 3658730893, 3662387977, 3662503093, 3663084541, 3668926801,
- 3669587533, 3672754633, 3677180797, 3679657997, 3682471321, 3685647701, 3685775741, 3692307161, 3695628133, 3697278427,
- 3700801861, 3705582073, 3705623281, 3708123301, 3708905341, 3709626961, 3712887289, 3713287801, 3713448769, 3718226401,
- 3721486081, 3723410161, 3723699373, 3725016749, 3727828501, 3729097633, 3733761739, 3736293461, 3745192001, 3746101189,
- 3749383681, 3751554581, 3751782737, 3754680403, 3756668401, 3759781369, 3760622689, 3760896133, 3762110881, 3767640601,
- 3773061337, 3774337201, 3784123501, 3787491457, 3798040471, 3798626833, 3799111681, 3800084401, 3805699501, 3807112123,
- 3807308269, 3807749821, 3809018947, 3813919453, 3817561777, 3817706621, 3821233121, 3827035237, 3832807681, 3833208961,
- 3842941741, 3846174151, 3846532801, 3847106803, 3850058689, 3852800033, 3863326897, 3865604023, 3867183937, 3874471147,
- 3874523017, 3875096893, 3875965417, 3886515361, 3886643801, 3887423437, 3887635753, 3891892421, 3891919417, 3894053311,
- 3896079281, 3897241129, 3897869201, 3898906129, 3900327241, 3903711841, 3905533721, 3905876501, 3907577521, 3907752241,
- 3912174421, 3914880337, 3914923211, 3915467341, 3915604421, 3915921241, 3918227437, 3922321561, 3926912669, 3929293061,
- 3934940833, 3935864017, 3936123601, 3945165841, 3947233201, 3947383201, 3953408801, 3953949421, 3955572001, 3958597301,
- 3958930441, 3959578801, 3960728641, 3962037061, 3966350203, 3967343161, 3971095301, 3973556837, 3979485931, 3982017601,
- 3987528793, 3987960913, 3991124341, 3992697997, 3997536427, 4005660961, 4007365741, 4011996871, 4015548769, 4017684529,
- 4018283501, 4020144133, 4026822577, 4027012021, 4027518961, 4028465873, 4028771849, 4031223841, 4034969401, 4034993269,
- 4035498409, 4036395581, 4042538497, 4044601751, 4044884689, 4048493983, 4053267217, 4054039841, 4057195309, 4058433931,
- 4059776533, 4060942381, 4061009971, 4064633821, 4067039461, 4067887501, 4068671881, 4071644893, 4075241633, 4075721921,
- 4076009857, 4079665633, 4079682361, 4083376067, 4085074909, 4088147617, 4088838913, 4092929149, 4098258707, 4099180801,
- 4100934241, 4103745689, 4105691393, 4108970251, 4109461709, 4109711581, 4110320663, 4113013141, 4115891893, 4117058221,
- 4117447441, 4121286907, 4127050621, 4129914673, 4133928761, 4135847101, 4136916001, 4137262541, 4138838401, 4139015987,
- 4150174393, 4155375349, 4157008813, 4162880401, 4166032873, 4183664101, 4185636781, 4186561633, 4187360341, 4191864013,
- 4192060699, 4195843037, 4196323561, 4204344601, 4206006229, 4206295433, 4212105409, 4215885697, 4218900001, 4220122321,
- 4232966251, 4234224601, 4237212061, 4243744201, 4244022301, 4244663651, 4247990917, 4250920459, 4251904273, 4255695013,
- 4257003353, 4261352869, 4271267333, 4275011401, 4277526901, 4278305651, 4282867213, 4285148981, 4293088801, 4294901761,
- }
-
- primes16 = [65536]byte{
- 2, 1, 1, 2, 1, 2, 1, 4, 3, 2, // 0-9
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 10-19
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 20-29
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 30-39
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 40-49
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 50-59
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 60-69
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 70-79
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 80-89
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 90-99
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 100-109
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 110-119
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 120-129
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 130-139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 140-149
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 150-159
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 160-169
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 170-179
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 180-189
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 190-199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 200-209
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 210-219
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 220-229
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 230-239
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 240-249
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 250-259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 260-269
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 270-279
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 280-289
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 290-299
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 300-309
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 310-319
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 320-329
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 330-339
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 340-349
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 350-359
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 360-369
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 370-379
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 380-389
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 390-399
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 400-409
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 410-419
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 420-429
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 430-439
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 440-449
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 450-459
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 460-469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 470-479
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 480-489
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 490-499
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 500-509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 510-519
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 520-529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 530-539
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 540-549
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 550-559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 560-569
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 570-579
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 580-589
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 590-599
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 600-609
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 610-619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 620-629
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 630-639
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 640-649
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 650-659
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 660-669
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 670-679
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 680-689
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 690-699
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 700-709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 710-719
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 720-729
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 730-739
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 740-749
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 750-759
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 760-769
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 770-779
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 780-789
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 790-799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 800-809
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 810-819
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 820-829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 830-839
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 840-849
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 850-859
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 860-869
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 870-879
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 880-889
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 890-899
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 900-909
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 910-919
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 920-929
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 930-939
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 940-949
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 950-959
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 960-969
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 970-979
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 980-989
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 990-999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 1000-1009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 1010-1019
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1020-1029
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 1030-1039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 1040-1049
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1050-1059
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 1060-1069
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 1070-1079
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 1080-1089
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 1090-1099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 1100-1109
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1110-1119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 1120-1129
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 1130-1139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1140-1149
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 1150-1159
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 1160-1169
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1170-1179
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1180-1189
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 1190-1199
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1200-1209
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 1210-1219
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 1220-1229
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 1230-1239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 1240-1249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 1250-1259
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 1260-1269
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 1270-1279
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 1280-1289
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 1290-1299
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 1300-1309
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 1310-1319
- 1, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 1320-1329
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 1330-1339
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 1340-1349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1350-1359
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1360-1369
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 1370-1379
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 1380-1389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 1390-1399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 1400-1409
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1410-1419
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 1420-1429
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 1430-1439
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 1440-1449
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 1450-1459
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1460-1469
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1470-1479
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 1480-1489
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 1490-1499
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1500-1509
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1510-1519
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 1520-1529
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1530-1539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 1540-1549
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 1550-1559
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 1560-1569
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 1570-1579
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 1580-1589
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 1590-1599
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 1600-1609
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 1610-1619
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 1620-1629
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 1630-1639
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 1640-1649
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1650-1659
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 24, // 1660-1669
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 1670-1679
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1680-1689
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 1690-1699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 1700-1709
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1710-1719
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 1720-1729
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 1730-1739
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1740-1749
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 1750-1759
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 1760-1769
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1770-1779
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 1780-1789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1790-1799
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1800-1809
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1810-1819
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 1820-1829
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 1830-1839
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 1840-1849
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1850-1859
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 1860-1869
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 1870-1879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 1880-1889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1890-1899
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1900-1909
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 1910-1919
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 1920-1929
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 1930-1939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 1940-1949
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 1950-1959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 1960-1969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 1970-1979
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 1980-1989
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 1990-1999
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2000-2009
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 2010-2019
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 2020-2029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 2030-2039
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2040-2049
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 2050-2059
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 2060-2069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2070-2079
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 2080-2089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 2090-2099
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2100-2109
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 2110-2119
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 2120-2129
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2130-2139
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 2140-2149
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2150-2159
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 2160-2169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 2170-2179
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 2180-2189
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2190-2199
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 2200-2209
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2210-2219
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 2220-2229
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 2230-2239
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2240-2249
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 2250-2259
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 2260-2269
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2270-2279
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 2280-2289
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 2290-2299
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 2300-2309
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 2310-2319
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2320-2329
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 2330-2339
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2340-2349
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 2350-2359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2360-2369
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2370-2379
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 2380-2389
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 2390-2399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2400-2409
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 2410-2419
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 2420-2429
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2430-2439
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 2440-2449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 2450-2459
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 2460-2469
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 2470-2479
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 2480-2489
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2490-2499
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 2500-2509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2510-2519
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2520-2529
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 2530-2539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 2540-2549
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 2550-2559
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 2560-2569
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 2570-2579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2580-2589
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 2590-2599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 2600-2609
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2610-2619
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2620-2629
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 2630-2639
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 2640-2649
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 2650-2659
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2660-2669
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 2670-2679
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 2680-2689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 2690-2699
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2700-2709
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 2710-2719
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 2720-2729
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 2730-2739
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 2740-2749
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 2750-2759
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 2760-2769
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 2770-2779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 2780-2789
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2790-2799
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 2800-2809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 2810-2819
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2820-2829
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 2830-2839
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 2840-2849
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 2850-2859
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 2860-2869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 2870-2879
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 2880-2889
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 2890-2899
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 2900-2909
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 2910-2919
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 2920-2929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 2930-2939
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 2940-2949
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 2950-2959
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 2960-2969
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 2970-2979
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 2980-2989
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 2990-2999
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3000-3009
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 3010-3019
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 3020-3029
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3030-3039
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 3040-3049
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3050-3059
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 3060-3069
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 3070-3079
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 3080-3089
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 3090-3099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 3100-3109
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 3110-3119
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 3120-3129
- 7, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 3130-3139
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 3140-3149
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 3150-3159
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 3160-3169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3170-3179
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3180-3189
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 3190-3199
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 3200-3209
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3210-3219
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 3220-3229
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 3230-3239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3240-3249
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 3250-3259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3260-3269
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 3270-3279
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 3280-3289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 3290-3299
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 3300-3309
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 3310-3319
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 3320-3329
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 3330-3339
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 3340-3349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 3350-3359
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3360-3369
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 3370-3379
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 3380-3389
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 3390-3399
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 3400-3409
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 3410-3419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 3420-3429
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 3430-3439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 3440-3449
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3450-3459
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 3460-3469
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 3470-3479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3480-3489
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 3490-3499
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3500-3509
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 3510-3519
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 3520-3529
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 3530-3539
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 3540-3549
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 3550-3559
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3560-3569
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3570-3579
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 3580-3589
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 3590-3599
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 3600-3609
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 3610-3619
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 3620-3629
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 3630-3639
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 3640-3649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 3650-3659
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3660-3669
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 3670-3679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3680-3689
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3690-3699
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 3700-3709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 3710-3719
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 3720-3729
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 3730-3739
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 3740-3749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3750-3759
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 3760-3769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 3770-3779
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 3780-3789
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 3790-3799
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 3800-3809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3810-3819
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 3820-3829
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 3830-3839
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3840-3849
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 3850-3859
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 3860-3869
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3870-3879
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 3880-3889
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 3890-3899
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 3900-3909
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 3910-3919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 3920-3929
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 3930-3939
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 3940-3949
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 3950-3959
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 3960-3969
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 3970-3979
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 3980-3989
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 3990-3999
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 4000-4009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 4010-4019
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 4020-4029
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 4030-4039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 4040-4049
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 4050-4059
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4060-4069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 4070-4079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4080-4089
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 4090-4099
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4100-4109
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 4110-4119
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 4120-4129
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 4130-4139
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4140-4149
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 18, // 4150-4159
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 4160-4169
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 4170-4179
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 4180-4189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4190-4199
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4200-4209
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 4210-4219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 4220-4229
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4230-4239
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 4240-4249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 4250-4259
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4260-4269
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 4270-4279
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 4280-4289
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 4290-4299
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 4300-4309
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 4310-4319
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 4320-4329
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 4330-4339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 4340-4349
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 4350-4359
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 4360-4369
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 4370-4379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4380-4389
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 4390-4399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 4400-4409
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4410-4419
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 4420-4429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4430-4439
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 4440-4449
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 4450-4459
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 4460-4469
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4470-4479
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 4480-4489
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 4490-4499
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 4500-4509
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 4510-4519
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 4520-4529
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 4530-4539
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 4540-4549
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4550-4559
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 4560-4569
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4570-4579
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 4580-4589
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 4590-4599
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 4600-4609
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4610-4619
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 4620-4629
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 4630-4639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 4640-4649
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 4650-4659
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 4660-4669
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 4670-4679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4680-4689
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4690-4699
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 4700-4709
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4710-4719
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 4720-4729
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 4730-4739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4740-4749
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 4750-4759
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 4760-4769
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4770-4779
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 4780-4789
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 4790-4799
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4800-4809
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 4810-4819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4820-4829
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 4830-4839
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 4840-4849
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4850-4859
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4860-4869
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 4870-4879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 4880-4889
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 4890-4899
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 4900-4909
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 4910-4919
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 4920-4929
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 4930-4939
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 4940-4949
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 4950-4959
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 4960-4969
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 4970-4979
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 4980-4989
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 4990-4999
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 5000-5009
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5010-5019
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 5020-5029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 5030-5039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5040-5049
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 5050-5059
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5060-5069
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5070-5079
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 5080-5089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 5090-5099
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5100-5109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 28, // 5110-5119
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 5120-5129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5130-5139
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5140-5149
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 5150-5159
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5160-5169
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 5170-5179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 5180-5189
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 5190-5199
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 5200-5209
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5210-5219
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5220-5229
- 1, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 5230-5239
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 5240-5249
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5250-5259
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 5260-5269
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 5270-5279
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5280-5289
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5290-5299
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 5300-5309
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 5310-5319
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 5320-5329
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 5330-5339
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5340-5349
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 5350-5359
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 5360-5369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5370-5379
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5380-5389
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 5390-5399
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5400-5409
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 5410-5419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5420-5429
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5430-5439
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 5440-5449
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 5450-5459
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5460-5469
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 5470-5479
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 5480-5489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5490-5499
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 5500-5509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 5510-5519
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5520-5529
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 5530-5539
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5540-5549
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5550-5559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 5560-5569
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 5570-5579
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5580-5589
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 5590-5599
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 5600-5609
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 5610-5619
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 5620-5629
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 5630-5639
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5640-5649
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 5650-5659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 5660-5669
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 5670-5679
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 5680-5689
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 5690-5699
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5700-5709
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 5710-5719
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5720-5729
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5730-5739
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 5740-5749
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 5750-5759
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 5760-5769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 5770-5779
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 5780-5789
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5790-5799
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5800-5809
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 5810-5819
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 5820-5829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 5830-5839
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 5840-5849
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 5850-5859
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 5860-5869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 5870-5879
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5880-5889
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 5890-5899
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 5900-5909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 5910-5919
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 5920-5929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 5930-5939
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 5940-5949
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 5950-5959
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 5960-5969
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 5970-5979
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 5980-5989
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 5990-5999
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6000-6009
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 6010-6019
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 6020-6029
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6030-6039
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 6040-6049
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 6050-6059
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6060-6069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 6070-6079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 6080-6089
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6090-6099
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6100-6109
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 6110-6119
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6120-6129
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 6130-6139
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 6140-6149
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6150-6159
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 6160-6169
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 6170-6179
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 6180-6189
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 6190-6199
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 6200-6209
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6210-6219
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 6220-6229
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 6230-6239
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 6240-6249
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6250-6259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 6260-6269
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 6270-6279
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 6280-6289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 6290-6299
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6300-6309
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6310-6319
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 6320-6329
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6330-6339
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 6340-6349
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 6350-6359
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6360-6369
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 6370-6379
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 6380-6389
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 6390-6399
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 6400-6409
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6410-6419
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 6420-6429
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 6430-6439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 6440-6449
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 6450-6459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 6460-6469
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 6470-6479
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6480-6489
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 6490-6499
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 6500-6509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6510-6519
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 6520-6529
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 6530-6539
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6540-6549
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 6550-6559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 6560-6569
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6570-6579
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 6580-6589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 6590-6599
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 6600-6609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 6610-6619
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 6620-6629
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 6630-6639
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6640-6649
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 6650-6659
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6660-6669
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 6670-6679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 6680-6689
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6690-6699
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 6700-6709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 6710-6719
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6720-6729
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 6730-6739
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 6740-6749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6750-6759
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 6760-6769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 6770-6779
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 6780-6789
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 6790-6799
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 6800-6809
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6810-6819
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 6820-6829
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 6830-6839
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 6840-6849
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6850-6859
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 6860-6869
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 6870-6879
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 6880-6889
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 6890-6899
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6900-6909
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 6910-6919
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 6920-6929
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 6930-6939
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 6940-6949
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 6950-6959
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6960-6969
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 6970-6979
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 6980-6989
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 6990-6999
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7000-7009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 7010-7019
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 7020-7029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 7030-7039
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 7040-7049
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 7050-7059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 7060-7069
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 7070-7079
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 7080-7089
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7090-7099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 7100-7109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7110-7119
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 7120-7129
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 7130-7139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7140-7149
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 7150-7159
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 7160-7169
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 7170-7179
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7180-7189
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 7190-7199
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 7200-7209
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 7210-7219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 7220-7229
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7230-7239
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 7240-7249
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 7250-7259
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 7260-7269
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7270-7279
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 7280-7289
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 7290-7299
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 7300-7309
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7310-7319
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7320-7329
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 7330-7339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 7340-7349
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 7350-7359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 7360-7369
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 7370-7379
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7380-7389
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 7390-7399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7400-7409
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 7410-7419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7420-7429
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 7430-7439
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7440-7449
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 7450-7459
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 7460-7469
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 7470-7479
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 7480-7489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 7490-7499
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 7500-7509
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7510-7519
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 7520-7529
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 7530-7539
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 7540-7549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 7550-7559
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7560-7569
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 7570-7579
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 7580-7589
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7590-7599
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 7600-7609
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7610-7619
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 7620-7629
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 7630-7639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 7640-7649
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 7650-7659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 7660-7669
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 7670-7679
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 7680-7689
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 7690-7699
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 7700-7709
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7710-7719
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 7720-7729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7730-7739
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7740-7749
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 30, // 7750-7759
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 7760-7769
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 7770-7779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 7780-7789
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 7790-7799
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 7800-7809
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7810-7819
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 7820-7829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7830-7839
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7840-7849
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 7850-7859
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7860-7869
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 7870-7879
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 7880-7889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 7890-7899
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 7900-7909
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 7910-7919
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 7920-7929
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 7930-7939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 7940-7949
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7950-7959
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 7960-7969
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 7970-7979
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 7980-7989
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 7990-7999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 8000-8009
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 8010-8019
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 8020-8029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 8030-8039
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8040-8049
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 8050-8059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 8060-8069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8070-8079
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 8080-8089
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 8090-8099
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8100-8109
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 8110-8119
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 8120-8129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 8130-8139
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 8140-8149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8150-8159
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 8160-8169
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 8170-8179
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8180-8189
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 8190-8199
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 8200-8209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 8210-8219
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8220-8229
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 8230-8239
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 8240-8249
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8250-8259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 8260-8269
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 8270-8279
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 8280-8289
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 8290-8299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8300-8309
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 8310-8319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 8320-8329
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 8330-8339
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8340-8349
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 8350-8359
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 8360-8369
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 8370-8379
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 30, // 8380-8389
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 8390-8399
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 8400-8409
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 8410-8419
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 8420-8429
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8430-8439
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 8440-8449
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8450-8459
- 1, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 8460-8469
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 8470-8479
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 8480-8489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8490-8499
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8500-8509
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 8510-8519
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 8520-8529
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 8530-8539
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 8540-8549
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8550-8559
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 8560-8569
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 8570-8579
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 8580-8589
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 8590-8599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 8600-8609
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8610-8619
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 8620-8629
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8630-8639
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 8640-8649
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8650-8659
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 8660-8669
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 8670-8679
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 8680-8689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 8690-8699
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 8700-8709
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 8710-8719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8720-8729
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 8730-8739
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 8740-8749
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 8750-8759
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 8760-8769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 8770-8779
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 8780-8789
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8790-8799
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 8800-8809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 8810-8819
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8820-8829
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 8830-8839
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 8840-8849
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8850-8859
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 8860-8869
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 8870-8879
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 8880-8889
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 8890-8899
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 8900-8909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8910-8919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 8920-8929
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 8930-8939
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 8940-8949
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 8950-8959
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 8960-8969
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 8970-8979
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 8980-8989
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 8990-8999
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 9000-9009
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 9010-9019
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 9020-9029
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9030-9039
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 9040-9049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 9050-9059
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 9060-9069
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 9070-9079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9080-9089
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9090-9099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 9100-9109
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9110-9119
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 9120-9129
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 9130-9139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9140-9149
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 9150-9159
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9160-9169
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 9170-9179
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 9180-9189
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 9190-9199
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 9200-9209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9210-9219
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 9220-9229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 9230-9239
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9240-9249
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 9250-9259
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9260-9269
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 9270-9279
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 9280-9289
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 9290-9299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9300-9309
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 9310-9319
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 9320-9329
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 9330-9339
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 9340-9349
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 9350-9359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9360-9369
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 9370-9379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9380-9389
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 9390-9399
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 9400-9409
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 9410-9419
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9420-9429
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 9430-9439
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 9440-9449
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9450-9459
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 9460-9469
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 9470-9479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9480-9489
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 9490-9499
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9500-9509
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9510-9519
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9520-9529
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 9530-9539
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 9540-9549
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 9550-9559
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 9560-9569
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9570-9579
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 9580-9589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9590-9599
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9600-9609
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 9610-9619
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 9620-9629
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9630-9639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 9640-9649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9650-9659
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9660-9669
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 9670-9679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 9680-9689
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 9690-9699
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 9700-9709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 9710-9719
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9720-9729
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 9730-9739
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 9740-9749
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9750-9759
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 9760-9769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9770-9779
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 9780-9789
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9790-9799
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 9800-9809
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 9810-9819
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 9820-9829
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 9830-9839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9840-9849
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 9850-9859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9860-9869
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9870-9879
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 9880-9889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9890-9899
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 9900-9909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 9910-9919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 9920-9929
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 9930-9939
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 9940-9949
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9950-9959
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 9960-9969
- 3, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 9970-9979
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 9980-9989
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 9990-9999
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 28, // 10000-10009
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 10010-10019
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 10020-10029
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 10030-10039
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 10040-10049
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10050-10059
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 10060-10069
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 10070-10079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10080-10089
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 10090-10099
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 10100-10109
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 10110-10119
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10120-10129
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 10130-10139
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10140-10149
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 10150-10159
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 10160-10169
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 10170-10179
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10180-10189
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 10190-10199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10200-10209
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10210-10219
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 10220-10229
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10230-10239
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 10240-10249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 10250-10259
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 10260-10269
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 10270-10279
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 10280-10289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10290-10299
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 10300-10309
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 10310-10319
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10320-10329
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 10330-10339
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 10340-10349
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 10350-10359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 10360-10369
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 10370-10379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10380-10389
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 28, // 10390-10399
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 10400-10409
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 10410-10419
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 10420-10429
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 10430-10439
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10440-10449
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 10450-10459
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 10460-10469
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 10470-10479
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 10480-10489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 10490-10499
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10500-10509
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 10510-10519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 10520-10529
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 10530-10539
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 10540-10549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 10550-10559
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 10560-10569
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 10570-10579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 10580-10589
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 10590-10599
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 10600-10609
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 10610-10619
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 10620-10629
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 10630-10639
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10640-10649
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 10650-10659
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 10660-10669
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 10670-10679
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 10680-10689
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 10690-10699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 10700-10709
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10710-10719
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 10720-10729
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 10730-10739
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10740-10749
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 10750-10759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10760-10769
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10770-10779
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 10780-10789
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 32, // 10790-10799
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 10800-10809
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 10810-10819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 10820-10829
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 10830-10839
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 10840-10849
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 10850-10859
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 10860-10869
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10870-10879
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 10880-10889
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10890-10899
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 28, // 10900-10909
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 10910-10919
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 10920-10929
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 10930-10939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 10940-10949
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 10950-10959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 10960-10969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 10970-10979
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 10980-10989
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 10990-10999
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 11000-11009
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11010-11019
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 11020-11029
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11030-11039
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 11040-11049
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 11050-11059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 11060-11069
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11070-11079
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 11080-11089
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 11090-11099
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11100-11109
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 11110-11119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11120-11129
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 11130-11139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 11140-11149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 11150-11159
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11160-11169
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 11170-11179
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11180-11189
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 11190-11199
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11200-11209
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 11210-11219
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 11220-11229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 11230-11239
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 11240-11249
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 11250-11259
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11260-11269
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 11270-11279
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 11280-11289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 11290-11299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11300-11309
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 11310-11319
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 11320-11329
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 11330-11339
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11340-11349
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 11350-11359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 11360-11369
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11370-11379
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 11380-11389
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 11390-11399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11400-11409
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11410-11419
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 11420-11429
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 11430-11439
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 11440-11449
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11450-11459
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 11460-11469
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11470-11479
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 11480-11489
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 11490-11499
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 11500-11509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 11510-11519
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 11520-11529
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 11530-11539
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 11540-11549
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 11550-11559
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 11560-11569
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 11570-11579
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 11580-11589
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 11590-11599
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11600-11609
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 11610-11619
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11620-11629
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 11630-11639
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11640-11649
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 11650-11659
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11660-11669
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 11670-11679
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 11680-11689
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 11690-11699
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11700-11709
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 11710-11719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11720-11729
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11730-11739
- 3, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 11740-11749
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 11750-11759
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11760-11769
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 11770-11779
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 11780-11789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11790-11799
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 11800-11809
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 11810-11819
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 11820-11829
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 24, // 11830-11839
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 11840-11849
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11850-11859
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 11860-11869
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11870-11879
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 11880-11889
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 11890-11899
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 11900-11909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11910-11919
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 11920-11929
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 11930-11939
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 11940-11949
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 11950-11959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 11960-11969
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 11970-11979
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 11980-11989
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 11990-11999
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12000-12009
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 12010-12019
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 12020-12029
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12030-12039
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 12040-12049
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 12050-12059
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12060-12069
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 12070-12079
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 12080-12089
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12090-12099
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 12100-12109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 24, // 12110-12119
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 12120-12129
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12130-12139
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 12140-12149
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12150-12159
- 1, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 12160-12169
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 12170-12179
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 12180-12189
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12190-12199
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 12200-12209
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 12210-12219
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 12220-12229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 12230-12239
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12240-12249
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 12250-12259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 12260-12269
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12270-12279
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 12280-12289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12290-12299
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 12300-12309
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12310-12319
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 12320-12329
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12330-12339
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 12340-12349
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 12350-12359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12360-12369
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 12370-12379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12380-12389
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12390-12399
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 12400-12409
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 12410-12419
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12420-12429
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 12430-12439
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12440-12449
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 12450-12459
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12460-12469
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 12470-12479
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12480-12489
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12490-12499
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 12500-12509
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 12510-12519
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 12520-12529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 12530-12539
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12540-12549
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 12550-12559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 12560-12569
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12570-12579
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 12580-12589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12590-12599
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12600-12609
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 12610-12619
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 12620-12629
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12630-12639
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12640-12649
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 12650-12659
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12660-12669
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 12670-12679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 12680-12689
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12690-12699
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 12700-12709
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 12710-12719
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 12720-12729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 12730-12739
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 12740-12749
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12750-12759
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 12760-12769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12770-12779
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12780-12789
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 12790-12799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 12800-12809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12810-12819
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 12820-12829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12830-12839
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12840-12849
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 12850-12859
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 12860-12869
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 12870-12879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 12880-12889
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 12890-12899
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 12900-12909
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 12910-12919
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 12920-12929
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12930-12939
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 12940-12949
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 12950-12959
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 12960-12969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 12970-12979
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 12980-12989
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 12990-12999
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 24, // 13000-13009
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 13010-13019
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13020-13029
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 13030-13039
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 13040-13049
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13050-13059
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 13060-13069
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 13070-13079
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13080-13089
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 13090-13099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 13100-13109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13110-13119
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 13120-13129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 13130-13139
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 13140-13149
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 13150-13159
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 13160-13169
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 13170-13179
- 3, 2, 1, 4, 3, 2, 1, 30, 29, 28, // 13180-13189
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 13190-13199
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 13200-13209
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 13210-13219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 13220-13229
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13230-13239
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 13240-13249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 13250-13259
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 13260-13269
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 13270-13279
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13280-13289
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 13290-13299
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 13300-13309
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 13310-13319
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 13320-13329
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 28, // 13330-13339
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 13340-13349
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 13350-13359
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 13360-13369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13370-13379
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 13380-13389
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 13390-13399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13400-13409
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 13410-13419
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 13420-13429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13430-13439
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13440-13449
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 13450-13459
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 13460-13469
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 13470-13479
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 13480-13489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 13490-13499
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13500-13509
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 13510-13519
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 13520-13529
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 13530-13539
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13540-13549
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 13550-13559
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 13560-13569
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 13570-13579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13580-13589
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 13590-13599
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13600-13609
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 13610-13619
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 13620-13629
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 13630-13639
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 13640-13649
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 13650-13659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 13660-13669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 13670-13679
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 13680-13689
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 13690-13699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 13700-13709
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13710-13719
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 13720-13729
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 13730-13739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13740-13749
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 13750-13759
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 13760-13769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13770-13779
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 13780-13789
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 13790-13799
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 13800-13809
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 13810-13819
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 13820-13829
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13830-13839
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 13840-13849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 13850-13859
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13860-13869
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 13870-13879
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 13880-13889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13890-13899
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 13900-13909
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 13910-13919
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 13920-13929
- 1, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 13930-13939
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 13940-13949
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 13950-13959
- 3, 2, 1, 4, 3, 2, 1, 30, 29, 28, // 13960-13969
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 13970-13979
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 13980-13989
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 13990-13999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 14000-14009
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 14010-14019
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 14020-14029
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 14030-14039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14040-14049
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 14050-14059
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14060-14069
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14070-14079
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 14080-14089
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 14090-14099
- 7, 6, 5, 4, 3, 2, 1, 36, 35, 34, // 14100-14109
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 14110-14119
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 14120-14129
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14130-14139
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 14140-14149
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 14150-14159
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14160-14169
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 14170-14179
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 14180-14189
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 14190-14199
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 14200-14209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14210-14219
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 14220-14229
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14230-14239
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 14240-14249
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 14250-14259
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 14260-14269
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14270-14279
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14280-14289
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 14290-14299
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 14300-14309
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14310-14319
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 14320-14329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14330-14339
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 14340-14349
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 14350-14359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 14360-14369
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 14370-14379
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 14380-14389
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14390-14399
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14400-14409
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 14410-14419
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 14420-14429
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 14430-14439
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 14440-14449
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14450-14459
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 14460-14469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 14470-14479
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 14480-14489
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14490-14499
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 14500-14509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 14510-14519
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14520-14529
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 14530-14539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 14540-14549
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14550-14559
- 1, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 14560-14569
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 14570-14579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14580-14589
- 1, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 14590-14599
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 14600-14609
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 14610-14619
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 14620-14629
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 14630-14639
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14640-14649
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 14650-14659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 14660-14669
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14670-14679
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 14680-14689
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 14690-14699
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14700-14709
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 14710-14719
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 14720-14729
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14730-14739
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 14740-14749
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 14750-14759
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14760-14769
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 14770-14779
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 14780-14789
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 14790-14799
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14800-14809
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 14810-14819
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14820-14829
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14830-14839
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 14840-14849
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 14850-14859
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 14860-14869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 14870-14879
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14880-14889
- 1, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 14890-14899
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 14900-14909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14910-14919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 14920-14929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 14930-14939
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 14940-14949
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 14950-14959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 14960-14969
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 14970-14979
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 14980-14989
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 14990-14999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15000-15009
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 15010-15019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15020-15029
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 15030-15039
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15040-15049
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 15050-15059
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15060-15069
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 15070-15079
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 15080-15089
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15090-15099
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 15100-15109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15110-15119
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15120-15129
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 15130-15139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 15140-15149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15150-15159
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15160-15169
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 15170-15179
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15180-15189
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 15190-15199
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 15200-15209
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 15210-15219
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15220-15229
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 15230-15239
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 15240-15249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 15250-15259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 15260-15269
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 15270-15279
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 15280-15289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 15290-15299
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15300-15309
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 15310-15319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 15320-15329
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 15330-15339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 15340-15349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 15350-15359
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15360-15369
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 15370-15379
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 15380-15389
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15390-15399
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15400-15409
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 15410-15419
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 15420-15429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 15430-15439
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 15440-15449
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15450-15459
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15460-15469
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 15470-15479
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 15480-15489
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 15490-15499
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15500-15509
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 15510-15519
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 15520-15529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15530-15539
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15540-15549
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 15550-15559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 15560-15569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15570-15579
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 15580-15589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15590-15599
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 15600-15609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 15610-15619
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 15620-15629
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15630-15639
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 15640-15649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15650-15659
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 15660-15669
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 15670-15679
- 3, 2, 1, 44, 43, 42, 41, 40, 39, 38, // 15680-15689
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 15690-15699
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 15700-15709
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 15710-15719
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 15720-15729
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 15730-15739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 15740-15749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15750-15759
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15760-15769
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 15770-15779
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 15780-15789
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15790-15799
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 15800-15809
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15810-15819
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 15820-15829
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 15830-15839
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 15840-15849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 15850-15859
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 15860-15869
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 15870-15879
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 15880-15889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15890-15899
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 15900-15909
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 15910-15919
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 15920-15929
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 15930-15939
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 15940-15949
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 15950-15959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15960-15969
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 15970-15979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15980-15989
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 15990-15999
- 1, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 16000-16009
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 16010-16019
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16020-16029
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 16030-16039
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 16040-16049
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16050-16059
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 16060-16069
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 16070-16079
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16080-16089
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16090-16099
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 16100-16109
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 16110-16119
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 16120-16129
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 16130-16139
- 1, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 16140-16149
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 16150-16159
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 16160-16169
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16170-16179
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 16180-16189
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 16190-16199
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 16200-16209
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16210-16219
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 16220-16229
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 16230-16239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 16240-16249
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 16250-16259
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16260-16269
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 16270-16279
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 16280-16289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16290-16299
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 16300-16309
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 16310-16319
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16320-16329
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 16330-16339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 16340-16349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16350-16359
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 16360-16369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16370-16379
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 16380-16389
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 16390-16399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16400-16409
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16410-16419
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16420-16429
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 16430-16439
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16440-16449
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 16450-16459
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 16460-16469
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16470-16479
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16480-16489
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 16490-16499
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 16500-16509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 16510-16519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 16520-16529
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 16530-16539
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16540-16549
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 16550-16559
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16560-16569
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 16570-16579
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 16580-16589
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16590-16599
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 16600-16609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 16610-16619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16620-16629
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 16630-16639
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 16640-16649
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16650-16659
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16660-16669
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 16670-16679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16680-16689
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 16690-16699
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 16700-16709
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 16710-16719
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 16720-16729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16730-16739
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 16740-16749
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 16750-16759
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 16760-16769
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 16770-16779
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 16780-16789
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 16790-16799
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16800-16809
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16810-16819
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 16820-16829
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16830-16839
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 16840-16849
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 16850-16859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16860-16869
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 16870-16879
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 16880-16889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16890-16899
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 16900-16909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 16910-16919
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 16920-16929
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16930-16939
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 16940-16949
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 16950-16959
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 16960-16969
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 16970-16979
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 16980-16989
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 16990-16999
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17000-17009
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17010-17019
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 17020-17029
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 17030-17039
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 17040-17049
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 17050-17059
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17060-17069
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 17070-17079
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17080-17089
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 17090-17099
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 17100-17109
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 17110-17119
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 17120-17129
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 17130-17139
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 17140-17149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 17150-17159
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 17160-17169
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17170-17179
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 17180-17189
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17190-17199
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 17200-17209
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 17210-17219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17220-17229
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 17230-17239
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17240-17249
- 7, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 17250-17259
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 17260-17269
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 17270-17279
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17280-17289
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 17290-17299
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17300-17309
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 17310-17319
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 17320-17329
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 17330-17339
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17340-17349
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 17350-17359
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17360-17369
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 17370-17379
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 17380-17389
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 17390-17399
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17400-17409
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 17410-17419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17420-17429
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17430-17439
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 17440-17449
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17450-17459
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 17460-17469
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 17470-17479
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 17480-17489
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 17490-17499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 17500-17509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 17510-17519
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 17520-17529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 17530-17539
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17540-17549
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 17550-17559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 17560-17569
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 17570-17579
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17580-17589
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 17590-17599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 17600-17609
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17610-17619
- 3, 2, 1, 4, 3, 2, 1, 30, 29, 28, // 17620-17629
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 17630-17639
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17640-17649
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 17650-17659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 17660-17669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17670-17679
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 17680-17689
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17690-17699
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 17700-17709
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 17710-17719
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 17720-17729
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 17730-17739
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 17740-17749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17750-17759
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 17760-17769
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17770-17779
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 17780-17789
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17790-17799
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 17800-17809
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17810-17819
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 17820-17829
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 17830-17839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17840-17849
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17850-17859
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 17860-17869
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17870-17879
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17880-17889
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 17890-17899
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 17900-17909
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17910-17919
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 17920-17929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 17930-17939
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 17940-17949
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 17950-17959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 17960-17969
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 17970-17979
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 24, // 17980-17989
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 17990-17999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18000-18009
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 18010-18019
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 18020-18029
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18030-18039
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 18040-18049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 18050-18059
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 18060-18069
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 18070-18079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 18080-18089
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 18090-18099
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 18100-18109
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 18110-18119
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 18120-18129
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 18130-18139
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 18140-18149
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 18150-18159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 18160-18169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18170-18179
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18180-18189
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 18190-18199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18200-18209
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 18210-18219
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 18220-18229
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 18230-18239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18240-18249
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 18250-18259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 18260-18269
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 18270-18279
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 18280-18289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18290-18299
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 18300-18309
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 18310-18319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 18320-18329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18330-18339
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18340-18349
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 18350-18359
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 18360-18369
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 18370-18379
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 18380-18389
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 18390-18399
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18400-18409
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 18410-18419
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 18420-18429
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 18430-18439
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 18440-18449
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 18450-18459
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 18460-18469
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18470-18479
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18480-18489
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 18490-18499
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 18500-18509
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 18510-18519
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 18520-18529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 18530-18539
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18540-18549
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 18550-18559
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 18560-18569
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18570-18579
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 18580-18589
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 18590-18599
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 18600-18609
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 18610-18619
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 18620-18629
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 18630-18639
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 18640-18649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18650-18659
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18660-18669
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 18670-18679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18680-18689
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18690-18699
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18700-18709
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 18710-18719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18720-18729
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18730-18739
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 18740-18749
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 18750-18759
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18760-18769
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 18770-18779
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 18780-18789
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 18790-18799
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 18800-18809
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 18810-18819
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 18820-18829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 18830-18839
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 18840-18849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 18850-18859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 18860-18869
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 18870-18879
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 18880-18889
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 18890-18899
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18900-18909
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 28, // 18910-18919
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 18920-18929
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 18930-18939
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 18940-18949
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 18950-18959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 18960-18969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 18970-18979
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 18980-18989
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 18990-18999
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 19000-19009
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 19010-19019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19020-19029
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 19030-19039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19040-19049
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 19050-19059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 19060-19069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 19070-19079
- 1, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 19080-19089
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 19090-19099
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 19100-19109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19110-19119
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 19120-19129
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 19130-19139
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 19140-19149
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 19150-19159
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 19160-19169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19170-19179
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 19180-19189
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 19190-19199
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 19200-19209
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 19210-19219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19220-19229
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 19230-19239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 19240-19249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 19250-19259
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 19260-19269
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 19270-19279
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 19280-19289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19290-19299
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 19300-19309
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 19310-19319
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 19320-19329
- 3, 2, 1, 40, 39, 38, 37, 36, 35, 34, // 19330-19339
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 19340-19349
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 19350-19359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 19360-19369
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 19370-19379
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 19380-19389
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 19390-19399
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 19400-19409
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 19410-19419
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 19420-19429
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 19430-19439
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 19440-19449
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 19450-19459
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 19460-19469
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 19470-19479
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 19480-19489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19490-19499
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 19500-19509
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 19510-19519
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19520-19529
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19530-19539
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 19540-19549
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 19550-19559
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19560-19569
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 19570-19579
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 19580-19589
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 19590-19599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 52, // 19600-19609
- 51, 50, 49, 48, 47, 46, 45, 44, 43, 42, // 19610-19619
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 19620-19629
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 19630-19639
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 19640-19649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19650-19659
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 19660-19669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19670-19679
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 19680-19689
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 19690-19699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 19700-19709
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 19710-19719
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 19720-19729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 19730-19739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19740-19749
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 19750-19759
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 19760-19769
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 19770-19779
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 19780-19789
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 19790-19799
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 19800-19809
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 19810-19819
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 19820-19829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19830-19839
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 19840-19849
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 19850-19859
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 19860-19869
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 19870-19879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 19880-19889
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 19890-19899
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 19900-19909
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 19910-19919
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 19920-19929
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 19930-19939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 19940-19949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19950-19959
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 19960-19969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 19970-19979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 19980-19989
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 19990-19999
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20000-20009
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20010-20019
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 20020-20029
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 20030-20039
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 20040-20049
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20050-20059
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 20060-20069
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 20070-20079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 20080-20089
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20090-20099
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 20100-20109
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 20110-20119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 20120-20129
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20130-20139
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 20140-20149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20150-20159
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20160-20169
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 20170-20179
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 20180-20189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20190-20199
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 20200-20209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 20210-20219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20220-20229
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 20230-20239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 20240-20249
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20250-20259
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 20260-20269
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 20270-20279
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 20280-20289
- 7, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 20290-20299
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 20300-20309
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20310-20319
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 20320-20329
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 20330-20339
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 20340-20349
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 20350-20359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 20360-20369
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 20370-20379
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 20380-20389
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 20390-20399
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 20400-20409
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 20410-20419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20420-20429
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20430-20439
- 1, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 20440-20449
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 20450-20459
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 20460-20469
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 20470-20479
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 20480-20489
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 20490-20499
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 20500-20509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20510-20519
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20520-20529
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 20530-20539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 20540-20549
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20550-20559
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 20560-20569
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 20570-20579
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20580-20589
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 20590-20599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20600-20609
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 20610-20619
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 20620-20629
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 20630-20639
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 20640-20649
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20650-20659
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 20660-20669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20670-20679
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20680-20689
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 20690-20699
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 20700-20709
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 20710-20719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20720-20729
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20730-20739
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 20740-20749
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 20750-20759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20760-20769
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 20770-20779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 20780-20789
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 20790-20799
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 40, // 20800-20809
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 20810-20819
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 20820-20829
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 20830-20839
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 20840-20849
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 20850-20859
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 20860-20869
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 20870-20879
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 20880-20889
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 20890-20899
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 20900-20909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20910-20919
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 20920-20929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 20930-20939
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 20940-20949
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 20950-20959
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 20960-20969
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20970-20979
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 20980-20989
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 20990-20999
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21000-21009
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 21010-21019
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 21020-21029
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 21030-21039
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 21040-21049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 21050-21059
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 21060-21069
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 21070-21079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 21080-21089
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21090-21099
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 21100-21109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21110-21119
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 21120-21129
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 21130-21139
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 21140-21149
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 21150-21159
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 21160-21169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 21170-21179
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 21180-21189
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 21190-21199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21200-21209
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21210-21219
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 21220-21229
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 21230-21239
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 21240-21249
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 21250-21259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 21260-21269
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 21270-21279
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 21280-21289
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 21290-21299
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 21300-21309
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 21310-21319
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 21320-21329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21330-21339
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 21340-21349
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 21350-21359
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 21360-21369
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 21370-21379
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 21380-21389
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 21390-21399
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 21400-21409
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 21410-21419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 21420-21429
- 3, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 21430-21439
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 21440-21449
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 21450-21459
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 21460-21469
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21470-21479
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 21480-21489
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 21490-21499
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 21500-21509
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 21510-21519
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 28, // 21520-21529
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 21530-21539
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 21540-21549
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 21550-21559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 21560-21569
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 21570-21579
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 21580-21589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 21590-21599
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21600-21609
- 1, 2, 1, 4, 3, 2, 1, 30, 29, 28, // 21610-21619
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 21620-21629
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 21630-21639
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 21640-21649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21650-21659
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 21660-21669
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 21670-21679
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 21680-21689
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21690-21699
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 21700-21709
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 21710-21719
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 21720-21729
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 21730-21739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21740-21749
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 21750-21759
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 21760-21769
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 21770-21779
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 21780-21789
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 21790-21799
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 21800-21809
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 21810-21819
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 21820-21829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 21830-21839
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21840-21849
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 21850-21859
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 21860-21869
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21870-21879
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 21880-21889
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 21890-21899
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21900-21909
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 21910-21919
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 21920-21929
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 21930-21939
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 21940-21949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21950-21959
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 21960-21969
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 21970-21979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 21980-21989
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 21990-21999
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 22000-22009
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 22010-22019
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 22020-22029
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 22030-22039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22040-22049
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22050-22059
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 22060-22069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 22070-22079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22080-22089
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 22090-22099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 22100-22109
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22110-22119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 22120-22129
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 22130-22139
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 22140-22149
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 22150-22159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22160-22169
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 22170-22179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 22180-22189
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 22190-22199
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 22200-22209
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 22210-22219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 22220-22229
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 22230-22239
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 22240-22249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 22250-22259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22260-22269
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 22270-22279
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 22280-22289
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22290-22299
- 3, 2, 1, 4, 3, 2, 1, 36, 35, 34, // 22300-22309
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 22310-22319
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 22320-22329
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22330-22339
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 22340-22349
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 22350-22359
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 22360-22369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22370-22379
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22380-22389
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 22390-22399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 22400-22409
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 22410-22419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22420-22429
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 22430-22439
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 22440-22449
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 22450-22459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 22460-22469
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22470-22479
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 22480-22489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22490-22499
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22500-22509
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 22510-22519
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22520-22529
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22530-22539
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 22540-22549
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 22550-22559
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 22560-22569
- 1, 2, 1, 40, 39, 38, 37, 36, 35, 34, // 22570-22579
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 22580-22589
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 22590-22599
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22600-22609
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 22610-22619
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 22620-22629
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 22630-22639
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 22640-22649
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 22650-22659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 22660-22669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 22670-22679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22680-22689
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 22690-22699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 22700-22709
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 22710-22719
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 22720-22729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 22730-22739
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22740-22749
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 22750-22759
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 22760-22769
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 22770-22779
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 22780-22789
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 22790-22799
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 22800-22809
- 1, 6, 5, 4, 3, 2, 1, 36, 35, 34, // 22810-22819
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 22820-22829
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 22830-22839
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22840-22849
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 22850-22859
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22860-22869
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 22870-22879
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 22880-22889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22890-22899
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 22900-22909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22910-22919
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 22920-22929
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 22930-22939
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 22940-22949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 22950-22959
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 22960-22969
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 22970-22979
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 22980-22989
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 22990-22999
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 23000-23009
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 23010-23019
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 23020-23029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 23030-23039
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23040-23049
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 23050-23059
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 23060-23069
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23070-23079
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 23080-23089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 23090-23099
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23100-23109
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 23110-23119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23120-23129
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23130-23139
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 23140-23149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 23150-23159
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 23160-23169
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 23170-23179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 23180-23189
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 23190-23199
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 23200-23209
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23210-23219
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 23220-23229
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 23230-23239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23240-23249
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 23250-23259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 23260-23269
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 23270-23279
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23280-23289
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 23290-23299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23300-23309
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23310-23319
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 23320-23329
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 23330-23339
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23340-23349
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 23350-23359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 23360-23369
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 23370-23379
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 23380-23389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 23390-23399
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23400-23409
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 23410-23419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23420-23429
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23430-23439
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 23440-23449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 23450-23459
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23460-23469
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 23470-23479
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23480-23489
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 23490-23499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 23500-23509
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 23510-23519
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23520-23529
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 23530-23539
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 23540-23549
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 23550-23559
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 23560-23569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23570-23579
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23580-23589
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 23590-23599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 23600-23609
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23610-23619
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 23620-23629
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 23630-23639
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 23640-23649
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23650-23659
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 23660-23669
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 23670-23679
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 30, // 23680-23689
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 23690-23699
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 23700-23709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 23710-23719
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 23720-23729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23730-23739
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 23740-23749
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 23750-23759
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 23760-23769
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 23770-23779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 23780-23789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23790-23799
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23800-23809
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 23810-23819
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 23820-23829
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 23830-23839
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23840-23849
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 23850-23859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 23860-23869
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 23870-23879
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 23880-23889
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 23890-23899
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 23900-23909
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 23910-23919
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 28, // 23920-23929
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 23930-23939
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 23940-23949
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 23950-23959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 23960-23969
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 23970-23979
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 23980-23989
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 23990-23999
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 24000-24009
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 24010-24019
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 24020-24029
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24030-24039
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 24040-24049
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24050-24059
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24060-24069
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 24070-24079
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 24080-24089
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 24090-24099
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 24100-24109
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 24110-24119
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24120-24129
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 24130-24139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24140-24149
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 24150-24159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 24160-24169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 24170-24179
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 24180-24189
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 24190-24199
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 24200-24209
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24210-24219
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 24220-24229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 24230-24239
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 24240-24249
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 24250-24259
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 24260-24269
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24270-24279
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 24280-24289
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 24290-24299
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 24300-24309
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 24310-24319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 24320-24329
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 24330-24339
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 24340-24349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 24350-24359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24360-24369
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 24370-24379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24380-24389
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 24390-24399
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 24400-24409
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 24410-24419
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 24420-24429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 24430-24439
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 24440-24449
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 24450-24459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 24460-24469
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 24470-24479
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 24480-24489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 24490-24499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 24500-24509
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 24510-24519
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 24520-24529
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 24530-24539
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 24540-24549
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 24550-24559
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24560-24569
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 24570-24579
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24580-24589
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 24590-24599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24600-24609
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24610-24619
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 24620-24629
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 24630-24639
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 24640-24649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 24650-24659
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24660-24669
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 24670-24679
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 24680-24689
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 24690-24699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 24700-24709
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 24710-24719
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24720-24729
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 24730-24739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 24740-24749
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24750-24759
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 24760-24769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24770-24779
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24780-24789
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 24790-24799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 24800-24809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24810-24819
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 24820-24829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 24830-24839
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 24840-24849
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 24850-24859
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 24860-24869
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 24870-24879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 24880-24889
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 24890-24899
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 24900-24909
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 24910-24919
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 24920-24929
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 24930-24939
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 24940-24949
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 24950-24959
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 24960-24969
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 24970-24979
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 24980-24989
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 24990-24999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25000-25009
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 25010-25019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25020-25029
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 25030-25039
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 25040-25049
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 25050-25059
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25060-25069
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 25070-25079
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 25080-25089
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 25090-25099
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25100-25109
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 25110-25119
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 25120-25129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 25130-25139
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 25140-25149
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 25150-25159
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 25160-25169
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25170-25179
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 25180-25189
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 25190-25199
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 25200-25209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 25210-25219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 25220-25229
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 25230-25239
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 25240-25249
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 25250-25259
- 1, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 25260-25269
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 25270-25279
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 25280-25289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25290-25299
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 25300-25309
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25310-25319
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 25320-25329
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 25330-25339
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 25340-25349
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 25350-25359
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 25360-25369
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 25370-25379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25380-25389
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 25390-25399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 25400-25409
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25410-25419
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 25420-25429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 25430-25439
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 25440-25449
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 25450-25459
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 25460-25469
- 1, 52, 51, 50, 49, 48, 47, 46, 45, 44, // 25470-25479
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 25480-25489
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 25490-25499
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 25500-25509
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25510-25519
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 25520-25529
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 25530-25539
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 25540-25549
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25550-25559
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 25560-25569
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 25570-25579
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 25580-25589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25590-25599
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 25600-25609
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25610-25619
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25620-25629
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 25630-25639
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 25640-25649
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 25650-25659
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 25660-25669
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 25670-25679
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25680-25689
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 25690-25699
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 25700-25709
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 25710-25719
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25720-25729
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 25730-25739
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 25740-25749
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 25750-25759
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 25760-25769
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 25770-25779
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25780-25789
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 25790-25799
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 25800-25809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 25810-25819
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 25820-25829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25830-25839
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 25840-25849
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 25850-25859
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 25860-25869
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 25870-25879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 25880-25889
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 25890-25899
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 25900-25909
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 25910-25919
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25920-25929
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 25930-25939
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 25940-25949
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 25950-25959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 25960-25969
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 25970-25979
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 25980-25989
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 25990-25999
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 26000-26009
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 26010-26019
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 26020-26029
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26030-26039
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26040-26049
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 26050-26059
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 26060-26069
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26070-26079
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 26080-26089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 26090-26099
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 26100-26109
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 26110-26119
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 26120-26129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26130-26139
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26140-26149
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 26150-26159
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26160-26169
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 26170-26179
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 26180-26189
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26190-26199
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 26200-26209
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 26210-26219
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 26220-26229
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 26230-26239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 26240-26249
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26250-26259
- 1, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 26260-26269
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 26270-26279
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26280-26289
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 26290-26299
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 26300-26309
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 26310-26319
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 26320-26329
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 26330-26339
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 26340-26349
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 26350-26359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26360-26369
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 26370-26379
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 26380-26389
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 26390-26399
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 26400-26409
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 26410-26419
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 26420-26429
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 26430-26439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 26440-26449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 26450-26459
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 26460-26469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 26470-26479
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 26480-26489
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 26490-26499
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26500-26509
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 26510-26519
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 26520-26529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 26530-26539
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 26540-26549
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 26550-26559
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26560-26569
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 26570-26579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26580-26589
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 26590-26599
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 26600-26609
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 26610-26619
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 26620-26629
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 26630-26639
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 26640-26649
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 26650-26659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 26660-26669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26670-26679
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 26680-26689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 26690-26699
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26700-26709
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 26710-26719
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 26720-26729
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 26730-26739
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 26740-26749
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 26750-26759
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 26760-26769
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 26770-26779
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 26780-26789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26790-26799
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26800-26809
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 26810-26819
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 26820-26829
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 26830-26839
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 26840-26849
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26850-26859
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 26860-26869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 26870-26879
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26880-26889
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 26890-26899
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 26900-26909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26910-26919
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 26920-26929
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 26930-26939
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 26940-26949
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 26950-26959
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 26960-26969
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 26970-26979
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 26980-26989
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 26990-26999
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27000-27009
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 27010-27019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27020-27029
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27030-27039
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 27040-27049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 27050-27059
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 27060-27069
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 27070-27079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27080-27089
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27090-27099
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 18, // 27100-27109
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27110-27119
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 27120-27129
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27130-27139
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 27140-27149
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 27150-27159
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 27160-27169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 27170-27179
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27180-27189
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 27190-27199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27200-27209
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 27210-27219
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 27220-27229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 27230-27239
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27240-27249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 27250-27259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27260-27269
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 27270-27279
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 27280-27289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 27290-27299
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 27300-27309
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 27310-27319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 27320-27329
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 27330-27339
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 27340-27349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27350-27359
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 27360-27369
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 27370-27379
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27380-27389
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 27390-27399
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 27400-27409
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27410-27419
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 27420-27429
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 27430-27439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 27440-27449
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 27450-27459
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 27460-27469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 27470-27479
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 27480-27489
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 27490-27499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 27500-27509
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27510-27519
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 27520-27529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 27530-27539
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27540-27549
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 27550-27559
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 27560-27569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27570-27579
- 1, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 27580-27589
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 27590-27599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27600-27609
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 27610-27619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27620-27629
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27630-27639
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 27640-27649
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 27650-27659
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27660-27669
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 27670-27679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 27680-27689
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 27690-27699
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 27700-27709
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 27710-27719
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27720-27729
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 27730-27739
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 27740-27749
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27750-27759
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 27760-27769
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 27770-27779
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27780-27789
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 27790-27799
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 27800-27809
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 27810-27819
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 27820-27829
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27830-27839
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 27840-27849
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 27850-27859
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 27860-27869
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27870-27879
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 27880-27889
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 27890-27899
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 27900-27909
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 27910-27919
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 27920-27929
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 27930-27939
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 27940-27949
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 27950-27959
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 27960-27969
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 27970-27979
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 27980-27989
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 27990-27999
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 28000-28009
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 28010-28019
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 28020-28029
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 28030-28039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28040-28049
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 28050-28059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 28060-28069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28070-28079
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 28080-28089
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 28090-28099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 28100-28109
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28110-28119
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 28120-28129
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 28130-28139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28140-28149
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28150-28159
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 28160-28169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28170-28179
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 28180-28189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28190-28199
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28200-28209
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 28210-28219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 48, // 28220-28229
- 47, 46, 45, 44, 43, 42, 41, 40, 39, 38, // 28230-28239
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 28240-28249
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 28250-28259
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 28260-28269
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 28270-28279
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 28280-28289
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 28290-28299
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 28300-28309
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 28310-28319
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 28320-28329
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 28330-28339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 28340-28349
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 28350-28359
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 28360-28369
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 28370-28379
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 28380-28389
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 28390-28399
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 28400-28409
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 28410-28419
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 28420-28429
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 28430-28439
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 28440-28449
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28450-28459
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 28460-28469
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 28470-28479
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28480-28489
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 28490-28499
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28500-28509
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 28510-28519
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 28520-28529
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 28530-28539
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 28540-28549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 28550-28559
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28560-28569
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 28570-28579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28580-28589
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 28590-28599
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 28600-28609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 28610-28619
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 28620-28629
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28630-28639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 28640-28649
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 28650-28659
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 28660-28669
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 28670-28679
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 28680-28689
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 28690-28699
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 28700-28709
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 28710-28719
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 28720-28729
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 28730-28739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28740-28749
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 28750-28759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28760-28769
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 28770-28779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 28780-28789
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 28790-28799
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 28800-28809
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 28810-28819
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 28820-28829
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 28830-28839
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 28840-28849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 28850-28859
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 28860-28869
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 28870-28879
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 28880-28889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28890-28899
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 28900-28909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28910-28919
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 28920-28929
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 28930-28939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 28940-28949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 28950-28959
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 28960-28969
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 28970-28979
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 28980-28989
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 28990-28999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 29000-29009
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 29010-29019
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 29020-29029
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 29030-29039
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 29040-29049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 29050-29059
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 29060-29069
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 29070-29079
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 29080-29089
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29090-29099
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 29100-29109
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29110-29119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 29120-29129
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 29130-29139
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 29140-29149
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 29150-29159
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 29160-29169
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 29170-29179
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29180-29189
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29190-29199
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 29200-29209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29210-29219
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29220-29229
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29230-29239
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 29240-29249
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 29250-29259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 29260-29269
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29270-29279
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 29280-29289
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 29290-29299
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 29300-29309
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29310-29319
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 29320-29329
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 29330-29339
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 29340-29349
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29350-29359
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 29360-29369
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29370-29379
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 29380-29389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 29390-29399
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29400-29409
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29410-29419
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 29420-29429
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 29430-29439
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 29440-29449
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 29450-29459
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29460-29469
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 29470-29479
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 29480-29489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29490-29499
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 29500-29509
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29510-29519
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 29520-29529
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 29530-29539
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 29540-29549
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29550-29559
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 29560-29569
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 29570-29579
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 29580-29589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 29590-29599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29600-29609
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 29610-29619
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 29620-29629
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 29630-29639
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 29640-29649
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29650-29659
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 29660-29669
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29670-29679
- 3, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 29680-29689
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 29690-29699
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29700-29709
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 29710-29719
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 29720-29729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29730-29739
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29740-29749
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 29750-29759
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 29760-29769
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 29770-29779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 29780-29789
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29790-29799
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 29800-29809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 29810-29819
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29820-29829
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 29830-29839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 29840-29849
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29850-29859
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 29860-29869
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 29870-29879
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 29880-29889
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 29890-29899
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29900-29909
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 29910-29919
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 29920-29929
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 29930-29939
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 29940-29949
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 29950-29959
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 29960-29969
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 29970-29979
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 29980-29989
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 29990-29999
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30000-30009
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 30010-30019
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 30020-30029
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 30030-30039
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 30040-30049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 30050-30059
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30060-30069
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 30070-30079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 30080-30089
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30090-30099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 30100-30109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 30110-30119
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30120-30129
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 30130-30139
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 30140-30149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30150-30159
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 30160-30169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30170-30179
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 30180-30189
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30190-30199
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 30200-30209
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30210-30219
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 30220-30229
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30230-30239
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30240-30249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 30250-30259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 30260-30269
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 30270-30279
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30280-30289
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 30290-30299
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30300-30309
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 30310-30319
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 30320-30329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30330-30339
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 30340-30349
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 30350-30359
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 30360-30369
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 30370-30379
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 30380-30389
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30390-30399
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 30400-30409
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 30410-30419
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 30420-30429
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 30430-30439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 30440-30449
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 30450-30459
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 30460-30469
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 30470-30479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30480-30489
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 30490-30499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 30500-30509
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 30510-30519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 30520-30529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 30530-30539
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30540-30549
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 18, // 30550-30559
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 30560-30569
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 30570-30579
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30580-30589
- 3, 2, 1, 38, 37, 36, 35, 34, 33, 32, // 30590-30599
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 30600-30609
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 30610-30619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30620-30629
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30630-30639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 30640-30649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30650-30659
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30660-30669
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 30670-30679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 30680-30689
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30690-30699
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 30700-30709
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 30710-30719
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 30720-30729
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 30730-30739
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 30740-30749
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30750-30759
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 30760-30769
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 30770-30779
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 30780-30789
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30790-30799
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 30800-30809
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 30810-30819
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 30820-30829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 30830-30839
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30840-30849
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 30850-30859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 30860-30869
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30870-30879
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 30880-30889
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 30890-30899
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30900-30909
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 30910-30919
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30920-30929
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 30930-30939
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 30940-30949
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 30950-30959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 30960-30969
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 30970-30979
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 30980-30989
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 30990-30999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31000-31009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 31010-31019
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31020-31029
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 31030-31039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31040-31049
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31050-31059
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 31060-31069
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 31070-31079
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31080-31089
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 31090-31099
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 31100-31109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31110-31119
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 31120-31129
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 31130-31139
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 31140-31149
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 31150-31159
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31160-31169
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 31170-31179
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 31180-31189
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 31190-31199
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 31200-31209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 31210-31219
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 31220-31229
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 31230-31239
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 31240-31249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 31250-31259
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 31260-31269
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 31270-31279
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 31280-31289
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31290-31299
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 31300-31309
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 31310-31319
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 31320-31329
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 31330-31339
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31340-31349
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 31350-31359
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 31360-31369
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 31370-31379
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 31380-31389
- 1, 2, 1, 4, 3, 2, 1, 72, 71, 70, // 31390-31399
- 69, 68, 67, 66, 65, 64, 63, 62, 61, 60, // 31400-31409
- 59, 58, 57, 56, 55, 54, 53, 52, 51, 50, // 31410-31419
- 49, 48, 47, 46, 45, 44, 43, 42, 41, 40, // 31420-31429
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 31430-31439
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 31440-31449
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 31450-31459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 31460-31469
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 31470-31479
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 31480-31489
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 31490-31499
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31500-31509
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 31510-31519
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31520-31529
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31530-31539
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 31540-31549
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31550-31559
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 31560-31569
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 31570-31579
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 31580-31589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31590-31599
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 31600-31609
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31610-31619
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 31620-31629
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31630-31639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 31640-31649
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 31650-31659
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 31660-31669
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31670-31679
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 31680-31689
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 31690-31699
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 31700-31709
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31710-31719
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 31720-31729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31730-31739
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31740-31749
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 31750-31759
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 31760-31769
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 31770-31779
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31780-31789
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 31790-31799
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31800-31809
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 31810-31819
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 31820-31829
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31830-31839
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 31840-31849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 31850-31859
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31860-31869
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 31870-31879
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 31880-31889
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31890-31899
- 7, 6, 5, 4, 3, 2, 1, 50, 49, 48, // 31900-31909
- 47, 46, 45, 44, 43, 42, 41, 40, 39, 38, // 31910-31919
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 31920-31929
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 31930-31939
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 31940-31949
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 31950-31959
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 31960-31969
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 31970-31979
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 31980-31989
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 31990-31999
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 32000-32009
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32010-32019
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 32020-32029
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32030-32039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32040-32049
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 32050-32059
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 32060-32069
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 32070-32079
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 32080-32089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 32090-32099
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32100-32109
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 32110-32119
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32120-32129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32130-32139
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 32140-32149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 32150-32159
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32160-32169
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 32170-32179
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 32180-32189
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32190-32199
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 32200-32209
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 32210-32219
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32220-32229
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 32230-32239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32240-32249
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 32250-32259
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 32260-32269
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 32270-32279
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32280-32289
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 32290-32299
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 32300-32309
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32310-32319
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 32320-32329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32330-32339
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32340-32349
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 32350-32359
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 32360-32369
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 32370-32379
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32380-32389
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32390-32399
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32400-32409
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 32410-32419
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 32420-32429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32430-32439
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 32440-32449
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32450-32459
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 32460-32469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 32470-32479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32480-32489
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 32490-32499
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 32500-32509
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32510-32519
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32520-32529
- 1, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 32530-32539
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32540-32549
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32550-32559
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 32560-32569
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 32570-32579
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 32580-32589
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32590-32599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 32600-32609
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32610-32619
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32620-32629
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 32630-32639
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 32640-32649
- 3, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 32650-32659
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 32660-32669
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32670-32679
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 32680-32689
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 32690-32699
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 32700-32709
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 30, // 32710-32719
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 32720-32729
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 32730-32739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 32740-32749
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32750-32759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32760-32769
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 32770-32779
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 32780-32789
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 32790-32799
- 1, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 32800-32809
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 32810-32819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 32820-32829
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 32830-32839
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 32840-32849
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 32850-32859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 32860-32869
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32870-32879
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 32880-32889
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 32890-32899
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 32900-32909
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 32910-32919
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32920-32929
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 32930-32939
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 32940-32949
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 32950-32959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 32960-32969
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 32970-32979
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 32980-32989
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 32990-32999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33000-33009
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 33010-33019
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 33020-33029
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 33030-33039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 33040-33049
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 33050-33059
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33060-33069
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 33070-33079
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 33080-33089
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33090-33099
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 33100-33109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 33110-33119
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 33120-33129
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 33130-33139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 33140-33149
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33150-33159
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 33160-33169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 33170-33179
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33180-33189
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 33190-33199
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 33200-33209
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33210-33219
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 33220-33229
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33230-33239
- 7, 6, 5, 4, 3, 2, 1, 40, 39, 38, // 33240-33249
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 33250-33259
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 33260-33269
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33270-33279
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 33280-33289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33290-33299
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33300-33309
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 33310-33319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 33320-33329
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33330-33339
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 33340-33349
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 33350-33359
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33360-33369
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 33370-33379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33380-33389
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33390-33399
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 33400-33409
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 33410-33419
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 33420-33429
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 33430-33439
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33440-33449
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 33450-33459
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 33460-33469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 33470-33479
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 33480-33489
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 33490-33499
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 33500-33509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33510-33519
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 33520-33529
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 33530-33539
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 33540-33549
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33550-33559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 33560-33569
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 33570-33579
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 33580-33589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 33590-33599
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33600-33609
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 33610-33619
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 33620-33629
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 33630-33639
- 1, 6, 5, 4, 3, 2, 1, 32, 31, 30, // 33640-33649
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 33650-33659
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 33660-33669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 33670-33679
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 33680-33689
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33690-33699
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 33700-33709
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 33710-33719
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 33720-33729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 33730-33739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 33740-33749
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 33750-33759
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 33760-33769
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 33770-33779
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33780-33789
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 33790-33799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 33800-33809
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33810-33819
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 33820-33829
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 33830-33839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33840-33849
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 33850-33859
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 33860-33869
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 33870-33879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 33880-33889
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 33890-33899
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33900-33909
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 33910-33919
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 33920-33929
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 33930-33939
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 33940-33949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 33950-33959
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 33960-33969
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 33970-33979
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 33980-33989
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 33990-33999
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 34000-34009
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 34010-34019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34020-34029
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 34030-34039
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 34040-34049
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 34050-34059
- 1, 62, 61, 60, 59, 58, 57, 56, 55, 54, // 34060-34069
- 53, 52, 51, 50, 49, 48, 47, 46, 45, 44, // 34070-34079
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 34080-34089
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 34090-34099
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 34100-34109
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34110-34119
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 34120-34129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34130-34139
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 34140-34149
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 34150-34159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34160-34169
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34170-34179
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 34180-34189
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 34190-34199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34200-34209
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 34210-34219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34220-34229
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 34230-34239
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34240-34249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 34250-34259
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 34260-34269
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 34270-34279
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 34280-34289
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 34290-34299
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 34300-34309
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 34310-34319
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 34320-34329
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 34330-34339
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34340-34349
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34350-34359
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 34360-34369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34370-34379
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 34380-34389
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34390-34399
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 34400-34409
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34410-34419
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 34420-34429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 34430-34439
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 34440-34449
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 34450-34459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 34460-34469
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34470-34479
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 34480-34489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 34490-34499
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34500-34509
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 34510-34519
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 34520-34529
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 34530-34539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 34, // 34540-34549
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 34550-34559
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 34560-34569
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34570-34579
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 34580-34589
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34590-34599
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 34600-34609
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 34610-34619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34620-34629
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 34630-34639
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 34640-34649
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 34650-34659
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 34660-34669
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 34670-34679
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 34680-34689
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 34690-34699
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 34700-34709
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34710-34719
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 34720-34729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 34730-34739
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 34740-34749
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 34750-34759
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 34760-34769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34770-34779
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 34780-34789
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 34790-34799
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 34800-34809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 34810-34819
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 34820-34829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34830-34839
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 34840-34849
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 34850-34859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34860-34869
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 34870-34879
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 34880-34889
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 34890-34899
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 34900-34909
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 34910-34919
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 34920-34929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 34930-34939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 34940-34949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34950-34959
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 34960-34969
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 34970-34979
- 1, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 34980-34989
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 34990-34999
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 35000-35009
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 35010-35019
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 35020-35029
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35030-35039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35040-35049
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 35050-35059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 35060-35069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35070-35079
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 35080-35089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 35090-35099
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 35100-35109
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 35110-35119
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 35120-35129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35130-35139
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 35140-35149
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 35150-35159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35160-35169
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 35170-35179
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35180-35189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35190-35199
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35200-35209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35210-35219
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 35220-35229
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35230-35239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35240-35249
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 35250-35259
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 35260-35269
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 35270-35279
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35280-35289
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35290-35299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35300-35309
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 35310-35319
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 35320-35329
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 35330-35339
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 35340-35349
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 35350-35359
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 35360-35369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35370-35379
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 35380-35389
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 35390-35399
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 35400-35409
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 35410-35419
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 35420-35429
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 35430-35439
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 35440-35449
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35450-35459
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 35460-35469
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35470-35479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35480-35489
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 35490-35499
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 35500-35509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35510-35519
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 35520-35529
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 35530-35539
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 35540-35549
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 35550-35559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 35560-35569
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 35570-35579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35580-35589
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 35590-35599
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 35600-35609
- 7, 6, 5, 4, 3, 2, 1, 54, 53, 52, // 35610-35619
- 51, 50, 49, 48, 47, 46, 45, 44, 43, 42, // 35620-35629
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 35630-35639
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 35640-35649
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35650-35659
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35660-35669
- 1, 6, 5, 4, 3, 2, 1, 52, 51, 50, // 35670-35679
- 49, 48, 47, 46, 45, 44, 43, 42, 41, 40, // 35680-35689
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 35690-35699
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 35700-35709
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 35710-35719
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 35720-35729
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 35730-35739
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 35740-35749
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 35750-35759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35760-35769
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 35770-35779
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 35780-35789
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 35790-35799
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 35800-35809
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 35810-35819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35820-35829
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 35830-35839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35840-35849
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 35850-35859
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 35860-35869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 35870-35879
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 35880-35889
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 35890-35899
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35900-35909
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 35910-35919
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 35920-35929
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 35930-35939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 35940-35949
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 35950-35959
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 35960-35969
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 35970-35979
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 35980-35989
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 35990-35999
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 36000-36009
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 36010-36019
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 36020-36029
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 36030-36039
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 36040-36049
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36050-36059
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 36060-36069
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 36070-36079
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 36080-36089
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 36090-36099
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 36100-36109
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 36110-36119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36120-36129
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 36130-36139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36140-36149
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36150-36159
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 36160-36169
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 36170-36179
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 36180-36189
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 36190-36199
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 36200-36209
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 36210-36219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 36220-36229
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36230-36239
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36240-36249
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36250-36259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 36260-36269
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 36270-36279
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36280-36289
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 36290-36299
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 36300-36309
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 36310-36319
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 36320-36329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36330-36339
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 36340-36349
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 36350-36359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36360-36369
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 36370-36379
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 44, // 36380-36389
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 36390-36399
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 36400-36409
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 36410-36419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36420-36429
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 36430-36439
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36440-36449
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 36450-36459
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 36460-36469
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 36470-36479
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36480-36489
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 36490-36499
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 36500-36509
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36510-36519
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 36520-36529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36530-36539
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36540-36549
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 36550-36559
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 36560-36569
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36570-36579
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 36580-36589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 36590-36599
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 36600-36609
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 36610-36619
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 36620-36629
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 36630-36639
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 36640-36649
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 36650-36659
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36660-36669
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 36670-36679
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 36680-36689
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 36690-36699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 36700-36709
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 36710-36719
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 36720-36729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 36730-36739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 36740-36749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36750-36759
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 36760-36769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 36770-36779
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 36780-36789
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 36790-36799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 36800-36809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36810-36819
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36820-36829
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 36830-36839
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 36840-36849
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 36850-36859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 36860-36869
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 36870-36879
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 36880-36889
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 36890-36899
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36900-36909
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 36910-36919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 36920-36929
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36930-36939
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 36940-36949
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 36950-36959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 36960-36969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 36970-36979
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 36980-36989
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 36990-36999
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 37000-37009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 37010-37019
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 37020-37029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 37030-37039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 37040-37049
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 37050-37059
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 37060-37069
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37070-37079
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 37080-37089
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 37090-37099
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37100-37109
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 37110-37119
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 37120-37129
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 37130-37139
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 37140-37149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 37150-37159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37160-37169
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37170-37179
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 37180-37189
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 37190-37199
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37200-37209
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 37210-37219
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 37220-37229
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 37230-37239
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 37240-37249
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 37250-37259
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 37260-37269
- 3, 2, 1, 4, 3, 2, 1, 30, 29, 28, // 37270-37279
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 37280-37289
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37290-37299
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 37300-37309
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 37310-37319
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37320-37329
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 37330-37339
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37340-37349
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 37350-37359
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 37360-37369
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 37370-37379
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37380-37389
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 37390-37399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 37400-37409
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 37410-37419
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 37420-37429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37430-37439
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 37440-37449
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 37450-37459
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 37460-37469
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 37470-37479
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 37480-37489
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 37490-37499
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 37500-37509
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 37510-37519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 37520-37529
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 37530-37539
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 37540-37549
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37550-37559
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 37560-37569
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 37570-37579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 37580-37589
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37590-37599
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 37600-37609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 37610-37619
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 37620-37629
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 37630-37639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 37640-37649
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 37650-37659
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 37660-37669
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 37670-37679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37680-37689
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 37690-37699
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37700-37709
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 37710-37719
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 37720-37729
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37730-37739
- 7, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 37740-37749
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 37750-37759
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 37760-37769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37770-37779
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 37780-37789
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 37790-37799
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37800-37809
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 37810-37819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37820-37829
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37830-37839
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 37840-37849
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 37850-37859
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37860-37869
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 37870-37879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 37880-37889
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 37890-37899
- 7, 6, 5, 4, 3, 2, 1, 44, 43, 42, // 37900-37909
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 37910-37919
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 37920-37929
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 37930-37939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 37940-37949
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 37950-37959
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 37960-37969
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 37970-37979
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 37980-37989
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 37990-37999
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38000-38009
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 38010-38019
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 38020-38029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 38030-38039
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 38040-38049
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 38050-38059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 38060-38069
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38070-38079
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 38080-38089
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 38090-38099
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38100-38109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 38110-38119
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 38120-38129
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 38130-38139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 38140-38149
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 38150-38159
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 38160-38169
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 38170-38179
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 38180-38189
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 38190-38199
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 38200-38209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 38210-38219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38220-38229
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 38230-38239
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 38240-38249
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38250-38259
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38260-38269
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 38270-38279
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 38280-38289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 38290-38299
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 38300-38309
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 38310-38319
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 38320-38329
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 38330-38339
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38340-38349
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 38350-38359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38360-38369
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 38370-38379
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38380-38389
- 3, 2, 1, 38, 37, 36, 35, 34, 33, 32, // 38390-38399
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 38400-38409
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 38410-38419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38420-38429
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 38430-38439
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 38440-38449
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 38450-38459
- 1, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 38460-38469
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 38470-38479
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 38480-38489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38490-38499
- 1, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 38500-38509
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 38510-38519
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 38520-38529
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38530-38539
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 38540-38549
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 38550-38559
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 24, // 38560-38569
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 38570-38579
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38580-38589
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 38590-38599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 38600-38609
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 38610-38619
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 38620-38629
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 38630-38639
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38640-38649
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 38650-38659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 38660-38669
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 38670-38679
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38680-38689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 38690-38699
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 38700-38709
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 38710-38719
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 38720-38729
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 38730-38739
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 38740-38749
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 38750-38759
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 38760-38769
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38770-38779
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 38780-38789
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38790-38799
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 38800-38809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38810-38819
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38820-38829
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 38830-38839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38840-38849
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38850-38859
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 38860-38869
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 38870-38879
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38880-38889
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38890-38899
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 38900-38909
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 38910-38919
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 38920-38929
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 38930-38939
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38940-38949
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 38950-38959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 38960-38969
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 38970-38979
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 38980-38989
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 38990-38999
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39000-39009
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 39010-39019
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 39020-39029
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39030-39039
- 1, 2, 1, 4, 3, 2, 1, 32, 31, 30, // 39040-39049
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 39050-39059
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39060-39069
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 39070-39079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 39080-39089
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 39090-39099
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 39100-39109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 39110-39119
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 39120-39129
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 39130-39139
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 39140-39149
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 39150-39159
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 39160-39169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39170-39179
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39180-39189
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 39190-39199
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 39200-39209
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 39210-39219
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 39220-39229
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 39230-39239
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39240-39249
- 1, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 39250-39259
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 39260-39269
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 39270-39279
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 39280-39289
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 39290-39299
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 39300-39309
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 39310-39319
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 39320-39329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39330-39339
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 39340-39349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 39350-39359
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 39360-39369
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 39370-39379
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 39380-39389
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 39390-39399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 39400-39409
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 39410-39419
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39420-39429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 39430-39439
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 39440-39449
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39450-39459
- 1, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 39460-39469
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 39470-39479
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39480-39489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 39490-39499
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 39500-39509
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39510-39519
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 39520-39529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39530-39539
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39540-39549
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 39550-39559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 39560-39569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39570-39579
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 39580-39589
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 39590-39599
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 39600-39609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 39610-39619
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 39620-39629
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 39630-39639
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39640-39649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 39650-39659
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 39660-39669
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 39670-39679
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 39680-39689
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 39690-39699
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 39700-39709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 39710-39719
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 39720-39729
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 39730-39739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 39740-39749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39750-39759
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 39760-39769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 39770-39779
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39780-39789
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 39790-39799
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 39800-39809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39810-39819
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 39820-39829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 39830-39839
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 39840-39849
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 39850-39859
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 39860-39869
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 39870-39879
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 39880-39889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39890-39899
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 39900-39909
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39910-39919
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 39920-39929
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 39930-39939
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 39940-39949
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 39950-39959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 39960-39969
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 39970-39979
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 39980-39989
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 39990-39999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 40000-40009
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 40010-40019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40020-40029
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 24, // 40030-40039
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 40040-40049
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40050-40059
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 40060-40069
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40070-40079
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 40080-40089
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 40090-40099
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40100-40109
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40110-40119
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 40120-40129
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 40130-40139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40140-40149
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 40150-40159
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 40160-40169
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 40170-40179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 40180-40189
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 40190-40199
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40200-40209
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 40210-40219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40220-40229
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 40230-40239
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40240-40249
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 40250-40259
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40260-40269
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 40270-40279
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 54, // 40280-40289
- 53, 52, 51, 50, 49, 48, 47, 46, 45, 44, // 40290-40299
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 40300-40309
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 40310-40319
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 40320-40329
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40330-40339
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 40340-40349
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 40350-40359
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 40360-40369
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40370-40379
- 7, 6, 5, 4, 3, 2, 1, 36, 35, 34, // 40380-40389
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 40390-40399
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 40400-40409
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40410-40419
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 40420-40429
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 40430-40439
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 40440-40449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 40450-40459
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40460-40469
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40470-40479
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 40480-40489
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 40490-40499
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 40500-40509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 40510-40519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 40520-40529
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40530-40539
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 40540-40549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 40550-40559
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40560-40569
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 40570-40579
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 40580-40589
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 40590-40599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 40600-40609
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40610-40619
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 40620-40629
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 54, // 40630-40639
- 53, 52, 51, 50, 49, 48, 47, 46, 45, 44, // 40640-40649
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 40650-40659
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 40660-40669
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 40670-40679
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40680-40689
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 40690-40699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 40700-40709
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 40710-40719
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 40720-40729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 40730-40739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40740-40749
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 40750-40759
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 40760-40769
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40770-40779
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 40780-40789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40790-40799
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40800-40809
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 40810-40819
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 40820-40829
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40830-40839
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 40840-40849
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 40850-40859
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 40860-40869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 40870-40879
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 40880-40889
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 40890-40899
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 40900-40909
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 40910-40919
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 40920-40929
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 40930-40939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 40940-40949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 40950-40959
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40960-40969
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 40970-40979
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 40980-40989
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 40990-40999
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41000-41009
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 41010-41019
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 41020-41029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 41030-41039
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 41040-41049
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 41050-41059
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 41060-41069
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 41070-41079
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 41080-41089
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 41090-41099
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 41100-41109
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 41110-41119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41120-41129
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41130-41139
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 41140-41149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41150-41159
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 41160-41169
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 41170-41179
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 41180-41189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41190-41199
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 41200-41209
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 41210-41219
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 41220-41229
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 41230-41239
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 41240-41249
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 41250-41259
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 41260-41269
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41270-41279
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 41280-41289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 34, // 41290-41299
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 41300-41309
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 41310-41319
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 41320-41329
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 41330-41339
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41340-41349
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 41350-41359
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 41360-41369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41370-41379
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 41380-41389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 41390-41399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41400-41409
- 1, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 41410-41419
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 41420-41429
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 41430-41439
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 41440-41449
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 41450-41459
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 41460-41469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 41470-41479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41480-41489
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 41490-41499
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 41500-41509
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 41510-41519
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 41520-41529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 41530-41539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 41540-41549
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 41550-41559
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 41560-41569
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 41570-41579
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 41580-41589
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 41590-41599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 41600-41609
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 41610-41619
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 41620-41629
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41630-41639
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 41640-41649
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 41650-41659
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 41660-41669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41670-41679
- 1, 6, 5, 4, 3, 2, 1, 32, 31, 30, // 41680-41689
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 41690-41699
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 41700-41709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 41710-41719
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 41720-41729
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 41730-41739
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 41740-41749
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 41750-41759
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41760-41769
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 41770-41779
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 41780-41789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41790-41799
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 41800-41809
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 41810-41819
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 41820-41829
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 41830-41839
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 41840-41849
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 41850-41859
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 41860-41869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 41870-41879
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 41880-41889
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 41890-41899
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 41900-41909
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 41910-41919
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 41920-41929
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41930-41939
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 41940-41949
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 41950-41959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 41960-41969
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 41970-41979
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 41980-41989
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 41990-41999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42000-42009
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 42010-42019
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 42020-42029
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42030-42039
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 42040-42049
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42050-42059
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42060-42069
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 42070-42079
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 42080-42089
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42090-42099
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 42100-42109
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 42110-42119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42120-42129
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 42130-42139
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 42140-42149
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 42150-42159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 42160-42169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 42170-42179
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42180-42189
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 42190-42199
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 42200-42209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42210-42219
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 42220-42229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 42230-42239
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 42240-42249
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 42250-42259
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 42260-42269
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42270-42279
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 42280-42289
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 42290-42299
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 42300-42309
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42310-42319
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 42320-42329
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 42330-42339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 42340-42349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 42350-42359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42360-42369
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 42370-42379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42380-42389
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42390-42399
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 24, // 42400-42409
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 42410-42419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42420-42429
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 42430-42439
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 42440-42449
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 42450-42459
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 42460-42469
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 42470-42479
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 42480-42489
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 42490-42499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 42500-42509
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 42510-42519
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42520-42529
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 42530-42539
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 42540-42549
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 42550-42559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 42560-42569
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 42570-42579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 42580-42589
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 42590-42599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42600-42609
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 42610-42619
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 42620-42629
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42630-42639
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 42640-42649
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 42650-42659
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 42660-42669
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42670-42679
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 42680-42689
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 42690-42699
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 42700-42709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 42710-42719
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 42720-42729
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42730-42739
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 42740-42749
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 42750-42759
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42760-42769
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 42770-42779
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42780-42789
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 42790-42799
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 42800-42809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 42810-42819
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 42820-42829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 42830-42839
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42840-42849
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 42850-42859
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 42860-42869
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 42870-42879
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 42880-42889
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 42890-42899
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 42900-42909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42910-42919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 42920-42929
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 42930-42939
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 42940-42949
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 42950-42959
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 42960-42969
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 42970-42979
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 42980-42989
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 42990-42999
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 43000-43009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 43010-43019
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 43020-43029
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 43030-43039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 43040-43049
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43050-43059
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 43060-43069
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 43070-43079
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43080-43089
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 43090-43099
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 43100-43109
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 43110-43119
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43120-43129
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 43130-43139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43140-43149
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 43150-43159
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 43160-43169
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 43170-43179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 43180-43189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43190-43199
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 43200-43209
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43210-43219
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 43220-43229
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 43230-43239
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 43240-43249
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43250-43259
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43260-43269
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43270-43279
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 43280-43289
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 43290-43299
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43300-43309
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 43310-43319
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43320-43329
- 1, 60, 59, 58, 57, 56, 55, 54, 53, 52, // 43330-43339
- 51, 50, 49, 48, 47, 46, 45, 44, 43, 42, // 43340-43349
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 43350-43359
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 43360-43369
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 43370-43379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43380-43389
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 43390-43399
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 43400-43409
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 43410-43419
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 43420-43429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43430-43439
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43440-43449
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 43450-43459
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 43460-43469
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43470-43479
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 43480-43489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 43490-43499
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 43500-43509
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 43510-43519
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 43520-43529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43530-43539
- 1, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 43540-43549
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 43550-43559
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43560-43569
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 43570-43579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43580-43589
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 43590-43599
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 43600-43609
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 43610-43619
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 43620-43629
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 43630-43639
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 43640-43649
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43650-43659
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 43660-43669
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 43670-43679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43680-43689
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 43690-43699
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43700-43709
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 43710-43719
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 43720-43729
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 43730-43739
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43740-43749
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 43750-43759
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 43760-43769
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 43770-43779
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 43780-43789
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 43790-43799
- 1, 52, 51, 50, 49, 48, 47, 46, 45, 44, // 43800-43809
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 43810-43819
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 43820-43829
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 43830-43839
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43840-43849
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 43850-43859
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 43860-43869
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 43870-43879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 43880-43889
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 43890-43899
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43900-43909
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 43910-43919
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 43920-43929
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 43930-43939
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 43940-43949
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 43950-43959
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 43960-43969
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 43970-43979
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 43980-43989
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 43990-43999
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 44000-44009
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 44010-44019
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 44020-44029
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44030-44039
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44040-44049
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 44050-44059
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44060-44069
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 44070-44079
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 44080-44089
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44090-44099
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44100-44109
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 44110-44119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 44120-44129
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 44130-44139
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 44140-44149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 44150-44159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44160-44169
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 44170-44179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 44180-44189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44190-44199
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 44200-44209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44210-44219
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 44220-44229
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 44230-44239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 44240-44249
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 44250-44259
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 44260-44269
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 44270-44279
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44280-44289
- 3, 2, 1, 58, 57, 56, 55, 54, 53, 52, // 44290-44299
- 51, 50, 49, 48, 47, 46, 45, 44, 43, 42, // 44300-44309
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 44310-44319
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 44320-44329
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 44330-44339
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44340-44349
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 44350-44359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44360-44369
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44370-44379
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 28, // 44380-44389
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 44390-44399
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 44400-44409
- 7, 6, 5, 4, 3, 2, 1, 32, 31, 30, // 44410-44419
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 44420-44429
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 44430-44439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 44440-44449
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 44450-44459
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 44460-44469
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44470-44479
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 44480-44489
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 44490-44499
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 44500-44509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 44510-44519
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44520-44529
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 44530-44539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 44540-44549
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44550-44559
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 44560-44569
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 44570-44579
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 44580-44589
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 44590-44599
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 44600-44609
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 44610-44619
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 44620-44629
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 44630-44639
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 44640-44649
- 1, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 44650-44659
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 44660-44669
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44670-44679
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 44680-44689
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 44690-44699
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44700-44709
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 44710-44719
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 44720-44729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44730-44739
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44740-44749
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 44750-44759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 44760-44769
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 44770-44779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 44780-44789
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 44790-44799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 44800-44809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 44810-44819
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 44820-44829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 44830-44839
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 44840-44849
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 44850-44859
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 44860-44869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 44870-44879
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 44880-44889
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 44890-44899
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 44900-44909
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 44910-44919
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 44920-44929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 44930-44939
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44940-44949
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 44950-44959
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 44960-44969
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 44970-44979
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 44980-44989
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 44990-44999
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45000-45009
- 3, 2, 1, 40, 39, 38, 37, 36, 35, 34, // 45010-45019
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 45020-45029
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 45030-45039
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45040-45049
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 45050-45059
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 45060-45069
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45070-45079
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 45080-45089
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 45090-45099
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 45100-45109
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 45110-45119
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 45120-45129
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 45130-45139
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 45140-45149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45150-45159
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 45160-45169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 45170-45179
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45180-45189
- 1, 6, 5, 4, 3, 2, 1, 36, 35, 34, // 45190-45199
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 45200-45209
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 45210-45219
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45220-45229
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 45230-45239
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 45240-45249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 45250-45259
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 45260-45269
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45270-45279
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 45280-45289
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 45290-45299
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 45300-45309
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 45310-45319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 45320-45329
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 45330-45339
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 45340-45349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45350-45359
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 45360-45369
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 45370-45379
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 45380-45389
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45390-45399
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 45400-45409
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 45410-45419
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45420-45429
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 42, // 45430-45439
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 45440-45449
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 45450-45459
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 45460-45469
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45470-45479
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45480-45489
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45490-45499
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 45500-45509
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45510-45519
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 45520-45529
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 45530-45539
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45540-45549
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 45550-45559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 45560-45569
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 45570-45579
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 45580-45589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 45590-45599
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45600-45609
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 45610-45619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45620-45629
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45630-45639
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 45640-45649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 45650-45659
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45660-45669
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 45670-45679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45680-45689
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 45690-45699
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 45700-45709
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 45710-45719
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 45720-45729
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 45730-45739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45740-45749
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45750-45759
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 45760-45769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 38, // 45770-45779
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 45780-45789
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 45790-45799
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 45800-45809
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 45810-45819
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 45820-45829
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 45830-45839
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45840-45849
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 45850-45859
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 45860-45869
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 45870-45879
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 45880-45889
- 3, 2, 1, 50, 49, 48, 47, 46, 45, 44, // 45890-45899
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 45900-45909
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 45910-45919
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 45920-45929
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 45930-45939
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 45940-45949
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 45950-45959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 45960-45969
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 45970-45979
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 32, // 45980-45989
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 45990-45999
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 46000-46009
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46010-46019
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 46020-46029
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46030-46039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46040-46049
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46050-46059
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46060-46069
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 46070-46079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46080-46089
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 46090-46099
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 46100-46109
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 46110-46119
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46120-46129
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 46130-46139
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 46140-46149
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 46150-46159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46160-46169
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46170-46179
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 46180-46189
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 46190-46199
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46200-46209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 46210-46219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 46220-46229
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 46230-46239
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 46240-46249
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46250-46259
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46260-46269
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 46270-46279
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 46280-46289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46290-46299
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 46300-46309
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 46310-46319
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 46320-46329
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 46330-46339
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46340-46349
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 46350-46359
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 46360-46369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46370-46379
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46380-46389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 46390-46399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46400-46409
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 46410-46419
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46420-46429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46430-46439
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 46440-46449
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 46450-46459
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46460-46469
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 46470-46479
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 46480-46489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 46490-46499
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 46500-46509
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46510-46519
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 46520-46529
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46530-46539
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 46540-46549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 46550-46559
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 46560-46569
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 46570-46579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46580-46589
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46590-46599
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46600-46609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 46610-46619
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46620-46629
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 46630-46639
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 46640-46649
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46650-46659
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 46660-46669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46670-46679
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 46680-46689
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46690-46699
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 46700-46709
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46710-46719
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 46720-46729
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 46730-46739
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 46740-46749
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 46750-46759
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46760-46769
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 46770-46779
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 46780-46789
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 46790-46799
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 46800-46809
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 46810-46819
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 46820-46829
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 46830-46839
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46840-46849
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 46850-46859
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 46860-46869
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 46870-46879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 46880-46889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 46890-46899
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 46900-46909
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 46910-46919
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46920-46929
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 46930-46939
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 46940-46949
- 7, 6, 5, 4, 3, 2, 1, 36, 35, 34, // 46950-46959
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 46960-46969
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 46970-46979
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 46980-46989
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 46990-46999
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47000-47009
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 47010-47019
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 47020-47029
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47030-47039
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47040-47049
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 28, // 47050-47059
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 47060-47069
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47070-47079
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 47080-47089
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 47090-47099
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47100-47109
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 47110-47119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 47120-47129
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 47130-47139
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 47140-47149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47150-47159
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 47160-47169
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 47170-47179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 47180-47189
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47190-47199
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 47200-47209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47210-47219
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47220-47229
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 47230-47239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47240-47249
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 47250-47259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 47260-47269
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 47270-47279
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 47280-47289
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 47290-47299
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 47300-47309
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 47310-47319
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 47320-47329
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 47330-47339
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47340-47349
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 47350-47359
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 47360-47369
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47370-47379
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 47380-47389
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47390-47399
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 47400-47409
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 47410-47419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47420-47429
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47430-47439
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 47440-47449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 32, // 47450-47459
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 47460-47469
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 47470-47479
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47480-47489
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 47490-47499
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 47500-47509
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 47510-47519
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 47520-47529
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 47530-47539
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 47540-47549
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 47550-47559
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 47560-47569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47570-47579
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47580-47589
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 47590-47599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 47600-47609
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 47610-47619
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 47620-47629
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 47630-47639
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 47640-47649
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 47650-47659
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 47660-47669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47670-47679
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 47680-47689
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 47690-47699
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47700-47709
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 47710-47719
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47720-47729
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 47730-47739
- 1, 2, 1, 34, 33, 32, 31, 30, 29, 28, // 47740-47749
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 47750-47759
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47760-47769
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 47770-47779
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47780-47789
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 47790-47799
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 47800-47809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 47810-47819
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 47820-47829
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 47830-47839
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 47840-47849
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 47850-47859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 47860-47869
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 47870-47879
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 47880-47889
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 47890-47899
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 47900-47909
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 47910-47919
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 47920-47929
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 47930-47939
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 47940-47949
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 47950-47959
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 47960-47969
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 47970-47979
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 47980-47989
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 47990-47999
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48000-48009
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 48010-48019
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 48020-48029
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 48030-48039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 48040-48049
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 48050-48059
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48060-48069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 48070-48079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48080-48089
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 48090-48099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 48100-48109
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 48110-48119
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48120-48129
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 48130-48139
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48140-48149
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 48150-48159
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 48160-48169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 48170-48179
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 48180-48189
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 48190-48199
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 48200-48209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48210-48219
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 48220-48229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 48230-48239
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 48240-48249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 48250-48259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48260-48269
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48270-48279
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 48280-48289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 48290-48299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48300-48309
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 48310-48319
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48320-48329
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 48330-48339
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48340-48349
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 48350-48359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48360-48369
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48370-48379
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 48380-48389
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 48390-48399
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 48400-48409
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 48410-48419
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48420-48429
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 48430-48439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 48440-48449
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48450-48459
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 48460-48469
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 48470-48479
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 48480-48489
- 1, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 48490-48499
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 48500-48509
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48510-48519
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 48520-48529
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 48530-48539
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 48540-48549
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48550-48559
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 48560-48569
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 48570-48579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 48580-48589
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 48590-48599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48600-48609
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 48610-48619
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 48620-48629
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48630-48639
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 48640-48649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48650-48659
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48660-48669
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 52, // 48670-48679
- 51, 50, 49, 48, 47, 46, 45, 44, 43, 42, // 48680-48689
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 48690-48699
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 48700-48709
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 48710-48719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48720-48729
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 48730-48739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 48740-48749
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 48750-48759
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 48760-48769
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 48770-48779
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 48780-48789
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 48790-48799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 48800-48809
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 48810-48819
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 48820-48829
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48830-48839
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 48840-48849
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 48850-48859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 48860-48869
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48870-48879
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 48880-48889
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48890-48899
- 7, 6, 5, 4, 3, 2, 1, 40, 39, 38, // 48900-48909
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 48910-48919
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 48920-48929
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 48930-48939
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 48940-48949
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 48950-48959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48960-48969
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 48970-48979
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 48980-48989
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 48990-48999
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 49000-49009
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 49010-49019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49020-49029
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 49030-49039
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 49040-49049
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 49050-49059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 49060-49069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49070-49079
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 49080-49089
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49090-49099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 49100-49109
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 49110-49119
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 49120-49129
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 49130-49139
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 49140-49149
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 49150-49159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 49160-49169
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 49170-49179
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49180-49189
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 49190-49199
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 49200-49209
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49210-49219
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 49220-49229
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 49230-49239
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49240-49249
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 49250-49259
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 49260-49269
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 49270-49279
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 49280-49289
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 49290-49299
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 49300-49309
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 49310-49319
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49320-49329
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 24, // 49330-49339
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 49340-49349
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49350-49359
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 22, // 49360-49369
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 49370-49379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49380-49389
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 49390-49399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 49400-49409
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 49410-49419
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 49420-49429
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 49430-49439
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49440-49449
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 49450-49459
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 49460-49469
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 49470-49479
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 49480-49489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 49490-49499
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 49500-49509
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49510-49519
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 49520-49529
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 49530-49539
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 49540-49549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 38, // 49550-49559
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 49560-49569
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 49570-49579
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 49580-49589
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 49590-49599
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 49600-49609
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 49610-49619
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 49620-49629
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 24, // 49630-49639
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 49640-49649
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49650-49659
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 49660-49669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49670-49679
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 49680-49689
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 49690-49699
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49700-49709
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 49710-49719
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 49720-49729
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 49730-49739
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 49740-49749
- 7, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 49750-49759
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 49760-49769
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49770-49779
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 49780-49789
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49790-49799
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 49800-49809
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49810-49819
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 49820-49829
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 49830-49839
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 49840-49849
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 49850-49859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49860-49869
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 49870-49879
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49880-49889
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 49890-49899
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 49900-49909
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 49910-49919
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 49920-49929
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 49930-49939
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 49940-49949
- 7, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 49950-49959
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 49960-49969
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 49970-49979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 49980-49989
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 49990-49999
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50000-50009
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50010-50019
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 50020-50029
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 50030-50039
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 50040-50049
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 50050-50059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 50060-50069
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 50070-50079
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50080-50089
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 50090-50099
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50100-50109
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 50110-50119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 50120-50129
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50130-50139
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50140-50149
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 50150-50159
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50160-50169
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 50170-50179
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 50180-50189
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50190-50199
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 50200-50209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50210-50219
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 50220-50229
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 50230-50239
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50240-50249
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50250-50259
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 50260-50269
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 50270-50279
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 50280-50289
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50290-50299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50300-50309
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50310-50319
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 50320-50329
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 50330-50339
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 50340-50349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 50350-50359
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 50360-50369
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50370-50379
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 50380-50389
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50390-50399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50400-50409
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50410-50419
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 50420-50429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50430-50439
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 50440-50449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 50450-50459
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 50460-50469
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 50470-50479
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50480-50489
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50490-50499
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 50500-50509
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 50510-50519
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 50520-50529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 50530-50539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 50540-50549
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 50550-50559
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50560-50569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50570-50579
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 50580-50589
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 28, // 50590-50599
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 50600-50609
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50610-50619
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 50620-50629
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50630-50639
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 50640-50649
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50650-50659
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50660-50669
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 50670-50679
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 50680-50689
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 50690-50699
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 50700-50709
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 50710-50719
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 50720-50729
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50730-50739
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 50740-50749
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 50750-50759
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50760-50769
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 50770-50779
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 32, // 50780-50789
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 50790-50799
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50800-50809
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50810-50819
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 50820-50829
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 50830-50839
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 50840-50849
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 50850-50859
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 50860-50869
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 50870-50879
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50880-50889
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 50890-50899
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 50900-50909
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 50910-50919
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 50920-50929
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 50930-50939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 50940-50949
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 50950-50959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 50960-50969
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 50970-50979
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 50980-50989
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 50990-50999
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 51000-51009
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 51010-51019
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51020-51029
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51030-51039
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 51040-51049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 51050-51059
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51060-51069
- 1, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 51070-51079
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 51080-51089
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 51090-51099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 51100-51109
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 51110-51119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51120-51129
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 51130-51139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51140-51149
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 51150-51159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 51160-51169
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 51170-51179
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51180-51189
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 51190-51199
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 51200-51209
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 51210-51219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 51220-51229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 51230-51239
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 51240-51249
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 51250-51259
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 51260-51269
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51270-51279
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 51280-51289
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 51290-51299
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 51300-51309
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 51310-51319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 51320-51329
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51330-51339
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 12, // 51340-51349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51350-51359
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 51360-51369
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51370-51379
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 51380-51389
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 51390-51399
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 51400-51409
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 51410-51419
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 51420-51429
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 51430-51439
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 51440-51449
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51450-51459
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51460-51469
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 51470-51479
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 51480-51489
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51490-51499
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 51500-51509
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 51510-51519
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 51520-51529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 51530-51539
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51540-51549
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51550-51559
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 51560-51569
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 51570-51579
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51580-51589
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 51590-51599
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 51600-51609
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 51610-51619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51620-51629
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 51630-51639
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 51640-51649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 51650-51659
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51660-51669
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 51670-51679
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 51680-51689
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 51690-51699
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51700-51709
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 51710-51719
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 51720-51729
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 51730-51739
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 51740-51749
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 51750-51759
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 51760-51769
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 51770-51779
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 51780-51789
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 51790-51799
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 51800-51809
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 51810-51819
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 51820-51829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 51830-51839
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51840-51849
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 51850-51859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 51860-51869
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 51870-51879
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 51880-51889
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 51890-51899
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 51900-51909
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 51910-51919
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 51920-51929
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51930-51939
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 51940-51949
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 51950-51959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51960-51969
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 51970-51979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 51980-51989
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 51990-51999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 52000-52009
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52010-52019
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 52020-52029
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 52030-52039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52040-52049
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 52050-52059
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 52060-52069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52070-52079
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 52080-52089
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 52090-52099
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 52100-52109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52110-52119
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 52120-52129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 52130-52139
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 52140-52149
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 52150-52159
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 52160-52169
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 52170-52179
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 52180-52189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52190-52199
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 52200-52209
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 52210-52219
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 52220-52229
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 52230-52239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 52240-52249
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 52250-52259
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 52260-52269
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 52270-52279
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 52280-52289
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52290-52299
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 52300-52309
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 52310-52319
- 1, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 52320-52329
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 52330-52339
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 52340-52349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52350-52359
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 52360-52369
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 52370-52379
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 52380-52389
- 1, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 52390-52399
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 52400-52409
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 52410-52419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 52420-52429
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 52430-52439
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 52440-52449
- 3, 2, 1, 4, 3, 2, 1, 32, 31, 30, // 52450-52459
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 52460-52469
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 52470-52479
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 52480-52489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52490-52499
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52500-52509
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 52510-52519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 52520-52529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52530-52539
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 52540-52549
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 52550-52559
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 52560-52569
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 52570-52579
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 52580-52589
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 52590-52599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 52600-52609
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 52610-52619
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 52620-52629
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 28, // 52630-52639
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 52640-52649
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 52650-52659
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 52660-52669
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 52670-52679
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52680-52689
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 52690-52699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 52700-52709
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52710-52719
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 52720-52729
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 52730-52739
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 52740-52749
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 52750-52759
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 52760-52769
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 52770-52779
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 52780-52789
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 52790-52799
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 52800-52809
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 52810-52819
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 52820-52829
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 52830-52839
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 52840-52849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 52850-52859
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 52860-52869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 52870-52879
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 52880-52889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52890-52899
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 52900-52909
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 52910-52919
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 52920-52929
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 52930-52939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 52940-52949
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 52950-52959
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 52960-52969
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 52970-52979
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 52980-52989
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 52990-52999
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 53000-53009
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 53010-53019
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 53020-53029
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53030-53039
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53040-53049
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53050-53059
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 53060-53069
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 53070-53079
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 53080-53089
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 53090-53099
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53100-53109
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 53110-53119
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 53120-53129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53130-53139
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 53140-53149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53150-53159
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53160-53169
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 53170-53179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 53180-53189
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53190-53199
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 53200-53209
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 53210-53219
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53220-53229
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 28, // 53230-53239
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 53240-53249
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53250-53259
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 53260-53269
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 53270-53279
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53280-53289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 53290-53299
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 53300-53309
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53310-53319
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 53320-53329
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 53330-53339
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53340-53349
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 53350-53359
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53360-53369
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53370-53379
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 53380-53389
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53390-53399
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53400-53409
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 53410-53419
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53420-53429
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53430-53439
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53440-53449
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 53450-53459
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53460-53469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 53470-53479
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 53480-53489
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53490-53499
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 53500-53509
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53510-53519
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 53520-53529
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53530-53539
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 53540-53549
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53550-53559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 53560-53569
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 53570-53579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53580-53589
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 53590-53599
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 53600-53609
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 53610-53619
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 53620-53629
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 53630-53639
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53640-53649
- 3, 2, 1, 4, 3, 2, 1, 24, 23, 22, // 53650-53659
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 53660-53669
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53670-53679
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53680-53689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 53690-53699
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53700-53709
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 53710-53719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53720-53729
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 53730-53739
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53740-53749
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 53750-53759
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53760-53769
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 53770-53779
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 53780-53789
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 53790-53799
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 53800-53809
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 53810-53819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53820-53829
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 53830-53839
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 53840-53849
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53850-53859
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 53860-53869
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53870-53879
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 53880-53889
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 53890-53899
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53900-53909
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 53910-53919
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 53920-53929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 53930-53939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 53940-53949
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 28, // 53950-53959
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 53960-53969
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 53970-53979
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 53980-53989
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 53990-53999
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54000-54009
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 54010-54019
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54020-54029
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 54030-54039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 54040-54049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 54050-54059
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 54060-54069
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 54070-54079
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 54080-54089
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54090-54099
- 1, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 54100-54109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54110-54119
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 54120-54129
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 54130-54139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54140-54149
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 54150-54159
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 54160-54169
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54170-54179
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 54180-54189
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 54190-54199
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54200-54209
- 7, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 54210-54219
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 54220-54229
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 54230-54239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54240-54249
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 54250-54259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 54260-54269
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 54270-54279
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 54280-54289
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 54290-54299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54300-54309
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 54310-54319
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 54320-54329
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54330-54339
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 54340-54349
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54350-54359
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 54360-54369
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 54370-54379
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 54380-54389
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54390-54399
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 54400-54409
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 54410-54419
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54420-54429
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 54430-54439
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 54440-54449
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 54450-54459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 54460-54469
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 54470-54479
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 54480-54489
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 54490-54499
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 54500-54509
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 54510-54519
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 54520-54529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 54530-54539
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 54540-54549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 54550-54559
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 54560-54569
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 54570-54579
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 54580-54589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54590-54599
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54600-54609
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 54610-54619
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 54620-54629
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54630-54639
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 54640-54649
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54650-54659
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 54660-54669
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 54670-54679
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 54680-54689
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 54690-54699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 54700-54709
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 54710-54719
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 54720-54729
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 54730-54739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54740-54749
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54750-54759
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 54760-54769
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 54770-54779
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 54780-54789
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 54790-54799
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 54800-54809
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 54810-54819
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 54820-54829
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 54830-54839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54840-54849
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 54850-54859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 54860-54869
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 54870-54879
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 54880-54889
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 54890-54899
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 54900-54909
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 54910-54919
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 54920-54929
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54930-54939
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 54940-54949
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 54950-54959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 54960-54969
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 54970-54979
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 54980-54989
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 54990-54999
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 55000-55009
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55010-55019
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 55020-55029
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 55030-55039
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 55040-55049
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 55050-55059
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55060-55069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 24, // 55070-55079
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 55080-55089
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55090-55099
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 55100-55109
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 55110-55119
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 55120-55129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 55130-55139
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 55140-55149
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55150-55159
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 55160-55169
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 55170-55179
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 55180-55189
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55190-55199
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 55200-55209
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 55210-55219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 55220-55229
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55230-55239
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 55240-55249
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 32, // 55250-55259
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 55260-55269
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 55270-55279
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55280-55289
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 55290-55299
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55300-55309
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 55310-55319
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55320-55329
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 55330-55339
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 55340-55349
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 55350-55359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55360-55369
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 55370-55379
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 55380-55389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 55390-55399
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55400-55409
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 55410-55419
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 55420-55429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 55430-55439
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 55440-55449
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 55450-55459
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 55460-55469
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 55470-55479
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 55480-55489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55490-55499
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55500-55509
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 55510-55519
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 55520-55529
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55530-55539
- 1, 6, 5, 4, 3, 2, 1, 32, 31, 30, // 55540-55549
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 55550-55559
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 55560-55569
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 55570-55579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 55580-55589
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55590-55599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 55600-55609
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 55610-55619
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55620-55629
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 55630-55639
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 55640-55649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55650-55659
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 55660-55669
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 55670-55679
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55680-55689
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 55690-55699
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55700-55709
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 55710-55719
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55720-55729
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 55730-55739
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 55740-55749
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 55750-55759
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 55760-55769
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 55770-55779
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 55780-55789
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 55790-55799
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 55800-55809
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 55810-55819
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 55820-55829
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 55830-55839
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 55840-55849
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 55850-55859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55860-55869
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 55870-55879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 55880-55889
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 55890-55899
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 55900-55909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 55910-55919
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 55920-55929
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 55930-55939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 55940-55949
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 55950-55959
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 55960-55969
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 55970-55979
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 55980-55989
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 55990-55999
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 30, // 56000-56009
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 56010-56019
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56020-56029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 56030-56039
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56040-56049
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 56050-56059
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 56060-56069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56070-56079
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 56080-56089
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 56090-56099
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56100-56109
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 56110-56119
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 56120-56129
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56130-56139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 56140-56149
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 56150-56159
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 56160-56169
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 56170-56179
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 56180-56189
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 56190-56199
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 28, // 56200-56209
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 56210-56219
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 56220-56229
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 56230-56239
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 56240-56249
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56250-56259
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 30, // 56260-56269
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 56270-56279
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56280-56289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 56290-56299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56300-56309
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 56310-56319
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56320-56329
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 56330-56339
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56340-56349
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 56350-56359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 56360-56369
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 56370-56379
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 56380-56389
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 56390-56399
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 56400-56409
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 56410-56419
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56420-56429
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 56430-56439
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 56440-56449
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 56450-56459
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 56460-56469
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 56470-56479
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 56480-56489
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56490-56499
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 56500-56509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 56510-56519
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 56520-56529
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 56530-56539
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 56540-56549
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56550-56559
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 56560-56569
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 56570-56579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56580-56589
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 56590-56599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56600-56609
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56610-56619
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 56620-56629
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 56630-56639
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 56640-56649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 56650-56659
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 56660-56669
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56670-56679
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 56680-56689
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56690-56699
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56700-56709
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 56710-56719
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56720-56729
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 56730-56739
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 56740-56749
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 56750-56759
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 56760-56769
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 56770-56779
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 56780-56789
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 56790-56799
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 56800-56809
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 56810-56819
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 56820-56829
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56830-56839
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 56840-56849
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 56850-56859
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56860-56869
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 56870-56879
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56880-56889
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 56890-56899
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 56900-56909
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56910-56919
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 56920-56929
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56930-56939
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 56940-56949
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 56950-56959
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 56960-56969
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 56970-56979
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 56980-56989
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 38, // 56990-56999
- 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 57000-57009
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 57010-57019
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57020-57029
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 57030-57039
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 57040-57049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 57050-57059
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57060-57069
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 57070-57079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 57080-57089
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 57090-57099
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 57100-57109
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 57110-57119
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57120-57129
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 57130-57139
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 57140-57149
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57150-57159
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 57160-57169
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 57170-57179
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57180-57189
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 57190-57199
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 57200-57209
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57210-57219
- 1, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 57220-57229
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57230-57239
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57240-57249
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 57250-57259
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 57260-57269
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57270-57279
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 57280-57289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57290-57299
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 57300-57309
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 57310-57319
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 57320-57329
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57330-57339
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 57340-57349
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57350-57359
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 57360-57369
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 57370-57379
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 57380-57389
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 57390-57399
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57400-57409
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 57410-57419
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 57420-57429
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 57430-57439
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57440-57449
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 57450-57459
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 57460-57469
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57470-57479
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 57480-57489
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 57490-57499
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 57500-57509
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57510-57519
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 28, // 57520-57529
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 57530-57539
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57540-57549
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 57550-57559
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57560-57569
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57570-57579
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 57580-57589
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 57590-57599
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 57600-57609
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 57610-57619
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57620-57629
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 57630-57639
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 57640-57649
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 57650-57659
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 57660-57669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 57670-57679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 57680-57689
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 57690-57699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 57700-57709
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 57710-57719
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 57720-57729
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 57730-57739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57740-57749
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 57750-57759
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57760-57769
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 57770-57779
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 57780-57789
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 57790-57799
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 20, // 57800-57809
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 57810-57819
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 57820-57829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 57830-57839
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 57840-57849
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 57850-57859
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 57860-57869
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57870-57879
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 57880-57889
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 57890-57899
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 57900-57909
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 57910-57919
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 57920-57929
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57930-57939
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 57940-57949
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 57950-57959
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 57960-57969
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 57970-57979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 57980-57989
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 57990-57999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 58000-58009
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 58010-58019
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58020-58029
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 58030-58039
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 58040-58049
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58050-58059
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58060-58069
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 58070-58079
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 58080-58089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 58090-58099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 58100-58109
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 58110-58119
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 58120-58129
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58130-58139
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58140-58149
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 58150-58159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 58160-58169
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 58170-58179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 58180-58189
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 58190-58199
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58200-58209
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 58210-58219
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 58220-58229
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58230-58239
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 58240-58249
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 58250-58259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58260-58269
- 1, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 58270-58279
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 58280-58289
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 58290-58299
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 58300-58309
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 58310-58319
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58320-58329
- 7, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 58330-58339
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 58340-58349
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 58350-58359
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 10, // 58360-58369
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 58370-58379
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58380-58389
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 58390-58399
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 58400-58409
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 58410-58419
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 58420-58429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 58430-58439
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58440-58449
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 58450-58459
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58460-58469
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58470-58479
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 58480-58489
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 58490-58499
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58500-58509
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 58510-58519
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58520-58529
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58530-58539
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 58540-58549
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58550-58559
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58560-58569
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 58570-58579
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 58580-58589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58590-58599
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 58600-58609
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 58610-58619
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58620-58629
- 1, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 58630-58639
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58640-58649
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58650-58659
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 58660-58669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 58670-58679
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58680-58689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 58690-58699
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58700-58709
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58710-58719
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58720-58729
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 58730-58739
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58740-58749
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58750-58759
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 58760-58769
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58770-58779
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 42, // 58780-58789
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 58790-58799
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 58800-58809
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 58810-58819
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58820-58829
- 1, 58, 57, 56, 55, 54, 53, 52, 51, 50, // 58830-58839
- 49, 48, 47, 46, 45, 44, 43, 42, 41, 40, // 58840-58849
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 58850-58859
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 58860-58869
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 58870-58879
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 58880-58889
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 58890-58899
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 58900-58909
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 58910-58919
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 58920-58929
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 58930-58939
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 58940-58949
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 58950-58959
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 58960-58969
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 58970-58979
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 58980-58989
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 58990-58999
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 59000-59009
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59010-59019
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 59020-59029
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 59030-59039
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59040-59049
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 59050-59059
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 59060-59069
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 59070-59079
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 59080-59089
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 59090-59099
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 59100-59109
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 59110-59119
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 59120-59129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59130-59139
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 59140-59149
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 59150-59159
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 59160-59169
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59170-59179
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 59180-59189
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 59190-59199
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 59200-59209
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 59210-59219
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59220-59229
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 59230-59239
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 59240-59249
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59250-59259
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 59260-59269
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 59270-59279
- 1, 52, 51, 50, 49, 48, 47, 46, 45, 44, // 59280-59289
- 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, // 59290-59299
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 59300-59309
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 59310-59319
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59320-59329
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 59330-59339
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59340-59349
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 59350-59359
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 59360-59369
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 59370-59379
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 59380-59389
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 59390-59399
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 59400-59409
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 59410-59419
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 59420-59429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59430-59439
- 1, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 59440-59449
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 59450-59459
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 59460-59469
- 1, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 59470-59479
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 59480-59489
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 59490-59499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 59500-59509
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 59510-59519
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 59520-59529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 59530-59539
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 59540-59549
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 59550-59559
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 59560-59569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59570-59579
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 59580-59589
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 59590-59599
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59600-59609
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 59610-59619
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 22, // 59620-59629
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 59630-59639
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59640-59649
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 59650-59659
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 59660-59669
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 59670-59679
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59680-59689
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 59690-59699
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 59700-59709
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59710-59719
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 59720-59729
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59730-59739
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 59740-59749
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 59750-59759
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59760-59769
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 59770-59779
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59780-59789
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 59790-59799
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 59800-59809
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 59810-59819
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59820-59829
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 59830-59839
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 59840-59849
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 59850-59859
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 59860-59869
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 59870-59879
- 7, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 59880-59889
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 59890-59899
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 59900-59909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59910-59919
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 59920-59929
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 59930-59939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59940-59949
- 1, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 59950-59959
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59960-59969
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 59970-59979
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 59980-59989
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 59990-59999
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60000-60009
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 60010-60019
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 60020-60029
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 60030-60039
- 1, 36, 35, 34, 33, 32, 31, 30, 29, 28, // 60040-60049
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 60050-60059
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 60060-60069
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60070-60079
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 60080-60089
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60090-60099
- 1, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 60100-60109
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 60110-60119
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60120-60129
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 60130-60139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 60140-60149
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60150-60159
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 40, // 60160-60169
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 60170-60179
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 60180-60189
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 60190-60199
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 60200-60209
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60210-60219
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 60220-60229
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 60230-60239
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60240-60249
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 60250-60259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60260-60269
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 60270-60279
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 60280-60289
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 60290-60299
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 60300-60309
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 60310-60319
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60320-60329
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60330-60339
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 60340-60349
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 60350-60359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60360-60369
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 60370-60379
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 60380-60389
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 60390-60399
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60400-60409
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 60410-60419
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 60420-60429
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60430-60439
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 60440-60449
- 7, 6, 5, 4, 3, 2, 1, 36, 35, 34, // 60450-60459
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 60460-60469
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 60470-60479
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60480-60489
- 3, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 60490-60499
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 60500-60509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60510-60519
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 60520-60529
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 50, // 60530-60539
- 49, 48, 47, 46, 45, 44, 43, 42, 41, 40, // 60540-60549
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 60550-60559
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 60560-60569
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 60570-60579
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 60580-60589
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60590-60599
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 60600-60609
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60610-60619
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 60620-60629
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 60630-60639
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 60640-60649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 60650-60659
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 60660-60669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 60670-60679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 60680-60689
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60690-60699
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 60700-60709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 60710-60719
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60720-60729
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 60730-60739
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 60740-60749
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 60750-60759
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 60760-60769
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 60770-60779
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60780-60789
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 60790-60799
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60800-60809
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60810-60819
- 1, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 60820-60829
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 60830-60839
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 60840-60849
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 60850-60859
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 60860-60869
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 60870-60879
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 60880-60889
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 60890-60899
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 60900-60909
- 3, 2, 1, 4, 3, 2, 1, 2, 1, 4, // 60910-60919
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 60920-60929
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 60930-60939
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 60940-60949
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 60950-60959
- 1, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 60960-60969
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 60970-60979
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 60980-60989
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 60990-60999
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 61000-61009
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 61010-61019
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 61020-61029
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61030-61039
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 61040-61049
- 1, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 61050-61059
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 61060-61069
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61070-61079
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61080-61089
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 22, // 61090-61099
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61100-61109
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61110-61119
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 61120-61129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61130-61139
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61140-61149
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 61150-61159
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 42, // 61160-61169
- 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, // 61170-61179
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 61180-61189
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61190-61199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61200-61209
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61210-61219
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 61220-61229
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61230-61239
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61240-61249
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 61250-61259
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61260-61269
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61270-61279
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 61280-61289
- 1, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 61290-61299
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 61300-61309
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61310-61319
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61320-61329
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 61330-61339
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 61340-61349
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 61350-61359
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 61360-61369
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 61370-61379
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61380-61389
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61390-61399
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 8, // 61400-61409
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 61410-61419
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61420-61429
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61430-61439
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61440-61449
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61450-61459
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 61460-61469
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61470-61479
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 61480-61489
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 61490-61499
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 61500-61509
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 24, // 61510-61519
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61520-61529
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61530-61539
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 61540-61549
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 2, // 61550-61559
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61560-61569
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61570-61579
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 61580-61589
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61590-61599
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 61600-61609
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 61610-61619
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 61620-61629
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 61630-61639
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 61640-61649
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 61650-61659
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 61660-61669
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 61670-61679
- 1, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 61680-61689
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61690-61699
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 61700-61709
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 61710-61719
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 61720-61729
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61730-61739
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61740-61749
- 1, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 61750-61759
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 61760-61769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61770-61779
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 61780-61789
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 61790-61799
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61800-61809
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 61810-61819
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 61820-61829
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 61830-61839
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 61840-61849
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61850-61859
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61860-61869
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 61870-61879
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 61880-61889
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 61890-61899
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 61900-61909
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 61910-61919
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 61920-61929
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 61930-61939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 61940-61949
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 61950-61959
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 61960-61969
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 61970-61979
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 61980-61989
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 61990-61999
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 62000-62009
- 1, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 62010-62019
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62020-62029
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 62030-62039
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62040-62049
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 62050-62059
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62060-62069
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62070-62079
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62080-62089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 62090-62099
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62100-62109
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 62110-62119
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 62120-62129
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 62130-62139
- 1, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 62140-62149
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 62150-62159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62160-62169
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62170-62179
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 62180-62189
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62190-62199
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62200-62209
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 62210-62219
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62220-62229
- 3, 2, 1, 40, 39, 38, 37, 36, 35, 34, // 62230-62239
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 62240-62249
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 62250-62259
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62260-62269
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 62270-62279
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 62280-62289
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 62290-62299
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 62300-62309
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62310-62319
- 3, 2, 1, 4, 3, 2, 1, 20, 19, 18, // 62320-62329
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 62330-62339
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 62340-62349
- 1, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 62350-62359
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 62360-62369
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62370-62379
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 62380-62389
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62390-62399
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 62400-62409
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62410-62419
- 3, 2, 1, 36, 35, 34, 33, 32, 31, 30, // 62420-62429
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 62430-62439
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62440-62449
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 62450-62459
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62460-62469
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 62470-62479
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 62480-62489
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 62490-62499
- 1, 6, 5, 4, 3, 2, 1, 26, 25, 24, // 62500-62509
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 62510-62519
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62520-62529
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 62530-62539
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 62540-62549
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62550-62559
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 62560-62569
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62570-62579
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62580-62589
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62590-62599
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 62600-62609
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 62610-62619
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62620-62629
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 62630-62639
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62640-62649
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 24, // 62650-62659
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 62660-62669
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62670-62679
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 62680-62689
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62690-62699
- 1, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 62700-62709
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62710-62719
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 62720-62729
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62730-62739
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 62740-62749
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 62750-62759
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 62760-62769
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 62770-62779
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62780-62789
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62790-62799
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62800-62809
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 62810-62819
- 7, 6, 5, 4, 3, 2, 1, 24, 23, 22, // 62820-62829
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 62830-62839
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62840-62849
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62850-62859
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 62860-62869
- 3, 2, 1, 24, 23, 22, 21, 20, 19, 18, // 62870-62879
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 62880-62889
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 62890-62899
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 62900-62909
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62910-62919
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 62920-62929
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 62930-62939
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 62940-62949
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 62950-62959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 62960-62969
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 62970-62979
- 1, 2, 1, 4, 3, 2, 1, 2, 1, 40, // 62980-62989
- 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, // 62990-62999
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 63000-63009
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63010-63019
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 63020-63029
- 1, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 63030-63039
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63040-63049
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 63050-63059
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63060-63069
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 18, // 63070-63079
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63080-63089
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63090-63099
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 63100-63109
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 63110-63119
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 63120-63129
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63130-63139
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 30, // 63140-63149
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 63150-63159
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63160-63169
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 63170-63179
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63180-63189
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 63190-63199
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63200-63209
- 1, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 63210-63219
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 63220-63229
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63230-63239
- 1, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 63240-63249
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 63250-63259
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63260-63269
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 63270-63279
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63280-63289
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 12, // 63290-63299
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63300-63309
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 63310-63319
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63320-63329
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 63330-63339
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63340-63349
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 63350-63359
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 63360-63369
- 7, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 63370-63379
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 63380-63389
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 63390-63399
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 63400-63409
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 63410-63419
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63420-63429
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 63430-63439
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 63440-63449
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 63450-63459
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 63460-63469
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 63470-63479
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63480-63489
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 22, // 63490-63499
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 63500-63509
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63510-63519
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63520-63529
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 63530-63539
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63540-63549
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 63550-63559
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63560-63569
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 63570-63579
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 63580-63589
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 63590-63599
- 1, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 63600-63609
- 1, 6, 5, 4, 3, 2, 1, 12, 11, 10, // 63610-63619
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 63620-63629
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63630-63639
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 10, // 63640-63649
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 63650-63659
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 63660-63669
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63670-63679
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 63680-63689
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63690-63699
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 63700-63709
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 63710-63719
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 63720-63729
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63730-63739
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 63740-63749
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63750-63759
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 63760-63769
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 63770-63779
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 63780-63789
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 63790-63799
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 63800-63809
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 63810-63819
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 63820-63829
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 63830-63839
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 63840-63849
- 3, 2, 1, 4, 3, 2, 1, 6, 5, 4, // 63850-63859
- 3, 2, 1, 38, 37, 36, 35, 34, 33, 32, // 63860-63869
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 63870-63879
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 63880-63889
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 63890-63899
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 63900-63909
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 63910-63919
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 20, // 63920-63929
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 63930-63939
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 28, // 63940-63949
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 63950-63959
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63960-63969
- 7, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 63970-63979
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 63980-63989
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 63990-63999
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 64000-64009
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 14, // 64010-64019
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64020-64029
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 64030-64039
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 64040-64049
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64050-64059
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 64060-64069
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64070-64079
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64080-64089
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 64090-64099
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 64100-64109
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64110-64119
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 64120-64129
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 64130-64139
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64140-64149
- 1, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 64150-64159
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64160-64169
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 64170-64179
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 28, // 64180-64189
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 64190-64199
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 64200-64209
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 64210-64219
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 64220-64229
- 1, 6, 5, 4, 3, 2, 1, 34, 33, 32, // 64230-64239
- 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, // 64240-64249
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 64250-64259
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64260-64269
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 64270-64279
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 64280-64289
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64290-64299
- 1, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 64300-64309
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 64310-64319
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 64320-64329
- 3, 2, 1, 40, 39, 38, 37, 36, 35, 34, // 64330-64339
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 64340-64349
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 64350-64359
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64360-64369
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 64370-64379
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 64380-64389
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 64390-64399
- 3, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 64400-64409
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 64410-64419
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64420-64429
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 64430-64439
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64440-64449
- 1, 2, 1, 30, 29, 28, 27, 26, 25, 24, // 64450-64459
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 64460-64469
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64470-64479
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 10, // 64480-64489
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 64490-64499
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64500-64509
- 3, 2, 1, 40, 39, 38, 37, 36, 35, 34, // 64510-64519
- 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, // 64520-64529
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 64530-64539
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64540-64549
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 64550-64559
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 64560-64569
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 64570-64579
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64580-64589
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64590-64599
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 64600-64609
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 64610-64619
- 1, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 64620-64629
- 3, 2, 1, 28, 27, 26, 25, 24, 23, 22, // 64630-64639
- 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, // 64640-64649
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64650-64659
- 1, 2, 1, 4, 3, 2, 1, 12, 11, 10, // 64660-64669
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 64670-64679
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64680-64689
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 64690-64699
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 8, // 64700-64709
- 7, 6, 5, 4, 3, 2, 1, 30, 29, 28, // 64710-64719
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 64720-64729
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 64730-64739
- 7, 6, 5, 4, 3, 2, 1, 16, 15, 14, // 64740-64749
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 64750-64759
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 64760-64769
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64770-64779
- 1, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 64780-64789
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 64790-64799
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64800-64809
- 1, 6, 5, 4, 3, 2, 1, 32, 31, 30, // 64810-64819
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 64820-64829
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 64830-64839
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 64840-64849
- 3, 2, 1, 18, 17, 16, 15, 14, 13, 12, // 64850-64859
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64860-64869
- 1, 6, 5, 4, 3, 2, 1, 2, 1, 12, // 64870-64879
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64880-64889
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64890-64899
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 64900-64909
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 64910-64919
- 1, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 64920-64929
- 7, 6, 5, 4, 3, 2, 1, 14, 13, 12, // 64930-64939
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 64940-64949
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 64950-64959
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 28, // 64960-64969
- 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, // 64970-64979
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 64980-64989
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 64990-64999
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 65000-65009
- 1, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 65010-65019
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 4, // 65020-65029
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 65030-65039
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 65040-65049
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 65050-65059
- 3, 2, 1, 8, 7, 6, 5, 4, 3, 2, // 65060-65069
- 1, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 65070-65079
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, // 65080-65089
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 65090-65099
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 65100-65109
- 1, 8, 7, 6, 5, 4, 3, 2, 1, 4, // 65110-65119
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 12, // 65120-65129
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 65130-65139
- 1, 6, 5, 4, 3, 2, 1, 20, 19, 18, // 65140-65149
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 65150-65159
- 7, 6, 5, 4, 3, 2, 1, 4, 3, 2, // 65160-65169
- 1, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 65170-65179
- 3, 2, 1, 20, 19, 18, 17, 16, 15, 14, // 65180-65189
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 65190-65199
- 3, 2, 1, 10, 9, 8, 7, 6, 5, 4, // 65200-65209
- 3, 2, 1, 26, 25, 24, 23, 22, 21, 20, // 65210-65219
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 65220-65229
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 65230-65239
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 65240-65249
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 65250-65259
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 18, // 65260-65269
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 65270-65279
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 65280-65289
- 3, 2, 1, 16, 15, 14, 13, 12, 11, 10, // 65290-65299
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 14, // 65300-65309
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 65310-65319
- 3, 2, 1, 4, 3, 2, 1, 26, 25, 24, // 65320-65329
- 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, // 65330-65339
- 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 65340-65349
- 3, 2, 1, 4, 3, 2, 1, 14, 13, 12, // 65350-65359
- 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 65360-65369
- 1, 10, 9, 8, 7, 6, 5, 4, 3, 2, // 65370-65379
- 1, 12, 11, 10, 9, 8, 7, 6, 5, 4, // 65380-65389
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 65390-65399
- 7, 6, 5, 4, 3, 2, 1, 6, 5, 4, // 65400-65409
- 3, 2, 1, 6, 5, 4, 3, 2, 1, 4, // 65410-65419
- 3, 2, 1, 14, 13, 12, 11, 10, 9, 8, // 65420-65429
- 7, 6, 5, 4, 3, 2, 1, 10, 9, 8, // 65430-65439
- 7, 6, 5, 4, 3, 2, 1, 2, 1, 30, // 65440-65449
- 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, // 65450-65459
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 65460-65469
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 18, // 65470-65479
- 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, // 65480-65489
- 7, 6, 5, 4, 3, 2, 1, 22, 21, 20, // 65490-65499
- 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, // 65500-65509
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, // 65510-65519
- 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 65520-65529
- 0, 0, 0, 0, 0, 0,
- }
-
- lohi [256]struct{ lo, hi int }
-)
-
-func init() {
- for i, v := range liars {
- blk := v >> 24
- x := &lohi[blk]
- if x.lo == 0 || i < x.lo {
- x.lo = i
- }
- if i > x.hi {
- x.hi = i
- }
- }
-}
diff --git a/vendor/github.com/cznic/mathutil/test_deps.go b/vendor/github.com/cznic/mathutil/test_deps.go
deleted file mode 100644
index 40054dcad..000000000
--- a/vendor/github.com/cznic/mathutil/test_deps.go
+++ /dev/null
@@ -1,11 +0,0 @@
-// Copyright (c) 2014 The mathutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mathutil
-
-// Pull test dependencies too.
-// Enables easy 'go test X' after 'go get X'
-import (
-// nothing yet
-)
diff --git a/vendor/github.com/cznic/sortutil/AUTHORS b/vendor/github.com/cznic/sortutil/AUTHORS
deleted file mode 100644
index 0078f5f5b..000000000
--- a/vendor/github.com/cznic/sortutil/AUTHORS
+++ /dev/null
@@ -1,11 +0,0 @@
-# This file lists authors for copyright purposes. This file is distinct from
-# the CONTRIBUTORS files. See the latter for an explanation.
-#
-# Names should be added to this file as:
-# Name or Organization
-#
-# The email address is not required for organizations.
-#
-# Please keep the list sorted.
-
-Jan Mercl <0xjnml@gmail.com>
diff --git a/vendor/github.com/cznic/sortutil/CONTRIBUTORS b/vendor/github.com/cznic/sortutil/CONTRIBUTORS
deleted file mode 100644
index 9c9a5dd84..000000000
--- a/vendor/github.com/cznic/sortutil/CONTRIBUTORS
+++ /dev/null
@@ -1,10 +0,0 @@
-# This file lists people who contributed code to this repository. The AUTHORS
-# file lists the copyright holders; this file lists people.
-#
-# Names should be added to this file like so:
-# Name
-#
-# Please keep the list sorted.
-
-Gary Burd
-Jan Mercl <0xjnml@gmail.com>
diff --git a/vendor/github.com/cznic/sortutil/LICENSE b/vendor/github.com/cznic/sortutil/LICENSE
deleted file mode 100644
index 67983e0e6..000000000
--- a/vendor/github.com/cznic/sortutil/LICENSE
+++ /dev/null
@@ -1,27 +0,0 @@
-Copyright (c) 2014 The sortutil Authors. All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are
-met:
-
- * Redistributions of source code must retain the above copyright
-notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above
-copyright notice, this list of conditions and the following disclaimer
-in the documentation and/or other materials provided with the
-distribution.
- * Neither the names of the authors nor the names of the
-contributors may be used to endorse or promote products derived from
-this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/github.com/cznic/sortutil/Makefile b/vendor/github.com/cznic/sortutil/Makefile
deleted file mode 100644
index 2dc62d186..000000000
--- a/vendor/github.com/cznic/sortutil/Makefile
+++ /dev/null
@@ -1,35 +0,0 @@
-# Copyright 2014 The sortutil Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean editor later nuke todo
-
-grep=--include=*.go
-
-all: editor
- go vet
- golint .
- make todo
-
-clean:
- go clean
- rm -f *~
-
-editor:
- gofmt -s -l -w *.go
- go test -i
- go test
- go build
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * || true
- @grep -nr $(grep) TODO * || true
- @grep -nr $(grep) BUG * || true
- @grep -nr $(grep) println * || true
diff --git a/vendor/github.com/cznic/sortutil/README b/vendor/github.com/cznic/sortutil/README
deleted file mode 100644
index 84ef92ccd..000000000
--- a/vendor/github.com/cznic/sortutil/README
+++ /dev/null
@@ -1,4 +0,0 @@
-Packages in this repository:
-
-Install: $ go get github.com/cznic/sortutil
-Godocs: http://godoc.org/github.com/cznic/sortutil
diff --git a/vendor/github.com/cznic/sortutil/sortutil.go b/vendor/github.com/cznic/sortutil/sortutil.go
deleted file mode 100644
index 132d3546e..000000000
--- a/vendor/github.com/cznic/sortutil/sortutil.go
+++ /dev/null
@@ -1,271 +0,0 @@
-// Copyright 2014 The sortutil Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Package sortutil provides utilities supplementing the standard 'sort' package.
-//
-// Changelog
-//
-// 2015-06-17: Added utils for math/big.{Int,Rat}.
-package sortutil
-
-import (
- "math/big"
-)
-
-import "sort"
-
-// BigIntSlice attaches the methods of sort.Interface to []*big.Int, sorting in increasing order.
-type BigIntSlice []*big.Int
-
-func (s BigIntSlice) Len() int { return len(s) }
-func (s BigIntSlice) Less(i, j int) bool { return s[i].Cmp(s[j]) < 0 }
-func (s BigIntSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s BigIntSlice) Sort() {
- sort.Sort(s)
-}
-
-// SearchBigInts searches for x in a sorted slice of *big.Int and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchBigInts(a []*big.Int, x *big.Int) int {
- return sort.Search(len(a), func(i int) bool { return a[i].Cmp(x) >= 0 })
-}
-
-// BigRatSlice attaches the methods of sort.Interface to []*big.Rat, sorting in increasing order.
-type BigRatSlice []*big.Rat
-
-func (s BigRatSlice) Len() int { return len(s) }
-func (s BigRatSlice) Less(i, j int) bool { return s[i].Cmp(s[j]) < 0 }
-func (s BigRatSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s BigRatSlice) Sort() {
- sort.Sort(s)
-}
-
-// SearchBigRats searches for x in a sorted slice of *big.Int and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchBigRats(a []*big.Rat, x *big.Rat) int {
- return sort.Search(len(a), func(i int) bool { return a[i].Cmp(x) >= 0 })
-}
-
-// ByteSlice attaches the methods of sort.Interface to []byte, sorting in increasing order.
-type ByteSlice []byte
-
-func (s ByteSlice) Len() int { return len(s) }
-func (s ByteSlice) Less(i, j int) bool { return s[i] < s[j] }
-func (s ByteSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s ByteSlice) Sort() {
- sort.Sort(s)
-}
-
-// SearchBytes searches for x in a sorted slice of bytes and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchBytes(a []byte, x byte) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Float32Slice attaches the methods of sort.Interface to []float32, sorting in increasing order.
-type Float32Slice []float32
-
-func (s Float32Slice) Len() int { return len(s) }
-func (s Float32Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Float32Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Float32Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchFloat32s searches for x in a sorted slice of float32 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchFloat32s(a []float32, x float32) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Int8Slice attaches the methods of sort.Interface to []int8, sorting in increasing order.
-type Int8Slice []int8
-
-func (s Int8Slice) Len() int { return len(s) }
-func (s Int8Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Int8Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Int8Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchInt8s searches for x in a sorted slice of int8 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchInt8s(a []int8, x int8) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Int16Slice attaches the methods of sort.Interface to []int16, sorting in increasing order.
-type Int16Slice []int16
-
-func (s Int16Slice) Len() int { return len(s) }
-func (s Int16Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Int16Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Int16Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchInt16s searches for x in a sorted slice of int16 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchInt16s(a []int16, x int16) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Int32Slice attaches the methods of sort.Interface to []int32, sorting in increasing order.
-type Int32Slice []int32
-
-func (s Int32Slice) Len() int { return len(s) }
-func (s Int32Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Int32Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Int32Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchInt32s searches for x in a sorted slice of int32 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchInt32s(a []int32, x int32) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Int64Slice attaches the methods of sort.Interface to []int64, sorting in increasing order.
-type Int64Slice []int64
-
-func (s Int64Slice) Len() int { return len(s) }
-func (s Int64Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Int64Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Int64Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchInt64s searches for x in a sorted slice of int64 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchInt64s(a []int64, x int64) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// UintSlice attaches the methods of sort.Interface to []uint, sorting in increasing order.
-type UintSlice []uint
-
-func (s UintSlice) Len() int { return len(s) }
-func (s UintSlice) Less(i, j int) bool { return s[i] < s[j] }
-func (s UintSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s UintSlice) Sort() {
- sort.Sort(s)
-}
-
-// SearchUints searches for x in a sorted slice of uints and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchUints(a []uint, x uint) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Uint16Slice attaches the methods of sort.Interface to []uint16, sorting in increasing order.
-type Uint16Slice []uint16
-
-func (s Uint16Slice) Len() int { return len(s) }
-func (s Uint16Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Uint16Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Uint16Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchUint16s searches for x in a sorted slice of uint16 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchUint16s(a []uint16, x uint16) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Uint32Slice attaches the methods of sort.Interface to []uint32, sorting in increasing order.
-type Uint32Slice []uint32
-
-func (s Uint32Slice) Len() int { return len(s) }
-func (s Uint32Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Uint32Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Uint32Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchUint32s searches for x in a sorted slice of uint32 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchUint32s(a []uint32, x uint32) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Uint64Slice attaches the methods of sort.Interface to []uint64, sorting in increasing order.
-type Uint64Slice []uint64
-
-func (s Uint64Slice) Len() int { return len(s) }
-func (s Uint64Slice) Less(i, j int) bool { return s[i] < s[j] }
-func (s Uint64Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s Uint64Slice) Sort() {
- sort.Sort(s)
-}
-
-// SearchUint64s searches for x in a sorted slice of uint64 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchUint64s(a []uint64, x uint64) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// RuneSlice attaches the methods of sort.Interface to []rune, sorting in increasing order.
-type RuneSlice []rune
-
-func (s RuneSlice) Len() int { return len(s) }
-func (s RuneSlice) Less(i, j int) bool { return s[i] < s[j] }
-func (s RuneSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
-
-// Sort is a convenience method.
-func (s RuneSlice) Sort() {
- sort.Sort(s)
-}
-
-// SearchRunes searches for x in a sorted slice of uint64 and returns the index
-// as specified by sort.Search. The slice must be sorted in ascending order.
-func SearchRunes(a []rune, x rune) int {
- return sort.Search(len(a), func(i int) bool { return a[i] >= x })
-}
-
-// Dedupe returns n, the number of distinct elements in data. The resulting
-// elements are sorted in elements [0, n) or data[:n] for a slice.
-func Dedupe(data sort.Interface) (n int) {
- if n = data.Len(); n < 2 {
- return n
- }
-
- sort.Sort(data)
- a, b := 0, 1
- for b < n {
- if data.Less(a, b) {
- a++
- if a != b {
- data.Swap(a, b)
- }
- }
- b++
- }
- return a + 1
-}
diff --git a/vendor/github.com/cznic/zappy/AUTHORS b/vendor/github.com/cznic/zappy/AUTHORS
deleted file mode 100644
index 22c8397d5..000000000
--- a/vendor/github.com/cznic/zappy/AUTHORS
+++ /dev/null
@@ -1,12 +0,0 @@
-# This file lists authors for copyright purposes. This file is distinct from
-# the CONTRIBUTORS files. See the latter for an explanation.
-#
-# Names should be added to this file as:
-# Name or Organization
-#
-# The email address is not required for organizations.
-#
-# Please keep the list sorted.
-
-Jan Mercl <0xjnml@gmail.com>
-The Snappy-Go Authors
diff --git a/vendor/github.com/cznic/zappy/CONTRIBUTORS b/vendor/github.com/cznic/zappy/CONTRIBUTORS
deleted file mode 100644
index 7693bdab7..000000000
--- a/vendor/github.com/cznic/zappy/CONTRIBUTORS
+++ /dev/null
@@ -1,10 +0,0 @@
-# This file lists people who contributed code to this repository. The AUTHORS
-# file lists the copyright holders; this file lists people.
-#
-# Names should be added to this file like so:
-# Name
-#
-# Please keep the list sorted.
-
-Jan Mercl <0xjnml@gmail.com>
-Mathieu Lonjaret
diff --git a/vendor/github.com/cznic/zappy/LICENSE b/vendor/github.com/cznic/zappy/LICENSE
deleted file mode 100644
index bc67059c5..000000000
--- a/vendor/github.com/cznic/zappy/LICENSE
+++ /dev/null
@@ -1,27 +0,0 @@
-Copyright (c) 2014 The zappy Authors. All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are
-met:
-
- * Redistributions of source code must retain the above copyright
-notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above
-copyright notice, this list of conditions and the following disclaimer
-in the documentation and/or other materials provided with the
-distribution.
- * Neither the names of the authors nor the names of the
-contributors may be used to endorse or promote products derived from
-this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/github.com/cznic/zappy/Makefile b/vendor/github.com/cznic/zappy/Makefile
deleted file mode 100644
index 864b4a4d3..000000000
--- a/vendor/github.com/cznic/zappy/Makefile
+++ /dev/null
@@ -1,55 +0,0 @@
-# Copyright 2016 The zappy Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-.PHONY: all clean cover cpu editor internalError later mem nuke todo edit
-
-grep=--include=*.go --include=*.l --include=*.y --include=*.yy
-ngrep='TODOOK\|parser\.go\|scanner\.go\|.*_string\.go'
-
-all: editor
- go vet 2>&1 | grep -v $(ngrep) || true
- golint 2>&1 | grep -v $(ngrep) || true
- make todo
- unused . || true
- misspell *.go
- gosimple || true
-
-clean:
- go clean
- rm -f *~ *.test *.out
-
-cover:
- t=$(shell tempfile) ; go test -coverprofile $$t && go tool cover -html $$t && unlink $$t
-
-cpu: clean
- go test -run @ -bench . -cpuprofile cpu.out
- go tool pprof -lines *.test cpu.out
-
-edit:
- gvim -p Makefile *.go
-
-editor:
- gofmt -l -s -w *.go
- go test
- go build
-
-internalError:
- egrep -ho '"internal error.*"' *.go | sort | cat -n
-
-later:
- @grep -n $(grep) LATER * || true
- @grep -n $(grep) MAYBE * || true
-
-mem: clean
- go test -run @ -bench . -memprofile mem.out -memprofilerate 1 -timeout 24h
- go tool pprof -lines -web -alloc_space *.test mem.out
-
-nuke: clean
- go clean -i
-
-todo:
- @grep -nr $(grep) ^[[:space:]]*_[[:space:]]*=[[:space:]][[:alpha:]][[:alnum:]]* * | grep -v $(ngrep) || true
- @grep -nr $(grep) TODO * | grep -v $(ngrep) || true
- @grep -nr $(grep) BUG * | grep -v $(ngrep) || true
- @grep -nr $(grep) [^[:alpha:]]println * | grep -v $(ngrep) || true
diff --git a/vendor/github.com/cznic/zappy/README.md b/vendor/github.com/cznic/zappy/README.md
deleted file mode 100644
index 6fc6f68a7..000000000
--- a/vendor/github.com/cznic/zappy/README.md
+++ /dev/null
@@ -1,9 +0,0 @@
-zappy
-=====
-
-Package zappy implements the zappy block-based compression format. It aims for
-a combination of good speed and reasonable compression.
-
-Installation: $ go get github.com/cznic/zappy
-
-Documentation: [godoc.org/github.com/cznic/zappy](http://godoc.org/github.com/cznic/zappy)
diff --git a/vendor/github.com/cznic/zappy/decode.go b/vendor/github.com/cznic/zappy/decode.go
deleted file mode 100644
index 867c8deea..000000000
--- a/vendor/github.com/cznic/zappy/decode.go
+++ /dev/null
@@ -1,38 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-package zappy
-
-import (
- "encoding/binary"
- "errors"
-)
-
-// ErrCorrupt reports that the input is invalid.
-var ErrCorrupt = errors.New("zappy: corrupt input")
-
-// DecodedLen returns the length of the decoded block.
-func DecodedLen(src []byte) (int, error) {
- v, _, err := decodedLen(src)
- return v, err
-}
-
-// decodedLen returns the length of the decoded block and the number of bytes
-// that the length header occupied.
-func decodedLen(src []byte) (blockLen, headerLen int, err error) {
- v, n := binary.Uvarint(src)
- if n == 0 {
- return 0, 0, ErrCorrupt
- }
-
- if uint64(int(v)) != v {
- return 0, 0, errors.New("zappy: decoded block is too large")
- }
-
- return int(v), n, nil
-}
diff --git a/vendor/github.com/cznic/zappy/decode_cgo.go b/vendor/github.com/cznic/zappy/decode_cgo.go
deleted file mode 100644
index e5fff17f5..000000000
--- a/vendor/github.com/cznic/zappy/decode_cgo.go
+++ /dev/null
@@ -1,125 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-// +build cgo,!purego
-
-package zappy
-
-import (
- "github.com/cznic/internal/buffer"
-)
-
-/*
-
-#include
-#include
-
-// supports only uint32 encoded values
-int uvarint(unsigned int* n, uint8_t* src, int len) {
- int r = 0;
- unsigned int v = 0;
- unsigned int s = 0;
- while ((len-- != 0) && (++r <= 5)) {
- uint8_t b = *src++;
- v = v | ((b&0x7f)<>1;
- if ((u&1) != 0)
- x = ~x;
- *n = x;
- return i;
-}
-
-int decode(int s, int len_src, uint8_t* src, int len_dst, uint8_t* dst) {
- int d = 0;
- int length;
- while (s < len_src) {
- int n, i = varint(&n, src+s, len_src-s);
- if (i <= 0) {
- return -1;
- }
-
- s += i;
- if (n >= 0) {
- length = n+1;
- if ((length > len_dst-d) || (length > len_src-s))
- return -1;
-
- memcpy(dst+d, src+s, length);
- d += length;
- s += length;
- continue;
- }
-
-
- length = -n;
- int offset;
- i = uvarint((unsigned int*)(&offset), src+s, len_src-s);
- if (i <= 0)
- return -1;
-
- s += i;
- if (s > len_src)
- return -1;
-
- int end = d+length;
- if ((offset > d) || (end > len_dst))
- return -1;
-
- for( ; d < end; d++)
- *(dst+d) = *(dst+d-offset);
- }
- return d;
-}
-
-*/
-import "C"
-
-func puregoDecode() bool { return false }
-
-// Decode returns the decoded form of src. The returned slice may be a sub-
-// slice of buf if buf was large enough to hold the entire decoded block.
-// Otherwise, a newly allocated slice will be returned.
-// It is valid to pass a nil buf.
-func Decode(buf, src []byte) ([]byte, error) {
- dLen, s, err := decodedLen(src)
- if err != nil {
- return nil, err
- }
-
- if dLen == 0 {
- if len(src) == 1 {
- return nil, nil
- }
-
- return nil, ErrCorrupt
- }
-
- if len(buf) < dLen {
- buf = *buffer.Get(dLen)
- }
-
- d := int(C.decode(C.int(s), C.int(len(src)), (*C.uint8_t)(&src[0]), C.int(len(buf)), (*C.uint8_t)(&buf[0])))
- if d != dLen {
- return nil, ErrCorrupt
- }
-
- return buf[:d], nil
-}
diff --git a/vendor/github.com/cznic/zappy/decode_nocgo.go b/vendor/github.com/cznic/zappy/decode_nocgo.go
deleted file mode 100644
index 2f6d3b1da..000000000
--- a/vendor/github.com/cznic/zappy/decode_nocgo.go
+++ /dev/null
@@ -1,91 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-// +build !cgo purego
-
-package zappy
-
-import (
- "encoding/binary"
-
- "github.com/cznic/internal/buffer"
-)
-
-func puregoDecode() bool { return true }
-
-// Decode returns the decoded form of src. The returned slice may be a sub-
-// slice of buf if buf was large enough to hold the entire decoded block.
-// Otherwise, a newly allocated slice will be returned.
-// It is valid to pass a nil buf.
-func Decode(buf, src []byte) ([]byte, error) {
- dLen, s, err := decodedLen(src)
- if err != nil {
- return nil, err
- }
-
- if dLen == 0 {
- if len(src) == 1 {
- return nil, nil
- }
-
- return nil, ErrCorrupt
- }
-
- if len(buf) < dLen {
- buf = *buffer.Get(dLen)
- }
-
- var d, offset, length int
- for s < len(src) {
- n, i := binary.Varint(src[s:])
- if i <= 0 {
- return nil, ErrCorrupt
- }
-
- s += i
- if n >= 0 {
- length = int(n + 1)
- if length > len(buf)-d || length > len(src)-s {
- return nil, ErrCorrupt
- }
-
- copy(buf[d:], src[s:s+length])
- d += length
- s += length
- continue
- }
-
- length = int(-n)
- off64, i := binary.Uvarint(src[s:])
- if i <= 0 {
- return nil, ErrCorrupt
- }
-
- offset = int(off64)
- s += i
- if s > len(src) {
- return nil, ErrCorrupt
- }
-
- end := d + length
- if offset > d || end > len(buf) {
- return nil, ErrCorrupt
- }
-
- for s, v := range buf[d-offset : end-offset] {
- buf[d+s] = v
- }
- d = end
-
- }
- if d != dLen {
- return nil, ErrCorrupt
- }
-
- return buf[:d], nil
-}
diff --git a/vendor/github.com/cznic/zappy/encode.go b/vendor/github.com/cznic/zappy/encode.go
deleted file mode 100644
index 5b8a20dd4..000000000
--- a/vendor/github.com/cznic/zappy/encode.go
+++ /dev/null
@@ -1,37 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-package zappy
-
-import (
- "encoding/binary"
-)
-
-// We limit how far copy back-references can go, the same as the snappy C++
-// code.
-const maxOffset = 1 << 20
-
-// emitCopy writes a copy chunk and returns the number of bytes written.
-func emitCopy(dst []byte, offset, length int) (n int) {
- n = binary.PutVarint(dst, int64(-length))
- n += binary.PutUvarint(dst[n:], uint64(offset))
- return
-}
-
-// emitLiteral writes a literal chunk and returns the number of bytes written.
-func emitLiteral(dst, lit []byte) (n int) {
- n = binary.PutVarint(dst, int64(len(lit)-1))
- n += copy(dst[n:], lit)
- return
-}
-
-// MaxEncodedLen returns the maximum length of a zappy block, given its
-// uncompressed length.
-func MaxEncodedLen(srcLen int) int {
- return 10 + srcLen + (srcLen+1)/2
-}
diff --git a/vendor/github.com/cznic/zappy/encode_cgo.go b/vendor/github.com/cznic/zappy/encode_cgo.go
deleted file mode 100644
index 0ebccef56..000000000
--- a/vendor/github.com/cznic/zappy/encode_cgo.go
+++ /dev/null
@@ -1,142 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-// +build cgo,!purego
-
-package zappy
-
-/*
-
-#include
-#include
-
-#define MAXOFFSET 1<<20
-
-int putUvarint(uint8_t* buf, unsigned int x) {
- int i = 1;
- for (; x >= 0x80; i++) {
- *buf++ = x|0x80;
- x >>= 7;
- }
- *buf = x;
- return i;
-}
-
-int putVarint(uint8_t* buf, int x) {
- unsigned int ux = x << 1;
- if (x < 0)
- ux = ~ux;
- return putUvarint(buf, ux);
-}
-
-int emitLiteral(uint8_t* dst, uint8_t* lit, int len_lit) {
- int n = putVarint(dst, len_lit-1);
- memcpy(dst+n, lit, len_lit);
- return n+len_lit;
-}
-
-int emitCopy(uint8_t* dst, int off, int len) {
- int n = putVarint(dst, -len);
- return n+putUvarint(dst+n, (unsigned int)off);
-}
-
-int encode(int d, uint8_t* dst, uint8_t* src, int len_src) {
- int table[1<<12];
- int s = 0;
- int t = 0;
- int lit = 0;
- int lim = 0;
- memset(table, 0, sizeof(table));
- for (lim = len_src-3; s < lim; ) {
- // Update the hash table.
- uint32_t b0 = src[s];
- uint32_t b1 = src[s+1];
- uint32_t b2 = src[s+2];
- uint32_t b3 = src[s+3];
- uint32_t h = b0 | (b1<<8) | (b2<<16) | (b3<<24);
- uint32_t i;
-more:
- i = (h*0x1e35a7bd)>>20;
- t = table[i];
- table[i] = s;
- // If t is invalid or src[s:s+4] differs from src[t:t+4], accumulate a literal byte.
- if ((t == 0) || (s-t >= MAXOFFSET) || (b0 != src[t]) || (b1 != src[t+1]) || (b2 != src[t+2]) || (b3 != src[t+3])) {
- s++;
- if (s >= lim)
- break;
-
- b0 = b1;
- b1 = b2;
- b2 = b3;
- b3 = src[s+3];
- h = (h>>8) | ((b3)<<24);
- goto more;
- }
-
- // Otherwise, we have a match. First, emit any pending literal bytes.
- if (lit != s) {
- d += emitLiteral(dst+d, src+lit, s-lit);
- }
- // Extend the match to be as long as possible.
- int s0 = s;
- s += 4;
- t += 4;
- while ((s < len_src) && (src[s] == src[t])) {
- s++;
- t++;
- }
- d += emitCopy(dst+d, s-t, s-s0);
- lit = s;
- }
- // Emit any final pending literal bytes and return.
- if (lit != len_src) {
- d += emitLiteral(dst+d, src+lit, len_src-lit);
- }
- return d;
-}
-
-*/
-import "C"
-
-import (
- "encoding/binary"
- "fmt"
- "math"
-
- "github.com/cznic/internal/buffer"
-)
-
-func puregoEncode() bool { return false }
-
-// Encode returns the encoded form of src. The returned slice may be a sub-
-// slice of buf if buf was large enough to hold the entire encoded block.
-// Otherwise, a newly allocated slice will be returned.
-// It is valid to pass a nil buf.
-func Encode(buf, src []byte) ([]byte, error) {
- if n := MaxEncodedLen(len(src)); len(buf) < n {
- buf = *buffer.Get(n)
- }
-
- if len(src) > math.MaxInt32 {
- return nil, fmt.Errorf("zappy.Encode: too long data: %d bytes", len(src))
- }
-
- // The block starts with the varint-encoded length of the decompressed bytes.
- d := binary.PutUvarint(buf, uint64(len(src)))
-
- // Return early if src is short.
- if len(src) <= 4 {
- if len(src) != 0 {
- d += emitLiteral(buf[d:], src)
- }
- return buf[:d], nil
- }
-
- d = int(C.encode(C.int(d), (*C.uint8_t)(&buf[0]), (*C.uint8_t)(&src[0]), C.int(len(src))))
- return buf[:d], nil
-}
diff --git a/vendor/github.com/cznic/zappy/encode_nocgo.go b/vendor/github.com/cznic/zappy/encode_nocgo.go
deleted file mode 100644
index af33eb927..000000000
--- a/vendor/github.com/cznic/zappy/encode_nocgo.go
+++ /dev/null
@@ -1,94 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-// +build !cgo purego
-
-package zappy
-
-import (
- "encoding/binary"
- "fmt"
- "math"
-
- "github.com/cznic/internal/buffer"
-)
-
-func puregoEncode() bool { return true }
-
-// Encode returns the encoded form of src. The returned slice may be a sub-
-// slice of buf if buf was large enough to hold the entire encoded block.
-// Otherwise, a newly allocated slice will be returned.
-// It is valid to pass a nil buf.
-func Encode(buf, src []byte) ([]byte, error) {
- if n := MaxEncodedLen(len(src)); len(buf) < n {
- buf = *buffer.Get(n)
- }
-
- if len(src) > math.MaxInt32 {
- return nil, fmt.Errorf("zappy.Encode: too long data: %d bytes", len(src))
- }
-
- // The block starts with the varint-encoded length of the decompressed bytes.
- d := binary.PutUvarint(buf, uint64(len(src)))
-
- // Return early if src is short.
- if len(src) <= 4 {
- if len(src) != 0 {
- d += emitLiteral(buf[d:], src)
- }
- return buf[:d], nil
- }
-
- // Iterate over the source bytes.
- var (
- table [1 << 12]int // Hash table
- s int // The iterator position.
- t int // The last position with the same hash as s.
- lit int // The start position of any pending literal bytes.
- )
- for lim := len(src) - 3; s < lim; {
- // Update the hash table.
- b0, b1, b2, b3 := src[s], src[s+1], src[s+2], src[s+3]
- h := uint32(b0) | uint32(b1)<<8 | uint32(b2)<<16 | uint32(b3)<<24
- more:
- p := &table[(h*0x1e35a7bd)>>20]
- t, *p = *p, s
- // If t is invalid or src[s:s+4] differs from src[t:t+4], accumulate a literal byte.
- if t == 0 || s-t >= maxOffset || b0 != src[t] || b1 != src[t+1] || b2 != src[t+2] || b3 != src[t+3] {
- s++
- if s >= lim {
- break
- }
-
- b0, b1, b2, b3 = b1, b2, b3, src[s+3]
- h = h>>8 | uint32(b3)<<24
- goto more
- }
-
- // Otherwise, we have a match. First, emit any pending literal bytes.
- if lit != s {
- d += emitLiteral(buf[d:], src[lit:s])
- }
- // Extend the match to be as long as possible.
- s0 := s
- s, t = s+4, t+4
- for s < len(src) && src[s] == src[t] {
- s++
- t++
- }
- // Emit the copied bytes.
- d += emitCopy(buf[d:], s-t, s-s0)
- lit = s
- }
-
- // Emit any final pending literal bytes and return.
- if lit != len(src) {
- d += emitLiteral(buf[d:], src[lit:])
- }
- return buf[:d], nil
-}
diff --git a/vendor/github.com/cznic/zappy/purego.sh b/vendor/github.com/cznic/zappy/purego.sh
deleted file mode 100644
index e2fec14e6..000000000
--- a/vendor/github.com/cznic/zappy/purego.sh
+++ /dev/null
@@ -1,11 +0,0 @@
-# Copyright 2014 The zappy Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-set -e
-set -v
-
-CGO_ENABLED=0 go test -purego true
-CGO_ENABLED=0 go test -purego true -tags purego
-CGO_ENABLED=1 go test -purego false
-CGO_ENABLED=1 go test -purego true -tags purego
diff --git a/vendor/github.com/cznic/zappy/zappy.go b/vendor/github.com/cznic/zappy/zappy.go
deleted file mode 100644
index 65d9efb12..000000000
--- a/vendor/github.com/cznic/zappy/zappy.go
+++ /dev/null
@@ -1,240 +0,0 @@
-// Copyright 2014 The zappy Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Copyright 2011 The Snappy-Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the SNAPPY-GO-LICENSE file.
-
-/*
-Package zappy implements the zappy block-based compression format. It aims for
-a combination of good speed and reasonable compression.
-
-Zappy is a format incompatible, API compatible fork of snappy[1]. The C++
-snappy implementation is at [2].
-
-Reasons for the fork
-
-The snappy compression is pretty good. Yet it has one problem built into its
-format definition[3] - the maximum length of a copy "instruction" is 64 bytes.
-For some specific usage patterns with long runs of repeated data, it turns out
-the compression is suboptimal. For example a 1:1000 "sparseness" 64kB bit index
-with only few set bits is compressed to about 3kB (about 1000 of 64B copy, 3
-byte "instructions").
-
-Format description
-
-Zappy uses much less complicated format than snappy. Each encoded block begins
-with the uvarint-encoded[4] length of the decoded data, followed by a sequence
-of chunks. Chunks begin and end on byte boundaries. The chunk starts with a
-varint encoded number N:
-
- N >= 0: N+1 literal bytes follow.
-
- N < 0: copy -N bytes, starting at offset M (in the following uvarint).
-
-Performance issues
-
-Compression rate is roughly the same as of snappy for the reference data set:
-
- testdata/html: snappy 23320, zappy 22943, 0.984, orig 102400
- testdata/urls.10K: snappy 334437, zappy 355163, 1.062, orig 702087
- testdata/house.jpg: snappy 126711, zappy 126694, 1.000, orig 126958
- testdata/mapreduce-osdi-1.pdf: snappy 77227, zappy 77646, 1.005, orig 94330
- testdata/html_x_4: snappy 92350, zappy 22956, 0.249, orig 409600
- testdata/cp.html: snappy 11938, zappy 12961, 1.086, orig 24603
- testdata/fields.c: snappy 4825, zappy 5395, 1.118, orig 11150
- testdata/grammar.lsp: snappy 1814, zappy 1933, 1.066, orig 3721
- testdata/kennedy.xls: snappy 423518, zappy 440597, 1.040, orig 1029744
- testdata/alice29.txt: snappy 89550, zappy 104016, 1.162, orig 152089
- testdata/asyoulik.txt: snappy 79583, zappy 91345, 1.148, orig 125179
- testdata/lcet10.txt: snappy 238761, zappy 275488, 1.154, orig 426754
- testdata/plrabn12.txt: snappy 324567, zappy 376885, 1.161, orig 481861
- testdata/ptt5: snappy 96350, zappy 91465, 0.949, orig 513216
- testdata/sum: snappy 18927, zappy 20015, 1.057, orig 38240
- testdata/xargs.1: snappy 2532, zappy 2793, 1.103, orig 4227
- testdata/geo.protodata: snappy 23362, zappy 20759, 0.889, orig 118588
- testdata/kppkn.gtb: snappy 73962, zappy 87200, 1.179, orig 184320
- TOTAL: snappy 2043734, zappy 2136254, 1.045, orig 4549067
-
-Zappy has better RLE handling (1/1000+1 non zero bytes in each index):
-
- Sparse bit index 16 B: snappy 9, zappy 9, 1.000
- Sparse bit index 32 B: snappy 10, zappy 10, 1.000
- Sparse bit index 64 B: snappy 11, zappy 10, 0.909
- Sparse bit index 128 B: snappy 16, zappy 14, 0.875
- Sparse bit index 256 B: snappy 22, zappy 14, 0.636
- Sparse bit index 512 B: snappy 36, zappy 16, 0.444
- Sparse bit index 1024 B: snappy 57, zappy 18, 0.316
- Sparse bit index 2048 B: snappy 111, zappy 32, 0.288
- Sparse bit index 4096 B: snappy 210, zappy 31, 0.148
- Sparse bit index 8192 B: snappy 419, zappy 75, 0.179
- Sparse bit index 16384 B: snappy 821, zappy 138, 0.168
- Sparse bit index 32768 B: snappy 1627, zappy 232, 0.143
- Sparse bit index 65536 B: snappy 3243, zappy 451, 0.139
-
-When compiled with CGO_ENABLED=1, zappy is now faster than Go snappy.
-Old=Go snappy, new=zappy:
-
- benchmark old MB/s new MB/s speedup
- BenchmarkWordsDecode1e3 148.98 189.04 1.27x
- BenchmarkWordsDecode1e4 150.29 182.51 1.21x
- BenchmarkWordsDecode1e5 145.79 182.95 1.25x
- BenchmarkWordsDecode1e6 167.43 187.69 1.12x
- BenchmarkWordsEncode1e3 47.11 145.69 3.09x
- BenchmarkWordsEncode1e4 81.47 136.50 1.68x
- BenchmarkWordsEncode1e5 78.86 127.93 1.62x
- BenchmarkWordsEncode1e6 96.81 142.95 1.48x
- Benchmark_UFlat0 316.87 463.19 1.46x
- Benchmark_UFlat1 231.56 350.32 1.51x
- Benchmark_UFlat2 3656.68 8258.39 2.26x
- Benchmark_UFlat3 892.56 1270.09 1.42x
- Benchmark_UFlat4 315.84 959.08 3.04x
- Benchmark_UFlat5 211.70 301.55 1.42x
- Benchmark_UFlat6 211.59 258.29 1.22x
- Benchmark_UFlat7 209.80 272.21 1.30x
- Benchmark_UFlat8 254.59 301.70 1.19x
- Benchmark_UFlat9 163.39 192.66 1.18x
- Benchmark_UFlat10 155.46 189.70 1.22x
- Benchmark_UFlat11 170.11 198.95 1.17x
- Benchmark_UFlat12 148.32 178.78 1.21x
- Benchmark_UFlat13 359.25 579.99 1.61x
- Benchmark_UFlat14 197.27 291.33 1.48x
- Benchmark_UFlat15 185.75 248.07 1.34x
- Benchmark_UFlat16 362.74 582.66 1.61x
- Benchmark_UFlat17 222.95 240.01 1.08x
- Benchmark_ZFlat0 188.66 311.89 1.65x
- Benchmark_ZFlat1 101.46 201.34 1.98x
- Benchmark_ZFlat2 93.62 244.50 2.61x
- Benchmark_ZFlat3 102.79 243.34 2.37x
- Benchmark_ZFlat4 191.64 625.32 3.26x
- Benchmark_ZFlat5 103.09 169.39 1.64x
- Benchmark_ZFlat6 110.35 182.57 1.65x
- Benchmark_ZFlat7 89.56 190.53 2.13x
- Benchmark_ZFlat8 154.05 235.68 1.53x
- Benchmark_ZFlat9 87.58 133.51 1.52x
- Benchmark_ZFlat10 82.08 127.51 1.55x
- Benchmark_ZFlat11 91.36 138.91 1.52x
- Benchmark_ZFlat12 79.24 123.02 1.55x
- Benchmark_ZFlat13 217.04 374.26 1.72x
- Benchmark_ZFlat14 100.33 168.03 1.67x
- Benchmark_ZFlat15 80.79 160.46 1.99x
- Benchmark_ZFlat16 213.32 375.79 1.76x
- Benchmark_ZFlat17 135.37 197.13 1.46x
-
-The package builds with CGO_ENABLED=0 as well, but the performance is worse.
-
- $ CGO_ENABLED=0 go test -test.run=NONE -test.bench=. > old.benchcmp
- $ CGO_ENABLED=1 go test -test.run=NONE -test.bench=. > new.benchcmp
- $ benchcmp old.benchcmp new.benchcmp
- benchmark old ns/op new ns/op delta
- BenchmarkWordsDecode1e3 9735 5288 -45.68%
- BenchmarkWordsDecode1e4 100229 55369 -44.76%
- BenchmarkWordsDecode1e5 1037611 546420 -47.34%
- BenchmarkWordsDecode1e6 9559352 5335307 -44.19%
- BenchmarkWordsEncode1e3 16206 6629 -59.10%
- BenchmarkWordsEncode1e4 140283 73161 -47.85%
- BenchmarkWordsEncode1e5 1476657 781756 -47.06%
- BenchmarkWordsEncode1e6 12702229 6997656 -44.91%
- Benchmark_UFlat0 397307 221198 -44.33%
- Benchmark_UFlat1 3890483 2008341 -48.38%
- Benchmark_UFlat2 35810 15398 -57.00%
- Benchmark_UFlat3 140850 74194 -47.32%
- Benchmark_UFlat4 814575 426783 -47.61%
- Benchmark_UFlat5 156995 81473 -48.10%
- Benchmark_UFlat6 77645 43161 -44.41%
- Benchmark_UFlat7 25415 13579 -46.57%
- Benchmark_UFlat8 6372440 3412916 -46.44%
- Benchmark_UFlat9 1453679 789956 -45.66%
- Benchmark_UFlat10 1243146 660747 -46.85%
- Benchmark_UFlat11 3903493 2146334 -45.02%
- Benchmark_UFlat12 5106250 2696144 -47.20%
- Benchmark_UFlat13 1641394 884969 -46.08%
- Benchmark_UFlat14 262206 131174 -49.97%
- Benchmark_UFlat15 32325 17047 -47.26%
- Benchmark_UFlat16 366991 204877 -44.17%
- Benchmark_UFlat17 1343988 770907 -42.64%
- Benchmark_ZFlat0 579954 329812 -43.13%
- Benchmark_ZFlat1 6564692 3504867 -46.61%
- Benchmark_ZFlat2 902029 513700 -43.05%
- Benchmark_ZFlat3 678722 384312 -43.38%
- Benchmark_ZFlat4 1197389 654361 -45.35%
- Benchmark_ZFlat5 262677 144939 -44.82%
- Benchmark_ZFlat6 111249 60876 -45.28%
- Benchmark_ZFlat7 39024 19420 -50.24%
- Benchmark_ZFlat8 8046106 4387928 -45.47%
- Benchmark_ZFlat9 2043167 1143139 -44.05%
- Benchmark_ZFlat10 1781604 980528 -44.96%
- Benchmark_ZFlat11 5478647 3078585 -43.81%
- Benchmark_ZFlat12 7245995 3929863 -45.77%
- Benchmark_ZFlat13 2432529 1371606 -43.61%
- Benchmark_ZFlat14 420315 227494 -45.88%
- Benchmark_ZFlat15 52378 26564 -49.28%
- Benchmark_ZFlat16 567047 316196 -44.24%
- Benchmark_ZFlat17 1630820 937310 -42.53%
-
- benchmark old MB/s new MB/s speedup
- BenchmarkWordsDecode1e3 102.71 189.08 1.84x
- BenchmarkWordsDecode1e4 99.77 180.60 1.81x
- BenchmarkWordsDecode1e5 96.38 183.01 1.90x
- BenchmarkWordsDecode1e6 104.61 187.43 1.79x
- BenchmarkWordsEncode1e3 61.70 150.85 2.44x
- BenchmarkWordsEncode1e4 71.28 136.68 1.92x
- BenchmarkWordsEncode1e5 67.72 127.92 1.89x
- BenchmarkWordsEncode1e6 78.73 142.90 1.82x
- Benchmark_UFlat0 257.73 462.93 1.80x
- Benchmark_UFlat1 180.46 349.59 1.94x
- Benchmark_UFlat2 3545.30 8244.61 2.33x
- Benchmark_UFlat3 669.72 1271.39 1.90x
- Benchmark_UFlat4 502.84 959.74 1.91x
- Benchmark_UFlat5 156.71 301.98 1.93x
- Benchmark_UFlat6 143.60 258.33 1.80x
- Benchmark_UFlat7 146.41 274.01 1.87x
- Benchmark_UFlat8 161.59 301.72 1.87x
- Benchmark_UFlat9 104.62 192.53 1.84x
- Benchmark_UFlat10 100.70 189.45 1.88x
- Benchmark_UFlat11 109.33 198.83 1.82x
- Benchmark_UFlat12 94.37 178.72 1.89x
- Benchmark_UFlat13 312.67 579.93 1.85x
- Benchmark_UFlat14 145.84 291.52 2.00x
- Benchmark_UFlat15 130.77 247.95 1.90x
- Benchmark_UFlat16 323.14 578.82 1.79x
- Benchmark_UFlat17 137.14 239.09 1.74x
- Benchmark_ZFlat0 176.57 310.48 1.76x
- Benchmark_ZFlat1 106.95 200.32 1.87x
- Benchmark_ZFlat2 140.75 247.14 1.76x
- Benchmark_ZFlat3 138.98 245.45 1.77x
- Benchmark_ZFlat4 342.08 625.95 1.83x
- Benchmark_ZFlat5 93.66 169.75 1.81x
- Benchmark_ZFlat6 100.23 183.16 1.83x
- Benchmark_ZFlat7 95.35 191.60 2.01x
- Benchmark_ZFlat8 127.98 234.68 1.83x
- Benchmark_ZFlat9 74.44 133.04 1.79x
- Benchmark_ZFlat10 70.26 127.66 1.82x
- Benchmark_ZFlat11 77.89 138.62 1.78x
- Benchmark_ZFlat12 66.50 122.62 1.84x
- Benchmark_ZFlat13 210.98 374.17 1.77x
- Benchmark_ZFlat14 90.98 168.09 1.85x
- Benchmark_ZFlat15 80.70 159.12 1.97x
- Benchmark_ZFlat16 209.13 375.04 1.79x
- Benchmark_ZFlat17 113.02 196.65 1.74x
- $
-
-Build tags
-
-If a constraint 'purego' appears in the build constraints [5] then a pure Go
-version is built regardless of the $CGO_ENABLED value.
-
- $ touch zappy.go ; go install -tags purego github.com/cznic/zappy # for example
-
-Information sources
-
-... referenced from the above documentation.
-
- [1]: http://github.com/golang/snappy
- [2]: http://code.google.com/p/snappy/
- [3]: http://code.google.com/p/snappy/source/browse/trunk/format_description.txt
- [4]: http://golang.org/pkg/encoding/binary/
- [5]: http://golang.org/pkg/go/build/#hdr-Build_Constraints
-*/
-package zappy
diff --git a/vendor/github.com/edsrzf/mmap-go/.gitignore b/vendor/github.com/edsrzf/mmap-go/.gitignore
deleted file mode 100644
index 9aa02c1ed..000000000
--- a/vendor/github.com/edsrzf/mmap-go/.gitignore
+++ /dev/null
@@ -1,8 +0,0 @@
-*.out
-*.5
-*.6
-*.8
-*.swp
-_obj
-_test
-testdata
diff --git a/vendor/github.com/edsrzf/mmap-go/LICENSE b/vendor/github.com/edsrzf/mmap-go/LICENSE
deleted file mode 100644
index 8f05f338a..000000000
--- a/vendor/github.com/edsrzf/mmap-go/LICENSE
+++ /dev/null
@@ -1,25 +0,0 @@
-Copyright (c) 2011, Evan Shaw
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without
-modification, are permitted provided that the following conditions are met:
- * Redistributions of source code must retain the above copyright
- notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
- * Neither the name of the copyright holder nor the
- names of its contributors may be used to endorse or promote products
- derived from this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
-ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
-DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY
-DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
-(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
-LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
-ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
-SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
diff --git a/vendor/github.com/edsrzf/mmap-go/README.md b/vendor/github.com/edsrzf/mmap-go/README.md
deleted file mode 100644
index 4cc2bfe1c..000000000
--- a/vendor/github.com/edsrzf/mmap-go/README.md
+++ /dev/null
@@ -1,12 +0,0 @@
-mmap-go
-=======
-
-mmap-go is a portable mmap package for the [Go programming language](http://golang.org).
-It has been tested on Linux (386, amd64), OS X, and Windows (386). It should also
-work on other Unix-like platforms, but hasn't been tested with them. I'm interested
-to hear about the results.
-
-I haven't been able to add more features without adding significant complexity,
-so mmap-go doesn't support mprotect, mincore, and maybe a few other things.
-If you're running on a Unix-like platform and need some of these features,
-I suggest Gustavo Niemeyer's [gommap](http://labix.org/gommap).
diff --git a/vendor/github.com/edsrzf/mmap-go/mmap.go b/vendor/github.com/edsrzf/mmap-go/mmap.go
deleted file mode 100644
index 14fb22580..000000000
--- a/vendor/github.com/edsrzf/mmap-go/mmap.go
+++ /dev/null
@@ -1,116 +0,0 @@
-// Copyright 2011 Evan Shaw. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// This file defines the common package interface and contains a little bit of
-// factored out logic.
-
-// Package mmap allows mapping files into memory. It tries to provide a simple, reasonably portable interface,
-// but doesn't go out of its way to abstract away every little platform detail.
-// This specifically means:
-// * forked processes may or may not inherit mappings
-// * a file's timestamp may or may not be updated by writes through mappings
-// * specifying a size larger than the file's actual size can increase the file's size
-// * If the mapped file is being modified by another process while your program's running, don't expect consistent results between platforms
-package mmap
-
-import (
- "errors"
- "os"
- "reflect"
- "unsafe"
-)
-
-const (
- // RDONLY maps the memory read-only.
- // Attempts to write to the MMap object will result in undefined behavior.
- RDONLY = 0
- // RDWR maps the memory as read-write. Writes to the MMap object will update the
- // underlying file.
- RDWR = 1 << iota
- // COPY maps the memory as copy-on-write. Writes to the MMap object will affect
- // memory, but the underlying file will remain unchanged.
- COPY
- // If EXEC is set, the mapped memory is marked as executable.
- EXEC
-)
-
-const (
- // If the ANON flag is set, the mapped memory will not be backed by a file.
- ANON = 1 << iota
-)
-
-// MMap represents a file mapped into memory.
-type MMap []byte
-
-// Map maps an entire file into memory.
-// If ANON is set in flags, f is ignored.
-func Map(f *os.File, prot, flags int) (MMap, error) {
- return MapRegion(f, -1, prot, flags, 0)
-}
-
-// MapRegion maps part of a file into memory.
-// The offset parameter must be a multiple of the system's page size.
-// If length < 0, the entire file will be mapped.
-// If ANON is set in flags, f is ignored.
-func MapRegion(f *os.File, length int, prot, flags int, offset int64) (MMap, error) {
- if offset%int64(os.Getpagesize()) != 0 {
- return nil, errors.New("offset parameter must be a multiple of the system's page size")
- }
-
- var fd uintptr
- if flags&ANON == 0 {
- fd = uintptr(f.Fd())
- if length < 0 {
- fi, err := f.Stat()
- if err != nil {
- return nil, err
- }
- length = int(fi.Size())
- }
- } else {
- if length <= 0 {
- return nil, errors.New("anonymous mapping requires non-zero length")
- }
- fd = ^uintptr(0)
- }
- return mmap(length, uintptr(prot), uintptr(flags), fd, offset)
-}
-
-func (m *MMap) header() *reflect.SliceHeader {
- return (*reflect.SliceHeader)(unsafe.Pointer(m))
-}
-
-// Lock keeps the mapped region in physical memory, ensuring that it will not be
-// swapped out.
-func (m MMap) Lock() error {
- dh := m.header()
- return lock(dh.Data, uintptr(dh.Len))
-}
-
-// Unlock reverses the effect of Lock, allowing the mapped region to potentially
-// be swapped out.
-// If m is already unlocked, aan error will result.
-func (m MMap) Unlock() error {
- dh := m.header()
- return unlock(dh.Data, uintptr(dh.Len))
-}
-
-// Flush synchronizes the mapping's contents to the file's contents on disk.
-func (m MMap) Flush() error {
- dh := m.header()
- return flush(dh.Data, uintptr(dh.Len))
-}
-
-// Unmap deletes the memory mapped region, flushes any remaining changes, and sets
-// m to nil.
-// Trying to read or write any remaining references to m after Unmap is called will
-// result in undefined behavior.
-// Unmap should only be called on the slice value that was originally returned from
-// a call to Map. Calling Unmap on a derived slice may cause errors.
-func (m *MMap) Unmap() error {
- dh := m.header()
- err := unmap(dh.Data, uintptr(dh.Len))
- *m = nil
- return err
-}
diff --git a/vendor/github.com/edsrzf/mmap-go/mmap_unix.go b/vendor/github.com/edsrzf/mmap-go/mmap_unix.go
deleted file mode 100644
index 4af98420d..000000000
--- a/vendor/github.com/edsrzf/mmap-go/mmap_unix.go
+++ /dev/null
@@ -1,67 +0,0 @@
-// Copyright 2011 Evan Shaw. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux openbsd solaris netbsd
-
-package mmap
-
-import (
- "syscall"
-)
-
-func mmap(len int, inprot, inflags, fd uintptr, off int64) ([]byte, error) {
- flags := syscall.MAP_SHARED
- prot := syscall.PROT_READ
- switch {
- case inprot© != 0:
- prot |= syscall.PROT_WRITE
- flags = syscall.MAP_PRIVATE
- case inprot&RDWR != 0:
- prot |= syscall.PROT_WRITE
- }
- if inprot&EXEC != 0 {
- prot |= syscall.PROT_EXEC
- }
- if inflags&ANON != 0 {
- flags |= syscall.MAP_ANON
- }
-
- b, err := syscall.Mmap(int(fd), off, len, prot, flags)
- if err != nil {
- return nil, err
- }
- return b, nil
-}
-
-func flush(addr, len uintptr) error {
- _, _, errno := syscall.Syscall(_SYS_MSYNC, addr, len, _MS_SYNC)
- if errno != 0 {
- return syscall.Errno(errno)
- }
- return nil
-}
-
-func lock(addr, len uintptr) error {
- _, _, errno := syscall.Syscall(syscall.SYS_MLOCK, addr, len, 0)
- if errno != 0 {
- return syscall.Errno(errno)
- }
- return nil
-}
-
-func unlock(addr, len uintptr) error {
- _, _, errno := syscall.Syscall(syscall.SYS_MUNLOCK, addr, len, 0)
- if errno != 0 {
- return syscall.Errno(errno)
- }
- return nil
-}
-
-func unmap(addr, len uintptr) error {
- _, _, errno := syscall.Syscall(syscall.SYS_MUNMAP, addr, len, 0)
- if errno != 0 {
- return syscall.Errno(errno)
- }
- return nil
-}
diff --git a/vendor/github.com/edsrzf/mmap-go/mmap_windows.go b/vendor/github.com/edsrzf/mmap-go/mmap_windows.go
deleted file mode 100644
index c3d2d02d3..000000000
--- a/vendor/github.com/edsrzf/mmap-go/mmap_windows.go
+++ /dev/null
@@ -1,125 +0,0 @@
-// Copyright 2011 Evan Shaw. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mmap
-
-import (
- "errors"
- "os"
- "sync"
- "syscall"
-)
-
-// mmap on Windows is a two-step process.
-// First, we call CreateFileMapping to get a handle.
-// Then, we call MapviewToFile to get an actual pointer into memory.
-// Because we want to emulate a POSIX-style mmap, we don't want to expose
-// the handle -- only the pointer. We also want to return only a byte slice,
-// not a struct, so it's convenient to manipulate.
-
-// We keep this map so that we can get back the original handle from the memory address.
-var handleLock sync.Mutex
-var handleMap = map[uintptr]syscall.Handle{}
-
-func mmap(len int, prot, flags, hfile uintptr, off int64) ([]byte, error) {
- flProtect := uint32(syscall.PAGE_READONLY)
- dwDesiredAccess := uint32(syscall.FILE_MAP_READ)
- switch {
- case prot© != 0:
- flProtect = syscall.PAGE_WRITECOPY
- dwDesiredAccess = syscall.FILE_MAP_COPY
- case prot&RDWR != 0:
- flProtect = syscall.PAGE_READWRITE
- dwDesiredAccess = syscall.FILE_MAP_WRITE
- }
- if prot&EXEC != 0 {
- flProtect <<= 4
- dwDesiredAccess |= syscall.FILE_MAP_EXECUTE
- }
-
- // The maximum size is the area of the file, starting from 0,
- // that we wish to allow to be mappable. It is the sum of
- // the length the user requested, plus the offset where that length
- // is starting from. This does not map the data into memory.
- maxSizeHigh := uint32((off + int64(len)) >> 32)
- maxSizeLow := uint32((off + int64(len)) & 0xFFFFFFFF)
- // TODO: Do we need to set some security attributes? It might help portability.
- h, errno := syscall.CreateFileMapping(syscall.Handle(hfile), nil, flProtect, maxSizeHigh, maxSizeLow, nil)
- if h == 0 {
- return nil, os.NewSyscallError("CreateFileMapping", errno)
- }
-
- // Actually map a view of the data into memory. The view's size
- // is the length the user requested.
- fileOffsetHigh := uint32(off >> 32)
- fileOffsetLow := uint32(off & 0xFFFFFFFF)
- addr, errno := syscall.MapViewOfFile(h, dwDesiredAccess, fileOffsetHigh, fileOffsetLow, uintptr(len))
- if addr == 0 {
- return nil, os.NewSyscallError("MapViewOfFile", errno)
- }
- handleLock.Lock()
- handleMap[addr] = h
- handleLock.Unlock()
-
- m := MMap{}
- dh := m.header()
- dh.Data = addr
- dh.Len = len
- dh.Cap = dh.Len
-
- return m, nil
-}
-
-func flush(addr, len uintptr) error {
- errno := syscall.FlushViewOfFile(addr, len)
- if errno != nil {
- return os.NewSyscallError("FlushViewOfFile", errno)
- }
-
- handleLock.Lock()
- defer handleLock.Unlock()
- handle, ok := handleMap[addr]
- if !ok {
- // should be impossible; we would've errored above
- return errors.New("unknown base address")
- }
-
- errno = syscall.FlushFileBuffers(handle)
- return os.NewSyscallError("FlushFileBuffers", errno)
-}
-
-func lock(addr, len uintptr) error {
- errno := syscall.VirtualLock(addr, len)
- return os.NewSyscallError("VirtualLock", errno)
-}
-
-func unlock(addr, len uintptr) error {
- errno := syscall.VirtualUnlock(addr, len)
- return os.NewSyscallError("VirtualUnlock", errno)
-}
-
-func unmap(addr, len uintptr) error {
- flush(addr, len)
- // Lock the UnmapViewOfFile along with the handleMap deletion.
- // As soon as we unmap the view, the OS is free to give the
- // same addr to another new map. We don't want another goroutine
- // to insert and remove the same addr into handleMap while
- // we're trying to remove our old addr/handle pair.
- handleLock.Lock()
- defer handleLock.Unlock()
- err := syscall.UnmapViewOfFile(addr)
- if err != nil {
- return err
- }
-
- handle, ok := handleMap[addr]
- if !ok {
- // should be impossible; we would've errored above
- return errors.New("unknown base address")
- }
- delete(handleMap, addr)
-
- e := syscall.CloseHandle(syscall.Handle(handle))
- return os.NewSyscallError("CloseHandle", e)
-}
diff --git a/vendor/github.com/edsrzf/mmap-go/msync_netbsd.go b/vendor/github.com/edsrzf/mmap-go/msync_netbsd.go
deleted file mode 100644
index a64b003e2..000000000
--- a/vendor/github.com/edsrzf/mmap-go/msync_netbsd.go
+++ /dev/null
@@ -1,8 +0,0 @@
-// Copyright 2011 Evan Shaw. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package mmap
-
-const _SYS_MSYNC = 277
-const _MS_SYNC = 0x04
diff --git a/vendor/github.com/edsrzf/mmap-go/msync_unix.go b/vendor/github.com/edsrzf/mmap-go/msync_unix.go
deleted file mode 100644
index 91ee5f40f..000000000
--- a/vendor/github.com/edsrzf/mmap-go/msync_unix.go
+++ /dev/null
@@ -1,14 +0,0 @@
-// Copyright 2011 Evan Shaw. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux openbsd solaris
-
-package mmap
-
-import (
- "syscall"
-)
-
-const _SYS_MSYNC = syscall.SYS_MSYNC
-const _MS_SYNC = syscall.MS_SYNC
diff --git a/vendor/github.com/huichen/murmur/README.md b/vendor/github.com/huichen/murmur/README.md
deleted file mode 100644
index 40a01c01f..000000000
--- a/vendor/github.com/huichen/murmur/README.md
+++ /dev/null
@@ -1,8 +0,0 @@
-murmur
-======
-
-Go Murmur3 hash implementation
-
-Based on
-
-http://en.wikipedia.org/wiki/MurmurHash
diff --git a/vendor/github.com/huichen/murmur/license.txt b/vendor/github.com/huichen/murmur/license.txt
deleted file mode 100644
index f4f68d885..000000000
--- a/vendor/github.com/huichen/murmur/license.txt
+++ /dev/null
@@ -1,13 +0,0 @@
-Copyright 2013 Hui Chen
-
-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.
diff --git a/vendor/github.com/huichen/murmur/murmur.go b/vendor/github.com/huichen/murmur/murmur.go
deleted file mode 100644
index c39f870bf..000000000
--- a/vendor/github.com/huichen/murmur/murmur.go
+++ /dev/null
@@ -1,58 +0,0 @@
-// Murmur3 32bit hash function based on
-// http://en.wikipedia.org/wiki/MurmurHash
-package murmur
-
-const (
- c1 = 0xcc9e2d51
- c2 = 0x1b873593
- c3 = 0x85ebca6b
- c4 = 0xc2b2ae35
- r1 = 15
- r2 = 13
- m = 5
- n = 0xe6546b64
-)
-
-var (
- Seed = uint32(1)
-)
-
-func Murmur3(key []byte) (hash uint32) {
- hash = Seed
- iByte := 0
- for ; iByte+4 <= len(key); iByte += 4 {
- k := uint32(key[iByte]) | uint32(key[iByte+1])<<8 | uint32(key[iByte+2])<<16 | uint32(key[iByte+3])<<24
- k *= c1
- k = (k << r1) | (k >> (32 - r1))
- k *= c2
- hash ^= k
- hash = (hash << r2) | (hash >> (32 - r2))
- hash = hash*m + n
- }
-
- var remainingBytes uint32
- switch len(key) - iByte {
- case 3:
- remainingBytes += uint32(key[iByte+2]) << 16
- fallthrough
- case 2:
- remainingBytes += uint32(key[iByte+1]) << 8
- fallthrough
- case 1:
- remainingBytes += uint32(key[iByte])
- remainingBytes *= c1
- remainingBytes = (remainingBytes << r1) | (remainingBytes >> (32 - r1))
- remainingBytes = remainingBytes * c2
- hash ^= remainingBytes
- }
-
- hash ^= uint32(len(key))
- hash ^= hash >> 16
- hash *= c3
- hash ^= hash >> 13
- hash *= c4
- hash ^= hash >> 16
-
- // 出发吧,狗嬷嬷!
- return
-}
diff --git a/vendor/github.com/huichen/sego/README.md b/vendor/github.com/huichen/sego/README.md
deleted file mode 100644
index ce4147c43..000000000
--- a/vendor/github.com/huichen/sego/README.md
+++ /dev/null
@@ -1,43 +0,0 @@
-sego
-====
-
-Go中文分词
-
-词典用双数组trie(Double-Array Trie)实现,
-分词器算法为基于词频的最短路径加动态规划。
-
-支持普通和搜索引擎两种分词模式,支持用户词典、词性标注,可运行JSON RPC服务。
-
-分词速度单线程9MB/s,goroutines并发42MB/s(8核Macbook Pro)。
-
-# 安装/更新
-
-```
-go get -u github.com/huichen/sego
-```
-
-# 使用
-
-
-```go
-package main
-
-import (
- "fmt"
- "github.com/huichen/sego"
-)
-
-func main() {
- // 载入词典
- var segmenter sego.Segmenter
- segmenter.LoadDictionary("github.com/huichen/sego/data/dictionary.txt")
-
- // 分词
- text := []byte("中华人民共和国中央人民政府")
- segments := segmenter.Segment(text)
-
- // 处理分词结果
- // 支持普通模式和搜索模式两种分词,见代码中SegmentsToString函数的注释。
- fmt.Println(sego.SegmentsToString(segments, false))
-}
-```
diff --git a/vendor/github.com/huichen/sego/dictionary.go b/vendor/github.com/huichen/sego/dictionary.go
deleted file mode 100644
index c25c73796..000000000
--- a/vendor/github.com/huichen/sego/dictionary.go
+++ /dev/null
@@ -1,65 +0,0 @@
-package sego
-
-import "github.com/adamzy/cedar-go"
-
-// Dictionary结构体实现了一个字串前缀树,一个分词可能出现在叶子节点也有可能出现在非叶节点
-type Dictionary struct {
- trie *cedar.Cedar // Cedar 前缀树
- maxTokenLength int // 词典中最长的分词
- tokens []Token // 词典中所有的分词,方便遍历
- totalFrequency int64 // 词典中所有分词的频率之和
-}
-
-func NewDictionary() *Dictionary {
- return &Dictionary{trie: cedar.New()}
-}
-
-// 词典中最长的分词
-func (dict *Dictionary) MaxTokenLength() int {
- return dict.maxTokenLength
-}
-
-// 词典中分词数目
-func (dict *Dictionary) NumTokens() int {
- return len(dict.tokens)
-}
-
-// 词典中所有分词的频率之和
-func (dict *Dictionary) TotalFrequency() int64 {
- return dict.totalFrequency
-}
-
-// 向词典中加入一个分词
-func (dict *Dictionary) addToken(token Token) {
- bytes := textSliceToBytes(token.text)
- _, err := dict.trie.Get(bytes)
- if err == nil {
- return
- }
-
- dict.trie.Insert(bytes, dict.NumTokens())
- dict.tokens = append(dict.tokens, token)
- dict.totalFrequency += int64(token.frequency)
- if len(token.text) > dict.maxTokenLength {
- dict.maxTokenLength = len(token.text)
- }
-}
-
-// 在词典中查找和字元组words可以前缀匹配的所有分词
-// 返回值为找到的分词数
-func (dict *Dictionary) lookupTokens(words []Text, tokens []*Token) (numOfTokens int) {
- var id, value int
- var err error
- for _, word := range words {
- id, err = dict.trie.Jump(word, id)
- if err != nil {
- break
- }
- value, err = dict.trie.Value(id)
- if err == nil {
- tokens[numOfTokens] = &dict.tokens[value]
- numOfTokens++
- }
- }
- return
-}
diff --git a/vendor/github.com/huichen/sego/license.txt b/vendor/github.com/huichen/sego/license.txt
deleted file mode 100644
index f4f68d885..000000000
--- a/vendor/github.com/huichen/sego/license.txt
+++ /dev/null
@@ -1,13 +0,0 @@
-Copyright 2013 Hui Chen
-
-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.
diff --git a/vendor/github.com/huichen/sego/segment.go b/vendor/github.com/huichen/sego/segment.go
deleted file mode 100644
index f58ad74f4..000000000
--- a/vendor/github.com/huichen/sego/segment.go
+++ /dev/null
@@ -1,28 +0,0 @@
-package sego
-
-// 文本中的一个分词
-type Segment struct {
- // 分词在文本中的起始字节位置
- start int
-
- // 分词在文本中的结束字节位置(不包括该位置)
- end int
-
- // 分词信息
- token *Token
-}
-
-// 返回分词在文本中的起始字节位置
-func (s *Segment) Start() int {
- return s.start
-}
-
-// 返回分词在文本中的结束字节位置(不包括该位置)
-func (s *Segment) End() int {
- return s.end
-}
-
-// 返回分词信息
-func (s *Segment) Token() *Token {
- return s.token
-}
diff --git a/vendor/github.com/huichen/sego/segmenter.go b/vendor/github.com/huichen/sego/segmenter.go
deleted file mode 100644
index 6fa6cd4c3..000000000
--- a/vendor/github.com/huichen/sego/segmenter.go
+++ /dev/null
@@ -1,295 +0,0 @@
-//Go中文分词
-package sego
-
-import (
- "bufio"
- "fmt"
- "log"
- "math"
- "os"
- "strconv"
- "strings"
- "unicode"
- "unicode/utf8"
-)
-
-const (
- minTokenFrequency = 2 // 仅从字典文件中读取大于等于此频率的分词
-)
-
-// 分词器结构体
-type Segmenter struct {
- dict *Dictionary
-}
-
-// 该结构体用于记录Viterbi算法中某字元处的向前分词跳转信息
-type jumper struct {
- minDistance float32
- token *Token
-}
-
-// 返回分词器使用的词典
-func (seg *Segmenter) Dictionary() *Dictionary {
- return seg.dict
-}
-
-// 从文件中载入词典
-//
-// 可以载入多个词典文件,文件名用","分隔,排在前面的词典优先载入分词,比如
-// "用户词典.txt,通用词典.txt"
-// 当一个分词既出现在用户词典也出现在通用词典中,则优先使用用户词典。
-//
-// 词典的格式为(每个分词一行):
-// 分词文本 频率 词性
-func (seg *Segmenter) LoadDictionary(files string) {
- seg.dict = NewDictionary()
- for _, file := range strings.Split(files, ",") {
- log.Printf("载入sego词典 %s", file)
- dictFile, err := os.Open(file)
- defer dictFile.Close()
- if err != nil {
- log.Fatalf("无法载入字典文件 \"%s\" \n", file)
- }
-
- reader := bufio.NewReader(dictFile)
- var text string
- var freqText string
- var frequency int
- var pos string
-
- // 逐行读入分词
- for {
- size, _ := fmt.Fscanln(reader, &text, &freqText, &pos)
-
- if size == 0 {
- // 文件结束
- break
- } else if size < 2 {
- // 无效行
- continue
- } else if size == 2 {
- // 没有词性标注时设为空字符串
- pos = ""
- }
-
- // 解析词频
- var err error
- frequency, err = strconv.Atoi(freqText)
- if err != nil {
- continue
- }
-
- // 过滤频率太小的词
- if frequency < minTokenFrequency {
- continue
- }
-
- // 将分词添加到字典中
- words := splitTextToWords([]byte(text))
- token := Token{text: words, frequency: frequency, pos: pos}
- seg.dict.addToken(token)
- }
- }
-
- // 计算每个分词的路径值,路径值含义见Token结构体的注释
- logTotalFrequency := float32(math.Log2(float64(seg.dict.totalFrequency)))
- for i := range seg.dict.tokens {
- token := &seg.dict.tokens[i]
- token.distance = logTotalFrequency - float32(math.Log2(float64(token.frequency)))
- }
-
- // 对每个分词进行细致划分,用于搜索引擎模式,该模式用法见Token结构体的注释。
- for i := range seg.dict.tokens {
- token := &seg.dict.tokens[i]
- segments := seg.segmentWords(token.text, true)
-
- // 计算需要添加的子分词数目
- numTokensToAdd := 0
- for iToken := 0; iToken < len(segments); iToken++ {
- if len(segments[iToken].token.text) > 1 {
- // 略去字元长度为一的分词
- // TODO: 这值得进一步推敲,特别是当字典中有英文复合词的时候
- numTokensToAdd++
- }
- }
- token.segments = make([]*Segment, numTokensToAdd)
-
- // 添加子分词
- iSegmentsToAdd := 0
- for iToken := 0; iToken < len(segments); iToken++ {
- if len(segments[iToken].token.text) > 1 {
- token.segments[iSegmentsToAdd] = &segments[iToken]
- iSegmentsToAdd++
- }
- }
- }
-
- log.Println("sego词典载入完毕")
-}
-
-// 对文本分词
-//
-// 输入参数:
-// bytes UTF8文本的字节数组
-//
-// 输出:
-// []Segment 划分的分词
-func (seg *Segmenter) Segment(bytes []byte) []Segment {
- return seg.internalSegment(bytes, false)
-}
-
-func (seg *Segmenter) internalSegment(bytes []byte, searchMode bool) []Segment {
- // 处理特殊情况
- if len(bytes) == 0 {
- return []Segment{}
- }
-
- // 划分字元
- text := splitTextToWords(bytes)
-
- return seg.segmentWords(text, searchMode)
-}
-
-func (seg *Segmenter) segmentWords(text []Text, searchMode bool) []Segment {
- // 搜索模式下该分词已无继续划分可能的情况
- if searchMode && len(text) == 1 {
- return []Segment{}
- }
-
- // jumpers定义了每个字元处的向前跳转信息,包括这个跳转对应的分词,
- // 以及从文本段开始到该字元的最短路径值
- jumpers := make([]jumper, len(text))
-
- tokens := make([]*Token, seg.dict.maxTokenLength)
- for current := 0; current < len(text); current++ {
- // 找到前一个字元处的最短路径,以便计算后续路径值
- var baseDistance float32
- if current == 0 {
- // 当本字元在文本首部时,基础距离应该是零
- baseDistance = 0
- } else {
- baseDistance = jumpers[current-1].minDistance
- }
-
- // 寻找所有以当前字元开头的分词
- numTokens := seg.dict.lookupTokens(
- text[current:minInt(current+seg.dict.maxTokenLength, len(text))], tokens)
-
- // 对所有可能的分词,更新分词结束字元处的跳转信息
- for iToken := 0; iToken < numTokens; iToken++ {
- location := current + len(tokens[iToken].text) - 1
- if !searchMode || current != 0 || location != len(text)-1 {
- updateJumper(&jumpers[location], baseDistance, tokens[iToken])
- }
- }
-
- // 当前字元没有对应分词时补加一个伪分词
- if numTokens == 0 || len(tokens[0].text) > 1 {
- updateJumper(&jumpers[current], baseDistance,
- &Token{text: []Text{text[current]}, frequency: 1, distance: 32, pos: "x"})
- }
- }
-
- // 从后向前扫描第一遍得到需要添加的分词数目
- numSeg := 0
- for index := len(text) - 1; index >= 0; {
- location := index - len(jumpers[index].token.text) + 1
- numSeg++
- index = location - 1
- }
-
- // 从后向前扫描第二遍添加分词到最终结果
- outputSegments := make([]Segment, numSeg)
- for index := len(text) - 1; index >= 0; {
- location := index - len(jumpers[index].token.text) + 1
- numSeg--
- outputSegments[numSeg].token = jumpers[index].token
- index = location - 1
- }
-
- // 计算各个分词的字节位置
- bytePosition := 0
- for iSeg := 0; iSeg < len(outputSegments); iSeg++ {
- outputSegments[iSeg].start = bytePosition
- bytePosition += textSliceByteLength(outputSegments[iSeg].token.text)
- outputSegments[iSeg].end = bytePosition
- }
- return outputSegments
-}
-
-// 更新跳转信息:
-// 1. 当该位置从未被访问过时(jumper.minDistance为零的情况),或者
-// 2. 当该位置的当前最短路径大于新的最短路径时
-// 将当前位置的最短路径值更新为baseDistance加上新分词的概率
-func updateJumper(jumper *jumper, baseDistance float32, token *Token) {
- newDistance := baseDistance + token.distance
- if jumper.minDistance == 0 || jumper.minDistance > newDistance {
- jumper.minDistance = newDistance
- jumper.token = token
- }
-}
-
-// 取两整数较小值
-func minInt(a, b int) int {
- if a > b {
- return b
- }
- return a
-}
-
-// 取两整数较大值
-func maxInt(a, b int) int {
- if a > b {
- return a
- }
- return b
-}
-
-// 将文本划分成字元
-func splitTextToWords(text Text) []Text {
- output := make([]Text, 0, len(text)/3)
- current := 0
- inAlphanumeric := true
- alphanumericStart := 0
- for current < len(text) {
- r, size := utf8.DecodeRune(text[current:])
- if size <= 2 && (unicode.IsLetter(r) || unicode.IsNumber(r)) {
- // 当前是拉丁字母或数字(非中日韩文字)
- if !inAlphanumeric {
- alphanumericStart = current
- inAlphanumeric = true
- }
- } else {
- if inAlphanumeric {
- inAlphanumeric = false
- if current != 0 {
- output = append(output, toLower(text[alphanumericStart:current]))
- }
- }
- output = append(output, text[current:current+size])
- }
- current += size
- }
-
- // 处理最后一个字元是英文的情况
- if inAlphanumeric {
- if current != 0 {
- output = append(output, toLower(text[alphanumericStart:current]))
- }
- }
-
- return output
-}
-
-// 将英文词转化为小写
-func toLower(text []byte) []byte {
- output := make([]byte, len(text))
- for i, t := range text {
- if t >= 'A' && t <= 'Z' {
- output[i] = t - 'A' + 'a'
- } else {
- output[i] = t
- }
- }
- return output
-}
diff --git a/vendor/github.com/huichen/sego/test_utils.go b/vendor/github.com/huichen/sego/test_utils.go
deleted file mode 100644
index 0c4abc191..000000000
--- a/vendor/github.com/huichen/sego/test_utils.go
+++ /dev/null
@@ -1,38 +0,0 @@
-package sego
-
-import (
- "fmt"
- "testing"
-)
-
-func expect(t *testing.T, expect string, actual interface{}) {
- actualString := fmt.Sprint(actual)
- if expect != actualString {
- t.Errorf("期待值=\"%s\", 实际=\"%s\"", expect, actualString)
- }
-}
-
-func printTokens(tokens []*Token, numTokens int) (output string) {
- for iToken := 0; iToken < numTokens; iToken++ {
- for _, word := range tokens[iToken].text {
- output += fmt.Sprint(string(word))
- }
- output += " "
- }
- return
-}
-
-func toWords(strings ...string) []Text {
- words := []Text{}
- for _, s := range strings {
- words = append(words, []byte(s))
- }
- return words
-}
-
-func bytesToString(bytes []Text) (output string) {
- for _, b := range bytes {
- output += (string(b) + "/")
- }
- return
-}
diff --git a/vendor/github.com/huichen/sego/token.go b/vendor/github.com/huichen/sego/token.go
deleted file mode 100644
index 47dd59b4e..000000000
--- a/vendor/github.com/huichen/sego/token.go
+++ /dev/null
@@ -1,50 +0,0 @@
-package sego
-
-// 字串类型,可以用来表达
-// 1. 一个字元,比如"中"又如"国", 英文的一个字元是一个词
-// 2. 一个分词,比如"中国"又如"人口"
-// 3. 一段文字,比如"中国有十三亿人口"
-type Text []byte
-
-// 一个分词
-type Token struct {
- // 分词的字串,这实际上是个字元数组
- text []Text
-
- // 分词在语料库中的词频
- frequency int
-
- // log2(总词频/该分词词频),这相当于log2(1/p(分词)),用作动态规划中
- // 该分词的路径长度。求解prod(p(分词))的最大值相当于求解
- // sum(distance(分词))的最小值,这就是“最短路径”的来历。
- distance float32
-
- // 词性标注
- pos string
-
- // 该分词文本的进一步分词划分,见Segments函数注释。
- segments []*Segment
-}
-
-// 返回分词文本
-func (token *Token) Text() string {
- return textSliceToString(token.text)
-}
-
-// 返回分词在语料库中的词频
-func (token *Token) Frequency() int {
- return token.frequency
-}
-
-// 返回分词词性标注
-func (token *Token) Pos() string {
- return token.pos
-}
-
-// 该分词文本的进一步分词划分,比如"中华人民共和国中央人民政府"这个分词
-// 有两个子分词"中华人民共和国"和"中央人民政府"。子分词也可以进一步有子分词
-// 形成一个树结构,遍历这个树就可以得到该分词的所有细致分词划分,这主要
-// 用于搜索引擎对一段文本进行全文搜索。
-func (token *Token) Segments() []*Segment {
- return token.segments
-}
diff --git a/vendor/github.com/huichen/sego/utils.go b/vendor/github.com/huichen/sego/utils.go
deleted file mode 100644
index 9d5f3ffa5..000000000
--- a/vendor/github.com/huichen/sego/utils.go
+++ /dev/null
@@ -1,93 +0,0 @@
-package sego
-
-import (
- "bytes"
- "fmt"
-)
-
-// 输出分词结果为字符串
-//
-// 有两种输出模式,以"中华人民共和国"为例
-//
-// 普通模式(searchMode=false)输出一个分词"中华人民共和国/ns "
-// 搜索模式(searchMode=true) 输出普通模式的再细致切分:
-// "中华/nz 人民/n 共和/nz 共和国/ns 人民共和国/nt 中华人民共和国/ns "
-//
-// 搜索模式主要用于给搜索引擎提供尽可能多的关键字,详情请见Token结构体的注释。
-func SegmentsToString(segs []Segment, searchMode bool) (output string) {
- if searchMode {
- for _, seg := range segs {
- output += tokenToString(seg.token)
- }
- } else {
- for _, seg := range segs {
- output += fmt.Sprintf(
- "%s/%s ", textSliceToString(seg.token.text), seg.token.pos)
- }
- }
- return
-}
-
-func tokenToString(token *Token) (output string) {
- for _, s := range token.segments {
- output += tokenToString(s.token)
- }
- output += fmt.Sprintf("%s/%s ", textSliceToString(token.text), token.pos)
- return
-}
-
-// 输出分词结果到一个字符串slice
-//
-// 有两种输出模式,以"中华人民共和国"为例
-//
-// 普通模式(searchMode=false)输出一个分词"[中华人民共和国]"
-// 搜索模式(searchMode=true) 输出普通模式的再细致切分:
-// "[中华 人民 共和 共和国 人民共和国 中华人民共和国]"
-//
-// 搜索模式主要用于给搜索引擎提供尽可能多的关键字,详情请见Token结构体的注释。
-
-func SegmentsToSlice(segs []Segment, searchMode bool) (output []string) {
- if searchMode {
- for _, seg := range segs {
- output = append(output, tokenToSlice(seg.token)...)
- }
- } else {
- for _, seg := range segs {
- output = append(output, seg.token.Text())
- }
- }
- return
-}
-
-func tokenToSlice(token *Token) (output []string) {
- for _, s := range token.segments {
- output = append(output, tokenToSlice(s.token)...)
- }
- output = append(output, textSliceToString(token.text))
- return output
-}
-
-// 将多个字元拼接一个字符串输出
-func textSliceToString(text []Text) string {
- var output string
- for _, word := range text {
- output += string(word)
- }
- return output
-}
-
-// 返回多个字元的字节总长度
-func textSliceByteLength(text []Text) (length int) {
- for _, word := range text {
- length += len(word)
- }
- return
-}
-
-func textSliceToBytes(text []Text) []byte {
- var buf bytes.Buffer
- for _, word := range text {
- buf.Write(word)
- }
- return buf.Bytes()
-}
diff --git a/vendor/github.com/huichen/wukong/core/indexer.go b/vendor/github.com/huichen/wukong/core/indexer.go
deleted file mode 100644
index 2f0663640..000000000
--- a/vendor/github.com/huichen/wukong/core/indexer.go
+++ /dev/null
@@ -1,574 +0,0 @@
-package core
-
-import (
- "log"
- "math"
- "sort"
- "sync"
-
- "github.com/huichen/wukong/types"
- "github.com/huichen/wukong/utils"
-)
-
-// 索引器
-type Indexer struct {
- // 从搜索键到文档列表的反向索引
- // 加了读写锁以保证读写安全
- tableLock struct {
- sync.RWMutex
- table map[string]*KeywordIndices
- docsState map[uint64]int // nil: 表示无状态记录,0: 存在于索引中,1: 等待删除,2: 等待加入
- }
- addCacheLock struct {
- sync.RWMutex
- addCachePointer int
- addCache types.DocumentsIndex
- }
- removeCacheLock struct {
- sync.RWMutex
- removeCachePointer int
- removeCache types.DocumentsId
- }
-
- initOptions types.IndexerInitOptions
- initialized bool
-
- // 这实际上是总文档数的一个近似
- numDocuments uint64
-
- // 所有被索引文本的总关键词数
- totalTokenLength float32
-
- // 每个文档的关键词长度
- docTokenLengths map[uint64]float32
-}
-
-// 反向索引表的一行,收集了一个搜索键出现的所有文档,按照DocId从小到大排序。
-type KeywordIndices struct {
- // 下面的切片是否为空,取决于初始化时IndexType的值
- docIds []uint64 // 全部类型都有
- frequencies []float32 // IndexType == FrequenciesIndex
- locations [][]int // IndexType == LocationsIndex
-}
-
-// 初始化索引器
-func (indexer *Indexer) Init(options types.IndexerInitOptions) {
- if indexer.initialized == true {
- log.Fatal("索引器不能初始化两次")
- }
- options.Init()
- indexer.initOptions = options
- indexer.initialized = true
-
- indexer.tableLock.table = make(map[string]*KeywordIndices)
- indexer.tableLock.docsState = make(map[uint64]int)
- indexer.addCacheLock.addCache = make([]*types.DocumentIndex, indexer.initOptions.DocCacheSize)
- indexer.removeCacheLock.removeCache = make([]uint64, indexer.initOptions.DocCacheSize*2)
- indexer.docTokenLengths = make(map[uint64]float32)
-}
-
-// 从KeywordIndices中得到第i个文档的DocId
-func (indexer *Indexer) getDocId(ti *KeywordIndices, i int) uint64 {
- return ti.docIds[i]
-}
-
-// 得到KeywordIndices中文档总数
-func (indexer *Indexer) getIndexLength(ti *KeywordIndices) int {
- return len(ti.docIds)
-}
-
-// 向 ADDCACHE 中加入一个文档
-func (indexer *Indexer) AddDocumentToCache(document *types.DocumentIndex, forceUpdate bool) {
- if indexer.initialized == false {
- log.Fatal("索引器尚未初始化")
- }
-
- indexer.addCacheLock.Lock()
- if document != nil {
- indexer.addCacheLock.addCache[indexer.addCacheLock.addCachePointer] = document
- indexer.addCacheLock.addCachePointer++
- }
- if indexer.addCacheLock.addCachePointer >= indexer.initOptions.DocCacheSize || forceUpdate {
- indexer.tableLock.Lock()
- position := 0
- for i := 0; i < indexer.addCacheLock.addCachePointer; i++ {
- docIndex := indexer.addCacheLock.addCache[i]
- if docState, ok := indexer.tableLock.docsState[docIndex.DocId]; ok && docState <= 1 {
- // ok && docState == 0 表示存在于索引中,需先删除再添加
- // ok && docState == 1 表示不一定存在于索引中,等待删除,需先删除再添加
- if position != i {
- indexer.addCacheLock.addCache[position], indexer.addCacheLock.addCache[i] =
- indexer.addCacheLock.addCache[i], indexer.addCacheLock.addCache[position]
- }
- if docState == 0 {
- indexer.removeCacheLock.Lock()
- indexer.removeCacheLock.removeCache[indexer.removeCacheLock.removeCachePointer] =
- docIndex.DocId
- indexer.removeCacheLock.removeCachePointer++
- indexer.removeCacheLock.Unlock()
- indexer.tableLock.docsState[docIndex.DocId] = 1
- indexer.numDocuments--
- }
- position++
- } else if !ok {
- indexer.tableLock.docsState[docIndex.DocId] = 2
- }
- }
-
- indexer.tableLock.Unlock()
- if indexer.RemoveDocumentToCache(0, forceUpdate) {
- // 只有当存在于索引表中的文档已被删除,其才可以重新加入到索引表中
- position = 0
- }
-
- addCachedDocuments := indexer.addCacheLock.addCache[position:indexer.addCacheLock.addCachePointer]
- indexer.addCacheLock.addCachePointer = position
- indexer.addCacheLock.Unlock()
- sort.Sort(addCachedDocuments)
- indexer.AddDocuments(&addCachedDocuments)
- } else {
- indexer.addCacheLock.Unlock()
- }
-}
-
-// 向反向索引表中加入 ADDCACHE 中所有文档
-func (indexer *Indexer) AddDocuments(documents *types.DocumentsIndex) {
- if indexer.initialized == false {
- log.Fatal("索引器尚未初始化")
- }
-
- indexer.tableLock.Lock()
- defer indexer.tableLock.Unlock()
- indexPointers := make(map[string]int, len(indexer.tableLock.table))
-
- // DocId 递增顺序遍历插入文档保证索引移动次数最少
- for i, document := range *documents {
- if i < len(*documents)-1 && (*documents)[i].DocId == (*documents)[i+1].DocId {
- // 如果有重复文档加入,因为稳定排序,只加入最后一个
- continue
- }
- if docState, ok := indexer.tableLock.docsState[document.DocId]; ok && docState == 1 {
- // 如果此时 docState 仍为 1,说明该文档需被删除
- // docState 合法状态为 nil & 2,保证一定不会插入已经在索引表中的文档
- continue
- }
-
- // 更新文档关键词总长度
- if document.TokenLength != 0 {
- indexer.docTokenLengths[document.DocId] = float32(document.TokenLength)
- indexer.totalTokenLength += document.TokenLength
- }
-
- docIdIsNew := true
- for _, keyword := range document.Keywords {
- indices, foundKeyword := indexer.tableLock.table[keyword.Text]
- if !foundKeyword {
- // 如果没找到该搜索键则加入
- ti := KeywordIndices{}
- switch indexer.initOptions.IndexType {
- case types.LocationsIndex:
- ti.locations = [][]int{keyword.Starts}
- case types.FrequenciesIndex:
- ti.frequencies = []float32{keyword.Frequency}
- }
- ti.docIds = []uint64{document.DocId}
- indexer.tableLock.table[keyword.Text] = &ti
- continue
- }
-
- // 查找应该插入的位置,且索引一定不存在
- position, _ := indexer.searchIndex(
- indices, indexPointers[keyword.Text], indexer.getIndexLength(indices)-1, document.DocId)
- indexPointers[keyword.Text] = position
- switch indexer.initOptions.IndexType {
- case types.LocationsIndex:
- indices.locations = append(indices.locations, []int{})
- copy(indices.locations[position+1:], indices.locations[position:])
- indices.locations[position] = keyword.Starts
- case types.FrequenciesIndex:
- indices.frequencies = append(indices.frequencies, float32(0))
- copy(indices.frequencies[position+1:], indices.frequencies[position:])
- indices.frequencies[position] = keyword.Frequency
- }
- indices.docIds = append(indices.docIds, 0)
- copy(indices.docIds[position+1:], indices.docIds[position:])
- indices.docIds[position] = document.DocId
- }
-
- // 更新文章状态和总数
- if docIdIsNew {
- indexer.tableLock.docsState[document.DocId] = 0
- indexer.numDocuments++
- }
- }
-}
-
-// 向 REMOVECACHE 中加入一个待删除文档
-// 返回值表示文档是否在索引表中被删除
-func (indexer *Indexer) RemoveDocumentToCache(docId uint64, forceUpdate bool) bool {
- if indexer.initialized == false {
- log.Fatal("索引器尚未初始化")
- }
-
- indexer.removeCacheLock.Lock()
- if docId != 0 {
- indexer.tableLock.Lock()
- if docState, ok := indexer.tableLock.docsState[docId]; ok && docState == 0 {
- indexer.removeCacheLock.removeCache[indexer.removeCacheLock.removeCachePointer] = docId
- indexer.removeCacheLock.removeCachePointer++
- indexer.tableLock.docsState[docId] = 1
- indexer.numDocuments--
- } else if ok && docState == 2 {
- // 删除一个等待加入的文档
- indexer.tableLock.docsState[docId] = 1
- } else if !ok {
- // 若文档不存在,则无法判断其是否在 addCache 中,需避免这样的操作
- }
- indexer.tableLock.Unlock()
- }
-
- if indexer.removeCacheLock.removeCachePointer > 0 &&
- (indexer.removeCacheLock.removeCachePointer >= indexer.initOptions.DocCacheSize ||
- forceUpdate) {
- removeCachedDocuments := indexer.removeCacheLock.removeCache[:indexer.removeCacheLock.removeCachePointer]
- indexer.removeCacheLock.removeCachePointer = 0
- indexer.removeCacheLock.Unlock()
- sort.Sort(removeCachedDocuments)
- indexer.RemoveDocuments(&removeCachedDocuments)
- return true
- }
- indexer.removeCacheLock.Unlock()
- return false
-}
-
-// 向反向索引表中删除 REMOVECACHE 中所有文档
-func (indexer *Indexer) RemoveDocuments(documents *types.DocumentsId) {
- if indexer.initialized == false {
- log.Fatal("索引器尚未初始化")
- }
-
- indexer.tableLock.Lock()
- defer indexer.tableLock.Unlock()
-
- // 更新文档关键词总长度,删除文档状态
- for _, docId := range *documents {
- indexer.totalTokenLength -= indexer.docTokenLengths[docId]
- delete(indexer.docTokenLengths, docId)
- delete(indexer.tableLock.docsState, docId)
- }
-
- for keyword, indices := range indexer.tableLock.table {
- indicesTop, indicesPointer := 0, 0
- documentsPointer := sort.Search(
- len(*documents), func(i int) bool { return (*documents)[i] >= indices.docIds[0] })
- // 双指针扫描,进行批量删除操作
- for documentsPointer < len(*documents) && indicesPointer < indexer.getIndexLength(indices) {
- if indices.docIds[indicesPointer] < (*documents)[documentsPointer] {
- if indicesTop != indicesPointer {
- switch indexer.initOptions.IndexType {
- case types.LocationsIndex:
- indices.locations[indicesTop] = indices.locations[indicesPointer]
- case types.FrequenciesIndex:
- indices.frequencies[indicesTop] = indices.frequencies[indicesPointer]
- }
- indices.docIds[indicesTop] = indices.docIds[indicesPointer]
- }
- indicesTop++
- indicesPointer++
- } else if indices.docIds[indicesPointer] == (*documents)[documentsPointer] {
- indicesPointer++
- documentsPointer++
- } else {
- documentsPointer++
- }
- }
- if indicesTop != indicesPointer {
- switch indexer.initOptions.IndexType {
- case types.LocationsIndex:
- indices.locations = append(
- indices.locations[:indicesTop], indices.locations[indicesPointer:]...)
- case types.FrequenciesIndex:
- indices.frequencies = append(
- indices.frequencies[:indicesTop], indices.frequencies[indicesPointer:]...)
- }
- indices.docIds = append(
- indices.docIds[:indicesTop], indices.docIds[indicesPointer:]...)
- }
- if len(indices.docIds) == 0 {
- delete(indexer.tableLock.table, keyword)
- }
- }
-}
-
-// 查找包含全部搜索键(AND操作)的文档
-// 当docIds不为nil时仅从docIds指定的文档中查找
-func (indexer *Indexer) Lookup(
- tokens []string, labels []string, docIds map[uint64]bool, countDocsOnly bool) (docs []types.IndexedDocument, numDocs int) {
- if indexer.initialized == false {
- log.Fatal("索引器尚未初始化")
- }
-
- if indexer.numDocuments == 0 {
- return
- }
- numDocs = 0
-
- // 合并关键词和标签为搜索键
- keywords := make([]string, len(tokens)+len(labels))
- copy(keywords, tokens)
- copy(keywords[len(tokens):], labels)
-
- indexer.tableLock.RLock()
- defer indexer.tableLock.RUnlock()
- table := make([]*KeywordIndices, len(keywords))
- for i, keyword := range keywords {
- indices, found := indexer.tableLock.table[keyword]
- if !found {
- // 当反向索引表中无此搜索键时直接返回
- return
- } else {
- // 否则加入反向表中
- table[i] = indices
- }
- }
-
- // 当没有找到时直接返回
- if len(table) == 0 {
- return
- }
-
- // 归并查找各个搜索键出现文档的交集
- // 从后向前查保证先输出DocId较大文档
- indexPointers := make([]int, len(table))
- for iTable := 0; iTable < len(table); iTable++ {
- indexPointers[iTable] = indexer.getIndexLength(table[iTable]) - 1
- }
- // 平均文本关键词长度,用于计算BM25
- avgDocLength := indexer.totalTokenLength / float32(indexer.numDocuments)
- for ; indexPointers[0] >= 0; indexPointers[0]-- {
- // 以第一个搜索键出现的文档作为基准,并遍历其他搜索键搜索同一文档
- baseDocId := indexer.getDocId(table[0], indexPointers[0])
- if docIds != nil {
- if _, found := docIds[baseDocId]; !found {
- continue
- }
- }
- iTable := 1
- found := true
- for ; iTable < len(table); iTable++ {
- // 二分法比简单的顺序归并效率高,也有更高效率的算法,
- // 但顺序归并也许是更好的选择,考虑到将来需要用链表重新实现
- // 以避免反向表添加新文档时的写锁。
- // TODO: 进一步研究不同求交集算法的速度和可扩展性。
- position, foundBaseDocId := indexer.searchIndex(table[iTable],
- 0, indexPointers[iTable], baseDocId)
- if foundBaseDocId {
- indexPointers[iTable] = position
- } else {
- if position == 0 {
- // 该搜索键中所有的文档ID都比baseDocId大,因此已经没有
- // 继续查找的必要。
- return
- } else {
- // 继续下一indexPointers[0]的查找
- indexPointers[iTable] = position - 1
- found = false
- break
- }
- }
- }
-
- if found {
- if docState, ok := indexer.tableLock.docsState[baseDocId]; !ok || docState != 0 {
- continue
- }
- indexedDoc := types.IndexedDocument{}
-
- // 当为LocationsIndex时计算关键词紧邻距离
- if indexer.initOptions.IndexType == types.LocationsIndex {
- // 计算有多少关键词是带有距离信息的
- numTokensWithLocations := 0
- for i, t := range table[:len(tokens)] {
- if len(t.locations[indexPointers[i]]) > 0 {
- numTokensWithLocations++
- }
- }
- if numTokensWithLocations != len(tokens) {
- if !countDocsOnly {
- docs = append(docs, types.IndexedDocument{
- DocId: baseDocId,
- })
- }
- numDocs++
- //当某个关键字对应多个文档且有lable关键字存在时,若直接break,将会丢失相当一部分搜索结果
- continue
- }
-
- // 计算搜索键在文档中的紧邻距离
- tokenProximity, tokenLocations := computeTokenProximity(table[:len(tokens)], indexPointers, tokens)
- indexedDoc.TokenProximity = int32(tokenProximity)
- indexedDoc.TokenSnippetLocations = tokenLocations
-
- // 添加TokenLocations
- indexedDoc.TokenLocations = make([][]int, len(tokens))
- for i, t := range table[:len(tokens)] {
- indexedDoc.TokenLocations[i] = t.locations[indexPointers[i]]
- }
- }
-
- // 当为LocationsIndex或者FrequenciesIndex时计算BM25
- if indexer.initOptions.IndexType == types.LocationsIndex ||
- indexer.initOptions.IndexType == types.FrequenciesIndex {
- bm25 := float32(0)
- d := indexer.docTokenLengths[baseDocId]
- for i, t := range table[:len(tokens)] {
- var frequency float32
- if indexer.initOptions.IndexType == types.LocationsIndex {
- frequency = float32(len(t.locations[indexPointers[i]]))
- } else {
- frequency = t.frequencies[indexPointers[i]]
- }
-
- // 计算BM25
- if len(t.docIds) > 0 && frequency > 0 && indexer.initOptions.BM25Parameters != nil && avgDocLength != 0 {
- // 带平滑的idf
- idf := float32(math.Log2(float64(indexer.numDocuments)/float64(len(t.docIds)) + 1))
- k1 := indexer.initOptions.BM25Parameters.K1
- b := indexer.initOptions.BM25Parameters.B
- bm25 += idf * frequency * (k1 + 1) / (frequency + k1*(1-b+b*d/avgDocLength))
- }
- }
- indexedDoc.BM25 = float32(bm25)
- }
-
- indexedDoc.DocId = baseDocId
- if !countDocsOnly {
- docs = append(docs, indexedDoc)
- }
- numDocs++
- }
- }
- return
-}
-
-// 二分法查找indices中某文档的索引项
-// 第一个返回参数为找到的位置或需要插入的位置
-// 第二个返回参数标明是否找到
-func (indexer *Indexer) searchIndex(
- indices *KeywordIndices, start int, end int, docId uint64) (int, bool) {
- // 特殊情况
- if indexer.getIndexLength(indices) == start {
- return start, false
- }
- if docId < indexer.getDocId(indices, start) {
- return start, false
- } else if docId == indexer.getDocId(indices, start) {
- return start, true
- }
- if docId > indexer.getDocId(indices, end) {
- return end + 1, false
- } else if docId == indexer.getDocId(indices, end) {
- return end, true
- }
-
- // 二分
- var middle int
- for end-start > 1 {
- middle = (start + end) / 2
- if docId == indexer.getDocId(indices, middle) {
- return middle, true
- } else if docId > indexer.getDocId(indices, middle) {
- start = middle
- } else {
- end = middle
- }
- }
- return end, false
-}
-
-// 计算搜索键在文本中的紧邻距离
-//
-// 假定第 i 个搜索键首字节出现在文本中的位置为 P_i,长度 L_i
-// 紧邻距离计算公式为
-//
-// ArgMin(Sum(Abs(P_(i+1) - P_i - L_i)))
-//
-// 具体由动态规划实现,依次计算前 i 个 token 在每个出现位置的最优值。
-// 选定的 P_i 通过 tokenLocations 参数传回。
-func computeTokenProximity(table []*KeywordIndices, indexPointers []int, tokens []string) (
- minTokenProximity int, tokenLocations []int) {
- minTokenProximity = -1
- tokenLocations = make([]int, len(tokens))
-
- var (
- currentLocations, nextLocations []int
- currentMinValues, nextMinValues []int
- path [][]int
- )
-
- // 初始化路径数组
- path = make([][]int, len(tokens))
- for i := 1; i < len(path); i++ {
- path[i] = make([]int, len(table[i].locations[indexPointers[i]]))
- }
-
- // 动态规划
- currentLocations = table[0].locations[indexPointers[0]]
- currentMinValues = make([]int, len(currentLocations))
- for i := 1; i < len(tokens); i++ {
- nextLocations = table[i].locations[indexPointers[i]]
- nextMinValues = make([]int, len(nextLocations))
- for j, _ := range nextMinValues {
- nextMinValues[j] = -1
- }
-
- var iNext int
- for iCurrent, currentLocation := range currentLocations {
- if currentMinValues[iCurrent] == -1 {
- continue
- }
- for iNext+1 < len(nextLocations) && nextLocations[iNext+1] < currentLocation {
- iNext++
- }
-
- update := func(from int, to int) {
- if to >= len(nextLocations) {
- return
- }
- value := currentMinValues[from] + utils.AbsInt(nextLocations[to]-currentLocations[from]-len(tokens[i-1]))
- if nextMinValues[to] == -1 || value < nextMinValues[to] {
- nextMinValues[to] = value
- path[i][to] = from
- }
- }
-
- // 最优解的状态转移只发生在左右最接近的位置
- update(iCurrent, iNext)
- update(iCurrent, iNext+1)
- }
-
- currentLocations = nextLocations
- currentMinValues = nextMinValues
- }
-
- // 找出最优解
- var cursor int
- for i, value := range currentMinValues {
- if value == -1 {
- continue
- }
- if minTokenProximity == -1 || value < minTokenProximity {
- minTokenProximity = value
- cursor = i
- }
- }
-
- // 从路径倒推出最优解的位置
- for i := len(tokens) - 1; i >= 0; i-- {
- if i != len(tokens)-1 {
- cursor = path[i+1][cursor]
- }
- tokenLocations[i] = table[i].locations[indexPointers[i]][cursor]
- }
- return
-}
diff --git a/vendor/github.com/huichen/wukong/core/ranker.go b/vendor/github.com/huichen/wukong/core/ranker.go
deleted file mode 100644
index 22dd99d97..000000000
--- a/vendor/github.com/huichen/wukong/core/ranker.go
+++ /dev/null
@@ -1,106 +0,0 @@
-package core
-
-import (
- "github.com/huichen/wukong/types"
- "github.com/huichen/wukong/utils"
- "log"
- "sort"
- "sync"
-)
-
-type Ranker struct {
- lock struct {
- sync.RWMutex
- fields map[uint64]interface{}
- docs map[uint64]bool
- }
- initialized bool
-}
-
-func (ranker *Ranker) Init() {
- if ranker.initialized == true {
- log.Fatal("排序器不能初始化两次")
- }
- ranker.initialized = true
-
- ranker.lock.fields = make(map[uint64]interface{})
- ranker.lock.docs = make(map[uint64]bool)
-}
-
-// 给某个文档添加评分字段
-func (ranker *Ranker) AddDoc(docId uint64, fields interface{}) {
- if ranker.initialized == false {
- log.Fatal("排序器尚未初始化")
- }
-
- ranker.lock.Lock()
- ranker.lock.fields[docId] = fields
- ranker.lock.docs[docId] = true
- ranker.lock.Unlock()
-}
-
-// 删除某个文档的评分字段
-func (ranker *Ranker) RemoveDoc(docId uint64) {
- if ranker.initialized == false {
- log.Fatal("排序器尚未初始化")
- }
-
- ranker.lock.Lock()
- delete(ranker.lock.fields, docId)
- delete(ranker.lock.docs, docId)
- ranker.lock.Unlock()
-}
-
-// 给文档评分并排序
-func (ranker *Ranker) Rank(
- docs []types.IndexedDocument, options types.RankOptions, countDocsOnly bool) (types.ScoredDocuments, int) {
- if ranker.initialized == false {
- log.Fatal("排序器尚未初始化")
- }
-
- // 对每个文档评分
- var outputDocs types.ScoredDocuments
- numDocs := 0
- for _, d := range docs {
- ranker.lock.RLock()
- // 判断doc是否存在
- if _, ok := ranker.lock.docs[d.DocId]; ok {
- fs := ranker.lock.fields[d.DocId]
- ranker.lock.RUnlock()
- // 计算评分并剔除没有分值的文档
- scores := options.ScoringCriteria.Score(d, fs)
- if len(scores) > 0 {
- if !countDocsOnly {
- outputDocs = append(outputDocs, types.ScoredDocument{
- DocId: d.DocId,
- Scores: scores,
- TokenSnippetLocations: d.TokenSnippetLocations,
- TokenLocations: d.TokenLocations})
- }
- numDocs++
- }
- } else {
- ranker.lock.RUnlock()
- }
- }
-
- // 排序
- if !countDocsOnly {
- if options.ReverseOrder {
- sort.Sort(sort.Reverse(outputDocs))
- } else {
- sort.Sort(outputDocs)
- }
- // 当用户要求只返回部分结果时返回部分结果
- var start, end int
- if options.MaxOutputs != 0 {
- start = utils.MinInt(options.OutputOffset, len(outputDocs))
- end = utils.MinInt(options.OutputOffset+options.MaxOutputs, len(outputDocs))
- } else {
- start = utils.MinInt(options.OutputOffset, len(outputDocs))
- end = len(outputDocs)
- }
- return outputDocs[start:end], numDocs
- }
- return outputDocs, numDocs
-}
diff --git a/vendor/github.com/huichen/wukong/core/test_utils.go b/vendor/github.com/huichen/wukong/core/test_utils.go
deleted file mode 100644
index 839f01f14..000000000
--- a/vendor/github.com/huichen/wukong/core/test_utils.go
+++ /dev/null
@@ -1,35 +0,0 @@
-package core
-
-import (
- "fmt"
- "github.com/huichen/wukong/types"
-)
-
-func indicesToString(indexer *Indexer, token string) (output string) {
- if indices, ok := indexer.tableLock.table[token]; ok {
- for i := 0; i < indexer.getIndexLength(indices); i++ {
- output += fmt.Sprintf("%d ",
- indexer.getDocId(indices, i))
- }
- }
- return
-}
-
-func indexedDocsToString(docs []types.IndexedDocument, numDocs int) (output string) {
- for _, doc := range docs {
- output += fmt.Sprintf("[%d %d %v] ",
- doc.DocId, doc.TokenProximity, doc.TokenSnippetLocations)
- }
- return
-}
-
-func scoredDocsToString(docs []types.ScoredDocument) (output string) {
- for _, doc := range docs {
- output += fmt.Sprintf("[%d [", doc.DocId)
- for _, score := range doc.Scores {
- output += fmt.Sprintf("%d ", int(score*1000))
- }
- output += "]] "
- }
- return
-}
diff --git a/vendor/github.com/huichen/wukong/engine/counters.go b/vendor/github.com/huichen/wukong/engine/counters.go
deleted file mode 100644
index 23317a706..000000000
--- a/vendor/github.com/huichen/wukong/engine/counters.go
+++ /dev/null
@@ -1,13 +0,0 @@
-package engine
-
-func (engine *Engine) NumTokenIndexAdded() uint64 {
- return engine.numTokenIndexAdded
-}
-
-func (engine *Engine) NumDocumentsIndexed() uint64 {
- return engine.numDocumentsIndexed
-}
-
-func (engine *Engine) NumDocumentsRemoved() uint64 {
- return engine.numDocumentsRemoved
-}
diff --git a/vendor/github.com/huichen/wukong/engine/engine.go b/vendor/github.com/huichen/wukong/engine/engine.go
deleted file mode 100644
index 302f60bed..000000000
--- a/vendor/github.com/huichen/wukong/engine/engine.go
+++ /dev/null
@@ -1,446 +0,0 @@
-package engine
-
-import (
- "fmt"
- "github.com/huichen/murmur"
- "github.com/huichen/sego"
- "github.com/huichen/wukong/core"
- "github.com/huichen/wukong/storage"
- "github.com/huichen/wukong/types"
- "github.com/huichen/wukong/utils"
- "log"
- "os"
- "runtime"
- "sort"
- "strconv"
- "sync/atomic"
- "time"
-)
-
-const (
- NumNanosecondsInAMillisecond = 1000000
- PersistentStorageFilePrefix = "wukong"
-)
-
-type Engine struct {
- // 计数器,用来统计有多少文档被索引等信息
- numDocumentsIndexed uint64
- numDocumentsRemoved uint64
- numDocumentsForceUpdated uint64
- numIndexingRequests uint64
- numRemovingRequests uint64
- numForceUpdatingRequests uint64
- numTokenIndexAdded uint64
- numDocumentsStored uint64
-
- // 记录初始化参数
- initOptions types.EngineInitOptions
- initialized bool
-
- indexers []core.Indexer
- rankers []core.Ranker
- segmenter sego.Segmenter
- stopTokens StopTokens
- dbs []storage.Storage
-
- // 建立索引器使用的通信通道
- segmenterChannel chan segmenterRequest
- indexerAddDocChannels []chan indexerAddDocumentRequest
- indexerRemoveDocChannels []chan indexerRemoveDocRequest
- rankerAddDocChannels []chan rankerAddDocRequest
-
- // 建立排序器使用的通信通道
- indexerLookupChannels []chan indexerLookupRequest
- rankerRankChannels []chan rankerRankRequest
- rankerRemoveDocChannels []chan rankerRemoveDocRequest
-
- // 建立持久存储使用的通信通道
- persistentStorageIndexDocumentChannels []chan persistentStorageIndexDocumentRequest
- persistentStorageInitChannel chan bool
-}
-
-func (engine *Engine) Init(options types.EngineInitOptions) {
- // 将线程数设置为CPU数
- runtime.GOMAXPROCS(runtime.NumCPU())
-
- // 初始化初始参数
- if engine.initialized {
- log.Fatal("请勿重复初始化引擎")
- }
- options.Init()
- engine.initOptions = options
- engine.initialized = true
-
- if !options.NotUsingSegmenter {
- // 载入分词器词典
- engine.segmenter.LoadDictionary(options.SegmenterDictionaries)
-
- // 初始化停用词
- engine.stopTokens.Init(options.StopTokenFile)
- }
-
- // 初始化索引器和排序器
- for shard := 0; shard < options.NumShards; shard++ {
- engine.indexers = append(engine.indexers, core.Indexer{})
- engine.indexers[shard].Init(*options.IndexerInitOptions)
-
- engine.rankers = append(engine.rankers, core.Ranker{})
- engine.rankers[shard].Init()
- }
-
- // 初始化分词器通道
- engine.segmenterChannel = make(
- chan segmenterRequest, options.NumSegmenterThreads)
-
- // 初始化索引器通道
- engine.indexerAddDocChannels = make(
- []chan indexerAddDocumentRequest, options.NumShards)
- engine.indexerRemoveDocChannels = make(
- []chan indexerRemoveDocRequest, options.NumShards)
- engine.indexerLookupChannels = make(
- []chan indexerLookupRequest, options.NumShards)
- for shard := 0; shard < options.NumShards; shard++ {
- engine.indexerAddDocChannels[shard] = make(
- chan indexerAddDocumentRequest,
- options.IndexerBufferLength)
- engine.indexerRemoveDocChannels[shard] = make(
- chan indexerRemoveDocRequest,
- options.IndexerBufferLength)
- engine.indexerLookupChannels[shard] = make(
- chan indexerLookupRequest,
- options.IndexerBufferLength)
- }
-
- // 初始化排序器通道
- engine.rankerAddDocChannels = make(
- []chan rankerAddDocRequest, options.NumShards)
- engine.rankerRankChannels = make(
- []chan rankerRankRequest, options.NumShards)
- engine.rankerRemoveDocChannels = make(
- []chan rankerRemoveDocRequest, options.NumShards)
- for shard := 0; shard < options.NumShards; shard++ {
- engine.rankerAddDocChannels[shard] = make(
- chan rankerAddDocRequest,
- options.RankerBufferLength)
- engine.rankerRankChannels[shard] = make(
- chan rankerRankRequest,
- options.RankerBufferLength)
- engine.rankerRemoveDocChannels[shard] = make(
- chan rankerRemoveDocRequest,
- options.RankerBufferLength)
- }
-
- // 初始化持久化存储通道
- if engine.initOptions.UsePersistentStorage {
- engine.persistentStorageIndexDocumentChannels =
- make([]chan persistentStorageIndexDocumentRequest,
- engine.initOptions.PersistentStorageShards)
- for shard := 0; shard < engine.initOptions.PersistentStorageShards; shard++ {
- engine.persistentStorageIndexDocumentChannels[shard] = make(
- chan persistentStorageIndexDocumentRequest)
- }
- engine.persistentStorageInitChannel = make(
- chan bool, engine.initOptions.PersistentStorageShards)
- }
-
- // 启动分词器
- for iThread := 0; iThread < options.NumSegmenterThreads; iThread++ {
- go engine.segmenterWorker()
- }
-
- // 启动索引器和排序器
- for shard := 0; shard < options.NumShards; shard++ {
- go engine.indexerAddDocumentWorker(shard)
- go engine.indexerRemoveDocWorker(shard)
- go engine.rankerAddDocWorker(shard)
- go engine.rankerRemoveDocWorker(shard)
-
- for i := 0; i < options.NumIndexerThreadsPerShard; i++ {
- go engine.indexerLookupWorker(shard)
- }
- for i := 0; i < options.NumRankerThreadsPerShard; i++ {
- go engine.rankerRankWorker(shard)
- }
- }
-
- // 启动持久化存储工作协程
- if engine.initOptions.UsePersistentStorage {
- err := os.MkdirAll(engine.initOptions.PersistentStorageFolder, 0700)
- if err != nil {
- log.Fatal("无法创建目录", engine.initOptions.PersistentStorageFolder)
- }
-
- // 打开或者创建数据库
- engine.dbs = make([]storage.Storage, engine.initOptions.PersistentStorageShards)
- for shard := 0; shard < engine.initOptions.PersistentStorageShards; shard++ {
- dbPath := engine.initOptions.PersistentStorageFolder + "/" + PersistentStorageFilePrefix + "." + strconv.Itoa(shard)
- db, err := storage.OpenStorage(dbPath)
- if db == nil || err != nil {
- log.Fatal("无法打开数据库", dbPath, ": ", err)
- }
- engine.dbs[shard] = db
- }
-
- // 从数据库中恢复
- for shard := 0; shard < engine.initOptions.PersistentStorageShards; shard++ {
- go engine.persistentStorageInitWorker(shard)
- }
-
- // 等待恢复完成
- for shard := 0; shard < engine.initOptions.PersistentStorageShards; shard++ {
- <-engine.persistentStorageInitChannel
- }
- for {
- runtime.Gosched()
- if engine.numIndexingRequests == engine.numDocumentsIndexed {
- break
- }
- }
-
- // 关闭并重新打开数据库
- for shard := 0; shard < engine.initOptions.PersistentStorageShards; shard++ {
- engine.dbs[shard].Close()
- dbPath := engine.initOptions.PersistentStorageFolder + "/" + PersistentStorageFilePrefix + "." + strconv.Itoa(shard)
- db, err := storage.OpenStorage(dbPath)
- if db == nil || err != nil {
- log.Fatal("无法打开数据库", dbPath, ": ", err)
- }
- engine.dbs[shard] = db
- }
-
- for shard := 0; shard < engine.initOptions.PersistentStorageShards; shard++ {
- go engine.persistentStorageIndexDocumentWorker(shard)
- }
- }
-
- atomic.AddUint64(&engine.numDocumentsStored, engine.numIndexingRequests)
-}
-
-// 将文档加入索引
-//
-// 输入参数:
-// docId 标识文档编号,必须唯一,docId == 0 表示非法文档(用于强制刷新索引),[1, +oo) 表示合法文档
-// data 见DocumentIndexData注释
-// forceUpdate 是否强制刷新 cache,如果设为 true,则尽快添加到索引,否则等待 cache 满之后一次全量添加
-//
-// 注意:
-// 1. 这个函数是线程安全的,请尽可能并发调用以提高索引速度
-// 2. 这个函数调用是非同步的,也就是说在函数返回时有可能文档还没有加入索引中,因此
-// 如果立刻调用Search可能无法查询到这个文档。强制刷新索引请调用FlushIndex函数。
-func (engine *Engine) IndexDocument(docId uint64, data types.DocumentIndexData, forceUpdate bool) {
- engine.internalIndexDocument(docId, data, forceUpdate)
-
- hash := murmur.Murmur3([]byte(fmt.Sprint("%d", docId))) % uint32(engine.initOptions.PersistentStorageShards)
- if engine.initOptions.UsePersistentStorage && docId != 0 {
- engine.persistentStorageIndexDocumentChannels[hash] <- persistentStorageIndexDocumentRequest{docId: docId, data: data}
- }
-}
-
-func (engine *Engine) internalIndexDocument(
- docId uint64, data types.DocumentIndexData, forceUpdate bool) {
- if !engine.initialized {
- log.Fatal("必须先初始化引擎")
- }
-
- if docId != 0 {
- atomic.AddUint64(&engine.numIndexingRequests, 1)
- }
- if forceUpdate {
- atomic.AddUint64(&engine.numForceUpdatingRequests, 1)
- }
- hash := murmur.Murmur3([]byte(fmt.Sprint("%d%s", docId, data.Content)))
- engine.segmenterChannel <- segmenterRequest{
- docId: docId, hash: hash, data: data, forceUpdate: forceUpdate}
-}
-
-// 将文档从索引中删除
-//
-// 输入参数:
-// docId 标识文档编号,必须唯一,docId == 0 表示非法文档(用于强制刷新索引),[1, +oo) 表示合法文档
-// forceUpdate 是否强制刷新 cache,如果设为 true,则尽快删除索引,否则等待 cache 满之后一次全量删除
-//
-// 注意:
-// 1. 这个函数是线程安全的,请尽可能并发调用以提高索引速度
-// 2. 这个函数调用是非同步的,也就是说在函数返回时有可能文档还没有加入索引中,因此
-// 如果立刻调用Search可能无法查询到这个文档。强制刷新索引请调用FlushIndex函数。
-func (engine *Engine) RemoveDocument(docId uint64, forceUpdate bool) {
- if !engine.initialized {
- log.Fatal("必须先初始化引擎")
- }
-
- if docId != 0 {
- atomic.AddUint64(&engine.numRemovingRequests, 1)
- }
- if forceUpdate {
- atomic.AddUint64(&engine.numForceUpdatingRequests, 1)
- }
- for shard := 0; shard < engine.initOptions.NumShards; shard++ {
- engine.indexerRemoveDocChannels[shard] <- indexerRemoveDocRequest{docId: docId, forceUpdate: forceUpdate}
- if docId == 0 {
- continue
- }
- engine.rankerRemoveDocChannels[shard] <- rankerRemoveDocRequest{docId: docId}
- }
-
- if engine.initOptions.UsePersistentStorage && docId != 0 {
- // 从数据库中删除
- hash := murmur.Murmur3([]byte(fmt.Sprint("%d", docId))) % uint32(engine.initOptions.PersistentStorageShards)
- go engine.persistentStorageRemoveDocumentWorker(docId, hash)
- }
-}
-
-// 查找满足搜索条件的文档,此函数线程安全
-func (engine *Engine) Search(request types.SearchRequest) (output types.SearchResponse) {
- if !engine.initialized {
- log.Fatal("必须先初始化引擎")
- }
-
- var rankOptions types.RankOptions
- if request.RankOptions == nil {
- rankOptions = *engine.initOptions.DefaultRankOptions
- } else {
- rankOptions = *request.RankOptions
- }
- if rankOptions.ScoringCriteria == nil {
- rankOptions.ScoringCriteria = engine.initOptions.DefaultRankOptions.ScoringCriteria
- }
-
- // 收集关键词
- tokens := []string{}
- if request.Text != "" {
- querySegments := engine.segmenter.Segment([]byte(request.Text))
- for _, s := range querySegments {
- token := s.Token().Text()
- if !engine.stopTokens.IsStopToken(token) {
- tokens = append(tokens, s.Token().Text())
- }
- }
- } else {
- for _, t := range request.Tokens {
- tokens = append(tokens, t)
- }
- }
-
- // 建立排序器返回的通信通道
- rankerReturnChannel := make(
- chan rankerReturnRequest, engine.initOptions.NumShards)
-
- // 生成查找请求
- lookupRequest := indexerLookupRequest{
- countDocsOnly: request.CountDocsOnly,
- tokens: tokens,
- labels: request.Labels,
- docIds: request.DocIds,
- options: rankOptions,
- rankerReturnChannel: rankerReturnChannel,
- orderless: request.Orderless,
- }
-
- // 向索引器发送查找请求
- for shard := 0; shard < engine.initOptions.NumShards; shard++ {
- engine.indexerLookupChannels[shard] <- lookupRequest
- }
-
- // 从通信通道读取排序器的输出
- numDocs := 0
- rankOutput := types.ScoredDocuments{}
- timeout := request.Timeout
- isTimeout := false
- if timeout <= 0 {
- // 不设置超时
- for shard := 0; shard < engine.initOptions.NumShards; shard++ {
- rankerOutput := <-rankerReturnChannel
- if !request.CountDocsOnly {
- for _, doc := range rankerOutput.docs {
- rankOutput = append(rankOutput, doc)
- }
- }
- numDocs += rankerOutput.numDocs
- }
- } else {
- // 设置超时
- deadline := time.Now().Add(time.Nanosecond * time.Duration(NumNanosecondsInAMillisecond*request.Timeout))
- for shard := 0; shard < engine.initOptions.NumShards; shard++ {
- select {
- case rankerOutput := <-rankerReturnChannel:
- if !request.CountDocsOnly {
- for _, doc := range rankerOutput.docs {
- rankOutput = append(rankOutput, doc)
- }
- }
- numDocs += rankerOutput.numDocs
- case <-time.After(deadline.Sub(time.Now())):
- isTimeout = true
- break
- }
- }
- }
-
- // 再排序
- if !request.CountDocsOnly && !request.Orderless {
- if rankOptions.ReverseOrder {
- sort.Sort(sort.Reverse(rankOutput))
- } else {
- sort.Sort(rankOutput)
- }
- }
-
- // 准备输出
- output.Tokens = tokens
- // 仅当CountDocsOnly为false时才充填output.Docs
- if !request.CountDocsOnly {
- if request.Orderless {
- // 无序状态无需对Offset截断
- output.Docs = rankOutput
- } else {
- var start, end int
- if rankOptions.MaxOutputs == 0 {
- start = utils.MinInt(rankOptions.OutputOffset, len(rankOutput))
- end = len(rankOutput)
- } else {
- start = utils.MinInt(rankOptions.OutputOffset, len(rankOutput))
- end = utils.MinInt(start+rankOptions.MaxOutputs, len(rankOutput))
- }
- output.Docs = rankOutput[start:end]
- }
- }
- output.NumDocs = numDocs
- output.Timeout = isTimeout
- return
-}
-
-// 阻塞等待直到所有索引添加完毕
-func (engine *Engine) FlushIndex() {
- for {
- runtime.Gosched()
- if engine.numIndexingRequests == engine.numDocumentsIndexed &&
- engine.numRemovingRequests*uint64(engine.initOptions.NumShards) == engine.numDocumentsRemoved &&
- (!engine.initOptions.UsePersistentStorage || engine.numIndexingRequests == engine.numDocumentsStored) {
- // 保证 CHANNEL 中 REQUESTS 全部被执行完
- break
- }
- }
- // 强制更新,保证其为最后的请求
- engine.IndexDocument(0, types.DocumentIndexData{}, true)
- for {
- runtime.Gosched()
- if engine.numForceUpdatingRequests*uint64(engine.initOptions.NumShards) == engine.numDocumentsForceUpdated {
- return
- }
- }
-}
-
-// 关闭引擎
-func (engine *Engine) Close() {
- engine.FlushIndex()
- if engine.initOptions.UsePersistentStorage {
- for _, db := range engine.dbs {
- db.Close()
- }
- }
-}
-
-// 从文本hash得到要分配到的shard
-func (engine *Engine) getShard(hash uint32) int {
- return int(hash - hash/uint32(engine.initOptions.NumShards)*uint32(engine.initOptions.NumShards))
-}
diff --git a/vendor/github.com/huichen/wukong/engine/indexer_worker.go b/vendor/github.com/huichen/wukong/engine/indexer_worker.go
deleted file mode 100644
index dac9e9560..000000000
--- a/vendor/github.com/huichen/wukong/engine/indexer_worker.go
+++ /dev/null
@@ -1,101 +0,0 @@
-package engine
-
-import (
- "github.com/huichen/wukong/types"
- "sync/atomic"
-)
-
-type indexerAddDocumentRequest struct {
- document *types.DocumentIndex
- forceUpdate bool
-}
-
-type indexerLookupRequest struct {
- countDocsOnly bool
- tokens []string
- labels []string
- docIds map[uint64]bool
- options types.RankOptions
- rankerReturnChannel chan rankerReturnRequest
- orderless bool
-}
-
-type indexerRemoveDocRequest struct {
- docId uint64
- forceUpdate bool
-}
-
-func (engine *Engine) indexerAddDocumentWorker(shard int) {
- for {
- request := <-engine.indexerAddDocChannels[shard]
- engine.indexers[shard].AddDocumentToCache(request.document, request.forceUpdate)
- if request.document != nil {
- atomic.AddUint64(&engine.numTokenIndexAdded,
- uint64(len(request.document.Keywords)))
- atomic.AddUint64(&engine.numDocumentsIndexed, 1)
- }
- if request.forceUpdate {
- atomic.AddUint64(&engine.numDocumentsForceUpdated, 1)
- }
- }
-}
-
-func (engine *Engine) indexerRemoveDocWorker(shard int) {
- for {
- request := <-engine.indexerRemoveDocChannels[shard]
- engine.indexers[shard].RemoveDocumentToCache(request.docId, request.forceUpdate)
- if request.docId != 0 {
- atomic.AddUint64(&engine.numDocumentsRemoved, 1)
- }
- if request.forceUpdate {
- atomic.AddUint64(&engine.numDocumentsForceUpdated, 1)
- }
- }
-}
-
-func (engine *Engine) indexerLookupWorker(shard int) {
- for {
- request := <-engine.indexerLookupChannels[shard]
-
- var docs []types.IndexedDocument
- var numDocs int
- if request.docIds == nil {
- docs, numDocs = engine.indexers[shard].Lookup(request.tokens, request.labels, nil, request.countDocsOnly)
- } else {
- docs, numDocs = engine.indexers[shard].Lookup(request.tokens, request.labels, request.docIds, request.countDocsOnly)
- }
-
- if request.countDocsOnly {
- request.rankerReturnChannel <- rankerReturnRequest{numDocs: numDocs}
- continue
- }
-
- if len(docs) == 0 {
- request.rankerReturnChannel <- rankerReturnRequest{}
- continue
- }
-
- if request.orderless {
- var outputDocs []types.ScoredDocument
- for _, d := range docs {
- outputDocs = append(outputDocs, types.ScoredDocument{
- DocId: d.DocId,
- TokenSnippetLocations: d.TokenSnippetLocations,
- TokenLocations: d.TokenLocations})
- }
- request.rankerReturnChannel <- rankerReturnRequest{
- docs: outputDocs,
- numDocs: len(outputDocs),
- }
- continue
- }
-
- rankerRequest := rankerRankRequest{
- countDocsOnly: request.countDocsOnly,
- docs: docs,
- options: request.options,
- rankerReturnChannel: request.rankerReturnChannel,
- }
- engine.rankerRankChannels[shard] <- rankerRequest
- }
-}
diff --git a/vendor/github.com/huichen/wukong/engine/persistent_storage_worker.go b/vendor/github.com/huichen/wukong/engine/persistent_storage_worker.go
deleted file mode 100644
index 69835c56b..000000000
--- a/vendor/github.com/huichen/wukong/engine/persistent_storage_worker.go
+++ /dev/null
@@ -1,66 +0,0 @@
-package engine
-
-import (
- "bytes"
- "encoding/binary"
- "encoding/gob"
- "github.com/huichen/wukong/types"
- "sync/atomic"
-)
-
-type persistentStorageIndexDocumentRequest struct {
- docId uint64
- data types.DocumentIndexData
-}
-
-func (engine *Engine) persistentStorageIndexDocumentWorker(shard int) {
- for {
- request := <-engine.persistentStorageIndexDocumentChannels[shard]
-
- // 得到key
- b := make([]byte, 10)
- length := binary.PutUvarint(b, request.docId)
-
- // 得到value
- var buf bytes.Buffer
- enc := gob.NewEncoder(&buf)
- err := enc.Encode(request.data)
- if err != nil {
- atomic.AddUint64(&engine.numDocumentsStored, 1)
- continue
- }
-
- // 将key-value写入数据库
- engine.dbs[shard].Set(b[0:length], buf.Bytes())
- atomic.AddUint64(&engine.numDocumentsStored, 1)
- }
-}
-
-func (engine *Engine) persistentStorageRemoveDocumentWorker(docId uint64, shard uint32) {
- // 得到key
- b := make([]byte, 10)
- length := binary.PutUvarint(b, docId)
-
- // 从数据库删除该key
- engine.dbs[shard].Delete(b[0:length])
-}
-
-func (engine *Engine) persistentStorageInitWorker(shard int) {
- engine.dbs[shard].ForEach(func(k, v []byte) error {
- key, value := k, v
- // 得到docID
- docId, _ := binary.Uvarint(key)
-
- // 得到data
- buf := bytes.NewReader(value)
- dec := gob.NewDecoder(buf)
- var data types.DocumentIndexData
- err := dec.Decode(&data)
- if err == nil {
- // 添加索引
- engine.internalIndexDocument(docId, data, false)
- }
- return nil
- })
- engine.persistentStorageInitChannel <- true
-}
diff --git a/vendor/github.com/huichen/wukong/engine/ranker_worker.go b/vendor/github.com/huichen/wukong/engine/ranker_worker.go
deleted file mode 100644
index 9d0cf000b..000000000
--- a/vendor/github.com/huichen/wukong/engine/ranker_worker.go
+++ /dev/null
@@ -1,52 +0,0 @@
-package engine
-
-import (
- "github.com/huichen/wukong/types"
-)
-
-type rankerAddDocRequest struct {
- docId uint64
- fields interface{}
-}
-
-type rankerRankRequest struct {
- docs []types.IndexedDocument
- options types.RankOptions
- rankerReturnChannel chan rankerReturnRequest
- countDocsOnly bool
-}
-
-type rankerReturnRequest struct {
- docs types.ScoredDocuments
- numDocs int
-}
-
-type rankerRemoveDocRequest struct {
- docId uint64
-}
-
-func (engine *Engine) rankerAddDocWorker(shard int) {
- for {
- request := <-engine.rankerAddDocChannels[shard]
- engine.rankers[shard].AddDoc(request.docId, request.fields)
- }
-}
-
-func (engine *Engine) rankerRankWorker(shard int) {
- for {
- request := <-engine.rankerRankChannels[shard]
- if request.options.MaxOutputs != 0 {
- request.options.MaxOutputs += request.options.OutputOffset
- }
- request.options.OutputOffset = 0
- outputDocs, numDocs := engine.rankers[shard].Rank(request.docs, request.options, request.countDocsOnly)
- request.rankerReturnChannel <- rankerReturnRequest{docs: outputDocs, numDocs: numDocs}
- }
-}
-
-func (engine *Engine) rankerRemoveDocWorker(shard int) {
- for {
- request := <-engine.rankerRemoveDocChannels[shard]
- engine.rankers[shard].RemoveDoc(request.docId)
- }
-}
diff --git a/vendor/github.com/huichen/wukong/engine/segmenter_worker.go b/vendor/github.com/huichen/wukong/engine/segmenter_worker.go
deleted file mode 100644
index d7ca2715c..000000000
--- a/vendor/github.com/huichen/wukong/engine/segmenter_worker.go
+++ /dev/null
@@ -1,97 +0,0 @@
-package engine
-
-import (
- "github.com/huichen/wukong/types"
-)
-
-type segmenterRequest struct {
- docId uint64
- hash uint32
- data types.DocumentIndexData
- forceUpdate bool
-}
-
-func (engine *Engine) segmenterWorker() {
- for {
- request := <-engine.segmenterChannel
- if request.docId == 0 {
- if request.forceUpdate {
- for i := 0; i < engine.initOptions.NumShards; i++ {
- engine.indexerAddDocChannels[i] <- indexerAddDocumentRequest{forceUpdate: true}
- }
- }
- continue
- }
-
- shard := engine.getShard(request.hash)
- tokensMap := make(map[string][]int)
- numTokens := 0
- if !engine.initOptions.NotUsingSegmenter && request.data.Content != "" {
- // 当文档正文不为空时,优先从内容分词中得到关键词
- segments := engine.segmenter.Segment([]byte(request.data.Content))
- for _, segment := range segments {
- token := segment.Token().Text()
- if !engine.stopTokens.IsStopToken(token) {
- tokensMap[token] = append(tokensMap[token], segment.Start())
- }
- }
- numTokens = len(segments)
- } else {
- // 否则载入用户输入的关键词
- for _, t := range request.data.Tokens {
- if !engine.stopTokens.IsStopToken(t.Text) {
- tokensMap[t.Text] = t.Locations
- }
- }
- numTokens = len(request.data.Tokens)
- }
-
- // 加入非分词的文档标签
- for _, label := range request.data.Labels {
- if !engine.initOptions.NotUsingSegmenter {
- if !engine.stopTokens.IsStopToken(label) {
- //当正文中已存在关键字时,若不判断,位置信息将会丢失
- if _, ok := tokensMap[label]; !ok {
- tokensMap[label] = []int{}
- }
- }
- } else {
- //当正文中已存在关键字时,若不判断,位置信息将会丢失
- if _, ok := tokensMap[label]; !ok {
- tokensMap[label] = []int{}
- }
- }
- }
-
- indexerRequest := indexerAddDocumentRequest{
- document: &types.DocumentIndex{
- DocId: request.docId,
- TokenLength: float32(numTokens),
- Keywords: make([]types.KeywordIndex, len(tokensMap)),
- },
- forceUpdate: request.forceUpdate,
- }
- iTokens := 0
- for k, v := range tokensMap {
- indexerRequest.document.Keywords[iTokens] = types.KeywordIndex{
- Text: k,
- // 非分词标注的词频设置为0,不参与tf-idf计算
- Frequency: float32(len(v)),
- Starts: v}
- iTokens++
- }
-
- engine.indexerAddDocChannels[shard] <- indexerRequest
- if request.forceUpdate {
- for i := 0; i < engine.initOptions.NumShards; i++ {
- if i == shard {
- continue
- }
- engine.indexerAddDocChannels[i] <- indexerAddDocumentRequest{forceUpdate: true}
- }
- }
- rankerRequest := rankerAddDocRequest{
- docId: request.docId, fields: request.data.Fields}
- engine.rankerAddDocChannels[shard] <- rankerRequest
- }
-}
diff --git a/vendor/github.com/huichen/wukong/engine/stop_tokens.go b/vendor/github.com/huichen/wukong/engine/stop_tokens.go
deleted file mode 100644
index 942ecbafa..000000000
--- a/vendor/github.com/huichen/wukong/engine/stop_tokens.go
+++ /dev/null
@@ -1,40 +0,0 @@
-package engine
-
-import (
- "bufio"
- "log"
- "os"
-)
-
-type StopTokens struct {
- stopTokens map[string]bool
-}
-
-// 从stopTokenFile中读入停用词,一个词一行
-// 文档索引建立时会跳过这些停用词
-func (st *StopTokens) Init(stopTokenFile string) {
- st.stopTokens = make(map[string]bool)
- if stopTokenFile == "" {
- return
- }
-
- file, err := os.Open(stopTokenFile)
- if err != nil {
- log.Fatal(err)
- }
- defer file.Close()
-
- scanner := bufio.NewScanner(file)
- for scanner.Scan() {
- text := scanner.Text()
- if text != "" {
- st.stopTokens[text] = true
- }
- }
-
-}
-
-func (st *StopTokens) IsStopToken(token string) bool {
- _, found := st.stopTokens[token]
- return found
-}
diff --git a/vendor/github.com/huichen/wukong/storage/bolt_storage.go b/vendor/github.com/huichen/wukong/storage/bolt_storage.go
deleted file mode 100644
index 046dc3a93..000000000
--- a/vendor/github.com/huichen/wukong/storage/bolt_storage.go
+++ /dev/null
@@ -1,69 +0,0 @@
-package storage
-
-import (
- "github.com/boltdb/bolt"
- "time"
-)
-
-var wukong_documents = []byte("wukong_documents")
-
-type boltStorage struct {
- db *bolt.DB
-}
-
-func openBoltStorage(path string) (Storage, error) {
- db, err := bolt.Open(path, 0600, &bolt.Options{Timeout: 3600 * time.Second})
- if err != nil {
- return nil, err
- }
- err = db.Update(func(tx *bolt.Tx) error {
- _, err := tx.CreateBucketIfNotExists(wukong_documents)
- return err
- })
- if err != nil {
- db.Close()
- return nil, err
- }
- return &boltStorage{db}, nil
-}
-
-func (s *boltStorage) WALName() string {
- return s.db.Path()
-}
-
-func (s *boltStorage) Set(k []byte, v []byte) error {
- return s.db.Update(func(tx *bolt.Tx) error {
- return tx.Bucket(wukong_documents).Put(k, v)
- })
-}
-
-func (s *boltStorage) Get(k []byte) (b []byte, err error) {
- err = s.db.View(func(tx *bolt.Tx) error {
- b = tx.Bucket(wukong_documents).Get(k)
- return nil
- })
- return
-}
-
-func (s *boltStorage) Delete(k []byte) error {
- return s.db.Update(func(tx *bolt.Tx) error {
- return tx.Bucket(wukong_documents).Delete(k)
- })
-}
-
-func (s *boltStorage) ForEach(fn func(k, v []byte) error) error {
- return s.db.View(func(tx *bolt.Tx) error {
- b := tx.Bucket(wukong_documents)
- c := b.Cursor()
- for k, v := c.First(); k != nil; k, v = c.Next() {
- if err := fn(k, v); err != nil {
- return err
- }
- }
- return nil
- })
-}
-
-func (s *boltStorage) Close() error {
- return s.db.Close()
-}
diff --git a/vendor/github.com/huichen/wukong/storage/kv_storage.go b/vendor/github.com/huichen/wukong/storage/kv_storage.go
deleted file mode 100644
index ebcd088e7..000000000
--- a/vendor/github.com/huichen/wukong/storage/kv_storage.go
+++ /dev/null
@@ -1,64 +0,0 @@
-package storage
-
-import (
- "github.com/cznic/kv"
- "io"
-)
-
-type kvStorage struct {
- db *kv.DB
-}
-
-func openKVStorage(path string) (Storage, error) {
- options := &kv.Options{}
- db, errOpen := kv.Open(path, options)
- if errOpen != nil {
- var errCreate error
- db, errCreate = kv.Create(path, options)
- if errCreate != nil {
- return &kvStorage{db}, errCreate
- }
- }
- return &kvStorage{db}, nil
-}
-
-func (s *kvStorage) WALName() string {
- return s.db.WALName()
-}
-
-func (s *kvStorage) Set(k []byte, v []byte) error {
- return s.db.Set(k, v)
-}
-
-func (s *kvStorage) Get(k []byte) ([]byte, error) {
- return s.db.Get(nil, k)
-}
-
-func (s *kvStorage) Delete(k []byte) error {
- return s.db.Delete(k)
-}
-
-func (s *kvStorage) ForEach(fn func(k, v []byte) error) error {
- iter, err := s.db.SeekFirst()
- if err == io.EOF {
- return nil
- } else if err != nil {
- return err
- }
- for {
- key, value, err := iter.Next()
- if err == io.EOF {
- break
- } else if err != nil {
- return err
- }
- if err := fn(key, value); err != nil {
- return err
- }
- }
- return nil
-}
-
-func (s *kvStorage) Close() error {
- return s.db.Close()
-}
diff --git a/vendor/github.com/huichen/wukong/storage/storage.go b/vendor/github.com/huichen/wukong/storage/storage.go
deleted file mode 100644
index 7a82a69c0..000000000
--- a/vendor/github.com/huichen/wukong/storage/storage.go
+++ /dev/null
@@ -1,37 +0,0 @@
-package storage
-
-import (
- "fmt"
- "os"
-)
-
-const DEFAULT_STORAGE_ENGINE = "bolt"
-
-var supportedStorage = map[string]func(path string) (Storage, error){
- "kv": openKVStorage,
- "bolt": openBoltStorage,
-}
-
-func RegisterStorageEngine(name string, fn func(path string) (Storage, error)) {
- supportedStorage[name] = fn
-}
-
-type Storage interface {
- Set(k, v []byte) error
- Get(k []byte) ([]byte, error)
- Delete(k []byte) error
- ForEach(fn func(k, v []byte) error) error
- Close() error
- WALName() string
-}
-
-func OpenStorage(path string) (Storage, error) {
- wse := os.Getenv("WUKONG_STORAGE_ENGINE")
- if wse == "" {
- wse = DEFAULT_STORAGE_ENGINE
- }
- if fn, has := supportedStorage[wse]; has {
- return fn(path)
- }
- return nil, fmt.Errorf("unsupported storage engine %v", wse)
-}
diff --git a/vendor/github.com/huichen/wukong/types/document_index_data.go b/vendor/github.com/huichen/wukong/types/document_index_data.go
deleted file mode 100644
index 421b2cfed..000000000
--- a/vendor/github.com/huichen/wukong/types/document_index_data.go
+++ /dev/null
@@ -1,27 +0,0 @@
-package types
-
-type DocumentIndexData struct {
- // 文档全文(必须是UTF-8格式),用于生成待索引的关键词
- Content string
-
- // 文档的关键词
- // 当Content不为空的时候,优先从Content中分词得到关键词。
- // Tokens存在的意义在于绕过悟空内置的分词器,在引擎外部
- // 进行分词和预处理。
- Tokens []TokenData
-
- // 文档标签(必须是UTF-8格式),比如文档的类别属性等,这些标签并不出现在文档文本中
- Labels []string
-
- // 文档的评分字段,可以接纳任何类型的结构体
- Fields interface{}
-}
-
-// 文档的一个关键词
-type TokenData struct {
- // 关键词的字符串
- Text string
-
- // 关键词的首字节在文档中出现的位置
- Locations []int
-}
diff --git a/vendor/github.com/huichen/wukong/types/engine_init_options.go b/vendor/github.com/huichen/wukong/types/engine_init_options.go
deleted file mode 100644
index 464213ff9..000000000
--- a/vendor/github.com/huichen/wukong/types/engine_init_options.go
+++ /dev/null
@@ -1,126 +0,0 @@
-package types
-
-import (
- "log"
- "runtime"
-)
-
-var (
- // EngineInitOptions的默认值
- defaultNumSegmenterThreads = runtime.NumCPU()
- defaultNumShards = 2
- defaultIndexerBufferLength = runtime.NumCPU()
- defaultNumIndexerThreadsPerShard = runtime.NumCPU()
- defaultRankerBufferLength = runtime.NumCPU()
- defaultNumRankerThreadsPerShard = runtime.NumCPU()
- defaultDefaultRankOptions = RankOptions{
- ScoringCriteria: RankByBM25{},
- }
- defaultIndexerInitOptions = IndexerInitOptions{
- IndexType: FrequenciesIndex,
- BM25Parameters: &defaultBM25Parameters,
- }
- defaultBM25Parameters = BM25Parameters{
- K1: 2.0,
- B: 0.75,
- }
- defaultPersistentStorageShards = 8
-)
-
-type EngineInitOptions struct {
- // 是否使用分词器
- // 默认使用,否则在启动阶段跳过SegmenterDictionaries和StopTokenFile设置
- // 如果你不需要在引擎内分词,可以将这个选项设为true
- // 注意,如果你不用分词器,那么在调用IndexDocument时DocumentIndexData中的Content会被忽略
- NotUsingSegmenter bool
-
- // 半角逗号分隔的字典文件,具体用法见
- // sego.Segmenter.LoadDictionary函数的注释
- SegmenterDictionaries string
-
- // 停用词文件
- StopTokenFile string
-
- // 分词器线程数
- NumSegmenterThreads int
-
- // 索引器和排序器的shard数目
- // 被检索/排序的文档会被均匀分配到各个shard中
- NumShards int
-
- // 索引器的信道缓冲长度
- IndexerBufferLength int
-
- // 索引器每个shard分配的线程数
- NumIndexerThreadsPerShard int
-
- // 排序器的信道缓冲长度
- RankerBufferLength int
-
- // 排序器每个shard分配的线程数
- NumRankerThreadsPerShard int
-
- // 索引器初始化选项
- IndexerInitOptions *IndexerInitOptions
-
- // 默认的搜索选项
- DefaultRankOptions *RankOptions
-
- // 是否使用持久数据库,以及数据库文件保存的目录和裂分数目
- UsePersistentStorage bool
- PersistentStorageFolder string
- PersistentStorageShards int
-}
-
-// 初始化EngineInitOptions,当用户未设定某个选项的值时用默认值取代
-func (options *EngineInitOptions) Init() {
- if !options.NotUsingSegmenter {
- if options.SegmenterDictionaries == "" {
- log.Fatal("字典文件不能为空")
- }
- }
-
- if options.NumSegmenterThreads == 0 {
- options.NumSegmenterThreads = defaultNumSegmenterThreads
- }
-
- if options.NumShards == 0 {
- options.NumShards = defaultNumShards
- }
-
- if options.IndexerBufferLength == 0 {
- options.IndexerBufferLength = defaultIndexerBufferLength
- }
-
- if options.NumIndexerThreadsPerShard == 0 {
- options.NumIndexerThreadsPerShard = defaultNumIndexerThreadsPerShard
- }
-
- if options.RankerBufferLength == 0 {
- options.RankerBufferLength = defaultRankerBufferLength
- }
-
- if options.NumRankerThreadsPerShard == 0 {
- options.NumRankerThreadsPerShard = defaultNumRankerThreadsPerShard
- }
-
- if options.IndexerInitOptions == nil {
- options.IndexerInitOptions = &defaultIndexerInitOptions
- }
-
- if options.IndexerInitOptions.BM25Parameters == nil {
- options.IndexerInitOptions.BM25Parameters = &defaultBM25Parameters
- }
-
- if options.DefaultRankOptions == nil {
- options.DefaultRankOptions = &defaultDefaultRankOptions
- }
-
- if options.DefaultRankOptions.ScoringCriteria == nil {
- options.DefaultRankOptions.ScoringCriteria = defaultDefaultRankOptions.ScoringCriteria
- }
-
- if options.PersistentStorageShards == 0 {
- options.PersistentStorageShards = defaultPersistentStorageShards
- }
-}
diff --git a/vendor/github.com/huichen/wukong/types/index.go b/vendor/github.com/huichen/wukong/types/index.go
deleted file mode 100644
index 9d034e791..000000000
--- a/vendor/github.com/huichen/wukong/types/index.go
+++ /dev/null
@@ -1,70 +0,0 @@
-package types
-
-type DocumentIndex struct {
- // 文本的DocId
- DocId uint64
-
- // 文本的关键词长
- TokenLength float32
-
- // 加入的索引键
- Keywords []KeywordIndex
-}
-
-// 反向索引项,这实际上标注了一个(搜索键,文档)对。
-type KeywordIndex struct {
- // 搜索键的UTF-8文本
- Text string
-
- // 搜索键词频
- Frequency float32
-
- // 搜索键在文档中的起始字节位置,按照升序排列
- Starts []int
-}
-
-// 索引器返回结果
-type IndexedDocument struct {
- DocId uint64
-
- // BM25,仅当索引类型为FrequenciesIndex或者LocationsIndex时返回有效值
- BM25 float32
-
- // 关键词在文档中的紧邻距离,紧邻距离的含义见computeTokenProximity的注释。
- // 仅当索引类型为LocationsIndex时返回有效值。
- TokenProximity int32
-
- // 紧邻距离计算得到的关键词位置,和Lookup函数输入tokens的长度一样且一一对应。
- // 仅当索引类型为LocationsIndex时返回有效值。
- TokenSnippetLocations []int
-
- // 关键词在文本中的具体位置。
- // 仅当索引类型为LocationsIndex时返回有效值。
- TokenLocations [][]int
-}
-
-// 方便批量加入文档索引
-type DocumentsIndex []*DocumentIndex
-
-func (docs DocumentsIndex) Len() int {
- return len(docs)
-}
-func (docs DocumentsIndex) Swap(i, j int) {
- docs[i], docs[j] = docs[j], docs[i]
-}
-func (docs DocumentsIndex) Less(i, j int) bool {
- return docs[i].DocId < docs[j].DocId
-}
-
-// 方便批量删除文档索引
-type DocumentsId []uint64
-
-func (docs DocumentsId) Len() int {
- return len(docs)
-}
-func (docs DocumentsId) Swap(i, j int) {
- docs[i], docs[j] = docs[j], docs[i]
-}
-func (docs DocumentsId) Less(i, j int) bool {
- return docs[i] < docs[j]
-}
diff --git a/vendor/github.com/huichen/wukong/types/indexer_init_options.go b/vendor/github.com/huichen/wukong/types/indexer_init_options.go
deleted file mode 100644
index 995b4bb30..000000000
--- a/vendor/github.com/huichen/wukong/types/indexer_init_options.go
+++ /dev/null
@@ -1,42 +0,0 @@
-package types
-
-// 这些常数定义了反向索引表存储的数据类型
-const (
- // 仅存储文档的docId
- DocIdsIndex = 0
-
- // 存储关键词的词频,用于计算BM25
- FrequenciesIndex = 1
-
- // 存储关键词在文档中出现的具体字节位置(可能有多个)
- // 如果你希望得到关键词紧邻度数据,必须使用LocationsIndex类型的索引
- LocationsIndex = 2
-
- // 默认插入索引表文档 CACHE SIZE
- defaultDocCacheSize = 300000
-)
-
-// 初始化索引器选项
-type IndexerInitOptions struct {
- // 索引表的类型,见上面的常数
- IndexType int
-
- // 待插入索引表文档 CACHE SIZE
- DocCacheSize int
-
- // BM25参数
- BM25Parameters *BM25Parameters
-}
-
-// 见http://en.wikipedia.org/wiki/Okapi_BM25
-// 默认值见engine_init_options.go
-type BM25Parameters struct {
- K1 float32
- B float32
-}
-
-func (options *IndexerInitOptions) Init() {
- if options.DocCacheSize == 0 {
- options.DocCacheSize = defaultDocCacheSize
- }
-}
diff --git a/vendor/github.com/huichen/wukong/types/scoring_criteria.go b/vendor/github.com/huichen/wukong/types/scoring_criteria.go
deleted file mode 100644
index cf90310de..000000000
--- a/vendor/github.com/huichen/wukong/types/scoring_criteria.go
+++ /dev/null
@@ -1,17 +0,0 @@
-package types
-
-// 评分规则通用接口
-type ScoringCriteria interface {
- // 给一个文档评分,文档排序时先用第一个分值比较,如果
- // 分值相同则转移到第二个分值,以此类推。
- // 返回空切片表明该文档应该从最终排序结果中剔除。
- Score(doc IndexedDocument, fields interface{}) []float32
-}
-
-// 一个简单的评分规则,文档分数为BM25
-type RankByBM25 struct {
-}
-
-func (rule RankByBM25) Score(doc IndexedDocument, fields interface{}) []float32 {
- return []float32{doc.BM25}
-}
diff --git a/vendor/github.com/huichen/wukong/types/search_request.go b/vendor/github.com/huichen/wukong/types/search_request.go
deleted file mode 100644
index 7b6a209e2..000000000
--- a/vendor/github.com/huichen/wukong/types/search_request.go
+++ /dev/null
@@ -1,45 +0,0 @@
-package types
-
-type SearchRequest struct {
- // 搜索的短语(必须是UTF-8格式),会被分词
- // 当值为空字符串时关键词会从下面的Tokens读入
- Text string
-
- // 关键词(必须是UTF-8格式),当Text不为空时优先使用Text
- // 通常你不需要自己指定关键词,除非你运行自己的分词程序
- Tokens []string
-
- // 文档标签(必须是UTF-8格式),标签不存在文档文本中,但也属于搜索键的一种
- Labels []string
-
- // 当不为nil时,仅从这些DocIds包含的键中搜索(忽略值)
- DocIds map[uint64]bool
-
- // 排序选项
- RankOptions *RankOptions
-
- // 超时,单位毫秒(千分之一秒)。此值小于等于零时不设超时。
- // 搜索超时的情况下仍有可能返回部分排序结果。
- Timeout int
-
- // 设为true时仅统计搜索到的文档个数,不返回具体的文档
- CountDocsOnly bool
-
- // 不排序,对于可在引擎外部(比如客户端)排序情况适用
- // 对返回文档很多的情况打开此选项可以有效节省时间
- Orderless bool
-}
-
-type RankOptions struct {
- // 文档的评分规则,值为nil时使用Engine初始化时设定的规则
- ScoringCriteria ScoringCriteria
-
- // 默认情况下(ReverseOrder=false)按照分数从大到小排序,否则从小到大排序
- ReverseOrder bool
-
- // 从第几条结果开始输出
- OutputOffset int
-
- // 最大输出的搜索结果数,为0时无限制
- MaxOutputs int
-}
diff --git a/vendor/github.com/huichen/wukong/types/search_response.go b/vendor/github.com/huichen/wukong/types/search_response.go
deleted file mode 100644
index 7cfc9310c..000000000
--- a/vendor/github.com/huichen/wukong/types/search_response.go
+++ /dev/null
@@ -1,57 +0,0 @@
-package types
-
-import (
- "github.com/huichen/wukong/utils"
-)
-
-type SearchResponse struct {
- // 搜索用到的关键词
- Tokens []string
-
- // 搜索到的文档,已排序
- Docs []ScoredDocument
-
- // 搜索是否超时。超时的情况下也可能会返回部分结果
- Timeout bool
-
- // 搜索到的文档个数。注意这是全部文档中满足条件的个数,可能比返回的文档数要大
- NumDocs int
-}
-
-type ScoredDocument struct {
- DocId uint64
-
- // 文档的打分值
- // 搜索结果按照Scores的值排序,先按照第一个数排,如果相同则按照第二个数排序,依次类推。
- Scores []float32
-
- // 用于生成摘要的关键词在文本中的字节位置,该切片长度和SearchResponse.Tokens的长度一样
- // 只有当IndexType == LocationsIndex时不为空
- TokenSnippetLocations []int
-
- // 关键词出现的位置
- // 只有当IndexType == LocationsIndex时不为空
- TokenLocations [][]int
-}
-
-// 为了方便排序
-
-type ScoredDocuments []ScoredDocument
-
-func (docs ScoredDocuments) Len() int {
- return len(docs)
-}
-func (docs ScoredDocuments) Swap(i, j int) {
- docs[i], docs[j] = docs[j], docs[i]
-}
-func (docs ScoredDocuments) Less(i, j int) bool {
- // 为了从大到小排序,这实际上实现的是More的功能
- for iScore := 0; iScore < utils.MinInt(len(docs[i].Scores), len(docs[j].Scores)); iScore++ {
- if docs[i].Scores[iScore] > docs[j].Scores[iScore] {
- return true
- } else if docs[i].Scores[iScore] < docs[j].Scores[iScore] {
- return false
- }
- }
- return len(docs[i].Scores) > len(docs[j].Scores)
-}
diff --git a/vendor/github.com/huichen/wukong/utils/test_utils.go b/vendor/github.com/huichen/wukong/utils/test_utils.go
deleted file mode 100644
index 343357d90..000000000
--- a/vendor/github.com/huichen/wukong/utils/test_utils.go
+++ /dev/null
@@ -1,13 +0,0 @@
-package utils
-
-import (
- "fmt"
- "testing"
-)
-
-func Expect(t *testing.T, expect string, actual interface{}) {
- actualString := fmt.Sprint(actual)
- if expect != actualString {
- t.Errorf("期待值=\"%s\", 实际=\"%s\"", expect, actualString)
- }
-}
diff --git a/vendor/github.com/huichen/wukong/utils/utils.go b/vendor/github.com/huichen/wukong/utils/utils.go
deleted file mode 100644
index 8648e5b15..000000000
--- a/vendor/github.com/huichen/wukong/utils/utils.go
+++ /dev/null
@@ -1,15 +0,0 @@
-package utils
-
-func AbsInt(a int) int {
- if a < 0 {
- return -a
- }
- return a
-}
-
-func MinInt(a, b int) int {
- if a < b {
- return a
- }
- return b
-}
diff --git a/vendor/golang.org/x/image/AUTHORS b/vendor/golang.org/x/image/AUTHORS
new file mode 100644
index 000000000..15167cd74
--- /dev/null
+++ b/vendor/golang.org/x/image/AUTHORS
@@ -0,0 +1,3 @@
+# This source code refers to The Go Authors for copyright purposes.
+# The master list of authors is in the main Go distribution,
+# visible at http://tip.golang.org/AUTHORS.
diff --git a/vendor/golang.org/x/image/CONTRIBUTORS b/vendor/golang.org/x/image/CONTRIBUTORS
new file mode 100644
index 000000000..1c4577e96
--- /dev/null
+++ b/vendor/golang.org/x/image/CONTRIBUTORS
@@ -0,0 +1,3 @@
+# This source code was written by the Go contributors.
+# The master list of contributors is in the main Go distribution,
+# visible at http://tip.golang.org/CONTRIBUTORS.
diff --git a/vendor/github.com/cznic/zappy/SNAPPY-GO-LICENSE b/vendor/golang.org/x/image/LICENSE
similarity index 95%
rename from vendor/github.com/cznic/zappy/SNAPPY-GO-LICENSE
rename to vendor/golang.org/x/image/LICENSE
index 6050c10f4..6a66aea5e 100644
--- a/vendor/github.com/cznic/zappy/SNAPPY-GO-LICENSE
+++ b/vendor/golang.org/x/image/LICENSE
@@ -1,4 +1,4 @@
-Copyright (c) 2011 The Snappy-Go Authors. All rights reserved.
+Copyright (c) 2009 The Go Authors. All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are
diff --git a/vendor/golang.org/x/image/PATENTS b/vendor/golang.org/x/image/PATENTS
new file mode 100644
index 000000000..733099041
--- /dev/null
+++ b/vendor/golang.org/x/image/PATENTS
@@ -0,0 +1,22 @@
+Additional IP Rights Grant (Patents)
+
+"This implementation" means the copyrightable works distributed by
+Google as part of the Go project.
+
+Google hereby grants to You a perpetual, worldwide, non-exclusive,
+no-charge, royalty-free, irrevocable (except as stated in this section)
+patent license to make, have made, use, offer to sell, sell, import,
+transfer and otherwise run, modify and propagate the contents of this
+implementation of Go, where such license applies only to those patent
+claims, both currently owned or controlled by Google and acquired in
+the future, licensable by Google that are necessarily infringed by this
+implementation of Go. This grant does not include claims that would be
+infringed only as a consequence of further modification of this
+implementation. If you or your agent or exclusive licensee institute or
+order or agree to the institution of patent litigation against any
+entity (including a cross-claim or counterclaim in a lawsuit) alleging
+that this implementation of Go or any code incorporated within this
+implementation of Go constitutes direct or contributory patent
+infringement, or inducement of patent infringement, then any patent
+rights granted to you under this License for this implementation of Go
+shall terminate as of the date such litigation is filed.
diff --git a/vendor/golang.org/x/image/font/font.go b/vendor/golang.org/x/image/font/font.go
new file mode 100644
index 000000000..92d9e1605
--- /dev/null
+++ b/vendor/golang.org/x/image/font/font.go
@@ -0,0 +1,359 @@
+// Copyright 2015 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// Package font defines an interface for font faces, for drawing text on an
+// image.
+//
+// Other packages provide font face implementations. For example, a truetype
+// package would provide one based on .ttf font files.
+package font
+
+import (
+ "image"
+ "image/draw"
+ "io"
+ "unicode/utf8"
+
+ "golang.org/x/image/math/fixed"
+)
+
+// TODO: who is responsible for caches (glyph images, glyph indices, kerns)?
+// The Drawer or the Face?
+
+// Face is a font face. Its glyphs are often derived from a font file, such as
+// "Comic_Sans_MS.ttf", but a face has a specific size, style, weight and
+// hinting. For example, the 12pt and 18pt versions of Comic Sans are two
+// different faces, even if derived from the same font file.
+//
+// A Face is not safe for concurrent use by multiple goroutines, as its methods
+// may re-use implementation-specific caches and mask image buffers.
+//
+// To create a Face, look to other packages that implement specific font file
+// formats.
+type Face interface {
+ io.Closer
+
+ // Glyph returns the draw.DrawMask parameters (dr, mask, maskp) to draw r's
+ // glyph at the sub-pixel destination location dot, and that glyph's
+ // advance width.
+ //
+ // It returns !ok if the face does not contain a glyph for r.
+ //
+ // The contents of the mask image returned by one Glyph call may change
+ // after the next Glyph call. Callers that want to cache the mask must make
+ // a copy.
+ Glyph(dot fixed.Point26_6, r rune) (
+ dr image.Rectangle, mask image.Image, maskp image.Point, advance fixed.Int26_6, ok bool)
+
+ // GlyphBounds returns the bounding box of r's glyph, drawn at a dot equal
+ // to the origin, and that glyph's advance width.
+ //
+ // It returns !ok if the face does not contain a glyph for r.
+ //
+ // The glyph's ascent and descent equal -bounds.Min.Y and +bounds.Max.Y. A
+ // visual depiction of what these metrics are is at
+ // https://developer.apple.com/library/mac/documentation/TextFonts/Conceptual/CocoaTextArchitecture/Art/glyph_metrics_2x.png
+ GlyphBounds(r rune) (bounds fixed.Rectangle26_6, advance fixed.Int26_6, ok bool)
+
+ // GlyphAdvance returns the advance width of r's glyph.
+ //
+ // It returns !ok if the face does not contain a glyph for r.
+ GlyphAdvance(r rune) (advance fixed.Int26_6, ok bool)
+
+ // Kern returns the horizontal adjustment for the kerning pair (r0, r1). A
+ // positive kern means to move the glyphs further apart.
+ Kern(r0, r1 rune) fixed.Int26_6
+
+ // Metrics returns the metrics for this Face.
+ Metrics() Metrics
+
+ // TODO: ColoredGlyph for various emoji?
+ // TODO: Ligatures? Shaping?
+}
+
+// Metrics holds the metrics for a Face. A visual depiction is at
+// https://developer.apple.com/library/mac/documentation/TextFonts/Conceptual/CocoaTextArchitecture/Art/glyph_metrics_2x.png
+type Metrics struct {
+ // Height is the recommended amount of vertical space between two lines of
+ // text.
+ Height fixed.Int26_6
+
+ // Ascent is the distance from the top of a line to its baseline.
+ Ascent fixed.Int26_6
+
+ // Descent is the distance from the bottom of a line to its baseline. The
+ // value is typically positive, even though a descender goes below the
+ // baseline.
+ Descent fixed.Int26_6
+}
+
+// Drawer draws text on a destination image.
+//
+// A Drawer is not safe for concurrent use by multiple goroutines, since its
+// Face is not.
+type Drawer struct {
+ // Dst is the destination image.
+ Dst draw.Image
+ // Src is the source image.
+ Src image.Image
+ // Face provides the glyph mask images.
+ Face Face
+ // Dot is the baseline location to draw the next glyph. The majority of the
+ // affected pixels will be above and to the right of the dot, but some may
+ // be below or to the left. For example, drawing a 'j' in an italic face
+ // may affect pixels below and to the left of the dot.
+ Dot fixed.Point26_6
+
+ // TODO: Clip image.Image?
+ // TODO: SrcP image.Point for Src images other than *image.Uniform? How
+ // does it get updated during DrawString?
+}
+
+// TODO: should DrawString return the last rune drawn, so the next DrawString
+// call can kern beforehand? Or should that be the responsibility of the caller
+// if they really want to do that, since they have to explicitly shift d.Dot
+// anyway? What if ligatures span more than two runes? What if grapheme
+// clusters span multiple runes?
+//
+// TODO: do we assume that the input is in any particular Unicode Normalization
+// Form?
+//
+// TODO: have DrawRunes(s []rune)? DrawRuneReader(io.RuneReader)?? If we take
+// io.RuneReader, we can't assume that we can rewind the stream.
+//
+// TODO: how does this work with line breaking: drawing text up until a
+// vertical line? Should DrawString return the number of runes drawn?
+
+// DrawBytes draws s at the dot and advances the dot's location.
+//
+// It is equivalent to DrawString(string(s)) but may be more efficient.
+func (d *Drawer) DrawBytes(s []byte) {
+ prevC := rune(-1)
+ for len(s) > 0 {
+ c, size := utf8.DecodeRune(s)
+ s = s[size:]
+ if prevC >= 0 {
+ d.Dot.X += d.Face.Kern(prevC, c)
+ }
+ dr, mask, maskp, advance, ok := d.Face.Glyph(d.Dot, c)
+ if !ok {
+ // TODO: is falling back on the U+FFFD glyph the responsibility of
+ // the Drawer or the Face?
+ // TODO: set prevC = '\ufffd'?
+ continue
+ }
+ draw.DrawMask(d.Dst, dr, d.Src, image.Point{}, mask, maskp, draw.Over)
+ d.Dot.X += advance
+ prevC = c
+ }
+}
+
+// DrawString draws s at the dot and advances the dot's location.
+func (d *Drawer) DrawString(s string) {
+ prevC := rune(-1)
+ for _, c := range s {
+ if prevC >= 0 {
+ d.Dot.X += d.Face.Kern(prevC, c)
+ }
+ dr, mask, maskp, advance, ok := d.Face.Glyph(d.Dot, c)
+ if !ok {
+ // TODO: is falling back on the U+FFFD glyph the responsibility of
+ // the Drawer or the Face?
+ // TODO: set prevC = '\ufffd'?
+ continue
+ }
+ draw.DrawMask(d.Dst, dr, d.Src, image.Point{}, mask, maskp, draw.Over)
+ d.Dot.X += advance
+ prevC = c
+ }
+}
+
+// BoundBytes returns the bounding box of s, drawn at the drawer dot, as well as
+// the advance.
+//
+// It is equivalent to BoundBytes(string(s)) but may be more efficient.
+func (d *Drawer) BoundBytes(s []byte) (bounds fixed.Rectangle26_6, advance fixed.Int26_6) {
+ bounds, advance = BoundBytes(d.Face, s)
+ bounds.Min = bounds.Min.Add(d.Dot)
+ bounds.Max = bounds.Max.Add(d.Dot)
+ return
+}
+
+// BoundString returns the bounding box of s, drawn at the drawer dot, as well
+// as the advance.
+func (d *Drawer) BoundString(s string) (bounds fixed.Rectangle26_6, advance fixed.Int26_6) {
+ bounds, advance = BoundString(d.Face, s)
+ bounds.Min = bounds.Min.Add(d.Dot)
+ bounds.Max = bounds.Max.Add(d.Dot)
+ return
+}
+
+// MeasureBytes returns how far dot would advance by drawing s.
+//
+// It is equivalent to MeasureString(string(s)) but may be more efficient.
+func (d *Drawer) MeasureBytes(s []byte) (advance fixed.Int26_6) {
+ return MeasureBytes(d.Face, s)
+}
+
+// MeasureString returns how far dot would advance by drawing s.
+func (d *Drawer) MeasureString(s string) (advance fixed.Int26_6) {
+ return MeasureString(d.Face, s)
+}
+
+// BoundBytes returns the bounding box of s with f, drawn at a dot equal to the
+// origin, as well as the advance.
+//
+// It is equivalent to BoundString(string(s)) but may be more efficient.
+func BoundBytes(f Face, s []byte) (bounds fixed.Rectangle26_6, advance fixed.Int26_6) {
+ prevC := rune(-1)
+ for len(s) > 0 {
+ c, size := utf8.DecodeRune(s)
+ s = s[size:]
+ if prevC >= 0 {
+ advance += f.Kern(prevC, c)
+ }
+ b, a, ok := f.GlyphBounds(c)
+ if !ok {
+ // TODO: is falling back on the U+FFFD glyph the responsibility of
+ // the Drawer or the Face?
+ // TODO: set prevC = '\ufffd'?
+ continue
+ }
+ b.Min.X += advance
+ b.Max.X += advance
+ bounds = bounds.Union(b)
+ advance += a
+ prevC = c
+ }
+ return
+}
+
+// BoundString returns the bounding box of s with f, drawn at a dot equal to the
+// origin, as well as the advance.
+func BoundString(f Face, s string) (bounds fixed.Rectangle26_6, advance fixed.Int26_6) {
+ prevC := rune(-1)
+ for _, c := range s {
+ if prevC >= 0 {
+ advance += f.Kern(prevC, c)
+ }
+ b, a, ok := f.GlyphBounds(c)
+ if !ok {
+ // TODO: is falling back on the U+FFFD glyph the responsibility of
+ // the Drawer or the Face?
+ // TODO: set prevC = '\ufffd'?
+ continue
+ }
+ b.Min.X += advance
+ b.Max.X += advance
+ bounds = bounds.Union(b)
+ advance += a
+ prevC = c
+ }
+ return
+}
+
+// MeasureBytes returns how far dot would advance by drawing s with f.
+//
+// It is equivalent to MeasureString(string(s)) but may be more efficient.
+func MeasureBytes(f Face, s []byte) (advance fixed.Int26_6) {
+ prevC := rune(-1)
+ for len(s) > 0 {
+ c, size := utf8.DecodeRune(s)
+ s = s[size:]
+ if prevC >= 0 {
+ advance += f.Kern(prevC, c)
+ }
+ a, ok := f.GlyphAdvance(c)
+ if !ok {
+ // TODO: is falling back on the U+FFFD glyph the responsibility of
+ // the Drawer or the Face?
+ // TODO: set prevC = '\ufffd'?
+ continue
+ }
+ advance += a
+ prevC = c
+ }
+ return advance
+}
+
+// MeasureString returns how far dot would advance by drawing s with f.
+func MeasureString(f Face, s string) (advance fixed.Int26_6) {
+ prevC := rune(-1)
+ for _, c := range s {
+ if prevC >= 0 {
+ advance += f.Kern(prevC, c)
+ }
+ a, ok := f.GlyphAdvance(c)
+ if !ok {
+ // TODO: is falling back on the U+FFFD glyph the responsibility of
+ // the Drawer or the Face?
+ // TODO: set prevC = '\ufffd'?
+ continue
+ }
+ advance += a
+ prevC = c
+ }
+ return advance
+}
+
+// Hinting selects how to quantize a vector font's glyph nodes.
+//
+// Not all fonts support hinting.
+type Hinting int
+
+const (
+ HintingNone Hinting = iota
+ HintingVertical
+ HintingFull
+)
+
+// Stretch selects a normal, condensed, or expanded face.
+//
+// Not all fonts support stretches.
+type Stretch int
+
+const (
+ StretchUltraCondensed Stretch = -4
+ StretchExtraCondensed Stretch = -3
+ StretchCondensed Stretch = -2
+ StretchSemiCondensed Stretch = -1
+ StretchNormal Stretch = +0
+ StretchSemiExpanded Stretch = +1
+ StretchExpanded Stretch = +2
+ StretchExtraExpanded Stretch = +3
+ StretchUltraExpanded Stretch = +4
+)
+
+// Style selects a normal, italic, or oblique face.
+//
+// Not all fonts support styles.
+type Style int
+
+const (
+ StyleNormal Style = iota
+ StyleItalic
+ StyleOblique
+)
+
+// Weight selects a normal, light or bold face.
+//
+// Not all fonts support weights.
+//
+// The named Weight constants (e.g. WeightBold) correspond to CSS' common
+// weight names (e.g. "Bold"), but the numerical values differ, so that in Go,
+// the zero value means to use a normal weight. For the CSS names and values,
+// see https://developer.mozilla.org/en/docs/Web/CSS/font-weight
+type Weight int
+
+const (
+ WeightThin Weight = -3 // CSS font-weight value 100.
+ WeightExtraLight Weight = -2 // CSS font-weight value 200.
+ WeightLight Weight = -1 // CSS font-weight value 300.
+ WeightNormal Weight = +0 // CSS font-weight value 400.
+ WeightMedium Weight = +1 // CSS font-weight value 500.
+ WeightSemiBold Weight = +2 // CSS font-weight value 600.
+ WeightBold Weight = +3 // CSS font-weight value 700.
+ WeightExtraBold Weight = +4 // CSS font-weight value 800.
+ WeightBlack Weight = +5 // CSS font-weight value 900.
+)
diff --git a/vendor/golang.org/x/image/math/fixed/fixed.go b/vendor/golang.org/x/image/math/fixed/fixed.go
new file mode 100644
index 000000000..be4147659
--- /dev/null
+++ b/vendor/golang.org/x/image/math/fixed/fixed.go
@@ -0,0 +1,410 @@
+// Copyright 2015 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// Package fixed implements fixed-point integer types.
+package fixed
+
+import (
+ "fmt"
+)
+
+// TODO: implement fmt.Formatter for %f and %g.
+
+// I returns the integer value i as an Int26_6.
+//
+// For example, passing the integer value 2 yields Int26_6(128).
+func I(i int) Int26_6 {
+ return Int26_6(i << 6)
+}
+
+// Int26_6 is a signed 26.6 fixed-point number.
+//
+// The integer part ranges from -33554432 to 33554431, inclusive. The
+// fractional part has 6 bits of precision.
+//
+// For example, the number one-and-a-quarter is Int26_6(1<<6 + 1<<4).
+type Int26_6 int32
+
+// String returns a human-readable representation of a 26.6 fixed-point number.
+//
+// For example, the number one-and-a-quarter becomes "1:16".
+func (x Int26_6) String() string {
+ const shift, mask = 6, 1<<6 - 1
+ if x >= 0 {
+ return fmt.Sprintf("%d:%02d", int32(x>>shift), int32(x&mask))
+ }
+ x = -x
+ if x >= 0 {
+ return fmt.Sprintf("-%d:%02d", int32(x>>shift), int32(x&mask))
+ }
+ return "-33554432:00" // The minimum value is -(1<<25).
+}
+
+// Floor returns the greatest integer value less than or equal to x.
+//
+// Its return type is int, not Int26_6.
+func (x Int26_6) Floor() int { return int((x + 0x00) >> 6) }
+
+// Round returns the nearest integer value to x. Ties are rounded up.
+//
+// Its return type is int, not Int26_6.
+func (x Int26_6) Round() int { return int((x + 0x20) >> 6) }
+
+// Ceil returns the least integer value greater than or equal to x.
+//
+// Its return type is int, not Int26_6.
+func (x Int26_6) Ceil() int { return int((x + 0x3f) >> 6) }
+
+// Mul returns x*y in 26.6 fixed-point arithmetic.
+func (x Int26_6) Mul(y Int26_6) Int26_6 {
+ return Int26_6((int64(x)*int64(y) + 1<<5) >> 6)
+}
+
+// Int52_12 is a signed 52.12 fixed-point number.
+//
+// The integer part ranges from -2251799813685248 to 2251799813685247,
+// inclusive. The fractional part has 12 bits of precision.
+//
+// For example, the number one-and-a-quarter is Int52_12(1<<12 + 1<<10).
+type Int52_12 int64
+
+// String returns a human-readable representation of a 52.12 fixed-point
+// number.
+//
+// For example, the number one-and-a-quarter becomes "1:1024".
+func (x Int52_12) String() string {
+ const shift, mask = 12, 1<<12 - 1
+ if x >= 0 {
+ return fmt.Sprintf("%d:%04d", int64(x>>shift), int64(x&mask))
+ }
+ x = -x
+ if x >= 0 {
+ return fmt.Sprintf("-%d:%04d", int64(x>>shift), int64(x&mask))
+ }
+ return "-2251799813685248:0000" // The minimum value is -(1<<51).
+}
+
+// Floor returns the greatest integer value less than or equal to x.
+//
+// Its return type is int, not Int52_12.
+func (x Int52_12) Floor() int { return int((x + 0x000) >> 12) }
+
+// Round returns the nearest integer value to x. Ties are rounded up.
+//
+// Its return type is int, not Int52_12.
+func (x Int52_12) Round() int { return int((x + 0x800) >> 12) }
+
+// Ceil returns the least integer value greater than or equal to x.
+//
+// Its return type is int, not Int52_12.
+func (x Int52_12) Ceil() int { return int((x + 0xfff) >> 12) }
+
+// Mul returns x*y in 52.12 fixed-point arithmetic.
+func (x Int52_12) Mul(y Int52_12) Int52_12 {
+ const M, N = 52, 12
+ lo, hi := muli64(int64(x), int64(y))
+ ret := Int52_12(hi<>N)
+ ret += Int52_12((lo >> (N - 1)) & 1) // Round to nearest, instead of rounding down.
+ return ret
+}
+
+// muli64 multiplies two int64 values, returning the 128-bit signed integer
+// result as two uint64 values.
+//
+// This implementation is similar to $GOROOT/src/runtime/softfloat64.go's mullu
+// function, which is in turn adapted from Hacker's Delight.
+func muli64(u, v int64) (lo, hi uint64) {
+ const (
+ s = 32
+ mask = 1<> s)
+ u0 := uint64(u & mask)
+ v1 := uint64(v >> s)
+ v0 := uint64(v & mask)
+
+ w0 := u0 * v0
+ t := u1*v0 + w0>>s
+ w1 := t & mask
+ w2 := uint64(int64(t) >> s)
+ w1 += u0 * v1
+ return uint64(u) * uint64(v), u1*v1 + w2 + uint64(int64(w1)>>s)
+}
+
+// P returns the integer values x and y as a Point26_6.
+//
+// For example, passing the integer values (2, -3) yields Point26_6{128, -192}.
+func P(x, y int) Point26_6 {
+ return Point26_6{Int26_6(x << 6), Int26_6(y << 6)}
+}
+
+// Point26_6 is a 26.6 fixed-point coordinate pair.
+//
+// It is analogous to the image.Point type in the standard library.
+type Point26_6 struct {
+ X, Y Int26_6
+}
+
+// Add returns the vector p+q.
+func (p Point26_6) Add(q Point26_6) Point26_6 {
+ return Point26_6{p.X + q.X, p.Y + q.Y}
+}
+
+// Sub returns the vector p-q.
+func (p Point26_6) Sub(q Point26_6) Point26_6 {
+ return Point26_6{p.X - q.X, p.Y - q.Y}
+}
+
+// Mul returns the vector p*k.
+func (p Point26_6) Mul(k Int26_6) Point26_6 {
+ return Point26_6{p.X * k / 64, p.Y * k / 64}
+}
+
+// Div returns the vector p/k.
+func (p Point26_6) Div(k Int26_6) Point26_6 {
+ return Point26_6{p.X * 64 / k, p.Y * 64 / k}
+}
+
+// In returns whether p is in r.
+func (p Point26_6) In(r Rectangle26_6) bool {
+ return r.Min.X <= p.X && p.X < r.Max.X && r.Min.Y <= p.Y && p.Y < r.Max.Y
+}
+
+// Point52_12 is a 52.12 fixed-point coordinate pair.
+//
+// It is analogous to the image.Point type in the standard library.
+type Point52_12 struct {
+ X, Y Int52_12
+}
+
+// Add returns the vector p+q.
+func (p Point52_12) Add(q Point52_12) Point52_12 {
+ return Point52_12{p.X + q.X, p.Y + q.Y}
+}
+
+// Sub returns the vector p-q.
+func (p Point52_12) Sub(q Point52_12) Point52_12 {
+ return Point52_12{p.X - q.X, p.Y - q.Y}
+}
+
+// Mul returns the vector p*k.
+func (p Point52_12) Mul(k Int52_12) Point52_12 {
+ return Point52_12{p.X * k / 4096, p.Y * k / 4096}
+}
+
+// Div returns the vector p/k.
+func (p Point52_12) Div(k Int52_12) Point52_12 {
+ return Point52_12{p.X * 4096 / k, p.Y * 4096 / k}
+}
+
+// In returns whether p is in r.
+func (p Point52_12) In(r Rectangle52_12) bool {
+ return r.Min.X <= p.X && p.X < r.Max.X && r.Min.Y <= p.Y && p.Y < r.Max.Y
+}
+
+// R returns the integer values minX, minY, maxX, maxY as a Rectangle26_6.
+//
+// For example, passing the integer values (0, 1, 2, 3) yields
+// Rectangle26_6{Point26_6{0, 64}, Point26_6{128, 192}}.
+//
+// Like the image.Rect function in the standard library, the returned rectangle
+// has minimum and maximum coordinates swapped if necessary so that it is
+// well-formed.
+func R(minX, minY, maxX, maxY int) Rectangle26_6 {
+ if minX > maxX {
+ minX, maxX = maxX, minX
+ }
+ if minY > maxY {
+ minY, maxY = maxY, minY
+ }
+ return Rectangle26_6{
+ Point26_6{
+ Int26_6(minX << 6),
+ Int26_6(minY << 6),
+ },
+ Point26_6{
+ Int26_6(maxX << 6),
+ Int26_6(maxY << 6),
+ },
+ }
+}
+
+// Rectangle26_6 is a 26.6 fixed-point coordinate rectangle. The Min bound is
+// inclusive and the Max bound is exclusive. It is well-formed if Min.X <=
+// Max.X and likewise for Y.
+//
+// It is analogous to the image.Rectangle type in the standard library.
+type Rectangle26_6 struct {
+ Min, Max Point26_6
+}
+
+// Add returns the rectangle r translated by p.
+func (r Rectangle26_6) Add(p Point26_6) Rectangle26_6 {
+ return Rectangle26_6{
+ Point26_6{r.Min.X + p.X, r.Min.Y + p.Y},
+ Point26_6{r.Max.X + p.X, r.Max.Y + p.Y},
+ }
+}
+
+// Sub returns the rectangle r translated by -p.
+func (r Rectangle26_6) Sub(p Point26_6) Rectangle26_6 {
+ return Rectangle26_6{
+ Point26_6{r.Min.X - p.X, r.Min.Y - p.Y},
+ Point26_6{r.Max.X - p.X, r.Max.Y - p.Y},
+ }
+}
+
+// Intersect returns the largest rectangle contained by both r and s. If the
+// two rectangles do not overlap then the zero rectangle will be returned.
+func (r Rectangle26_6) Intersect(s Rectangle26_6) Rectangle26_6 {
+ if r.Min.X < s.Min.X {
+ r.Min.X = s.Min.X
+ }
+ if r.Min.Y < s.Min.Y {
+ r.Min.Y = s.Min.Y
+ }
+ if r.Max.X > s.Max.X {
+ r.Max.X = s.Max.X
+ }
+ if r.Max.Y > s.Max.Y {
+ r.Max.Y = s.Max.Y
+ }
+ // Letting r0 and s0 be the values of r and s at the time that the method
+ // is called, this next line is equivalent to:
+ //
+ // if max(r0.Min.X, s0.Min.X) >= min(r0.Max.X, s0.Max.X) || likewiseForY { etc }
+ if r.Empty() {
+ return Rectangle26_6{}
+ }
+ return r
+}
+
+// Union returns the smallest rectangle that contains both r and s.
+func (r Rectangle26_6) Union(s Rectangle26_6) Rectangle26_6 {
+ if r.Empty() {
+ return s
+ }
+ if s.Empty() {
+ return r
+ }
+ if r.Min.X > s.Min.X {
+ r.Min.X = s.Min.X
+ }
+ if r.Min.Y > s.Min.Y {
+ r.Min.Y = s.Min.Y
+ }
+ if r.Max.X < s.Max.X {
+ r.Max.X = s.Max.X
+ }
+ if r.Max.Y < s.Max.Y {
+ r.Max.Y = s.Max.Y
+ }
+ return r
+}
+
+// Empty returns whether the rectangle contains no points.
+func (r Rectangle26_6) Empty() bool {
+ return r.Min.X >= r.Max.X || r.Min.Y >= r.Max.Y
+}
+
+// In returns whether every point in r is in s.
+func (r Rectangle26_6) In(s Rectangle26_6) bool {
+ if r.Empty() {
+ return true
+ }
+ // Note that r.Max is an exclusive bound for r, so that r.In(s)
+ // does not require that r.Max.In(s).
+ return s.Min.X <= r.Min.X && r.Max.X <= s.Max.X &&
+ s.Min.Y <= r.Min.Y && r.Max.Y <= s.Max.Y
+}
+
+// Rectangle52_12 is a 52.12 fixed-point coordinate rectangle. The Min bound is
+// inclusive and the Max bound is exclusive. It is well-formed if Min.X <=
+// Max.X and likewise for Y.
+//
+// It is analogous to the image.Rectangle type in the standard library.
+type Rectangle52_12 struct {
+ Min, Max Point52_12
+}
+
+// Add returns the rectangle r translated by p.
+func (r Rectangle52_12) Add(p Point52_12) Rectangle52_12 {
+ return Rectangle52_12{
+ Point52_12{r.Min.X + p.X, r.Min.Y + p.Y},
+ Point52_12{r.Max.X + p.X, r.Max.Y + p.Y},
+ }
+}
+
+// Sub returns the rectangle r translated by -p.
+func (r Rectangle52_12) Sub(p Point52_12) Rectangle52_12 {
+ return Rectangle52_12{
+ Point52_12{r.Min.X - p.X, r.Min.Y - p.Y},
+ Point52_12{r.Max.X - p.X, r.Max.Y - p.Y},
+ }
+}
+
+// Intersect returns the largest rectangle contained by both r and s. If the
+// two rectangles do not overlap then the zero rectangle will be returned.
+func (r Rectangle52_12) Intersect(s Rectangle52_12) Rectangle52_12 {
+ if r.Min.X < s.Min.X {
+ r.Min.X = s.Min.X
+ }
+ if r.Min.Y < s.Min.Y {
+ r.Min.Y = s.Min.Y
+ }
+ if r.Max.X > s.Max.X {
+ r.Max.X = s.Max.X
+ }
+ if r.Max.Y > s.Max.Y {
+ r.Max.Y = s.Max.Y
+ }
+ // Letting r0 and s0 be the values of r and s at the time that the method
+ // is called, this next line is equivalent to:
+ //
+ // if max(r0.Min.X, s0.Min.X) >= min(r0.Max.X, s0.Max.X) || likewiseForY { etc }
+ if r.Empty() {
+ return Rectangle52_12{}
+ }
+ return r
+}
+
+// Union returns the smallest rectangle that contains both r and s.
+func (r Rectangle52_12) Union(s Rectangle52_12) Rectangle52_12 {
+ if r.Empty() {
+ return s
+ }
+ if s.Empty() {
+ return r
+ }
+ if r.Min.X > s.Min.X {
+ r.Min.X = s.Min.X
+ }
+ if r.Min.Y > s.Min.Y {
+ r.Min.Y = s.Min.Y
+ }
+ if r.Max.X < s.Max.X {
+ r.Max.X = s.Max.X
+ }
+ if r.Max.Y < s.Max.Y {
+ r.Max.Y = s.Max.Y
+ }
+ return r
+}
+
+// Empty returns whether the rectangle contains no points.
+func (r Rectangle52_12) Empty() bool {
+ return r.Min.X >= r.Max.X || r.Min.Y >= r.Max.Y
+}
+
+// In returns whether every point in r is in s.
+func (r Rectangle52_12) In(s Rectangle52_12) bool {
+ if r.Empty() {
+ return true
+ }
+ // Note that r.Max is an exclusive bound for r, so that r.In(s)
+ // does not require that r.Max.In(s).
+ return s.Min.X <= r.Min.X && r.Max.X <= s.Max.X &&
+ s.Min.Y <= r.Min.Y && r.Max.Y <= s.Max.Y
+}
diff --git a/vendor/golang.org/x/sys/unix/.gitignore b/vendor/golang.org/x/sys/unix/.gitignore
deleted file mode 100644
index e48271590..000000000
--- a/vendor/golang.org/x/sys/unix/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-_obj/
diff --git a/vendor/golang.org/x/sys/unix/README.md b/vendor/golang.org/x/sys/unix/README.md
deleted file mode 100644
index bc6f6031f..000000000
--- a/vendor/golang.org/x/sys/unix/README.md
+++ /dev/null
@@ -1,173 +0,0 @@
-# Building `sys/unix`
-
-The sys/unix package provides access to the raw system call interface of the
-underlying operating system. See: https://godoc.org/golang.org/x/sys/unix
-
-Porting Go to a new architecture/OS combination or adding syscalls, types, or
-constants to an existing architecture/OS pair requires some manual effort;
-however, there are tools that automate much of the process.
-
-## Build Systems
-
-There are currently two ways we generate the necessary files. We are currently
-migrating the build system to use containers so the builds are reproducible.
-This is being done on an OS-by-OS basis. Please update this documentation as
-components of the build system change.
-
-### Old Build System (currently for `GOOS != "Linux" || GOARCH == "sparc64"`)
-
-The old build system generates the Go files based on the C header files
-present on your system. This means that files
-for a given GOOS/GOARCH pair must be generated on a system with that OS and
-architecture. This also means that the generated code can differ from system
-to system, based on differences in the header files.
-
-To avoid this, if you are using the old build system, only generate the Go
-files on an installation with unmodified header files. It is also important to
-keep track of which version of the OS the files were generated from (ex.
-Darwin 14 vs Darwin 15). This makes it easier to track the progress of changes
-and have each OS upgrade correspond to a single change.
-
-To build the files for your current OS and architecture, make sure GOOS and
-GOARCH are set correctly and run `mkall.sh`. This will generate the files for
-your specific system. Running `mkall.sh -n` shows the commands that will be run.
-
-Requirements: bash, perl, go
-
-### New Build System (currently for `GOOS == "Linux" && GOARCH != "sparc64"`)
-
-The new build system uses a Docker container to generate the go files directly
-from source checkouts of the kernel and various system libraries. This means
-that on any platform that supports Docker, all the files using the new build
-system can be generated at once, and generated files will not change based on
-what the person running the scripts has installed on their computer.
-
-The OS specific files for the new build system are located in the `${GOOS}`
-directory, and the build is coordinated by the `${GOOS}/mkall.go` program. When
-the kernel or system library updates, modify the Dockerfile at
-`${GOOS}/Dockerfile` to checkout the new release of the source.
-
-To build all the files under the new build system, you must be on an amd64/Linux
-system and have your GOOS and GOARCH set accordingly. Running `mkall.sh` will
-then generate all of the files for all of the GOOS/GOARCH pairs in the new build
-system. Running `mkall.sh -n` shows the commands that will be run.
-
-Requirements: bash, perl, go, docker
-
-## Component files
-
-This section describes the various files used in the code generation process.
-It also contains instructions on how to modify these files to add a new
-architecture/OS or to add additional syscalls, types, or constants. Note that
-if you are using the new build system, the scripts cannot be called normally.
-They must be called from within the docker container.
-
-### asm files
-
-The hand-written assembly file at `asm_${GOOS}_${GOARCH}.s` implements system
-call dispatch. There are three entry points:
-```
- func Syscall(trap, a1, a2, a3 uintptr) (r1, r2, err uintptr)
- func Syscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2, err uintptr)
- func RawSyscall(trap, a1, a2, a3 uintptr) (r1, r2, err uintptr)
-```
-The first and second are the standard ones; they differ only in how many
-arguments can be passed to the kernel. The third is for low-level use by the
-ForkExec wrapper. Unlike the first two, it does not call into the scheduler to
-let it know that a system call is running.
-
-When porting Go to an new architecture/OS, this file must be implemented for
-each GOOS/GOARCH pair.
-
-### mksysnum
-
-Mksysnum is a script located at `${GOOS}/mksysnum.pl` (or `mksysnum_${GOOS}.pl`
-for the old system). This script takes in a list of header files containing the
-syscall number declarations and parses them to produce the corresponding list of
-Go numeric constants. See `zsysnum_${GOOS}_${GOARCH}.go` for the generated
-constants.
-
-Adding new syscall numbers is mostly done by running the build on a sufficiently
-new installation of the target OS (or updating the source checkouts for the
-new build system). However, depending on the OS, you make need to update the
-parsing in mksysnum.
-
-### mksyscall.pl
-
-The `syscall.go`, `syscall_${GOOS}.go`, `syscall_${GOOS}_${GOARCH}.go` are
-hand-written Go files which implement system calls (for unix, the specific OS,
-or the specific OS/Architecture pair respectively) that need special handling
-and list `//sys` comments giving prototypes for ones that can be generated.
-
-The mksyscall.pl script takes the `//sys` and `//sysnb` comments and converts
-them into syscalls. This requires the name of the prototype in the comment to
-match a syscall number in the `zsysnum_${GOOS}_${GOARCH}.go` file. The function
-prototype can be exported (capitalized) or not.
-
-Adding a new syscall often just requires adding a new `//sys` function prototype
-with the desired arguments and a capitalized name so it is exported. However, if
-you want the interface to the syscall to be different, often one will make an
-unexported `//sys` prototype, an then write a custom wrapper in
-`syscall_${GOOS}.go`.
-
-### types files
-
-For each OS, there is a hand-written Go file at `${GOOS}/types.go` (or
-`types_${GOOS}.go` on the old system). This file includes standard C headers and
-creates Go type aliases to the corresponding C types. The file is then fed
-through godef to get the Go compatible definitions. Finally, the generated code
-is fed though mkpost.go to format the code correctly and remove any hidden or
-private identifiers. This cleaned-up code is written to
-`ztypes_${GOOS}_${GOARCH}.go`.
-
-The hardest part about preparing this file is figuring out which headers to
-include and which symbols need to be `#define`d to get the actual data
-structures that pass through to the kernel system calls. Some C libraries
-preset alternate versions for binary compatibility and translate them on the
-way in and out of system calls, but there is almost always a `#define` that can
-get the real ones.
-See `types_darwin.go` and `linux/types.go` for examples.
-
-To add a new type, add in the necessary include statement at the top of the
-file (if it is not already there) and add in a type alias line. Note that if
-your type is significantly different on different architectures, you may need
-some `#if/#elif` macros in your include statements.
-
-### mkerrors.sh
-
-This script is used to generate the system's various constants. This doesn't
-just include the error numbers and error strings, but also the signal numbers
-an a wide variety of miscellaneous constants. The constants come from the list
-of include files in the `includes_${uname}` variable. A regex then picks out
-the desired `#define` statements, and generates the corresponding Go constants.
-The error numbers and strings are generated from `#include `, and the
-signal numbers and strings are generated from `#include `. All of
-these constants are written to `zerrors_${GOOS}_${GOARCH}.go` via a C program,
-`_errors.c`, which prints out all the constants.
-
-To add a constant, add the header that includes it to the appropriate variable.
-Then, edit the regex (if necessary) to match the desired constant. Avoid making
-the regex too broad to avoid matching unintended constants.
-
-
-## Generated files
-
-### `zerror_${GOOS}_${GOARCH}.go`
-
-A file containing all of the system's generated error numbers, error strings,
-signal numbers, and constants. Generated by `mkerrors.sh` (see above).
-
-### `zsyscall_${GOOS}_${GOARCH}.go`
-
-A file containing all the generated syscalls for a specific GOOS and GOARCH.
-Generated by `mksyscall.pl` (see above).
-
-### `zsysnum_${GOOS}_${GOARCH}.go`
-
-A list of numeric constants for all the syscall number of the specific GOOS
-and GOARCH. Generated by mksysnum (see above).
-
-### `ztypes_${GOOS}_${GOARCH}.go`
-
-A file containing Go types for passing into (or returning from) syscalls.
-Generated by godefs and the types file (see above).
diff --git a/vendor/golang.org/x/sys/unix/asm_darwin_386.s b/vendor/golang.org/x/sys/unix/asm_darwin_386.s
deleted file mode 100644
index 8a7278319..000000000
--- a/vendor/golang.org/x/sys/unix/asm_darwin_386.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for 386, Darwin
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_darwin_amd64.s b/vendor/golang.org/x/sys/unix/asm_darwin_amd64.s
deleted file mode 100644
index 6321421f2..000000000
--- a/vendor/golang.org/x/sys/unix/asm_darwin_amd64.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for AMD64, Darwin
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-104
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_darwin_arm.s b/vendor/golang.org/x/sys/unix/asm_darwin_arm.s
deleted file mode 100644
index 333242d50..000000000
--- a/vendor/golang.org/x/sys/unix/asm_darwin_arm.s
+++ /dev/null
@@ -1,30 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-// +build arm,darwin
-
-#include "textflag.h"
-
-//
-// System call support for ARM, Darwin
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- B syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- B syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- B syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- B syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- B syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_darwin_arm64.s b/vendor/golang.org/x/sys/unix/asm_darwin_arm64.s
deleted file mode 100644
index 97e017437..000000000
--- a/vendor/golang.org/x/sys/unix/asm_darwin_arm64.s
+++ /dev/null
@@ -1,30 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-// +build arm64,darwin
-
-#include "textflag.h"
-
-//
-// System call support for AMD64, Darwin
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- B syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- B syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-104
- B syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- B syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- B syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s b/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s
deleted file mode 100644
index d5ed6726c..000000000
--- a/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for AMD64, DragonFly
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-64
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-88
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-112
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-64
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-88
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_freebsd_386.s b/vendor/golang.org/x/sys/unix/asm_freebsd_386.s
deleted file mode 100644
index c9a0a2601..000000000
--- a/vendor/golang.org/x/sys/unix/asm_freebsd_386.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for 386, FreeBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_freebsd_amd64.s b/vendor/golang.org/x/sys/unix/asm_freebsd_amd64.s
deleted file mode 100644
index 35172477c..000000000
--- a/vendor/golang.org/x/sys/unix/asm_freebsd_amd64.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for AMD64, FreeBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-104
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_freebsd_arm.s b/vendor/golang.org/x/sys/unix/asm_freebsd_arm.s
deleted file mode 100644
index 9227c875b..000000000
--- a/vendor/golang.org/x/sys/unix/asm_freebsd_arm.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2012 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for ARM, FreeBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- B syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- B syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- B syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- B syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- B syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_386.s b/vendor/golang.org/x/sys/unix/asm_linux_386.s
deleted file mode 100644
index 4db290932..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_386.s
+++ /dev/null
@@ -1,35 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for 386, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- JMP syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- JMP syscall·RawSyscall6(SB)
-
-TEXT ·socketcall(SB),NOSPLIT,$0-36
- JMP syscall·socketcall(SB)
-
-TEXT ·rawsocketcall(SB),NOSPLIT,$0-36
- JMP syscall·rawsocketcall(SB)
-
-TEXT ·seek(SB),NOSPLIT,$0-28
- JMP syscall·seek(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_amd64.s b/vendor/golang.org/x/sys/unix/asm_linux_amd64.s
deleted file mode 100644
index 44e25c62f..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_amd64.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for AMD64, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- JMP syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- JMP syscall·RawSyscall6(SB)
-
-TEXT ·gettimeofday(SB),NOSPLIT,$0-16
- JMP syscall·gettimeofday(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_arm.s b/vendor/golang.org/x/sys/unix/asm_linux_arm.s
deleted file mode 100644
index cf0b57465..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_arm.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for arm, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- B syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- B syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- B syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- B syscall·RawSyscall6(SB)
-
-TEXT ·seek(SB),NOSPLIT,$0-32
- B syscall·seek(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_arm64.s b/vendor/golang.org/x/sys/unix/asm_linux_arm64.s
deleted file mode 100644
index 4be9bfede..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_arm64.s
+++ /dev/null
@@ -1,24 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build arm64
-// +build !gccgo
-
-#include "textflag.h"
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- B syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- B syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- B syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- B syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_mips64x.s b/vendor/golang.org/x/sys/unix/asm_linux_mips64x.s
deleted file mode 100644
index 724e580c4..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_mips64x.s
+++ /dev/null
@@ -1,28 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build mips64 mips64le
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for mips64, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- JMP syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_mipsx.s b/vendor/golang.org/x/sys/unix/asm_linux_mipsx.s
deleted file mode 100644
index 2ea425755..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_mipsx.s
+++ /dev/null
@@ -1,31 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build mips mipsle
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for mips, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_ppc64x.s b/vendor/golang.org/x/sys/unix/asm_linux_ppc64x.s
deleted file mode 100644
index 8d231feb4..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_ppc64x.s
+++ /dev/null
@@ -1,28 +0,0 @@
-// Copyright 2014 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build ppc64 ppc64le
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for ppc64, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- BR syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- BR syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- BR syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- BR syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_linux_s390x.s b/vendor/golang.org/x/sys/unix/asm_linux_s390x.s
deleted file mode 100644
index 11889859f..000000000
--- a/vendor/golang.org/x/sys/unix/asm_linux_s390x.s
+++ /dev/null
@@ -1,28 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build s390x
-// +build linux
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for s390x, Linux
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- BR syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- BR syscall·Syscall6(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- BR syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- BR syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_netbsd_386.s b/vendor/golang.org/x/sys/unix/asm_netbsd_386.s
deleted file mode 100644
index 48bdcd763..000000000
--- a/vendor/golang.org/x/sys/unix/asm_netbsd_386.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for 386, NetBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_netbsd_amd64.s b/vendor/golang.org/x/sys/unix/asm_netbsd_amd64.s
deleted file mode 100644
index 2ede05c72..000000000
--- a/vendor/golang.org/x/sys/unix/asm_netbsd_amd64.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for AMD64, NetBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-104
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_netbsd_arm.s b/vendor/golang.org/x/sys/unix/asm_netbsd_arm.s
deleted file mode 100644
index e8928571c..000000000
--- a/vendor/golang.org/x/sys/unix/asm_netbsd_arm.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2013 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for ARM, NetBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- B syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- B syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- B syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- B syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- B syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_openbsd_386.s b/vendor/golang.org/x/sys/unix/asm_openbsd_386.s
deleted file mode 100644
index 00576f3c8..000000000
--- a/vendor/golang.org/x/sys/unix/asm_openbsd_386.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for 386, OpenBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-28
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-40
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-52
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-28
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-40
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_openbsd_amd64.s b/vendor/golang.org/x/sys/unix/asm_openbsd_amd64.s
deleted file mode 100644
index 790ef77f8..000000000
--- a/vendor/golang.org/x/sys/unix/asm_openbsd_amd64.s
+++ /dev/null
@@ -1,29 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System call support for AMD64, OpenBSD
-//
-
-// Just jump to package syscall's implementation for all these functions.
-// The runtime may know about them.
-
-TEXT ·Syscall(SB),NOSPLIT,$0-56
- JMP syscall·Syscall(SB)
-
-TEXT ·Syscall6(SB),NOSPLIT,$0-80
- JMP syscall·Syscall6(SB)
-
-TEXT ·Syscall9(SB),NOSPLIT,$0-104
- JMP syscall·Syscall9(SB)
-
-TEXT ·RawSyscall(SB),NOSPLIT,$0-56
- JMP syscall·RawSyscall(SB)
-
-TEXT ·RawSyscall6(SB),NOSPLIT,$0-80
- JMP syscall·RawSyscall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/asm_solaris_amd64.s b/vendor/golang.org/x/sys/unix/asm_solaris_amd64.s
deleted file mode 100644
index 43ed17a05..000000000
--- a/vendor/golang.org/x/sys/unix/asm_solaris_amd64.s
+++ /dev/null
@@ -1,17 +0,0 @@
-// Copyright 2014 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !gccgo
-
-#include "textflag.h"
-
-//
-// System calls for amd64, Solaris are implemented in runtime/syscall_solaris.go
-//
-
-TEXT ·sysvicall6(SB),NOSPLIT,$0-64
- JMP syscall·sysvicall6(SB)
-
-TEXT ·rawSysvicall6(SB),NOSPLIT,$0-64
- JMP syscall·rawSysvicall6(SB)
diff --git a/vendor/golang.org/x/sys/unix/bluetooth_linux.go b/vendor/golang.org/x/sys/unix/bluetooth_linux.go
deleted file mode 100644
index 6e3229697..000000000
--- a/vendor/golang.org/x/sys/unix/bluetooth_linux.go
+++ /dev/null
@@ -1,35 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Bluetooth sockets and messages
-
-package unix
-
-// Bluetooth Protocols
-const (
- BTPROTO_L2CAP = 0
- BTPROTO_HCI = 1
- BTPROTO_SCO = 2
- BTPROTO_RFCOMM = 3
- BTPROTO_BNEP = 4
- BTPROTO_CMTP = 5
- BTPROTO_HIDP = 6
- BTPROTO_AVDTP = 7
-)
-
-const (
- HCI_CHANNEL_RAW = 0
- HCI_CHANNEL_USER = 1
- HCI_CHANNEL_MONITOR = 2
- HCI_CHANNEL_CONTROL = 3
-)
-
-// Socketoption Level
-const (
- SOL_BLUETOOTH = 0x112
- SOL_HCI = 0x0
- SOL_L2CAP = 0x6
- SOL_RFCOMM = 0x12
- SOL_SCO = 0x11
-)
diff --git a/vendor/golang.org/x/sys/unix/constants.go b/vendor/golang.org/x/sys/unix/constants.go
deleted file mode 100644
index a96f0ebc2..000000000
--- a/vendor/golang.org/x/sys/unix/constants.go
+++ /dev/null
@@ -1,13 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd solaris
-
-package unix
-
-const (
- R_OK = 0x4
- W_OK = 0x2
- X_OK = 0x1
-)
diff --git a/vendor/golang.org/x/sys/unix/dirent.go b/vendor/golang.org/x/sys/unix/dirent.go
deleted file mode 100644
index bd475812b..000000000
--- a/vendor/golang.org/x/sys/unix/dirent.go
+++ /dev/null
@@ -1,102 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux nacl netbsd openbsd solaris
-
-package unix
-
-import "unsafe"
-
-// readInt returns the size-bytes unsigned integer in native byte order at offset off.
-func readInt(b []byte, off, size uintptr) (u uint64, ok bool) {
- if len(b) < int(off+size) {
- return 0, false
- }
- if isBigEndian {
- return readIntBE(b[off:], size), true
- }
- return readIntLE(b[off:], size), true
-}
-
-func readIntBE(b []byte, size uintptr) uint64 {
- switch size {
- case 1:
- return uint64(b[0])
- case 2:
- _ = b[1] // bounds check hint to compiler; see golang.org/issue/14808
- return uint64(b[1]) | uint64(b[0])<<8
- case 4:
- _ = b[3] // bounds check hint to compiler; see golang.org/issue/14808
- return uint64(b[3]) | uint64(b[2])<<8 | uint64(b[1])<<16 | uint64(b[0])<<24
- case 8:
- _ = b[7] // bounds check hint to compiler; see golang.org/issue/14808
- return uint64(b[7]) | uint64(b[6])<<8 | uint64(b[5])<<16 | uint64(b[4])<<24 |
- uint64(b[3])<<32 | uint64(b[2])<<40 | uint64(b[1])<<48 | uint64(b[0])<<56
- default:
- panic("syscall: readInt with unsupported size")
- }
-}
-
-func readIntLE(b []byte, size uintptr) uint64 {
- switch size {
- case 1:
- return uint64(b[0])
- case 2:
- _ = b[1] // bounds check hint to compiler; see golang.org/issue/14808
- return uint64(b[0]) | uint64(b[1])<<8
- case 4:
- _ = b[3] // bounds check hint to compiler; see golang.org/issue/14808
- return uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24
- case 8:
- _ = b[7] // bounds check hint to compiler; see golang.org/issue/14808
- return uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 |
- uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56
- default:
- panic("syscall: readInt with unsupported size")
- }
-}
-
-// ParseDirent parses up to max directory entries in buf,
-// appending the names to names. It returns the number of
-// bytes consumed from buf, the number of entries added
-// to names, and the new names slice.
-func ParseDirent(buf []byte, max int, names []string) (consumed int, count int, newnames []string) {
- origlen := len(buf)
- count = 0
- for max != 0 && len(buf) > 0 {
- reclen, ok := direntReclen(buf)
- if !ok || reclen > uint64(len(buf)) {
- return origlen, count, names
- }
- rec := buf[:reclen]
- buf = buf[reclen:]
- ino, ok := direntIno(rec)
- if !ok {
- break
- }
- if ino == 0 { // File absent in directory.
- continue
- }
- const namoff = uint64(unsafe.Offsetof(Dirent{}.Name))
- namlen, ok := direntNamlen(rec)
- if !ok || namoff+namlen > uint64(len(rec)) {
- break
- }
- name := rec[namoff : namoff+namlen]
- for i, c := range name {
- if c == 0 {
- name = name[:i]
- break
- }
- }
- // Check for useless names before allocating a string.
- if string(name) == "." || string(name) == ".." {
- continue
- }
- max--
- count++
- names = append(names, string(name))
- }
- return origlen - len(buf), count, names
-}
diff --git a/vendor/golang.org/x/sys/unix/endian_big.go b/vendor/golang.org/x/sys/unix/endian_big.go
deleted file mode 100644
index 5e9269063..000000000
--- a/vendor/golang.org/x/sys/unix/endian_big.go
+++ /dev/null
@@ -1,9 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-//
-// +build ppc64 s390x mips mips64
-
-package unix
-
-const isBigEndian = true
diff --git a/vendor/golang.org/x/sys/unix/endian_little.go b/vendor/golang.org/x/sys/unix/endian_little.go
deleted file mode 100644
index 085df2d8d..000000000
--- a/vendor/golang.org/x/sys/unix/endian_little.go
+++ /dev/null
@@ -1,9 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-//
-// +build 386 amd64 amd64p32 arm arm64 ppc64le mipsle mips64le
-
-package unix
-
-const isBigEndian = false
diff --git a/vendor/golang.org/x/sys/unix/env_unix.go b/vendor/golang.org/x/sys/unix/env_unix.go
deleted file mode 100644
index 45e281a04..000000000
--- a/vendor/golang.org/x/sys/unix/env_unix.go
+++ /dev/null
@@ -1,27 +0,0 @@
-// Copyright 2010 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd solaris
-
-// Unix environment variables.
-
-package unix
-
-import "syscall"
-
-func Getenv(key string) (value string, found bool) {
- return syscall.Getenv(key)
-}
-
-func Setenv(key, value string) error {
- return syscall.Setenv(key, value)
-}
-
-func Clearenv() {
- syscall.Clearenv()
-}
-
-func Environ() []string {
- return syscall.Environ()
-}
diff --git a/vendor/golang.org/x/sys/unix/env_unset.go b/vendor/golang.org/x/sys/unix/env_unset.go
deleted file mode 100644
index 922226255..000000000
--- a/vendor/golang.org/x/sys/unix/env_unset.go
+++ /dev/null
@@ -1,14 +0,0 @@
-// Copyright 2014 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build go1.4
-
-package unix
-
-import "syscall"
-
-func Unsetenv(key string) error {
- // This was added in Go 1.4.
- return syscall.Unsetenv(key)
-}
diff --git a/vendor/golang.org/x/sys/unix/flock.go b/vendor/golang.org/x/sys/unix/flock.go
deleted file mode 100644
index ce67a5952..000000000
--- a/vendor/golang.org/x/sys/unix/flock.go
+++ /dev/null
@@ -1,24 +0,0 @@
-// +build linux darwin freebsd openbsd netbsd dragonfly
-
-// Copyright 2014 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd
-
-package unix
-
-import "unsafe"
-
-// fcntl64Syscall is usually SYS_FCNTL, but is overridden on 32-bit Linux
-// systems by flock_linux_32bit.go to be SYS_FCNTL64.
-var fcntl64Syscall uintptr = SYS_FCNTL
-
-// FcntlFlock performs a fcntl syscall for the F_GETLK, F_SETLK or F_SETLKW command.
-func FcntlFlock(fd uintptr, cmd int, lk *Flock_t) error {
- _, _, errno := Syscall(fcntl64Syscall, fd, uintptr(cmd), uintptr(unsafe.Pointer(lk)))
- if errno == 0 {
- return nil
- }
- return errno
-}
diff --git a/vendor/golang.org/x/sys/unix/flock_linux_32bit.go b/vendor/golang.org/x/sys/unix/flock_linux_32bit.go
deleted file mode 100644
index fc0e50e03..000000000
--- a/vendor/golang.org/x/sys/unix/flock_linux_32bit.go
+++ /dev/null
@@ -1,13 +0,0 @@
-// +build linux,386 linux,arm linux,mips linux,mipsle
-
-// Copyright 2014 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package unix
-
-func init() {
- // On 32-bit Linux systems, the fcntl syscall that matches Go's
- // Flock_t type is SYS_FCNTL64, not SYS_FCNTL.
- fcntl64Syscall = SYS_FCNTL64
-}
diff --git a/vendor/golang.org/x/sys/unix/gccgo.go b/vendor/golang.org/x/sys/unix/gccgo.go
deleted file mode 100644
index 94c823212..000000000
--- a/vendor/golang.org/x/sys/unix/gccgo.go
+++ /dev/null
@@ -1,46 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build gccgo
-
-package unix
-
-import "syscall"
-
-// We can't use the gc-syntax .s files for gccgo. On the plus side
-// much of the functionality can be written directly in Go.
-
-//extern gccgoRealSyscall
-func realSyscall(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r, errno uintptr)
-
-func Syscall(trap, a1, a2, a3 uintptr) (r1, r2 uintptr, err syscall.Errno) {
- syscall.Entersyscall()
- r, errno := realSyscall(trap, a1, a2, a3, 0, 0, 0, 0, 0, 0)
- syscall.Exitsyscall()
- return r, 0, syscall.Errno(errno)
-}
-
-func Syscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err syscall.Errno) {
- syscall.Entersyscall()
- r, errno := realSyscall(trap, a1, a2, a3, a4, a5, a6, 0, 0, 0)
- syscall.Exitsyscall()
- return r, 0, syscall.Errno(errno)
-}
-
-func Syscall9(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno) {
- syscall.Entersyscall()
- r, errno := realSyscall(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9)
- syscall.Exitsyscall()
- return r, 0, syscall.Errno(errno)
-}
-
-func RawSyscall(trap, a1, a2, a3 uintptr) (r1, r2 uintptr, err syscall.Errno) {
- r, errno := realSyscall(trap, a1, a2, a3, 0, 0, 0, 0, 0, 0)
- return r, 0, syscall.Errno(errno)
-}
-
-func RawSyscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err syscall.Errno) {
- r, errno := realSyscall(trap, a1, a2, a3, a4, a5, a6, 0, 0, 0)
- return r, 0, syscall.Errno(errno)
-}
diff --git a/vendor/golang.org/x/sys/unix/gccgo_c.c b/vendor/golang.org/x/sys/unix/gccgo_c.c
deleted file mode 100644
index 07f6be039..000000000
--- a/vendor/golang.org/x/sys/unix/gccgo_c.c
+++ /dev/null
@@ -1,41 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build gccgo
-
-#include
-#include
-#include
-
-#define _STRINGIFY2_(x) #x
-#define _STRINGIFY_(x) _STRINGIFY2_(x)
-#define GOSYM_PREFIX _STRINGIFY_(__USER_LABEL_PREFIX__)
-
-// Call syscall from C code because the gccgo support for calling from
-// Go to C does not support varargs functions.
-
-struct ret {
- uintptr_t r;
- uintptr_t err;
-};
-
-struct ret
-gccgoRealSyscall(uintptr_t trap, uintptr_t a1, uintptr_t a2, uintptr_t a3, uintptr_t a4, uintptr_t a5, uintptr_t a6, uintptr_t a7, uintptr_t a8, uintptr_t a9)
-{
- struct ret r;
-
- errno = 0;
- r.r = syscall(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9);
- r.err = errno;
- return r;
-}
-
-// Define the use function in C so that it is not inlined.
-
-extern void use(void *) __asm__ (GOSYM_PREFIX GOPKGPATH ".use") __attribute__((noinline));
-
-void
-use(void *p __attribute__ ((unused)))
-{
-}
diff --git a/vendor/golang.org/x/sys/unix/gccgo_linux_amd64.go b/vendor/golang.org/x/sys/unix/gccgo_linux_amd64.go
deleted file mode 100644
index bffe1a77d..000000000
--- a/vendor/golang.org/x/sys/unix/gccgo_linux_amd64.go
+++ /dev/null
@@ -1,20 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build gccgo,linux,amd64
-
-package unix
-
-import "syscall"
-
-//extern gettimeofday
-func realGettimeofday(*Timeval, *byte) int32
-
-func gettimeofday(tv *Timeval) (err syscall.Errno) {
- r := realGettimeofday(tv, nil)
- if r < 0 {
- return syscall.GetErrno()
- }
- return 0
-}
diff --git a/vendor/golang.org/x/sys/unix/gccgo_linux_sparc64.go b/vendor/golang.org/x/sys/unix/gccgo_linux_sparc64.go
deleted file mode 100644
index 56332692c..000000000
--- a/vendor/golang.org/x/sys/unix/gccgo_linux_sparc64.go
+++ /dev/null
@@ -1,20 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build gccgo,linux,sparc64
-
-package unix
-
-import "syscall"
-
-//extern sysconf
-func realSysconf(name int) int64
-
-func sysconf(name int) (n int64, err syscall.Errno) {
- r := realSysconf(name)
- if r < 0 {
- return 0, syscall.GetErrno()
- }
- return r, 0
-}
diff --git a/vendor/golang.org/x/sys/unix/mkall.sh b/vendor/golang.org/x/sys/unix/mkall.sh
deleted file mode 100644
index f0d6566f2..000000000
--- a/vendor/golang.org/x/sys/unix/mkall.sh
+++ /dev/null
@@ -1,179 +0,0 @@
-#!/usr/bin/env bash
-# Copyright 2009 The Go Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-# This script runs or (given -n) prints suggested commands to generate files for
-# the Architecture/OS specified by the GOARCH and GOOS environment variables.
-# See README.md for more information about how the build system works.
-
-GOOSARCH="${GOOS}_${GOARCH}"
-
-# defaults
-mksyscall="./mksyscall.pl"
-mkerrors="./mkerrors.sh"
-zerrors="zerrors_$GOOSARCH.go"
-mksysctl=""
-zsysctl="zsysctl_$GOOSARCH.go"
-mksysnum=
-mktypes=
-run="sh"
-cmd=""
-
-case "$1" in
--syscalls)
- for i in zsyscall*go
- do
- # Run the command line that appears in the first line
- # of the generated file to regenerate it.
- sed 1q $i | sed 's;^// ;;' | sh > _$i && gofmt < _$i > $i
- rm _$i
- done
- exit 0
- ;;
--n)
- run="cat"
- cmd="echo"
- shift
-esac
-
-case "$#" in
-0)
- ;;
-*)
- echo 'usage: mkall.sh [-n]' 1>&2
- exit 2
-esac
-
-if [[ "$GOOS" = "linux" ]] && [[ "$GOARCH" != "sparc64" ]]; then
- # Use then new build system
- # Files generated through docker (use $cmd so you can Ctl-C the build or run)
- $cmd docker build --tag generate:$GOOS $GOOS
- $cmd docker run --interactive --tty --volume $(dirname "$(readlink -f "$0")"):/build generate:$GOOS
- exit
-fi
-
-GOOSARCH_in=syscall_$GOOSARCH.go
-case "$GOOSARCH" in
-_* | *_ | _)
- echo 'undefined $GOOS_$GOARCH:' "$GOOSARCH" 1>&2
- exit 1
- ;;
-darwin_386)
- mkerrors="$mkerrors -m32"
- mksyscall="./mksyscall.pl -l32"
- mksysnum="./mksysnum_darwin.pl $(xcrun --show-sdk-path --sdk macosx)/usr/include/sys/syscall.h"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-darwin_amd64)
- mkerrors="$mkerrors -m64"
- mksysnum="./mksysnum_darwin.pl $(xcrun --show-sdk-path --sdk macosx)/usr/include/sys/syscall.h"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-darwin_arm)
- mkerrors="$mkerrors"
- mksysnum="./mksysnum_darwin.pl /usr/include/sys/syscall.h"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-darwin_arm64)
- mkerrors="$mkerrors -m64"
- mksysnum="./mksysnum_darwin.pl $(xcrun --show-sdk-path --sdk iphoneos)/usr/include/sys/syscall.h"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-dragonfly_386)
- mkerrors="$mkerrors -m32"
- mksyscall="./mksyscall.pl -l32 -dragonfly"
- mksysnum="curl -s 'http://gitweb.dragonflybsd.org/dragonfly.git/blob_plain/HEAD:/sys/kern/syscalls.master' | ./mksysnum_dragonfly.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-dragonfly_amd64)
- mkerrors="$mkerrors -m64"
- mksyscall="./mksyscall.pl -dragonfly"
- mksysnum="curl -s 'http://gitweb.dragonflybsd.org/dragonfly.git/blob_plain/HEAD:/sys/kern/syscalls.master' | ./mksysnum_dragonfly.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-freebsd_386)
- mkerrors="$mkerrors -m32"
- mksyscall="./mksyscall.pl -l32"
- mksysnum="curl -s 'http://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master' | ./mksysnum_freebsd.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-freebsd_amd64)
- mkerrors="$mkerrors -m64"
- mksysnum="curl -s 'http://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master' | ./mksysnum_freebsd.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-freebsd_arm)
- mkerrors="$mkerrors"
- mksyscall="./mksyscall.pl -l32 -arm"
- mksysnum="curl -s 'http://svn.freebsd.org/base/stable/10/sys/kern/syscalls.master' | ./mksysnum_freebsd.pl"
- # Let the type of C char be signed for making the bare syscall
- # API consistent across over platforms.
- mktypes="GOARCH=$GOARCH go tool cgo -godefs -- -fsigned-char"
- ;;
-linux_sparc64)
- GOOSARCH_in=syscall_linux_sparc64.go
- unistd_h=/usr/include/sparc64-linux-gnu/asm/unistd.h
- mkerrors="$mkerrors -m64"
- mksysnum="./mksysnum_linux.pl $unistd_h"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-netbsd_386)
- mkerrors="$mkerrors -m32"
- mksyscall="./mksyscall.pl -l32 -netbsd"
- mksysnum="curl -s 'http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/src/sys/kern/syscalls.master' | ./mksysnum_netbsd.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-netbsd_amd64)
- mkerrors="$mkerrors -m64"
- mksyscall="./mksyscall.pl -netbsd"
- mksysnum="curl -s 'http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/src/sys/kern/syscalls.master' | ./mksysnum_netbsd.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-openbsd_386)
- mkerrors="$mkerrors -m32"
- mksyscall="./mksyscall.pl -l32 -openbsd"
- mksysctl="./mksysctl_openbsd.pl"
- zsysctl="zsysctl_openbsd.go"
- mksysnum="curl -s 'http://cvsweb.openbsd.org/cgi-bin/cvsweb/~checkout~/src/sys/kern/syscalls.master' | ./mksysnum_openbsd.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-openbsd_amd64)
- mkerrors="$mkerrors -m64"
- mksyscall="./mksyscall.pl -openbsd"
- mksysctl="./mksysctl_openbsd.pl"
- zsysctl="zsysctl_openbsd.go"
- mksysnum="curl -s 'http://cvsweb.openbsd.org/cgi-bin/cvsweb/~checkout~/src/sys/kern/syscalls.master' | ./mksysnum_openbsd.pl"
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-solaris_amd64)
- mksyscall="./mksyscall_solaris.pl"
- mkerrors="$mkerrors -m64"
- mksysnum=
- mktypes="GOARCH=$GOARCH go tool cgo -godefs"
- ;;
-*)
- echo 'unrecognized $GOOS_$GOARCH: ' "$GOOSARCH" 1>&2
- exit 1
- ;;
-esac
-
-(
- if [ -n "$mkerrors" ]; then echo "$mkerrors |gofmt >$zerrors"; fi
- case "$GOOS" in
- *)
- syscall_goos="syscall_$GOOS.go"
- case "$GOOS" in
- darwin | dragonfly | freebsd | netbsd | openbsd)
- syscall_goos="syscall_bsd.go $syscall_goos"
- ;;
- esac
- if [ -n "$mksyscall" ]; then echo "$mksyscall -tags $GOOS,$GOARCH $syscall_goos $GOOSARCH_in |gofmt >zsyscall_$GOOSARCH.go"; fi
- ;;
- esac
- if [ -n "$mksysctl" ]; then echo "$mksysctl |gofmt >$zsysctl"; fi
- if [ -n "$mksysnum" ]; then echo "$mksysnum |gofmt >zsysnum_$GOOSARCH.go"; fi
- if [ -n "$mktypes" ]; then
- echo "$mktypes types_$GOOS.go | go run mkpost.go > ztypes_$GOOSARCH.go";
- fi
-) | $run
diff --git a/vendor/golang.org/x/sys/unix/mkerrors.sh b/vendor/golang.org/x/sys/unix/mkerrors.sh
deleted file mode 100644
index 1bd1c9e6e..000000000
--- a/vendor/golang.org/x/sys/unix/mkerrors.sh
+++ /dev/null
@@ -1,545 +0,0 @@
-#!/usr/bin/env bash
-# Copyright 2009 The Go Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-# Generate Go code listing errors and other #defined constant
-# values (ENAMETOOLONG etc.), by asking the preprocessor
-# about the definitions.
-
-unset LANG
-export LC_ALL=C
-export LC_CTYPE=C
-
-if test -z "$GOARCH" -o -z "$GOOS"; then
- echo 1>&2 "GOARCH or GOOS not defined in environment"
- exit 1
-fi
-
-# Check that we are using the new build system if we should
-if [[ "$GOOS" -eq "linux" ]] && [[ "$GOARCH" != "sparc64" ]]; then
- if [[ "$GOLANG_SYS_BUILD" -ne "docker" ]]; then
- echo 1>&2 "In the new build system, mkerrors should not be called directly."
- echo 1>&2 "See README.md"
- exit 1
- fi
-fi
-
-CC=${CC:-cc}
-
-if [[ "$GOOS" -eq "solaris" ]]; then
- # Assumes GNU versions of utilities in PATH.
- export PATH=/usr/gnu/bin:$PATH
-fi
-
-uname=$(uname)
-
-includes_Darwin='
-#define _DARWIN_C_SOURCE
-#define KERNEL
-#define _DARWIN_USE_64_BIT_INODE
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-'
-
-includes_DragonFly='
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-'
-
-includes_FreeBSD='
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-#if __FreeBSD__ >= 10
-#define IFT_CARP 0xf8 // IFT_CARP is deprecated in FreeBSD 10
-#undef SIOCAIFADDR
-#define SIOCAIFADDR _IOW(105, 26, struct oifaliasreq) // ifaliasreq contains if_data
-#undef SIOCSIFPHYADDR
-#define SIOCSIFPHYADDR _IOW(105, 70, struct oifaliasreq) // ifaliasreq contains if_data
-#endif
-'
-
-includes_Linux='
-#define _LARGEFILE_SOURCE
-#define _LARGEFILE64_SOURCE
-#ifndef __LP64__
-#define _FILE_OFFSET_BITS 64
-#endif
-#define _GNU_SOURCE
-
-// is broken on powerpc64, as it fails to include definitions of
-// these structures. We just include them copied from .
-#if defined(__powerpc__)
-struct sgttyb {
- char sg_ispeed;
- char sg_ospeed;
- char sg_erase;
- char sg_kill;
- short sg_flags;
-};
-
-struct tchars {
- char t_intrc;
- char t_quitc;
- char t_startc;
- char t_stopc;
- char t_eofc;
- char t_brkc;
-};
-
-struct ltchars {
- char t_suspc;
- char t_dsuspc;
- char t_rprntc;
- char t_flushc;
- char t_werasc;
- char t_lnextc;
-};
-#endif
-
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-#ifndef MSG_FASTOPEN
-#define MSG_FASTOPEN 0x20000000
-#endif
-
-#ifndef PTRACE_GETREGS
-#define PTRACE_GETREGS 0xc
-#endif
-
-#ifndef PTRACE_SETREGS
-#define PTRACE_SETREGS 0xd
-#endif
-
-#ifndef SOL_NETLINK
-#define SOL_NETLINK 270
-#endif
-
-#ifdef SOL_BLUETOOTH
-// SPARC includes this in /usr/include/sparc64-linux-gnu/bits/socket.h
-// but it is already in bluetooth_linux.go
-#undef SOL_BLUETOOTH
-#endif
-
-// Certain constants are missing from the fs/crypto UAPI
-#define FS_KEY_DESC_PREFIX "fscrypt:"
-#define FS_KEY_DESC_PREFIX_SIZE 8
-#define FS_MAX_KEY_SIZE 64
-'
-
-includes_NetBSD='
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-// Needed since refers to it...
-#define schedppq 1
-'
-
-includes_OpenBSD='
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-// We keep some constants not supported in OpenBSD 5.5 and beyond for
-// the promise of compatibility.
-#define EMUL_ENABLED 0x1
-#define EMUL_NATIVE 0x2
-#define IPV6_FAITH 0x1d
-#define IPV6_OPTIONS 0x1
-#define IPV6_RTHDR_STRICT 0x1
-#define IPV6_SOCKOPT_RESERVED1 0x3
-#define SIOCGIFGENERIC 0xc020693a
-#define SIOCSIFGENERIC 0x80206939
-#define WALTSIG 0x4
-'
-
-includes_SunOS='
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-'
-
-
-includes='
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-'
-ccflags="$@"
-
-# Write go tool cgo -godefs input.
-(
- echo package unix
- echo
- echo '/*'
- indirect="includes_$(uname)"
- echo "${!indirect} $includes"
- echo '*/'
- echo 'import "C"'
- echo 'import "syscall"'
- echo
- echo 'const ('
-
- # The gcc command line prints all the #defines
- # it encounters while processing the input
- echo "${!indirect} $includes" | $CC -x c - -E -dM $ccflags |
- awk '
- $1 != "#define" || $2 ~ /\(/ || $3 == "" {next}
-
- $2 ~ /^E([ABCD]X|[BIS]P|[SD]I|S|FL)$/ {next} # 386 registers
- $2 ~ /^(SIGEV_|SIGSTKSZ|SIGRT(MIN|MAX))/ {next}
- $2 ~ /^(SCM_SRCRT)$/ {next}
- $2 ~ /^(MAP_FAILED)$/ {next}
- $2 ~ /^ELF_.*$/ {next}# contains ELF_ARCH, etc.
-
- $2 ~ /^EXTATTR_NAMESPACE_NAMES/ ||
- $2 ~ /^EXTATTR_NAMESPACE_[A-Z]+_STRING/ {next}
-
- $2 !~ /^ETH_/ &&
- $2 !~ /^EPROC_/ &&
- $2 !~ /^EQUIV_/ &&
- $2 !~ /^EXPR_/ &&
- $2 ~ /^E[A-Z0-9_]+$/ ||
- $2 ~ /^B[0-9_]+$/ ||
- $2 == "BOTHER" ||
- $2 ~ /^CI?BAUD(EX)?$/ ||
- $2 == "IBSHIFT" ||
- $2 ~ /^V[A-Z0-9]+$/ ||
- $2 ~ /^CS[A-Z0-9]/ ||
- $2 ~ /^I(SIG|CANON|CRNL|UCLC|EXTEN|MAXBEL|STRIP|UTF8)$/ ||
- $2 ~ /^IGN/ ||
- $2 ~ /^IX(ON|ANY|OFF)$/ ||
- $2 ~ /^IN(LCR|PCK)$/ ||
- $2 ~ /(^FLU?SH)|(FLU?SH$)/ ||
- $2 ~ /^C(LOCAL|READ|MSPAR|RTSCTS)$/ ||
- $2 == "BRKINT" ||
- $2 == "HUPCL" ||
- $2 == "PENDIN" ||
- $2 == "TOSTOP" ||
- $2 == "XCASE" ||
- $2 == "ALTWERASE" ||
- $2 == "NOKERNINFO" ||
- $2 ~ /^PAR/ ||
- $2 ~ /^SIG[^_]/ ||
- $2 ~ /^O[CNPFPL][A-Z]+[^_][A-Z]+$/ ||
- $2 ~ /^(NL|CR|TAB|BS|VT|FF)DLY$/ ||
- $2 ~ /^(NL|CR|TAB|BS|VT|FF)[0-9]$/ ||
- $2 ~ /^O?XTABS$/ ||
- $2 ~ /^TC[IO](ON|OFF)$/ ||
- $2 ~ /^IN_/ ||
- $2 ~ /^LOCK_(SH|EX|NB|UN)$/ ||
- $2 ~ /^(AF|SOCK|SO|SOL|IPPROTO|IP|IPV6|ICMP6|TCP|EVFILT|NOTE|EV|SHUT|PROT|MAP|PACKET|MSG|SCM|MCL|DT|MADV|PR)_/ ||
- $2 ~ /^FALLOC_/ ||
- $2 == "ICMPV6_FILTER" ||
- $2 == "SOMAXCONN" ||
- $2 == "NAME_MAX" ||
- $2 == "IFNAMSIZ" ||
- $2 ~ /^CTL_(MAXNAME|NET|QUERY)$/ ||
- $2 ~ /^SYSCTL_VERS/ ||
- $2 ~ /^(MS|MNT)_/ ||
- $2 ~ /^TUN(SET|GET|ATTACH|DETACH)/ ||
- $2 ~ /^(O|F|FD|NAME|S|PTRACE|PT)_/ ||
- $2 ~ /^LINUX_REBOOT_CMD_/ ||
- $2 ~ /^LINUX_REBOOT_MAGIC[12]$/ ||
- $2 !~ "NLA_TYPE_MASK" &&
- $2 ~ /^(NETLINK|NLM|NLMSG|NLA|IFA|IFAN|RT|RTCF|RTN|RTPROT|RTNH|ARPHRD|ETH_P)_/ ||
- $2 ~ /^SIOC/ ||
- $2 ~ /^TIOC/ ||
- $2 ~ /^TCGET/ ||
- $2 ~ /^TCSET/ ||
- $2 ~ /^TC(FLSH|SBRKP?|XONC)$/ ||
- $2 !~ "RTF_BITS" &&
- $2 ~ /^(IFF|IFT|NET_RT|RTM|RTF|RTV|RTA|RTAX)_/ ||
- $2 ~ /^BIOC/ ||
- $2 ~ /^RUSAGE_(SELF|CHILDREN|THREAD)/ ||
- $2 ~ /^RLIMIT_(AS|CORE|CPU|DATA|FSIZE|NOFILE|STACK)|RLIM_INFINITY/ ||
- $2 ~ /^PRIO_(PROCESS|PGRP|USER)/ ||
- $2 ~ /^CLONE_[A-Z_]+/ ||
- $2 !~ /^(BPF_TIMEVAL)$/ &&
- $2 ~ /^(BPF|DLT)_/ ||
- $2 ~ /^CLOCK_/ ||
- $2 ~ /^CAN_/ ||
- $2 ~ /^ALG_/ ||
- $2 ~ /^FS_(POLICY_FLAGS|KEY_DESC|ENCRYPTION_MODE|[A-Z0-9_]+_KEY_SIZE|IOC_(GET|SET)_ENCRYPTION)/ ||
- $2 ~ /^GRND_/ ||
- $2 ~ /^SPLICE_/ ||
- $2 ~ /^(VM|VMADDR)_/ ||
- $2 !~ "WMESGLEN" &&
- $2 ~ /^W[A-Z0-9]+$/ ||
- $2 ~ /^BLK[A-Z]*(GET$|SET$|BUF$|PART$|SIZE)/ {printf("\t%s = C.%s\n", $2, $2)}
- $2 ~ /^__WCOREFLAG$/ {next}
- $2 ~ /^__W[A-Z0-9]+$/ {printf("\t%s = C.%s\n", substr($2,3), $2)}
-
- {next}
- ' | sort
-
- echo ')'
-) >_const.go
-
-# Pull out the error names for later.
-errors=$(
- echo '#include ' | $CC -x c - -E -dM $ccflags |
- awk '$1=="#define" && $2 ~ /^E[A-Z0-9_]+$/ { print $2 }' |
- sort
-)
-
-# Pull out the signal names for later.
-signals=$(
- echo '#include ' | $CC -x c - -E -dM $ccflags |
- awk '$1=="#define" && $2 ~ /^SIG[A-Z0-9]+$/ { print $2 }' |
- egrep -v '(SIGSTKSIZE|SIGSTKSZ|SIGRT)' |
- sort
-)
-
-# Again, writing regexps to a file.
-echo '#include ' | $CC -x c - -E -dM $ccflags |
- awk '$1=="#define" && $2 ~ /^E[A-Z0-9_]+$/ { print "^\t" $2 "[ \t]*=" }' |
- sort >_error.grep
-echo '#include ' | $CC -x c - -E -dM $ccflags |
- awk '$1=="#define" && $2 ~ /^SIG[A-Z0-9]+$/ { print "^\t" $2 "[ \t]*=" }' |
- egrep -v '(SIGSTKSIZE|SIGSTKSZ|SIGRT)' |
- sort >_signal.grep
-
-echo '// mkerrors.sh' "$@"
-echo '// Code generated by the command above; see README.md. DO NOT EDIT.'
-echo
-echo "// +build ${GOARCH},${GOOS}"
-echo
-go tool cgo -godefs -- "$@" _const.go >_error.out
-cat _error.out | grep -vf _error.grep | grep -vf _signal.grep
-echo
-echo '// Errors'
-echo 'const ('
-cat _error.out | grep -f _error.grep | sed 's/=\(.*\)/= syscall.Errno(\1)/'
-echo ')'
-
-echo
-echo '// Signals'
-echo 'const ('
-cat _error.out | grep -f _signal.grep | sed 's/=\(.*\)/= syscall.Signal(\1)/'
-echo ')'
-
-# Run C program to print error and syscall strings.
-(
- echo -E "
-#include
-#include
-#include
-#include
-#include
-#include
-
-#define nelem(x) (sizeof(x)/sizeof((x)[0]))
-
-enum { A = 'A', Z = 'Z', a = 'a', z = 'z' }; // avoid need for single quotes below
-
-int errors[] = {
-"
- for i in $errors
- do
- echo -E ' '$i,
- done
-
- echo -E "
-};
-
-int signals[] = {
-"
- for i in $signals
- do
- echo -E ' '$i,
- done
-
- # Use -E because on some systems bash builtin interprets \n itself.
- echo -E '
-};
-
-static int
-intcmp(const void *a, const void *b)
-{
- return *(int*)a - *(int*)b;
-}
-
-int
-main(void)
-{
- int i, e;
- char buf[1024], *p;
-
- printf("\n\n// Error table\n");
- printf("var errors = [...]string {\n");
- qsort(errors, nelem(errors), sizeof errors[0], intcmp);
- for(i=0; i 0 && errors[i-1] == e)
- continue;
- strcpy(buf, strerror(e));
- // lowercase first letter: Bad -> bad, but STREAM -> STREAM.
- if(A <= buf[0] && buf[0] <= Z && a <= buf[1] && buf[1] <= z)
- buf[0] += a - A;
- printf("\t%d: \"%s\",\n", e, buf);
- }
- printf("}\n\n");
-
- printf("\n\n// Signal table\n");
- printf("var signals = [...]string {\n");
- qsort(signals, nelem(signals), sizeof signals[0], intcmp);
- for(i=0; i 0 && signals[i-1] == e)
- continue;
- strcpy(buf, strsignal(e));
- // lowercase first letter: Bad -> bad, but STREAM -> STREAM.
- if(A <= buf[0] && buf[0] <= Z && a <= buf[1] && buf[1] <= z)
- buf[0] += a - A;
- // cut trailing : number.
- p = strrchr(buf, ":"[0]);
- if(p)
- *p = '\0';
- printf("\t%d: \"%s\",\n", e, buf);
- }
- printf("}\n\n");
-
- return 0;
-}
-
-'
-) >_errors.c
-
-$CC $ccflags -o _errors _errors.c && $GORUN ./_errors && rm -f _errors.c _errors _const.go _error.grep _signal.grep _error.out
diff --git a/vendor/golang.org/x/sys/unix/mkpost.go b/vendor/golang.org/x/sys/unix/mkpost.go
deleted file mode 100644
index d3ff659bb..000000000
--- a/vendor/golang.org/x/sys/unix/mkpost.go
+++ /dev/null
@@ -1,88 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build ignore
-
-// mkpost processes the output of cgo -godefs to
-// modify the generated types. It is used to clean up
-// the sys API in an architecture specific manner.
-//
-// mkpost is run after cgo -godefs; see README.md.
-package main
-
-import (
- "bytes"
- "fmt"
- "go/format"
- "io/ioutil"
- "log"
- "os"
- "regexp"
-)
-
-func main() {
- // Get the OS and architecture (using GOARCH_TARGET if it exists)
- goos := os.Getenv("GOOS")
- goarch := os.Getenv("GOARCH_TARGET")
- if goarch == "" {
- goarch = os.Getenv("GOARCH")
- }
- // Check that we are using the new build system if we should be.
- if goos == "linux" && goarch != "sparc64" {
- if os.Getenv("GOLANG_SYS_BUILD") != "docker" {
- os.Stderr.WriteString("In the new build system, mkpost should not be called directly.\n")
- os.Stderr.WriteString("See README.md\n")
- os.Exit(1)
- }
- }
-
- b, err := ioutil.ReadAll(os.Stdin)
- if err != nil {
- log.Fatal(err)
- }
-
- // If we have empty Ptrace structs, we should delete them. Only s390x emits
- // nonempty Ptrace structs.
- ptraceRexexp := regexp.MustCompile(`type Ptrace((Psw|Fpregs|Per) struct {\s*})`)
- b = ptraceRexexp.ReplaceAll(b, nil)
-
- // Replace the control_regs union with a blank identifier for now.
- controlRegsRegex := regexp.MustCompile(`(Control_regs)\s+\[0\]uint64`)
- b = controlRegsRegex.ReplaceAll(b, []byte("_ [0]uint64"))
-
- // Remove fields that are added by glibc
- // Note that this is unstable as the identifers are private.
- removeFieldsRegex := regexp.MustCompile(`X__glibc\S*`)
- b = removeFieldsRegex.ReplaceAll(b, []byte("_"))
-
- // We refuse to export private fields on s390x
- if goarch == "s390x" && goos == "linux" {
- // Remove cgo padding fields
- removeFieldsRegex := regexp.MustCompile(`Pad_cgo_\d+`)
- b = removeFieldsRegex.ReplaceAll(b, []byte("_"))
-
- // Remove padding, hidden, or unused fields
- removeFieldsRegex = regexp.MustCompile(`X_\S+`)
- b = removeFieldsRegex.ReplaceAll(b, []byte("_"))
- }
-
- // Remove the first line of warning from cgo
- b = b[bytes.IndexByte(b, '\n')+1:]
- // Modify the command in the header to include:
- // mkpost, our own warning, and a build tag.
- replacement := fmt.Sprintf(`$1 | go run mkpost.go
-// Code generated by the command above; see README.md. DO NOT EDIT.
-
-// +build %s,%s`, goarch, goos)
- cgoCommandRegex := regexp.MustCompile(`(cgo -godefs .*)`)
- b = cgoCommandRegex.ReplaceAll(b, []byte(replacement))
-
- // gofmt
- b, err = format.Source(b)
- if err != nil {
- log.Fatal(err)
- }
-
- os.Stdout.Write(b)
-}
diff --git a/vendor/golang.org/x/sys/unix/mksyscall.pl b/vendor/golang.org/x/sys/unix/mksyscall.pl
deleted file mode 100644
index fb929b4ce..000000000
--- a/vendor/golang.org/x/sys/unix/mksyscall.pl
+++ /dev/null
@@ -1,328 +0,0 @@
-#!/usr/bin/env perl
-# Copyright 2009 The Go Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style
-# license that can be found in the LICENSE file.
-
-# This program reads a file containing function prototypes
-# (like syscall_darwin.go) and generates system call bodies.
-# The prototypes are marked by lines beginning with "//sys"
-# and read like func declarations if //sys is replaced by func, but:
-# * The parameter lists must give a name for each argument.
-# This includes return parameters.
-# * The parameter lists must give a type for each argument:
-# the (x, y, z int) shorthand is not allowed.
-# * If the return parameter is an error number, it must be named errno.
-
-# A line beginning with //sysnb is like //sys, except that the
-# goroutine will not be suspended during the execution of the system
-# call. This must only be used for system calls which can never
-# block, as otherwise the system call could cause all goroutines to
-# hang.
-
-use strict;
-
-my $cmdline = "mksyscall.pl " . join(' ', @ARGV);
-my $errors = 0;
-my $_32bit = "";
-my $plan9 = 0;
-my $openbsd = 0;
-my $netbsd = 0;
-my $dragonfly = 0;
-my $arm = 0; # 64-bit value should use (even, odd)-pair
-my $tags = ""; # build tags
-
-if($ARGV[0] eq "-b32") {
- $_32bit = "big-endian";
- shift;
-} elsif($ARGV[0] eq "-l32") {
- $_32bit = "little-endian";
- shift;
-}
-if($ARGV[0] eq "-plan9") {
- $plan9 = 1;
- shift;
-}
-if($ARGV[0] eq "-openbsd") {
- $openbsd = 1;
- shift;
-}
-if($ARGV[0] eq "-netbsd") {
- $netbsd = 1;
- shift;
-}
-if($ARGV[0] eq "-dragonfly") {
- $dragonfly = 1;
- shift;
-}
-if($ARGV[0] eq "-arm") {
- $arm = 1;
- shift;
-}
-if($ARGV[0] eq "-tags") {
- shift;
- $tags = $ARGV[0];
- shift;
-}
-
-if($ARGV[0] =~ /^-/) {
- print STDERR "usage: mksyscall.pl [-b32 | -l32] [-tags x,y] [file ...]\n";
- exit 1;
-}
-
-# Check that we are using the new build system if we should
-if($ENV{'GOOS'} eq "linux" && $ENV{'GOARCH'} ne "sparc64") {
- if($ENV{'GOLANG_SYS_BUILD'} ne "docker") {
- print STDERR "In the new build system, mksyscall should not be called directly.\n";
- print STDERR "See README.md\n";
- exit 1;
- }
-}
-
-
-sub parseparamlist($) {
- my ($list) = @_;
- $list =~ s/^\s*//;
- $list =~ s/\s*$//;
- if($list eq "") {
- return ();
- }
- return split(/\s*,\s*/, $list);
-}
-
-sub parseparam($) {
- my ($p) = @_;
- if($p !~ /^(\S*) (\S*)$/) {
- print STDERR "$ARGV:$.: malformed parameter: $p\n";
- $errors = 1;
- return ("xx", "int");
- }
- return ($1, $2);
-}
-
-my $text = "";
-while(<>) {
- chomp;
- s/\s+/ /g;
- s/^\s+//;
- s/\s+$//;
- my $nonblock = /^\/\/sysnb /;
- next if !/^\/\/sys / && !$nonblock;
-
- # Line must be of the form
- # func Open(path string, mode int, perm int) (fd int, errno error)
- # Split into name, in params, out params.
- if(!/^\/\/sys(nb)? (\w+)\(([^()]*)\)\s*(?:\(([^()]+)\))?\s*(?:=\s*((?i)SYS_[A-Z0-9_]+))?$/) {
- print STDERR "$ARGV:$.: malformed //sys declaration\n";
- $errors = 1;
- next;
- }
- my ($func, $in, $out, $sysname) = ($2, $3, $4, $5);
-
- # Split argument lists on comma.
- my @in = parseparamlist($in);
- my @out = parseparamlist($out);
-
- # Try in vain to keep people from editing this file.
- # The theory is that they jump into the middle of the file
- # without reading the header.
- $text .= "// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT\n\n";
-
- # Go function header.
- my $out_decl = @out ? sprintf(" (%s)", join(', ', @out)) : "";
- $text .= sprintf "func %s(%s)%s {\n", $func, join(', ', @in), $out_decl;
-
- # Check if err return available
- my $errvar = "";
- foreach my $p (@out) {
- my ($name, $type) = parseparam($p);
- if($type eq "error") {
- $errvar = $name;
- last;
- }
- }
-
- # Prepare arguments to Syscall.
- my @args = ();
- my $n = 0;
- foreach my $p (@in) {
- my ($name, $type) = parseparam($p);
- if($type =~ /^\*/) {
- push @args, "uintptr(unsafe.Pointer($name))";
- } elsif($type eq "string" && $errvar ne "") {
- $text .= "\tvar _p$n *byte\n";
- $text .= "\t_p$n, $errvar = BytePtrFromString($name)\n";
- $text .= "\tif $errvar != nil {\n\t\treturn\n\t}\n";
- push @args, "uintptr(unsafe.Pointer(_p$n))";
- $n++;
- } elsif($type eq "string") {
- print STDERR "$ARGV:$.: $func uses string arguments, but has no error return\n";
- $text .= "\tvar _p$n *byte\n";
- $text .= "\t_p$n, _ = BytePtrFromString($name)\n";
- push @args, "uintptr(unsafe.Pointer(_p$n))";
- $n++;
- } elsif($type =~ /^\[\](.*)/) {
- # Convert slice into pointer, length.
- # Have to be careful not to take address of &a[0] if len == 0:
- # pass dummy pointer in that case.
- # Used to pass nil, but some OSes or simulators reject write(fd, nil, 0).
- $text .= "\tvar _p$n unsafe.Pointer\n";
- $text .= "\tif len($name) > 0 {\n\t\t_p$n = unsafe.Pointer(\&${name}[0])\n\t}";
- $text .= " else {\n\t\t_p$n = unsafe.Pointer(&_zero)\n\t}";
- $text .= "\n";
- push @args, "uintptr(_p$n)", "uintptr(len($name))";
- $n++;
- } elsif($type eq "int64" && ($openbsd || $netbsd)) {
- push @args, "0";
- if($_32bit eq "big-endian") {
- push @args, "uintptr($name>>32)", "uintptr($name)";
- } elsif($_32bit eq "little-endian") {
- push @args, "uintptr($name)", "uintptr($name>>32)";
- } else {
- push @args, "uintptr($name)";
- }
- } elsif($type eq "int64" && $dragonfly) {
- if ($func !~ /^extp(read|write)/i) {
- push @args, "0";
- }
- if($_32bit eq "big-endian") {
- push @args, "uintptr($name>>32)", "uintptr($name)";
- } elsif($_32bit eq "little-endian") {
- push @args, "uintptr($name)", "uintptr($name>>32)";
- } else {
- push @args, "uintptr($name)";
- }
- } elsif($type eq "int64" && $_32bit ne "") {
- if(@args % 2 && $arm) {
- # arm abi specifies 64-bit argument uses
- # (even, odd) pair
- push @args, "0"
- }
- if($_32bit eq "big-endian") {
- push @args, "uintptr($name>>32)", "uintptr($name)";
- } else {
- push @args, "uintptr($name)", "uintptr($name>>32)";
- }
- } else {
- push @args, "uintptr($name)";
- }
- }
-
- # Determine which form to use; pad args with zeros.
- my $asm = "Syscall";
- if ($nonblock) {
- $asm = "RawSyscall";
- }
- if(@args <= 3) {
- while(@args < 3) {
- push @args, "0";
- }
- } elsif(@args <= 6) {
- $asm .= "6";
- while(@args < 6) {
- push @args, "0";
- }
- } elsif(@args <= 9) {
- $asm .= "9";
- while(@args < 9) {
- push @args, "0";
- }
- } else {
- print STDERR "$ARGV:$.: too many arguments to system call\n";
- }
-
- # System call number.
- if($sysname eq "") {
- $sysname = "SYS_$func";
- $sysname =~ s/([a-z])([A-Z])/${1}_$2/g; # turn FooBar into Foo_Bar
- $sysname =~ y/a-z/A-Z/;
- }
-
- # Actual call.
- my $args = join(', ', @args);
- my $call = "$asm($sysname, $args)";
-
- # Assign return values.
- my $body = "";
- my @ret = ("_", "_", "_");
- my $do_errno = 0;
- for(my $i=0; $i<@out; $i++) {
- my $p = $out[$i];
- my ($name, $type) = parseparam($p);
- my $reg = "";
- if($name eq "err" && !$plan9) {
- $reg = "e1";
- $ret[2] = $reg;
- $do_errno = 1;
- } elsif($name eq "err" && $plan9) {
- $ret[0] = "r0";
- $ret[2] = "e1";
- next;
- } else {
- $reg = sprintf("r%d", $i);
- $ret[$i] = $reg;
- }
- if($type eq "bool") {
- $reg = "$reg != 0";
- }
- if($type eq "int64" && $_32bit ne "") {
- # 64-bit number in r1:r0 or r0:r1.
- if($i+2 > @out) {
- print STDERR "$ARGV:$.: not enough registers for int64 return\n";
- }
- if($_32bit eq "big-endian") {
- $reg = sprintf("int64(r%d)<<32 | int64(r%d)", $i, $i+1);
- } else {
- $reg = sprintf("int64(r%d)<<32 | int64(r%d)", $i+1, $i);
- }
- $ret[$i] = sprintf("r%d", $i);
- $ret[$i+1] = sprintf("r%d", $i+1);
- }
- if($reg ne "e1" || $plan9) {
- $body .= "\t$name = $type($reg)\n";
- }
- }
- if ($ret[0] eq "_" && $ret[1] eq "_" && $ret[2] eq "_") {
- $text .= "\t$call\n";
- } else {
- $text .= "\t$ret[0], $ret[1], $ret[2] := $call\n";
- }
- $text .= $body;
-
- if ($plan9 && $ret[2] eq "e1") {
- $text .= "\tif int32(r0) == -1 {\n";
- $text .= "\t\terr = e1\n";
- $text .= "\t}\n";
- } elsif ($do_errno) {
- $text .= "\tif e1 != 0 {\n";
- $text .= "\t\terr = errnoErr(e1)\n";
- $text .= "\t}\n";
- }
- $text .= "\treturn\n";
- $text .= "}\n\n";
-}
-
-chomp $text;
-chomp $text;
-
-if($errors) {
- exit 1;
-}
-
-print <) {
- chomp;
- s/\s+/ /g;
- s/^\s+//;
- s/\s+$//;
- $package = $1 if !$package && /^package (\S+)$/;
- my $nonblock = /^\/\/sysnb /;
- next if !/^\/\/sys / && !$nonblock;
-
- # Line must be of the form
- # func Open(path string, mode int, perm int) (fd int, err error)
- # Split into name, in params, out params.
- if(!/^\/\/sys(nb)? (\w+)\(([^()]*)\)\s*(?:\(([^()]+)\))?\s*(?:=\s*(?:(\w*)\.)?(\w*))?$/) {
- print STDERR "$ARGV:$.: malformed //sys declaration\n";
- $errors = 1;
- next;
- }
- my ($nb, $func, $in, $out, $modname, $sysname) = ($1, $2, $3, $4, $5, $6);
-
- # Split argument lists on comma.
- my @in = parseparamlist($in);
- my @out = parseparamlist($out);
-
- # So file name.
- if($modname eq "") {
- $modname = "libc";
- }
-
- # System call name.
- if($sysname eq "") {
- $sysname = "$func";
- }
-
- # System call pointer variable name.
- my $sysvarname = "proc$sysname";
-
- my $strconvfunc = "BytePtrFromString";
- my $strconvtype = "*byte";
-
- $sysname =~ y/A-Z/a-z/; # All libc functions are lowercase.
-
- # Runtime import of function to allow cross-platform builds.
- $dynimports .= "//go:cgo_import_dynamic libc_${sysname} ${sysname} \"$modname.so\"\n";
- # Link symbol to proc address variable.
- $linknames .= "//go:linkname ${sysvarname} libc_${sysname}\n";
- # Library proc address variable.
- push @vars, $sysvarname;
-
- # Go function header.
- $out = join(', ', @out);
- if($out ne "") {
- $out = " ($out)";
- }
- if($text ne "") {
- $text .= "\n"
- }
- $text .= sprintf "func %s(%s)%s {\n", $func, join(', ', @in), $out;
-
- # Check if err return available
- my $errvar = "";
- foreach my $p (@out) {
- my ($name, $type) = parseparam($p);
- if($type eq "error") {
- $errvar = $name;
- last;
- }
- }
-
- # Prepare arguments to Syscall.
- my @args = ();
- my $n = 0;
- foreach my $p (@in) {
- my ($name, $type) = parseparam($p);
- if($type =~ /^\*/) {
- push @args, "uintptr(unsafe.Pointer($name))";
- } elsif($type eq "string" && $errvar ne "") {
- $text .= "\tvar _p$n $strconvtype\n";
- $text .= "\t_p$n, $errvar = $strconvfunc($name)\n";
- $text .= "\tif $errvar != nil {\n\t\treturn\n\t}\n";
- push @args, "uintptr(unsafe.Pointer(_p$n))";
- $n++;
- } elsif($type eq "string") {
- print STDERR "$ARGV:$.: $func uses string arguments, but has no error return\n";
- $text .= "\tvar _p$n $strconvtype\n";
- $text .= "\t_p$n, _ = $strconvfunc($name)\n";
- push @args, "uintptr(unsafe.Pointer(_p$n))";
- $n++;
- } elsif($type =~ /^\[\](.*)/) {
- # Convert slice into pointer, length.
- # Have to be careful not to take address of &a[0] if len == 0:
- # pass nil in that case.
- $text .= "\tvar _p$n *$1\n";
- $text .= "\tif len($name) > 0 {\n\t\t_p$n = \&$name\[0]\n\t}\n";
- push @args, "uintptr(unsafe.Pointer(_p$n))", "uintptr(len($name))";
- $n++;
- } elsif($type eq "int64" && $_32bit ne "") {
- if($_32bit eq "big-endian") {
- push @args, "uintptr($name >> 32)", "uintptr($name)";
- } else {
- push @args, "uintptr($name)", "uintptr($name >> 32)";
- }
- } elsif($type eq "bool") {
- $text .= "\tvar _p$n uint32\n";
- $text .= "\tif $name {\n\t\t_p$n = 1\n\t} else {\n\t\t_p$n = 0\n\t}\n";
- push @args, "uintptr(_p$n)";
- $n++;
- } else {
- push @args, "uintptr($name)";
- }
- }
- my $nargs = @args;
-
- # Determine which form to use; pad args with zeros.
- my $asm = "sysvicall6";
- if ($nonblock) {
- $asm = "rawSysvicall6";
- }
- if(@args <= 6) {
- while(@args < 6) {
- push @args, "0";
- }
- } else {
- print STDERR "$ARGV:$.: too many arguments to system call\n";
- }
-
- # Actual call.
- my $args = join(', ', @args);
- my $call = "$asm(uintptr(unsafe.Pointer(&$sysvarname)), $nargs, $args)";
-
- # Assign return values.
- my $body = "";
- my $failexpr = "";
- my @ret = ("_", "_", "_");
- my @pout= ();
- my $do_errno = 0;
- for(my $i=0; $i<@out; $i++) {
- my $p = $out[$i];
- my ($name, $type) = parseparam($p);
- my $reg = "";
- if($name eq "err") {
- $reg = "e1";
- $ret[2] = $reg;
- $do_errno = 1;
- } else {
- $reg = sprintf("r%d", $i);
- $ret[$i] = $reg;
- }
- if($type eq "bool") {
- $reg = "$reg != 0";
- }
- if($type eq "int64" && $_32bit ne "") {
- # 64-bit number in r1:r0 or r0:r1.
- if($i+2 > @out) {
- print STDERR "$ARGV:$.: not enough registers for int64 return\n";
- }
- if($_32bit eq "big-endian") {
- $reg = sprintf("int64(r%d)<<32 | int64(r%d)", $i, $i+1);
- } else {
- $reg = sprintf("int64(r%d)<<32 | int64(r%d)", $i+1, $i);
- }
- $ret[$i] = sprintf("r%d", $i);
- $ret[$i+1] = sprintf("r%d", $i+1);
- }
- if($reg ne "e1") {
- $body .= "\t$name = $type($reg)\n";
- }
- }
- if ($ret[0] eq "_" && $ret[1] eq "_" && $ret[2] eq "_") {
- $text .= "\t$call\n";
- } else {
- $text .= "\t$ret[0], $ret[1], $ret[2] := $call\n";
- }
- $text .= $body;
-
- if ($do_errno) {
- $text .= "\tif e1 != 0 {\n";
- $text .= "\t\terr = e1\n";
- $text .= "\t}\n";
- }
- $text .= "\treturn\n";
- $text .= "}\n";
-}
-
-if($errors) {
- exit 1;
-}
-
-print < "net.inet",
- "net.inet.ipproto" => "net.inet",
- "net.inet6.ipv6proto" => "net.inet6",
- "net.inet6.ipv6" => "net.inet6.ip6",
- "net.inet.icmpv6" => "net.inet6.icmp6",
- "net.inet6.divert6" => "net.inet6.divert",
- "net.inet6.tcp6" => "net.inet.tcp",
- "net.inet6.udp6" => "net.inet.udp",
- "mpls" => "net.mpls",
- "swpenc" => "vm.swapencrypt"
-);
-
-# Node mappings
-my %node_map = (
- "net.inet.ip.ifq" => "net.ifq",
- "net.inet.pfsync" => "net.pfsync",
- "net.mpls.ifq" => "net.ifq"
-);
-
-my $ctlname;
-my %mib = ();
-my %sysctl = ();
-my $node;
-
-sub debug() {
- print STDERR "$_[0]\n" if $debug;
-}
-
-# Walk the MIB and build a sysctl name to OID mapping.
-sub build_sysctl() {
- my ($node, $name, $oid) = @_;
- my %node = %{$node};
- my @oid = @{$oid};
-
- foreach my $key (sort keys %node) {
- my @node = @{$node{$key}};
- my $nodename = $name.($name ne '' ? '.' : '').$key;
- my @nodeoid = (@oid, $node[0]);
- if ($node[1] eq 'CTLTYPE_NODE') {
- if (exists $node_map{$nodename}) {
- $node = \%mib;
- $ctlname = $node_map{$nodename};
- foreach my $part (split /\./, $ctlname) {
- $node = \%{@{$$node{$part}}[2]};
- }
- } else {
- $node = $node[2];
- }
- &build_sysctl($node, $nodename, \@nodeoid);
- } elsif ($node[1] ne '') {
- $sysctl{$nodename} = \@nodeoid;
- }
- }
-}
-
-foreach my $ctl (@ctls) {
- $ctls{$ctl} = $ctl;
-}
-
-# Build MIB
-foreach my $header (@headers) {
- &debug("Processing $header...");
- open HEADER, "/usr/include/$header" ||
- print STDERR "Failed to open $header\n";
- while () {
- if ($_ =~ /^#define\s+(CTL_NAMES)\s+{/ ||
- $_ =~ /^#define\s+(CTL_(.*)_NAMES)\s+{/ ||
- $_ =~ /^#define\s+((.*)CTL_NAMES)\s+{/) {
- if ($1 eq 'CTL_NAMES') {
- # Top level.
- $node = \%mib;
- } else {
- # Node.
- my $nodename = lc($2);
- if ($header =~ /^netinet\//) {
- $ctlname = "net.inet.$nodename";
- } elsif ($header =~ /^netinet6\//) {
- $ctlname = "net.inet6.$nodename";
- } elsif ($header =~ /^net\//) {
- $ctlname = "net.$nodename";
- } else {
- $ctlname = "$nodename";
- $ctlname =~ s/^(fs|net|kern)_/$1\./;
- }
- if (exists $ctl_map{$ctlname}) {
- $ctlname = $ctl_map{$ctlname};
- }
- if (not exists $ctls{$ctlname}) {
- &debug("Ignoring $ctlname...");
- next;
- }
-
- # Walk down from the top of the MIB.
- $node = \%mib;
- foreach my $part (split /\./, $ctlname) {
- if (not exists $$node{$part}) {
- &debug("Missing node $part");
- $$node{$part} = [ 0, '', {} ];
- }
- $node = \%{@{$$node{$part}}[2]};
- }
- }
-
- # Populate current node with entries.
- my $i = -1;
- while (defined($_) && $_ !~ /^}/) {
- $_ = ;
- $i++ if $_ =~ /{.*}/;
- next if $_ !~ /{\s+"(\w+)",\s+(CTLTYPE_[A-Z]+)\s+}/;
- $$node{$1} = [ $i, $2, {} ];
- }
- }
- }
- close HEADER;
-}
-
-&build_sysctl(\%mib, "", []);
-
-print <){
- if(/^#define\s+SYS_(\w+)\s+([0-9]+)/){
- my $name = $1;
- my $num = $2;
- $name =~ y/a-z/A-Z/;
- print " SYS_$name = $num;"
- }
-}
-
-print <){
- if(/^([0-9]+)\s+STD\s+({ \S+\s+(\w+).*)$/){
- my $num = $1;
- my $proto = $2;
- my $name = "SYS_$3";
- $name =~ y/a-z/A-Z/;
-
- # There are multiple entries for enosys and nosys, so comment them out.
- if($name =~ /^SYS_E?NOSYS$/){
- $name = "// $name";
- }
- if($name eq 'SYS_SYS_EXIT'){
- $name = 'SYS_EXIT';
- }
-
- print " $name = $num; // $proto\n";
- }
-}
-
-print <){
- if(/^([0-9]+)\s+\S+\s+STD\s+({ \S+\s+(\w+).*)$/){
- my $num = $1;
- my $proto = $2;
- my $name = "SYS_$3";
- $name =~ y/a-z/A-Z/;
-
- # There are multiple entries for enosys and nosys, so comment them out.
- if($name =~ /^SYS_E?NOSYS$/){
- $name = "// $name";
- }
- if($name eq 'SYS_SYS_EXIT'){
- $name = 'SYS_EXIT';
- }
- if($name =~ /^SYS_CAP_+/ || $name =~ /^SYS___CAP_+/){
- next
- }
-
- print " $name = $num; // $proto\n";
-
- # We keep Capsicum syscall numbers for FreeBSD
- # 9-STABLE here because we are not sure whether they
- # are mature and stable.
- if($num == 513){
- print " SYS_CAP_NEW = 514 // { int cap_new(int fd, uint64_t rights); }\n";
- print " SYS_CAP_GETRIGHTS = 515 // { int cap_getrights(int fd, \\\n";
- print " SYS_CAP_ENTER = 516 // { int cap_enter(void); }\n";
- print " SYS_CAP_GETMODE = 517 // { int cap_getmode(u_int *modep); }\n";
- }
- }
-}
-
-print <){
- if($line =~ /^(.*)\\$/) {
- # Handle continuation
- $line = $1;
- $_ =~ s/^\s+//;
- $line .= $_;
- } else {
- # New line
- $line = $_;
- }
- next if $line =~ /\\$/;
- if($line =~ /^([0-9]+)\s+((STD)|(NOERR))\s+(RUMP\s+)?({\s+\S+\s*\*?\s*\|(\S+)\|(\S*)\|(\w+).*\s+})(\s+(\S+))?$/) {
- my $num = $1;
- my $proto = $6;
- my $compat = $8;
- my $name = "$7_$9";
-
- $name = "$7_$11" if $11 ne '';
- $name =~ y/a-z/A-Z/;
-
- if($compat eq '' || $compat eq '30' || $compat eq '50') {
- print " $name = $num; // $proto\n";
- }
- }
-}
-
-print <){
- if(/^([0-9]+)\s+STD\s+(NOLOCK\s+)?({ \S+\s+\*?(\w+).*)$/){
- my $num = $1;
- my $proto = $3;
- my $name = $4;
- $name =~ y/a-z/A-Z/;
-
- # There are multiple entries for enosys and nosys, so comment them out.
- if($name =~ /^SYS_E?NOSYS$/){
- $name = "// $name";
- }
- if($name eq 'SYS_SYS_EXIT'){
- $name = 'SYS_EXIT';
- }
-
- print " $name = $num; // $proto\n";
- }
-}
-
-print < uint64(len(b)) {
- return nil, nil, EINVAL
- }
- return h, b[cmsgAlignOf(SizeofCmsghdr):h.Len], nil
-}
-
-// UnixRights encodes a set of open file descriptors into a socket
-// control message for sending to another process.
-func UnixRights(fds ...int) []byte {
- datalen := len(fds) * 4
- b := make([]byte, CmsgSpace(datalen))
- h := (*Cmsghdr)(unsafe.Pointer(&b[0]))
- h.Level = SOL_SOCKET
- h.Type = SCM_RIGHTS
- h.SetLen(CmsgLen(datalen))
- data := cmsgData(h)
- for _, fd := range fds {
- *(*int32)(data) = int32(fd)
- data = unsafe.Pointer(uintptr(data) + 4)
- }
- return b
-}
-
-// ParseUnixRights decodes a socket control message that contains an
-// integer array of open file descriptors from another process.
-func ParseUnixRights(m *SocketControlMessage) ([]int, error) {
- if m.Header.Level != SOL_SOCKET {
- return nil, EINVAL
- }
- if m.Header.Type != SCM_RIGHTS {
- return nil, EINVAL
- }
- fds := make([]int, len(m.Data)>>2)
- for i, j := 0, 0; i < len(m.Data); i += 4 {
- fds[j] = int(*(*int32)(unsafe.Pointer(&m.Data[i])))
- j++
- }
- return fds, nil
-}
diff --git a/vendor/golang.org/x/sys/unix/str.go b/vendor/golang.org/x/sys/unix/str.go
deleted file mode 100644
index 35ed66435..000000000
--- a/vendor/golang.org/x/sys/unix/str.go
+++ /dev/null
@@ -1,26 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd solaris
-
-package unix
-
-func itoa(val int) string { // do it here rather than with fmt to avoid dependency
- if val < 0 {
- return "-" + uitoa(uint(-val))
- }
- return uitoa(uint(val))
-}
-
-func uitoa(val uint) string {
- var buf [32]byte // big enough for int64
- i := len(buf) - 1
- for val >= 10 {
- buf[i] = byte(val%10 + '0')
- i--
- val /= 10
- }
- buf[i] = byte(val + '0')
- return string(buf[i:])
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall.go b/vendor/golang.org/x/sys/unix/syscall.go
deleted file mode 100644
index e2ee36452..000000000
--- a/vendor/golang.org/x/sys/unix/syscall.go
+++ /dev/null
@@ -1,69 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd solaris
-
-// Package unix contains an interface to the low-level operating system
-// primitives. OS details vary depending on the underlying system, and
-// by default, godoc will display OS-specific documentation for the current
-// system. If you want godoc to display OS documentation for another
-// system, set $GOOS and $GOARCH to the desired system. For example, if
-// you want to view documentation for freebsd/arm on linux/amd64, set $GOOS
-// to freebsd and $GOARCH to arm.
-// The primary use of this package is inside other packages that provide a more
-// portable interface to the system, such as "os", "time" and "net". Use
-// those packages rather than this one if you can.
-// For details of the functions and data types in this package consult
-// the manuals for the appropriate operating system.
-// These calls return err == nil to indicate success; otherwise
-// err represents an operating system error describing the failure and
-// holds a value of type syscall.Errno.
-package unix
-
-// ByteSliceFromString returns a NUL-terminated slice of bytes
-// containing the text of s. If s contains a NUL byte at any
-// location, it returns (nil, EINVAL).
-func ByteSliceFromString(s string) ([]byte, error) {
- for i := 0; i < len(s); i++ {
- if s[i] == 0 {
- return nil, EINVAL
- }
- }
- a := make([]byte, len(s)+1)
- copy(a, s)
- return a, nil
-}
-
-// BytePtrFromString returns a pointer to a NUL-terminated array of
-// bytes containing the text of s. If s contains a NUL byte at any
-// location, it returns (nil, EINVAL).
-func BytePtrFromString(s string) (*byte, error) {
- a, err := ByteSliceFromString(s)
- if err != nil {
- return nil, err
- }
- return &a[0], nil
-}
-
-// Single-word zero for use when we need a valid pointer to 0 bytes.
-// See mkunix.pl.
-var _zero uintptr
-
-func (ts *Timespec) Unix() (sec int64, nsec int64) {
- return int64(ts.Sec), int64(ts.Nsec)
-}
-
-func (tv *Timeval) Unix() (sec int64, nsec int64) {
- return int64(tv.Sec), int64(tv.Usec) * 1000
-}
-
-func (ts *Timespec) Nano() int64 {
- return int64(ts.Sec)*1e9 + int64(ts.Nsec)
-}
-
-func (tv *Timeval) Nano() int64 {
- return int64(tv.Sec)*1e9 + int64(tv.Usec)*1000
-}
-
-func TimevalToNsec(tv Timeval) int64 { return int64(tv.Sec)*1e9 + int64(tv.Usec)*1e3 }
diff --git a/vendor/golang.org/x/sys/unix/syscall_bsd.go b/vendor/golang.org/x/sys/unix/syscall_bsd.go
deleted file mode 100644
index ccb29c75c..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_bsd.go
+++ /dev/null
@@ -1,614 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd netbsd openbsd
-
-// BSD system call wrappers shared by *BSD based systems
-// including OS X (Darwin) and FreeBSD. Like the other
-// syscall_*.go files it is compiled as Go code but also
-// used as input to mksyscall which parses the //sys
-// lines and generates system call stubs.
-
-package unix
-
-import (
- "runtime"
- "syscall"
- "unsafe"
-)
-
-/*
- * Wrapped
- */
-
-//sysnb getgroups(ngid int, gid *_Gid_t) (n int, err error)
-//sysnb setgroups(ngid int, gid *_Gid_t) (err error)
-
-func Getgroups() (gids []int, err error) {
- n, err := getgroups(0, nil)
- if err != nil {
- return nil, err
- }
- if n == 0 {
- return nil, nil
- }
-
- // Sanity check group count. Max is 16 on BSD.
- if n < 0 || n > 1000 {
- return nil, EINVAL
- }
-
- a := make([]_Gid_t, n)
- n, err = getgroups(n, &a[0])
- if err != nil {
- return nil, err
- }
- gids = make([]int, n)
- for i, v := range a[0:n] {
- gids[i] = int(v)
- }
- return
-}
-
-func Setgroups(gids []int) (err error) {
- if len(gids) == 0 {
- return setgroups(0, nil)
- }
-
- a := make([]_Gid_t, len(gids))
- for i, v := range gids {
- a[i] = _Gid_t(v)
- }
- return setgroups(len(a), &a[0])
-}
-
-func ReadDirent(fd int, buf []byte) (n int, err error) {
- // Final argument is (basep *uintptr) and the syscall doesn't take nil.
- // 64 bits should be enough. (32 bits isn't even on 386). Since the
- // actual system call is getdirentries64, 64 is a good guess.
- // TODO(rsc): Can we use a single global basep for all calls?
- var base = (*uintptr)(unsafe.Pointer(new(uint64)))
- return Getdirentries(fd, buf, base)
-}
-
-// Wait status is 7 bits at bottom, either 0 (exited),
-// 0x7F (stopped), or a signal number that caused an exit.
-// The 0x80 bit is whether there was a core dump.
-// An extra number (exit code, signal causing a stop)
-// is in the high bits.
-
-type WaitStatus uint32
-
-const (
- mask = 0x7F
- core = 0x80
- shift = 8
-
- exited = 0
- stopped = 0x7F
-)
-
-func (w WaitStatus) Exited() bool { return w&mask == exited }
-
-func (w WaitStatus) ExitStatus() int {
- if w&mask != exited {
- return -1
- }
- return int(w >> shift)
-}
-
-func (w WaitStatus) Signaled() bool { return w&mask != stopped && w&mask != 0 }
-
-func (w WaitStatus) Signal() syscall.Signal {
- sig := syscall.Signal(w & mask)
- if sig == stopped || sig == 0 {
- return -1
- }
- return sig
-}
-
-func (w WaitStatus) CoreDump() bool { return w.Signaled() && w&core != 0 }
-
-func (w WaitStatus) Stopped() bool { return w&mask == stopped && syscall.Signal(w>>shift) != SIGSTOP }
-
-func (w WaitStatus) Continued() bool { return w&mask == stopped && syscall.Signal(w>>shift) == SIGSTOP }
-
-func (w WaitStatus) StopSignal() syscall.Signal {
- if !w.Stopped() {
- return -1
- }
- return syscall.Signal(w>>shift) & 0xFF
-}
-
-func (w WaitStatus) TrapCause() int { return -1 }
-
-//sys wait4(pid int, wstatus *_C_int, options int, rusage *Rusage) (wpid int, err error)
-
-func Wait4(pid int, wstatus *WaitStatus, options int, rusage *Rusage) (wpid int, err error) {
- var status _C_int
- wpid, err = wait4(pid, &status, options, rusage)
- if wstatus != nil {
- *wstatus = WaitStatus(status)
- }
- return
-}
-
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys Shutdown(s int, how int) (err error)
-
-func (sa *SockaddrInet4) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Port < 0 || sa.Port > 0xFFFF {
- return nil, 0, EINVAL
- }
- sa.raw.Len = SizeofSockaddrInet4
- sa.raw.Family = AF_INET
- p := (*[2]byte)(unsafe.Pointer(&sa.raw.Port))
- p[0] = byte(sa.Port >> 8)
- p[1] = byte(sa.Port)
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), _Socklen(sa.raw.Len), nil
-}
-
-func (sa *SockaddrInet6) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Port < 0 || sa.Port > 0xFFFF {
- return nil, 0, EINVAL
- }
- sa.raw.Len = SizeofSockaddrInet6
- sa.raw.Family = AF_INET6
- p := (*[2]byte)(unsafe.Pointer(&sa.raw.Port))
- p[0] = byte(sa.Port >> 8)
- p[1] = byte(sa.Port)
- sa.raw.Scope_id = sa.ZoneId
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), _Socklen(sa.raw.Len), nil
-}
-
-func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, _Socklen, error) {
- name := sa.Name
- n := len(name)
- if n >= len(sa.raw.Path) || n == 0 {
- return nil, 0, EINVAL
- }
- sa.raw.Len = byte(3 + n) // 2 for Family, Len; 1 for NUL
- sa.raw.Family = AF_UNIX
- for i := 0; i < n; i++ {
- sa.raw.Path[i] = int8(name[i])
- }
- return unsafe.Pointer(&sa.raw), _Socklen(sa.raw.Len), nil
-}
-
-func (sa *SockaddrDatalink) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Index == 0 {
- return nil, 0, EINVAL
- }
- sa.raw.Len = sa.Len
- sa.raw.Family = AF_LINK
- sa.raw.Index = sa.Index
- sa.raw.Type = sa.Type
- sa.raw.Nlen = sa.Nlen
- sa.raw.Alen = sa.Alen
- sa.raw.Slen = sa.Slen
- for i := 0; i < len(sa.raw.Data); i++ {
- sa.raw.Data[i] = sa.Data[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrDatalink, nil
-}
-
-func anyToSockaddr(rsa *RawSockaddrAny) (Sockaddr, error) {
- switch rsa.Addr.Family {
- case AF_LINK:
- pp := (*RawSockaddrDatalink)(unsafe.Pointer(rsa))
- sa := new(SockaddrDatalink)
- sa.Len = pp.Len
- sa.Family = pp.Family
- sa.Index = pp.Index
- sa.Type = pp.Type
- sa.Nlen = pp.Nlen
- sa.Alen = pp.Alen
- sa.Slen = pp.Slen
- for i := 0; i < len(sa.Data); i++ {
- sa.Data[i] = pp.Data[i]
- }
- return sa, nil
-
- case AF_UNIX:
- pp := (*RawSockaddrUnix)(unsafe.Pointer(rsa))
- if pp.Len < 2 || pp.Len > SizeofSockaddrUnix {
- return nil, EINVAL
- }
- sa := new(SockaddrUnix)
-
- // Some BSDs include the trailing NUL in the length, whereas
- // others do not. Work around this by subtracting the leading
- // family and len. The path is then scanned to see if a NUL
- // terminator still exists within the length.
- n := int(pp.Len) - 2 // subtract leading Family, Len
- for i := 0; i < n; i++ {
- if pp.Path[i] == 0 {
- // found early NUL; assume Len included the NUL
- // or was overestimating.
- n = i
- break
- }
- }
- bytes := (*[10000]byte)(unsafe.Pointer(&pp.Path[0]))[0:n]
- sa.Name = string(bytes)
- return sa, nil
-
- case AF_INET:
- pp := (*RawSockaddrInet4)(unsafe.Pointer(rsa))
- sa := new(SockaddrInet4)
- p := (*[2]byte)(unsafe.Pointer(&pp.Port))
- sa.Port = int(p[0])<<8 + int(p[1])
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
-
- case AF_INET6:
- pp := (*RawSockaddrInet6)(unsafe.Pointer(rsa))
- sa := new(SockaddrInet6)
- p := (*[2]byte)(unsafe.Pointer(&pp.Port))
- sa.Port = int(p[0])<<8 + int(p[1])
- sa.ZoneId = pp.Scope_id
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
- }
- return nil, EAFNOSUPPORT
-}
-
-func Accept(fd int) (nfd int, sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- nfd, err = accept(fd, &rsa, &len)
- if err != nil {
- return
- }
- if runtime.GOOS == "darwin" && len == 0 {
- // Accepted socket has no address.
- // This is likely due to a bug in xnu kernels,
- // where instead of ECONNABORTED error socket
- // is accepted, but has no address.
- Close(nfd)
- return 0, nil, ECONNABORTED
- }
- sa, err = anyToSockaddr(&rsa)
- if err != nil {
- Close(nfd)
- nfd = 0
- }
- return
-}
-
-func Getsockname(fd int) (sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- if err = getsockname(fd, &rsa, &len); err != nil {
- return
- }
- // TODO(jsing): DragonFly has a "bug" (see issue 3349), which should be
- // reported upstream.
- if runtime.GOOS == "dragonfly" && rsa.Addr.Family == AF_UNSPEC && rsa.Addr.Len == 0 {
- rsa.Addr.Family = AF_UNIX
- rsa.Addr.Len = SizeofSockaddrUnix
- }
- return anyToSockaddr(&rsa)
-}
-
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-
-func GetsockoptByte(fd, level, opt int) (value byte, err error) {
- var n byte
- vallen := _Socklen(1)
- err = getsockopt(fd, level, opt, unsafe.Pointer(&n), &vallen)
- return n, err
-}
-
-func GetsockoptInet4Addr(fd, level, opt int) (value [4]byte, err error) {
- vallen := _Socklen(4)
- err = getsockopt(fd, level, opt, unsafe.Pointer(&value[0]), &vallen)
- return value, err
-}
-
-func GetsockoptIPMreq(fd, level, opt int) (*IPMreq, error) {
- var value IPMreq
- vallen := _Socklen(SizeofIPMreq)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptIPv6Mreq(fd, level, opt int) (*IPv6Mreq, error) {
- var value IPv6Mreq
- vallen := _Socklen(SizeofIPv6Mreq)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptIPv6MTUInfo(fd, level, opt int) (*IPv6MTUInfo, error) {
- var value IPv6MTUInfo
- vallen := _Socklen(SizeofIPv6MTUInfo)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptICMPv6Filter(fd, level, opt int) (*ICMPv6Filter, error) {
- var value ICMPv6Filter
- vallen := _Socklen(SizeofICMPv6Filter)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-
-func Recvmsg(fd int, p, oob []byte, flags int) (n, oobn int, recvflags int, from Sockaddr, err error) {
- var msg Msghdr
- var rsa RawSockaddrAny
- msg.Name = (*byte)(unsafe.Pointer(&rsa))
- msg.Namelen = uint32(SizeofSockaddrAny)
- var iov Iovec
- if len(p) > 0 {
- iov.Base = (*byte)(unsafe.Pointer(&p[0]))
- iov.SetLen(len(p))
- }
- var dummy byte
- if len(oob) > 0 {
- // receive at least one normal byte
- if len(p) == 0 {
- iov.Base = &dummy
- iov.SetLen(1)
- }
- msg.Control = (*byte)(unsafe.Pointer(&oob[0]))
- msg.SetControllen(len(oob))
- }
- msg.Iov = &iov
- msg.Iovlen = 1
- if n, err = recvmsg(fd, &msg, flags); err != nil {
- return
- }
- oobn = int(msg.Controllen)
- recvflags = int(msg.Flags)
- // source address is only specified if the socket is unconnected
- if rsa.Addr.Family != AF_UNSPEC {
- from, err = anyToSockaddr(&rsa)
- }
- return
-}
-
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-
-func Sendmsg(fd int, p, oob []byte, to Sockaddr, flags int) (err error) {
- _, err = SendmsgN(fd, p, oob, to, flags)
- return
-}
-
-func SendmsgN(fd int, p, oob []byte, to Sockaddr, flags int) (n int, err error) {
- var ptr unsafe.Pointer
- var salen _Socklen
- if to != nil {
- ptr, salen, err = to.sockaddr()
- if err != nil {
- return 0, err
- }
- }
- var msg Msghdr
- msg.Name = (*byte)(unsafe.Pointer(ptr))
- msg.Namelen = uint32(salen)
- var iov Iovec
- if len(p) > 0 {
- iov.Base = (*byte)(unsafe.Pointer(&p[0]))
- iov.SetLen(len(p))
- }
- var dummy byte
- if len(oob) > 0 {
- // send at least one normal byte
- if len(p) == 0 {
- iov.Base = &dummy
- iov.SetLen(1)
- }
- msg.Control = (*byte)(unsafe.Pointer(&oob[0]))
- msg.SetControllen(len(oob))
- }
- msg.Iov = &iov
- msg.Iovlen = 1
- if n, err = sendmsg(fd, &msg, flags); err != nil {
- return 0, err
- }
- if len(oob) > 0 && len(p) == 0 {
- n = 0
- }
- return n, nil
-}
-
-//sys kevent(kq int, change unsafe.Pointer, nchange int, event unsafe.Pointer, nevent int, timeout *Timespec) (n int, err error)
-
-func Kevent(kq int, changes, events []Kevent_t, timeout *Timespec) (n int, err error) {
- var change, event unsafe.Pointer
- if len(changes) > 0 {
- change = unsafe.Pointer(&changes[0])
- }
- if len(events) > 0 {
- event = unsafe.Pointer(&events[0])
- }
- return kevent(kq, change, len(changes), event, len(events), timeout)
-}
-
-//sys sysctl(mib []_C_int, old *byte, oldlen *uintptr, new *byte, newlen uintptr) (err error) = SYS___SYSCTL
-
-// sysctlmib translates name to mib number and appends any additional args.
-func sysctlmib(name string, args ...int) ([]_C_int, error) {
- // Translate name to mib number.
- mib, err := nametomib(name)
- if err != nil {
- return nil, err
- }
-
- for _, a := range args {
- mib = append(mib, _C_int(a))
- }
-
- return mib, nil
-}
-
-func Sysctl(name string) (string, error) {
- return SysctlArgs(name)
-}
-
-func SysctlArgs(name string, args ...int) (string, error) {
- buf, err := SysctlRaw(name, args...)
- if err != nil {
- return "", err
- }
- n := len(buf)
-
- // Throw away terminating NUL.
- if n > 0 && buf[n-1] == '\x00' {
- n--
- }
- return string(buf[0:n]), nil
-}
-
-func SysctlUint32(name string) (uint32, error) {
- return SysctlUint32Args(name)
-}
-
-func SysctlUint32Args(name string, args ...int) (uint32, error) {
- mib, err := sysctlmib(name, args...)
- if err != nil {
- return 0, err
- }
-
- n := uintptr(4)
- buf := make([]byte, 4)
- if err := sysctl(mib, &buf[0], &n, nil, 0); err != nil {
- return 0, err
- }
- if n != 4 {
- return 0, EIO
- }
- return *(*uint32)(unsafe.Pointer(&buf[0])), nil
-}
-
-func SysctlUint64(name string, args ...int) (uint64, error) {
- mib, err := sysctlmib(name, args...)
- if err != nil {
- return 0, err
- }
-
- n := uintptr(8)
- buf := make([]byte, 8)
- if err := sysctl(mib, &buf[0], &n, nil, 0); err != nil {
- return 0, err
- }
- if n != 8 {
- return 0, EIO
- }
- return *(*uint64)(unsafe.Pointer(&buf[0])), nil
-}
-
-func SysctlRaw(name string, args ...int) ([]byte, error) {
- mib, err := sysctlmib(name, args...)
- if err != nil {
- return nil, err
- }
-
- // Find size.
- n := uintptr(0)
- if err := sysctl(mib, nil, &n, nil, 0); err != nil {
- return nil, err
- }
- if n == 0 {
- return nil, nil
- }
-
- // Read into buffer of that size.
- buf := make([]byte, n)
- if err := sysctl(mib, &buf[0], &n, nil, 0); err != nil {
- return nil, err
- }
-
- // The actual call may return less than the original reported required
- // size so ensure we deal with that.
- return buf[:n], nil
-}
-
-//sys utimes(path string, timeval *[2]Timeval) (err error)
-
-func Utimes(path string, tv []Timeval) error {
- if tv == nil {
- return utimes(path, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- return utimes(path, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-func UtimesNano(path string, ts []Timespec) error {
- if ts == nil {
- return utimes(path, nil)
- }
- // TODO: The BSDs can do utimensat with SYS_UTIMENSAT but it
- // isn't supported by darwin so this uses utimes instead
- if len(ts) != 2 {
- return EINVAL
- }
- // Not as efficient as it could be because Timespec and
- // Timeval have different types in the different OSes
- tv := [2]Timeval{
- NsecToTimeval(TimespecToNsec(ts[0])),
- NsecToTimeval(TimespecToNsec(ts[1])),
- }
- return utimes(path, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-//sys futimes(fd int, timeval *[2]Timeval) (err error)
-
-func Futimes(fd int, tv []Timeval) error {
- if tv == nil {
- return futimes(fd, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- return futimes(fd, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-//sys fcntl(fd int, cmd int, arg int) (val int, err error)
-
-// TODO: wrap
-// Acct(name nil-string) (err error)
-// Gethostuuid(uuid *byte, timeout *Timespec) (err error)
-// Madvise(addr *byte, len int, behav int) (err error)
-// Mprotect(addr *byte, len int, prot int) (err error)
-// Msync(addr *byte, len int, flags int) (err error)
-// Ptrace(req int, pid int, addr uintptr, data int) (ret uintptr, err error)
-
-var mapper = &mmapper{
- active: make(map[*byte][]byte),
- mmap: mmap,
- munmap: munmap,
-}
-
-func Mmap(fd int, offset int64, length int, prot int, flags int) (data []byte, err error) {
- return mapper.Mmap(fd, offset, length, prot, flags)
-}
-
-func Munmap(b []byte) (err error) {
- return mapper.Munmap(b)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_darwin.go b/vendor/golang.org/x/sys/unix/syscall_darwin.go
deleted file mode 100644
index 7d91ac02a..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_darwin.go
+++ /dev/null
@@ -1,493 +0,0 @@
-// Copyright 2009,2010 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Darwin system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and wrap
-// it in our own nicer implementation, either here or in
-// syscall_bsd.go or syscall_unix.go.
-
-package unix
-
-import (
- errorspkg "errors"
- "syscall"
- "unsafe"
-)
-
-const ImplementsGetwd = true
-
-func Getwd() (string, error) {
- buf := make([]byte, 2048)
- attrs, err := getAttrList(".", attrList{CommonAttr: attrCmnFullpath}, buf, 0)
- if err == nil && len(attrs) == 1 && len(attrs[0]) >= 2 {
- wd := string(attrs[0])
- // Sanity check that it's an absolute path and ends
- // in a null byte, which we then strip.
- if wd[0] == '/' && wd[len(wd)-1] == 0 {
- return wd[:len(wd)-1], nil
- }
- }
- // If pkg/os/getwd.go gets ENOTSUP, it will fall back to the
- // slow algorithm.
- return "", ENOTSUP
-}
-
-type SockaddrDatalink struct {
- Len uint8
- Family uint8
- Index uint16
- Type uint8
- Nlen uint8
- Alen uint8
- Slen uint8
- Data [12]int8
- raw RawSockaddrDatalink
-}
-
-// Translate "kern.hostname" to []_C_int{0,1,2,3}.
-func nametomib(name string) (mib []_C_int, err error) {
- const siz = unsafe.Sizeof(mib[0])
-
- // NOTE(rsc): It seems strange to set the buffer to have
- // size CTL_MAXNAME+2 but use only CTL_MAXNAME
- // as the size. I don't know why the +2 is here, but the
- // kernel uses +2 for its own implementation of this function.
- // I am scared that if we don't include the +2 here, the kernel
- // will silently write 2 words farther than we specify
- // and we'll get memory corruption.
- var buf [CTL_MAXNAME + 2]_C_int
- n := uintptr(CTL_MAXNAME) * siz
-
- p := (*byte)(unsafe.Pointer(&buf[0]))
- bytes, err := ByteSliceFromString(name)
- if err != nil {
- return nil, err
- }
-
- // Magic sysctl: "setting" 0.3 to a string name
- // lets you read back the array of integers form.
- if err = sysctl([]_C_int{0, 3}, p, &n, &bytes[0], uintptr(len(name))); err != nil {
- return nil, err
- }
- return buf[0 : n/siz], nil
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen))
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen))
-}
-
-//sys ptrace(request int, pid int, addr uintptr, data uintptr) (err error)
-func PtraceAttach(pid int) (err error) { return ptrace(PT_ATTACH, pid, 0, 0) }
-func PtraceDetach(pid int) (err error) { return ptrace(PT_DETACH, pid, 0, 0) }
-
-const (
- attrBitMapCount = 5
- attrCmnFullpath = 0x08000000
-)
-
-type attrList struct {
- bitmapCount uint16
- _ uint16
- CommonAttr uint32
- VolAttr uint32
- DirAttr uint32
- FileAttr uint32
- Forkattr uint32
-}
-
-func getAttrList(path string, attrList attrList, attrBuf []byte, options uint) (attrs [][]byte, err error) {
- if len(attrBuf) < 4 {
- return nil, errorspkg.New("attrBuf too small")
- }
- attrList.bitmapCount = attrBitMapCount
-
- var _p0 *byte
- _p0, err = BytePtrFromString(path)
- if err != nil {
- return nil, err
- }
-
- _, _, e1 := Syscall6(
- SYS_GETATTRLIST,
- uintptr(unsafe.Pointer(_p0)),
- uintptr(unsafe.Pointer(&attrList)),
- uintptr(unsafe.Pointer(&attrBuf[0])),
- uintptr(len(attrBuf)),
- uintptr(options),
- 0,
- )
- if e1 != 0 {
- return nil, e1
- }
- size := *(*uint32)(unsafe.Pointer(&attrBuf[0]))
-
- // dat is the section of attrBuf that contains valid data,
- // without the 4 byte length header. All attribute offsets
- // are relative to dat.
- dat := attrBuf
- if int(size) < len(attrBuf) {
- dat = dat[:size]
- }
- dat = dat[4:] // remove length prefix
-
- for i := uint32(0); int(i) < len(dat); {
- header := dat[i:]
- if len(header) < 8 {
- return attrs, errorspkg.New("truncated attribute header")
- }
- datOff := *(*int32)(unsafe.Pointer(&header[0]))
- attrLen := *(*uint32)(unsafe.Pointer(&header[4]))
- if datOff < 0 || uint32(datOff)+attrLen > uint32(len(dat)) {
- return attrs, errorspkg.New("truncated results; attrBuf too small")
- }
- end := uint32(datOff) + attrLen
- attrs = append(attrs, dat[datOff:end])
- i = end
- if r := i % 4; r != 0 {
- i += (4 - r)
- }
- }
- return
-}
-
-//sysnb pipe() (r int, w int, err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- p[0], p[1], err = pipe()
- return
-}
-
-func Getfsstat(buf []Statfs_t, flags int) (n int, err error) {
- var _p0 unsafe.Pointer
- var bufsize uintptr
- if len(buf) > 0 {
- _p0 = unsafe.Pointer(&buf[0])
- bufsize = unsafe.Sizeof(Statfs_t{}) * uintptr(len(buf))
- }
- r0, _, e1 := Syscall(SYS_GETFSSTAT64, uintptr(_p0), bufsize, uintptr(flags))
- n = int(r0)
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-/*
- * Wrapped
- */
-
-//sys kill(pid int, signum int, posix int) (err error)
-
-func Kill(pid int, signum syscall.Signal) (err error) { return kill(pid, int(signum), 1) }
-
-/*
- * Exposed directly
- */
-//sys Access(path string, mode uint32) (err error)
-//sys Adjtime(delta *Timeval, olddelta *Timeval) (err error)
-//sys Chdir(path string) (err error)
-//sys Chflags(path string, flags int) (err error)
-//sys Chmod(path string, mode uint32) (err error)
-//sys Chown(path string, uid int, gid int) (err error)
-//sys Chroot(path string) (err error)
-//sys Close(fd int) (err error)
-//sys Dup(fd int) (nfd int, err error)
-//sys Dup2(from int, to int) (err error)
-//sys Exchangedata(path1 string, path2 string, options int) (err error)
-//sys Exit(code int)
-//sys Fchdir(fd int) (err error)
-//sys Fchflags(fd int, flags int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Flock(fd int, how int) (err error)
-//sys Fpathconf(fd int, name int) (val int, err error)
-//sys Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64
-//sys Fstatfs(fd int, stat *Statfs_t) (err error) = SYS_FSTATFS64
-//sys Fsync(fd int) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sys Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) = SYS_GETDIRENTRIES64
-//sys Getdtablesize() (size int)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (uid int)
-//sysnb Getgid() (gid int)
-//sysnb Getpgid(pid int) (pgid int, err error)
-//sysnb Getpgrp() (pgrp int)
-//sysnb Getpid() (pid int)
-//sysnb Getppid() (ppid int)
-//sys Getpriority(which int, who int) (prio int, err error)
-//sysnb Getrlimit(which int, lim *Rlimit) (err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Getsid(pid int) (sid int, err error)
-//sysnb Getuid() (uid int)
-//sysnb Issetugid() (tainted bool)
-//sys Kqueue() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Link(path string, link string) (err error)
-//sys Listen(s int, backlog int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error) = SYS_LSTAT64
-//sys Mkdir(path string, mode uint32) (err error)
-//sys Mkfifo(path string, mode uint32) (err error)
-//sys Mknod(path string, mode uint32, dev int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Munlockall() (err error)
-//sys Open(path string, mode int, perm uint32) (fd int, err error)
-//sys Pathconf(path string, name int) (val int, err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error)
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Readlink(path string, buf []byte) (n int, err error)
-//sys Rename(from string, to string) (err error)
-//sys Revoke(path string) (err error)
-//sys Rmdir(path string) (err error)
-//sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK
-//sys Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error)
-//sys Setegid(egid int) (err error)
-//sysnb Seteuid(euid int) (err error)
-//sysnb Setgid(gid int) (err error)
-//sys Setlogin(name string) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sys Setpriority(which int, who int, prio int) (err error)
-//sys Setprivexec(flag int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sysnb Setrlimit(which int, lim *Rlimit) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Settimeofday(tp *Timeval) (err error)
-//sysnb Setuid(uid int) (err error)
-//sys Stat(path string, stat *Stat_t) (err error) = SYS_STAT64
-//sys Statfs(path string, stat *Statfs_t) (err error) = SYS_STATFS64
-//sys Symlink(path string, link string) (err error)
-//sys Sync() (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys Umask(newmask int) (oldmask int)
-//sys Undelete(path string) (err error)
-//sys Unlink(path string) (err error)
-//sys Unmount(path string, flags int) (err error)
-//sys write(fd int, p []byte) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error)
-//sys munmap(addr uintptr, length uintptr) (err error)
-//sys readlen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_READ
-//sys writelen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_WRITE
-
-/*
- * Unimplemented
- */
-// Profil
-// Sigaction
-// Sigprocmask
-// Getlogin
-// Sigpending
-// Sigaltstack
-// Ioctl
-// Reboot
-// Execve
-// Vfork
-// Sbrk
-// Sstk
-// Ovadvise
-// Mincore
-// Setitimer
-// Swapon
-// Select
-// Sigsuspend
-// Readv
-// Writev
-// Nfssvc
-// Getfh
-// Quotactl
-// Mount
-// Csops
-// Waitid
-// Add_profil
-// Kdebug_trace
-// Sigreturn
-// Mmap
-// Mlock
-// Munlock
-// Atsocket
-// Kqueue_from_portset_np
-// Kqueue_portset
-// Getattrlist
-// Setattrlist
-// Getdirentriesattr
-// Searchfs
-// Delete
-// Copyfile
-// Poll
-// Watchevent
-// Waitevent
-// Modwatch
-// Getxattr
-// Fgetxattr
-// Setxattr
-// Fsetxattr
-// Removexattr
-// Fremovexattr
-// Listxattr
-// Flistxattr
-// Fsctl
-// Initgroups
-// Posix_spawn
-// Nfsclnt
-// Fhopen
-// Minherit
-// Semsys
-// Msgsys
-// Shmsys
-// Semctl
-// Semget
-// Semop
-// Msgctl
-// Msgget
-// Msgsnd
-// Msgrcv
-// Shmat
-// Shmctl
-// Shmdt
-// Shmget
-// Shm_open
-// Shm_unlink
-// Sem_open
-// Sem_close
-// Sem_unlink
-// Sem_wait
-// Sem_trywait
-// Sem_post
-// Sem_getvalue
-// Sem_init
-// Sem_destroy
-// Open_extended
-// Umask_extended
-// Stat_extended
-// Lstat_extended
-// Fstat_extended
-// Chmod_extended
-// Fchmod_extended
-// Access_extended
-// Settid
-// Gettid
-// Setsgroups
-// Getsgroups
-// Setwgroups
-// Getwgroups
-// Mkfifo_extended
-// Mkdir_extended
-// Identitysvc
-// Shared_region_check_np
-// Shared_region_map_np
-// __pthread_mutex_destroy
-// __pthread_mutex_init
-// __pthread_mutex_lock
-// __pthread_mutex_trylock
-// __pthread_mutex_unlock
-// __pthread_cond_init
-// __pthread_cond_destroy
-// __pthread_cond_broadcast
-// __pthread_cond_signal
-// Setsid_with_pid
-// __pthread_cond_timedwait
-// Aio_fsync
-// Aio_return
-// Aio_suspend
-// Aio_cancel
-// Aio_error
-// Aio_read
-// Aio_write
-// Lio_listio
-// __pthread_cond_wait
-// Iopolicysys
-// Mlockall
-// Munlockall
-// __pthread_kill
-// __pthread_sigmask
-// __sigwait
-// __disable_threadsignal
-// __pthread_markcancel
-// __pthread_canceled
-// __semwait_signal
-// Proc_info
-// sendfile
-// Stat64_extended
-// Lstat64_extended
-// Fstat64_extended
-// __pthread_chdir
-// __pthread_fchdir
-// Audit
-// Auditon
-// Getauid
-// Setauid
-// Getaudit
-// Setaudit
-// Getaudit_addr
-// Setaudit_addr
-// Auditctl
-// Bsdthread_create
-// Bsdthread_terminate
-// Stack_snapshot
-// Bsdthread_register
-// Workq_open
-// Workq_ops
-// __mac_execve
-// __mac_syscall
-// __mac_get_file
-// __mac_set_file
-// __mac_get_link
-// __mac_set_link
-// __mac_get_proc
-// __mac_set_proc
-// __mac_get_fd
-// __mac_set_fd
-// __mac_get_pid
-// __mac_get_lcid
-// __mac_get_lctx
-// __mac_set_lctx
-// Setlcid
-// Read_nocancel
-// Write_nocancel
-// Open_nocancel
-// Close_nocancel
-// Wait4_nocancel
-// Recvmsg_nocancel
-// Sendmsg_nocancel
-// Recvfrom_nocancel
-// Accept_nocancel
-// Msync_nocancel
-// Fcntl_nocancel
-// Select_nocancel
-// Fsync_nocancel
-// Connect_nocancel
-// Sigsuspend_nocancel
-// Readv_nocancel
-// Writev_nocancel
-// Sendto_nocancel
-// Pread_nocancel
-// Pwrite_nocancel
-// Waitid_nocancel
-// Poll_nocancel
-// Msgsnd_nocancel
-// Msgrcv_nocancel
-// Sem_wait_nocancel
-// Aio_suspend_nocancel
-// __sigwait_nocancel
-// __semwait_signal_nocancel
-// __mac_mount
-// __mac_get_mount
-// __mac_getfsstat
diff --git a/vendor/golang.org/x/sys/unix/syscall_darwin_386.go b/vendor/golang.org/x/sys/unix/syscall_darwin_386.go
deleted file mode 100644
index c172a3da5..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_darwin_386.go
+++ /dev/null
@@ -1,77 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build 386,darwin
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int32(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int32(nsec / 1e9)
- return
-}
-
-//sysnb gettimeofday(tp *Timeval) (sec int32, usec int32, err error)
-func Gettimeofday(tv *Timeval) (err error) {
- // The tv passed to gettimeofday must be non-nil
- // but is otherwise unused. The answers come back
- // in the two registers.
- sec, usec, err := gettimeofday(tv)
- tv.Sec = int32(sec)
- tv.Usec = int32(usec)
- return err
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var length = uint64(count)
-
- _, _, e1 := Syscall9(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr(*offset>>32), uintptr(unsafe.Pointer(&length)), 0, 0, 0, 0)
-
- written = int(length)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
-
-// SYS___SYSCTL is used by syscall_bsd.go for all BSDs, but in modern versions
-// of darwin/386 the syscall is called sysctl instead of __sysctl.
-const SYS___SYSCTL = SYS_SYSCTL
diff --git a/vendor/golang.org/x/sys/unix/syscall_darwin_amd64.go b/vendor/golang.org/x/sys/unix/syscall_darwin_amd64.go
deleted file mode 100644
index fc1e5a4a8..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_darwin_amd64.go
+++ /dev/null
@@ -1,79 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,darwin
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-//sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-//sysnb gettimeofday(tp *Timeval) (sec int64, usec int32, err error)
-func Gettimeofday(tv *Timeval) (err error) {
- // The tv passed to gettimeofday must be non-nil
- // but is otherwise unused. The answers come back
- // in the two registers.
- sec, usec, err := gettimeofday(tv)
- tv.Sec = sec
- tv.Usec = usec
- return err
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint64(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var length = uint64(count)
-
- _, _, e1 := Syscall6(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr(unsafe.Pointer(&length)), 0, 0)
-
- written = int(length)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
-
-// SYS___SYSCTL is used by syscall_bsd.go for all BSDs, but in modern versions
-// of darwin/amd64 the syscall is called sysctl instead of __sysctl.
-const SYS___SYSCTL = SYS_SYSCTL
diff --git a/vendor/golang.org/x/sys/unix/syscall_darwin_arm.go b/vendor/golang.org/x/sys/unix/syscall_darwin_arm.go
deleted file mode 100644
index d286cf408..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_darwin_arm.go
+++ /dev/null
@@ -1,71 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int32(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int32(nsec / 1e9)
- return
-}
-
-//sysnb gettimeofday(tp *Timeval) (sec int32, usec int32, err error)
-func Gettimeofday(tv *Timeval) (err error) {
- // The tv passed to gettimeofday must be non-nil
- // but is otherwise unused. The answers come back
- // in the two registers.
- sec, usec, err := gettimeofday(tv)
- tv.Sec = int32(sec)
- tv.Usec = int32(usec)
- return err
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var length = uint64(count)
-
- _, _, e1 := Syscall9(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr(*offset>>32), uintptr(unsafe.Pointer(&length)), 0, 0, 0, 0)
-
- written = int(length)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno) // sic
diff --git a/vendor/golang.org/x/sys/unix/syscall_darwin_arm64.go b/vendor/golang.org/x/sys/unix/syscall_darwin_arm64.go
deleted file mode 100644
index c33905cdc..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_darwin_arm64.go
+++ /dev/null
@@ -1,77 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build arm64,darwin
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 16384 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-//sysnb gettimeofday(tp *Timeval) (sec int64, usec int32, err error)
-func Gettimeofday(tv *Timeval) (err error) {
- // The tv passed to gettimeofday must be non-nil
- // but is otherwise unused. The answers come back
- // in the two registers.
- sec, usec, err := gettimeofday(tv)
- tv.Sec = sec
- tv.Usec = usec
- return err
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint64(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var length = uint64(count)
-
- _, _, e1 := Syscall6(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr(unsafe.Pointer(&length)), 0, 0)
-
- written = int(length)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno) // sic
-
-// SYS___SYSCTL is used by syscall_bsd.go for all BSDs, but in modern versions
-// of darwin/arm64 the syscall is called sysctl instead of __sysctl.
-const SYS___SYSCTL = SYS_SYSCTL
diff --git a/vendor/golang.org/x/sys/unix/syscall_dragonfly.go b/vendor/golang.org/x/sys/unix/syscall_dragonfly.go
deleted file mode 100644
index 7e0210fc9..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_dragonfly.go
+++ /dev/null
@@ -1,425 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// DragonFly BSD system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and wrap
-// it in our own nicer implementation, either here or in
-// syscall_bsd.go or syscall_unix.go.
-
-package unix
-
-import "unsafe"
-
-type SockaddrDatalink struct {
- Len uint8
- Family uint8
- Index uint16
- Type uint8
- Nlen uint8
- Alen uint8
- Slen uint8
- Data [12]int8
- Rcf uint16
- Route [16]uint16
- raw RawSockaddrDatalink
-}
-
-// Translate "kern.hostname" to []_C_int{0,1,2,3}.
-func nametomib(name string) (mib []_C_int, err error) {
- const siz = unsafe.Sizeof(mib[0])
-
- // NOTE(rsc): It seems strange to set the buffer to have
- // size CTL_MAXNAME+2 but use only CTL_MAXNAME
- // as the size. I don't know why the +2 is here, but the
- // kernel uses +2 for its own implementation of this function.
- // I am scared that if we don't include the +2 here, the kernel
- // will silently write 2 words farther than we specify
- // and we'll get memory corruption.
- var buf [CTL_MAXNAME + 2]_C_int
- n := uintptr(CTL_MAXNAME) * siz
-
- p := (*byte)(unsafe.Pointer(&buf[0]))
- bytes, err := ByteSliceFromString(name)
- if err != nil {
- return nil, err
- }
-
- // Magic sysctl: "setting" 0.3 to a string name
- // lets you read back the array of integers form.
- if err = sysctl([]_C_int{0, 3}, p, &n, &bytes[0], uintptr(len(name))); err != nil {
- return nil, err
- }
- return buf[0 : n/siz], nil
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- namlen, ok := direntNamlen(buf)
- if !ok {
- return 0, false
- }
- return (16 + namlen + 1 + 7) &^ 7, true
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen))
-}
-
-//sysnb pipe() (r int, w int, err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- p[0], p[1], err = pipe()
- return
-}
-
-//sys extpread(fd int, p []byte, flags int, offset int64) (n int, err error)
-func Pread(fd int, p []byte, offset int64) (n int, err error) {
- return extpread(fd, p, 0, offset)
-}
-
-//sys extpwrite(fd int, p []byte, flags int, offset int64) (n int, err error)
-func Pwrite(fd int, p []byte, offset int64) (n int, err error) {
- return extpwrite(fd, p, 0, offset)
-}
-
-func Accept4(fd, flags int) (nfd int, sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- nfd, err = accept4(fd, &rsa, &len, flags)
- if err != nil {
- return
- }
- if len > SizeofSockaddrAny {
- panic("RawSockaddrAny too small")
- }
- sa, err = anyToSockaddr(&rsa)
- if err != nil {
- Close(nfd)
- nfd = 0
- }
- return
-}
-
-func Getfsstat(buf []Statfs_t, flags int) (n int, err error) {
- var _p0 unsafe.Pointer
- var bufsize uintptr
- if len(buf) > 0 {
- _p0 = unsafe.Pointer(&buf[0])
- bufsize = unsafe.Sizeof(Statfs_t{}) * uintptr(len(buf))
- }
- r0, _, e1 := Syscall(SYS_GETFSSTAT, uintptr(_p0), bufsize, uintptr(flags))
- n = int(r0)
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-/*
- * Exposed directly
- */
-//sys Access(path string, mode uint32) (err error)
-//sys Adjtime(delta *Timeval, olddelta *Timeval) (err error)
-//sys Chdir(path string) (err error)
-//sys Chflags(path string, flags int) (err error)
-//sys Chmod(path string, mode uint32) (err error)
-//sys Chown(path string, uid int, gid int) (err error)
-//sys Chroot(path string) (err error)
-//sys Close(fd int) (err error)
-//sys Dup(fd int) (nfd int, err error)
-//sys Dup2(from int, to int) (err error)
-//sys Exit(code int)
-//sys Fchdir(fd int) (err error)
-//sys Fchflags(fd int, flags int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Flock(fd int, how int) (err error)
-//sys Fpathconf(fd int, name int) (val int, err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, stat *Statfs_t) (err error)
-//sys Fsync(fd int) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sys Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error)
-//sys Getdtablesize() (size int)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (uid int)
-//sysnb Getgid() (gid int)
-//sysnb Getpgid(pid int) (pgid int, err error)
-//sysnb Getpgrp() (pgrp int)
-//sysnb Getpid() (pid int)
-//sysnb Getppid() (ppid int)
-//sys Getpriority(which int, who int) (prio int, err error)
-//sysnb Getrlimit(which int, lim *Rlimit) (err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Getsid(pid int) (sid int, err error)
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Getuid() (uid int)
-//sys Issetugid() (tainted bool)
-//sys Kill(pid int, signum syscall.Signal) (err error)
-//sys Kqueue() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Link(path string, link string) (err error)
-//sys Listen(s int, backlog int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Mkdir(path string, mode uint32) (err error)
-//sys Mkfifo(path string, mode uint32) (err error)
-//sys Mknod(path string, mode uint32, dev int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Munlockall() (err error)
-//sys Nanosleep(time *Timespec, leftover *Timespec) (err error)
-//sys Open(path string, mode int, perm uint32) (fd int, err error)
-//sys Pathconf(path string, name int) (val int, err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Readlink(path string, buf []byte) (n int, err error)
-//sys Rename(from string, to string) (err error)
-//sys Revoke(path string) (err error)
-//sys Rmdir(path string) (err error)
-//sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK
-//sys Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error)
-//sysnb Setegid(egid int) (err error)
-//sysnb Seteuid(euid int) (err error)
-//sysnb Setgid(gid int) (err error)
-//sys Setlogin(name string) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sys Setpriority(which int, who int, prio int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(which int, lim *Rlimit) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Settimeofday(tp *Timeval) (err error)
-//sysnb Setuid(uid int) (err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, stat *Statfs_t) (err error)
-//sys Symlink(path string, link string) (err error)
-//sys Sync() (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys Umask(newmask int) (oldmask int)
-//sys Undelete(path string) (err error)
-//sys Unlink(path string) (err error)
-//sys Unmount(path string, flags int) (err error)
-//sys write(fd int, p []byte) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error)
-//sys munmap(addr uintptr, length uintptr) (err error)
-//sys readlen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_READ
-//sys writelen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_WRITE
-//sys accept4(fd int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (nfd int, err error)
-
-/*
- * Unimplemented
- * TODO(jsing): Update this list for DragonFly.
- */
-// Profil
-// Sigaction
-// Sigprocmask
-// Getlogin
-// Sigpending
-// Sigaltstack
-// Ioctl
-// Reboot
-// Execve
-// Vfork
-// Sbrk
-// Sstk
-// Ovadvise
-// Mincore
-// Setitimer
-// Swapon
-// Select
-// Sigsuspend
-// Readv
-// Writev
-// Nfssvc
-// Getfh
-// Quotactl
-// Mount
-// Csops
-// Waitid
-// Add_profil
-// Kdebug_trace
-// Sigreturn
-// Mmap
-// Mlock
-// Munlock
-// Atsocket
-// Kqueue_from_portset_np
-// Kqueue_portset
-// Getattrlist
-// Setattrlist
-// Getdirentriesattr
-// Searchfs
-// Delete
-// Copyfile
-// Poll
-// Watchevent
-// Waitevent
-// Modwatch
-// Getxattr
-// Fgetxattr
-// Setxattr
-// Fsetxattr
-// Removexattr
-// Fremovexattr
-// Listxattr
-// Flistxattr
-// Fsctl
-// Initgroups
-// Posix_spawn
-// Nfsclnt
-// Fhopen
-// Minherit
-// Semsys
-// Msgsys
-// Shmsys
-// Semctl
-// Semget
-// Semop
-// Msgctl
-// Msgget
-// Msgsnd
-// Msgrcv
-// Shmat
-// Shmctl
-// Shmdt
-// Shmget
-// Shm_open
-// Shm_unlink
-// Sem_open
-// Sem_close
-// Sem_unlink
-// Sem_wait
-// Sem_trywait
-// Sem_post
-// Sem_getvalue
-// Sem_init
-// Sem_destroy
-// Open_extended
-// Umask_extended
-// Stat_extended
-// Lstat_extended
-// Fstat_extended
-// Chmod_extended
-// Fchmod_extended
-// Access_extended
-// Settid
-// Gettid
-// Setsgroups
-// Getsgroups
-// Setwgroups
-// Getwgroups
-// Mkfifo_extended
-// Mkdir_extended
-// Identitysvc
-// Shared_region_check_np
-// Shared_region_map_np
-// __pthread_mutex_destroy
-// __pthread_mutex_init
-// __pthread_mutex_lock
-// __pthread_mutex_trylock
-// __pthread_mutex_unlock
-// __pthread_cond_init
-// __pthread_cond_destroy
-// __pthread_cond_broadcast
-// __pthread_cond_signal
-// Setsid_with_pid
-// __pthread_cond_timedwait
-// Aio_fsync
-// Aio_return
-// Aio_suspend
-// Aio_cancel
-// Aio_error
-// Aio_read
-// Aio_write
-// Lio_listio
-// __pthread_cond_wait
-// Iopolicysys
-// Mlockall
-// Munlockall
-// __pthread_kill
-// __pthread_sigmask
-// __sigwait
-// __disable_threadsignal
-// __pthread_markcancel
-// __pthread_canceled
-// __semwait_signal
-// Proc_info
-// Stat64_extended
-// Lstat64_extended
-// Fstat64_extended
-// __pthread_chdir
-// __pthread_fchdir
-// Audit
-// Auditon
-// Getauid
-// Setauid
-// Getaudit
-// Setaudit
-// Getaudit_addr
-// Setaudit_addr
-// Auditctl
-// Bsdthread_create
-// Bsdthread_terminate
-// Stack_snapshot
-// Bsdthread_register
-// Workq_open
-// Workq_ops
-// __mac_execve
-// __mac_syscall
-// __mac_get_file
-// __mac_set_file
-// __mac_get_link
-// __mac_set_link
-// __mac_get_proc
-// __mac_set_proc
-// __mac_get_fd
-// __mac_set_fd
-// __mac_get_pid
-// __mac_get_lcid
-// __mac_get_lctx
-// __mac_set_lctx
-// Setlcid
-// Read_nocancel
-// Write_nocancel
-// Open_nocancel
-// Close_nocancel
-// Wait4_nocancel
-// Recvmsg_nocancel
-// Sendmsg_nocancel
-// Recvfrom_nocancel
-// Accept_nocancel
-// Msync_nocancel
-// Fcntl_nocancel
-// Select_nocancel
-// Fsync_nocancel
-// Connect_nocancel
-// Sigsuspend_nocancel
-// Readv_nocancel
-// Writev_nocancel
-// Sendto_nocancel
-// Pread_nocancel
-// Pwrite_nocancel
-// Waitid_nocancel
-// Poll_nocancel
-// Msgsnd_nocancel
-// Msgrcv_nocancel
-// Sem_wait_nocancel
-// Aio_suspend_nocancel
-// __sigwait_nocancel
-// __semwait_signal_nocancel
-// __mac_mount
-// __mac_get_mount
-// __mac_getfsstat
diff --git a/vendor/golang.org/x/sys/unix/syscall_dragonfly_amd64.go b/vendor/golang.org/x/sys/unix/syscall_dragonfly_amd64.go
deleted file mode 100644
index da7cb7982..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_dragonfly_amd64.go
+++ /dev/null
@@ -1,61 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,dragonfly
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = nsec % 1e9 / 1e3
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint64(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var writtenOut uint64 = 0
- _, _, e1 := Syscall9(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr(count), 0, uintptr(unsafe.Pointer(&writtenOut)), 0, 0, 0)
-
- written = int(writtenOut)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
diff --git a/vendor/golang.org/x/sys/unix/syscall_freebsd.go b/vendor/golang.org/x/sys/unix/syscall_freebsd.go
deleted file mode 100644
index 077d1f39a..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_freebsd.go
+++ /dev/null
@@ -1,666 +0,0 @@
-// Copyright 2009,2010 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// FreeBSD system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and wrap
-// it in our own nicer implementation, either here or in
-// syscall_bsd.go or syscall_unix.go.
-
-package unix
-
-import "unsafe"
-
-type SockaddrDatalink struct {
- Len uint8
- Family uint8
- Index uint16
- Type uint8
- Nlen uint8
- Alen uint8
- Slen uint8
- Data [46]int8
- raw RawSockaddrDatalink
-}
-
-// Translate "kern.hostname" to []_C_int{0,1,2,3}.
-func nametomib(name string) (mib []_C_int, err error) {
- const siz = unsafe.Sizeof(mib[0])
-
- // NOTE(rsc): It seems strange to set the buffer to have
- // size CTL_MAXNAME+2 but use only CTL_MAXNAME
- // as the size. I don't know why the +2 is here, but the
- // kernel uses +2 for its own implementation of this function.
- // I am scared that if we don't include the +2 here, the kernel
- // will silently write 2 words farther than we specify
- // and we'll get memory corruption.
- var buf [CTL_MAXNAME + 2]_C_int
- n := uintptr(CTL_MAXNAME) * siz
-
- p := (*byte)(unsafe.Pointer(&buf[0]))
- bytes, err := ByteSliceFromString(name)
- if err != nil {
- return nil, err
- }
-
- // Magic sysctl: "setting" 0.3 to a string name
- // lets you read back the array of integers form.
- if err = sysctl([]_C_int{0, 3}, p, &n, &bytes[0], uintptr(len(name))); err != nil {
- return nil, err
- }
- return buf[0 : n/siz], nil
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen))
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen))
-}
-
-//sysnb pipe() (r int, w int, err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- p[0], p[1], err = pipe()
- return
-}
-
-func GetsockoptIPMreqn(fd, level, opt int) (*IPMreqn, error) {
- var value IPMreqn
- vallen := _Socklen(SizeofIPMreqn)
- errno := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, errno
-}
-
-func SetsockoptIPMreqn(fd, level, opt int, mreq *IPMreqn) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(mreq), unsafe.Sizeof(*mreq))
-}
-
-func Accept4(fd, flags int) (nfd int, sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- nfd, err = accept4(fd, &rsa, &len, flags)
- if err != nil {
- return
- }
- if len > SizeofSockaddrAny {
- panic("RawSockaddrAny too small")
- }
- sa, err = anyToSockaddr(&rsa)
- if err != nil {
- Close(nfd)
- nfd = 0
- }
- return
-}
-
-func Getfsstat(buf []Statfs_t, flags int) (n int, err error) {
- var _p0 unsafe.Pointer
- var bufsize uintptr
- if len(buf) > 0 {
- _p0 = unsafe.Pointer(&buf[0])
- bufsize = unsafe.Sizeof(Statfs_t{}) * uintptr(len(buf))
- }
- r0, _, e1 := Syscall(SYS_GETFSSTAT, uintptr(_p0), bufsize, uintptr(flags))
- n = int(r0)
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-// Derive extattr namespace and attribute name
-
-func xattrnamespace(fullattr string) (ns int, attr string, err error) {
- s := -1
- for idx, val := range fullattr {
- if val == '.' {
- s = idx
- break
- }
- }
-
- if s == -1 {
- return -1, "", ENOATTR
- }
-
- namespace := fullattr[0:s]
- attr = fullattr[s+1:]
-
- switch namespace {
- case "user":
- return EXTATTR_NAMESPACE_USER, attr, nil
- case "system":
- return EXTATTR_NAMESPACE_SYSTEM, attr, nil
- default:
- return -1, "", ENOATTR
- }
-}
-
-func initxattrdest(dest []byte, idx int) (d unsafe.Pointer) {
- if len(dest) > idx {
- return unsafe.Pointer(&dest[idx])
- } else {
- return unsafe.Pointer(_zero)
- }
-}
-
-// FreeBSD implements its own syscalls to handle extended attributes
-
-func Getxattr(file string, attr string, dest []byte) (sz int, err error) {
- d := initxattrdest(dest, 0)
- destsize := len(dest)
-
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return -1, err
- }
-
- return ExtattrGetFile(file, nsid, a, uintptr(d), destsize)
-}
-
-func Fgetxattr(fd int, attr string, dest []byte) (sz int, err error) {
- d := initxattrdest(dest, 0)
- destsize := len(dest)
-
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return -1, err
- }
-
- return ExtattrGetFd(fd, nsid, a, uintptr(d), destsize)
-}
-
-func Lgetxattr(link string, attr string, dest []byte) (sz int, err error) {
- d := initxattrdest(dest, 0)
- destsize := len(dest)
-
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return -1, err
- }
-
- return ExtattrGetLink(link, nsid, a, uintptr(d), destsize)
-}
-
-// flags are unused on FreeBSD
-
-func Fsetxattr(fd int, attr string, data []byte, flags int) (err error) {
- d := unsafe.Pointer(&data[0])
- datasiz := len(data)
-
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return
- }
-
- _, err = ExtattrSetFd(fd, nsid, a, uintptr(d), datasiz)
- return
-}
-
-func Setxattr(file string, attr string, data []byte, flags int) (err error) {
- d := unsafe.Pointer(&data[0])
- datasiz := len(data)
-
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return
- }
-
- _, err = ExtattrSetFile(file, nsid, a, uintptr(d), datasiz)
- return
-}
-
-func Lsetxattr(link string, attr string, data []byte, flags int) (err error) {
- d := unsafe.Pointer(&data[0])
- datasiz := len(data)
-
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return
- }
-
- _, err = ExtattrSetLink(link, nsid, a, uintptr(d), datasiz)
- return
-}
-
-func Removexattr(file string, attr string) (err error) {
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return
- }
-
- err = ExtattrDeleteFile(file, nsid, a)
- return
-}
-
-func Fremovexattr(fd int, attr string) (err error) {
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return
- }
-
- err = ExtattrDeleteFd(fd, nsid, a)
- return
-}
-
-func Lremovexattr(link string, attr string) (err error) {
- nsid, a, err := xattrnamespace(attr)
- if err != nil {
- return
- }
-
- err = ExtattrDeleteLink(link, nsid, a)
- return
-}
-
-func Listxattr(file string, dest []byte) (sz int, err error) {
- d := initxattrdest(dest, 0)
- destsiz := len(dest)
-
- // FreeBSD won't allow you to list xattrs from multiple namespaces
- s := 0
- var e error
- for _, nsid := range [...]int{EXTATTR_NAMESPACE_USER, EXTATTR_NAMESPACE_SYSTEM} {
- stmp, e := ExtattrListFile(file, nsid, uintptr(d), destsiz)
-
- /* Errors accessing system attrs are ignored so that
- * we can implement the Linux-like behavior of omitting errors that
- * we don't have read permissions on
- *
- * Linux will still error if we ask for user attributes on a file that
- * we don't have read permissions on, so don't ignore those errors
- */
- if e != nil && e == EPERM && nsid != EXTATTR_NAMESPACE_USER {
- e = nil
- continue
- } else if e != nil {
- return s, e
- }
-
- s += stmp
- destsiz -= s
- if destsiz < 0 {
- destsiz = 0
- }
- d = initxattrdest(dest, s)
- }
-
- return s, e
-}
-
-func Flistxattr(fd int, dest []byte) (sz int, err error) {
- d := initxattrdest(dest, 0)
- destsiz := len(dest)
-
- s := 0
- var e error
- for _, nsid := range [...]int{EXTATTR_NAMESPACE_USER, EXTATTR_NAMESPACE_SYSTEM} {
- stmp, e := ExtattrListFd(fd, nsid, uintptr(d), destsiz)
- if e != nil && e == EPERM && nsid != EXTATTR_NAMESPACE_USER {
- e = nil
- continue
- } else if e != nil {
- return s, e
- }
-
- s += stmp
- destsiz -= s
- if destsiz < 0 {
- destsiz = 0
- }
- d = initxattrdest(dest, s)
- }
-
- return s, e
-}
-
-func Llistxattr(link string, dest []byte) (sz int, err error) {
- d := initxattrdest(dest, 0)
- destsiz := len(dest)
-
- s := 0
- var e error
- for _, nsid := range [...]int{EXTATTR_NAMESPACE_USER, EXTATTR_NAMESPACE_SYSTEM} {
- stmp, e := ExtattrListLink(link, nsid, uintptr(d), destsiz)
- if e != nil && e == EPERM && nsid != EXTATTR_NAMESPACE_USER {
- e = nil
- continue
- } else if e != nil {
- return s, e
- }
-
- s += stmp
- destsiz -= s
- if destsiz < 0 {
- destsiz = 0
- }
- d = initxattrdest(dest, s)
- }
-
- return s, e
-}
-
-/*
- * Exposed directly
- */
-//sys Access(path string, mode uint32) (err error)
-//sys Adjtime(delta *Timeval, olddelta *Timeval) (err error)
-//sys Chdir(path string) (err error)
-//sys Chflags(path string, flags int) (err error)
-//sys Chmod(path string, mode uint32) (err error)
-//sys Chown(path string, uid int, gid int) (err error)
-//sys Chroot(path string) (err error)
-//sys Close(fd int) (err error)
-//sys Dup(fd int) (nfd int, err error)
-//sys Dup2(from int, to int) (err error)
-//sys Exit(code int)
-//sys ExtattrGetFd(fd int, attrnamespace int, attrname string, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrSetFd(fd int, attrnamespace int, attrname string, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrDeleteFd(fd int, attrnamespace int, attrname string) (err error)
-//sys ExtattrListFd(fd int, attrnamespace int, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrGetFile(file string, attrnamespace int, attrname string, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrSetFile(file string, attrnamespace int, attrname string, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrDeleteFile(file string, attrnamespace int, attrname string) (err error)
-//sys ExtattrListFile(file string, attrnamespace int, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrGetLink(link string, attrnamespace int, attrname string, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrSetLink(link string, attrnamespace int, attrname string, data uintptr, nbytes int) (ret int, err error)
-//sys ExtattrDeleteLink(link string, attrnamespace int, attrname string) (err error)
-//sys ExtattrListLink(link string, attrnamespace int, data uintptr, nbytes int) (ret int, err error)
-//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_POSIX_FADVISE
-//sys Fchdir(fd int) (err error)
-//sys Fchflags(fd int, flags int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Flock(fd int, how int) (err error)
-//sys Fpathconf(fd int, name int) (val int, err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, stat *Statfs_t) (err error)
-//sys Fsync(fd int) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sys Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error)
-//sys Getdtablesize() (size int)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (uid int)
-//sysnb Getgid() (gid int)
-//sysnb Getpgid(pid int) (pgid int, err error)
-//sysnb Getpgrp() (pgrp int)
-//sysnb Getpid() (pid int)
-//sysnb Getppid() (ppid int)
-//sys Getpriority(which int, who int) (prio int, err error)
-//sysnb Getrlimit(which int, lim *Rlimit) (err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Getsid(pid int) (sid int, err error)
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Getuid() (uid int)
-//sys Issetugid() (tainted bool)
-//sys Kill(pid int, signum syscall.Signal) (err error)
-//sys Kqueue() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Link(path string, link string) (err error)
-//sys Listen(s int, backlog int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Mkdir(path string, mode uint32) (err error)
-//sys Mkfifo(path string, mode uint32) (err error)
-//sys Mknod(path string, mode uint32, dev int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Munlockall() (err error)
-//sys Nanosleep(time *Timespec, leftover *Timespec) (err error)
-//sys Open(path string, mode int, perm uint32) (fd int, err error)
-//sys Pathconf(path string, name int) (val int, err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error)
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Readlink(path string, buf []byte) (n int, err error)
-//sys Rename(from string, to string) (err error)
-//sys Revoke(path string) (err error)
-//sys Rmdir(path string) (err error)
-//sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK
-//sys Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error)
-//sysnb Setegid(egid int) (err error)
-//sysnb Seteuid(euid int) (err error)
-//sysnb Setgid(gid int) (err error)
-//sys Setlogin(name string) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sys Setpriority(which int, who int, prio int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(which int, lim *Rlimit) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Settimeofday(tp *Timeval) (err error)
-//sysnb Setuid(uid int) (err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, stat *Statfs_t) (err error)
-//sys Symlink(path string, link string) (err error)
-//sys Sync() (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys Umask(newmask int) (oldmask int)
-//sys Undelete(path string) (err error)
-//sys Unlink(path string) (err error)
-//sys Unmount(path string, flags int) (err error)
-//sys write(fd int, p []byte) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error)
-//sys munmap(addr uintptr, length uintptr) (err error)
-//sys readlen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_READ
-//sys writelen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_WRITE
-//sys accept4(fd int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (nfd int, err error)
-
-/*
- * Unimplemented
- */
-// Profil
-// Sigaction
-// Sigprocmask
-// Getlogin
-// Sigpending
-// Sigaltstack
-// Ioctl
-// Reboot
-// Execve
-// Vfork
-// Sbrk
-// Sstk
-// Ovadvise
-// Mincore
-// Setitimer
-// Swapon
-// Select
-// Sigsuspend
-// Readv
-// Writev
-// Nfssvc
-// Getfh
-// Quotactl
-// Mount
-// Csops
-// Waitid
-// Add_profil
-// Kdebug_trace
-// Sigreturn
-// Mmap
-// Mlock
-// Munlock
-// Atsocket
-// Kqueue_from_portset_np
-// Kqueue_portset
-// Getattrlist
-// Setattrlist
-// Getdirentriesattr
-// Searchfs
-// Delete
-// Copyfile
-// Poll
-// Watchevent
-// Waitevent
-// Modwatch
-// Getxattr
-// Fgetxattr
-// Setxattr
-// Fsetxattr
-// Removexattr
-// Fremovexattr
-// Listxattr
-// Flistxattr
-// Fsctl
-// Initgroups
-// Posix_spawn
-// Nfsclnt
-// Fhopen
-// Minherit
-// Semsys
-// Msgsys
-// Shmsys
-// Semctl
-// Semget
-// Semop
-// Msgctl
-// Msgget
-// Msgsnd
-// Msgrcv
-// Shmat
-// Shmctl
-// Shmdt
-// Shmget
-// Shm_open
-// Shm_unlink
-// Sem_open
-// Sem_close
-// Sem_unlink
-// Sem_wait
-// Sem_trywait
-// Sem_post
-// Sem_getvalue
-// Sem_init
-// Sem_destroy
-// Open_extended
-// Umask_extended
-// Stat_extended
-// Lstat_extended
-// Fstat_extended
-// Chmod_extended
-// Fchmod_extended
-// Access_extended
-// Settid
-// Gettid
-// Setsgroups
-// Getsgroups
-// Setwgroups
-// Getwgroups
-// Mkfifo_extended
-// Mkdir_extended
-// Identitysvc
-// Shared_region_check_np
-// Shared_region_map_np
-// __pthread_mutex_destroy
-// __pthread_mutex_init
-// __pthread_mutex_lock
-// __pthread_mutex_trylock
-// __pthread_mutex_unlock
-// __pthread_cond_init
-// __pthread_cond_destroy
-// __pthread_cond_broadcast
-// __pthread_cond_signal
-// Setsid_with_pid
-// __pthread_cond_timedwait
-// Aio_fsync
-// Aio_return
-// Aio_suspend
-// Aio_cancel
-// Aio_error
-// Aio_read
-// Aio_write
-// Lio_listio
-// __pthread_cond_wait
-// Iopolicysys
-// Mlockall
-// Munlockall
-// __pthread_kill
-// __pthread_sigmask
-// __sigwait
-// __disable_threadsignal
-// __pthread_markcancel
-// __pthread_canceled
-// __semwait_signal
-// Proc_info
-// Stat64_extended
-// Lstat64_extended
-// Fstat64_extended
-// __pthread_chdir
-// __pthread_fchdir
-// Audit
-// Auditon
-// Getauid
-// Setauid
-// Getaudit
-// Setaudit
-// Getaudit_addr
-// Setaudit_addr
-// Auditctl
-// Bsdthread_create
-// Bsdthread_terminate
-// Stack_snapshot
-// Bsdthread_register
-// Workq_open
-// Workq_ops
-// __mac_execve
-// __mac_syscall
-// __mac_get_file
-// __mac_set_file
-// __mac_get_link
-// __mac_set_link
-// __mac_get_proc
-// __mac_set_proc
-// __mac_get_fd
-// __mac_set_fd
-// __mac_get_pid
-// __mac_get_lcid
-// __mac_get_lctx
-// __mac_set_lctx
-// Setlcid
-// Read_nocancel
-// Write_nocancel
-// Open_nocancel
-// Close_nocancel
-// Wait4_nocancel
-// Recvmsg_nocancel
-// Sendmsg_nocancel
-// Recvfrom_nocancel
-// Accept_nocancel
-// Msync_nocancel
-// Fcntl_nocancel
-// Select_nocancel
-// Fsync_nocancel
-// Connect_nocancel
-// Sigsuspend_nocancel
-// Readv_nocancel
-// Writev_nocancel
-// Sendto_nocancel
-// Pread_nocancel
-// Pwrite_nocancel
-// Waitid_nocancel
-// Poll_nocancel
-// Msgsnd_nocancel
-// Msgrcv_nocancel
-// Sem_wait_nocancel
-// Aio_suspend_nocancel
-// __sigwait_nocancel
-// __semwait_signal_nocancel
-// __mac_mount
-// __mac_get_mount
-// __mac_getfsstat
diff --git a/vendor/golang.org/x/sys/unix/syscall_freebsd_386.go b/vendor/golang.org/x/sys/unix/syscall_freebsd_386.go
deleted file mode 100644
index 6a0cd804d..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_freebsd_386.go
+++ /dev/null
@@ -1,61 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build 386,freebsd
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int32(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int32(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var writtenOut uint64 = 0
- _, _, e1 := Syscall9(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr((*offset)>>32), uintptr(count), 0, uintptr(unsafe.Pointer(&writtenOut)), 0, 0)
-
- written = int(writtenOut)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
diff --git a/vendor/golang.org/x/sys/unix/syscall_freebsd_amd64.go b/vendor/golang.org/x/sys/unix/syscall_freebsd_amd64.go
deleted file mode 100644
index e142540ef..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_freebsd_amd64.go
+++ /dev/null
@@ -1,61 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,freebsd
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = nsec % 1e9 / 1e3
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint64(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var writtenOut uint64 = 0
- _, _, e1 := Syscall9(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr(count), 0, uintptr(unsafe.Pointer(&writtenOut)), 0, 0, 0)
-
- written = int(writtenOut)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
diff --git a/vendor/golang.org/x/sys/unix/syscall_freebsd_arm.go b/vendor/golang.org/x/sys/unix/syscall_freebsd_arm.go
deleted file mode 100644
index 5504cb125..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_freebsd_arm.go
+++ /dev/null
@@ -1,61 +0,0 @@
-// Copyright 2012 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build arm,freebsd
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return ts.Sec*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = nsec / 1e9
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- var writtenOut uint64 = 0
- _, _, e1 := Syscall9(SYS_SENDFILE, uintptr(infd), uintptr(outfd), uintptr(*offset), uintptr((*offset)>>32), uintptr(count), 0, uintptr(unsafe.Pointer(&writtenOut)), 0, 0)
-
- written = int(writtenOut)
-
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func Syscall9(num, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux.go b/vendor/golang.org/x/sys/unix/syscall_linux.go
deleted file mode 100644
index 9737e08b0..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux.go
+++ /dev/null
@@ -1,1297 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Linux system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and
-// wrap it in our own nicer implementation.
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-/*
- * Wrapped
- */
-
-func Access(path string, mode uint32) (err error) {
- return Faccessat(AT_FDCWD, path, mode, 0)
-}
-
-func Chmod(path string, mode uint32) (err error) {
- return Fchmodat(AT_FDCWD, path, mode, 0)
-}
-
-func Chown(path string, uid int, gid int) (err error) {
- return Fchownat(AT_FDCWD, path, uid, gid, 0)
-}
-
-func Creat(path string, mode uint32) (fd int, err error) {
- return Open(path, O_CREAT|O_WRONLY|O_TRUNC, mode)
-}
-
-//sys Linkat(olddirfd int, oldpath string, newdirfd int, newpath string, flags int) (err error)
-
-func Link(oldpath string, newpath string) (err error) {
- return Linkat(AT_FDCWD, oldpath, AT_FDCWD, newpath, 0)
-}
-
-func Mkdir(path string, mode uint32) (err error) {
- return Mkdirat(AT_FDCWD, path, mode)
-}
-
-func Mknod(path string, mode uint32, dev int) (err error) {
- return Mknodat(AT_FDCWD, path, mode, dev)
-}
-
-func Open(path string, mode int, perm uint32) (fd int, err error) {
- return openat(AT_FDCWD, path, mode|O_LARGEFILE, perm)
-}
-
-//sys openat(dirfd int, path string, flags int, mode uint32) (fd int, err error)
-
-func Openat(dirfd int, path string, flags int, mode uint32) (fd int, err error) {
- return openat(dirfd, path, flags|O_LARGEFILE, mode)
-}
-
-//sys ppoll(fds *PollFd, nfds int, timeout *Timespec, sigmask *Sigset_t) (n int, err error)
-
-func Ppoll(fds []PollFd, timeout *Timespec, sigmask *Sigset_t) (n int, err error) {
- if len(fds) == 0 {
- return ppoll(nil, 0, timeout, sigmask)
- }
- return ppoll(&fds[0], len(fds), timeout, sigmask)
-}
-
-//sys Readlinkat(dirfd int, path string, buf []byte) (n int, err error)
-
-func Readlink(path string, buf []byte) (n int, err error) {
- return Readlinkat(AT_FDCWD, path, buf)
-}
-
-func Rename(oldpath string, newpath string) (err error) {
- return Renameat(AT_FDCWD, oldpath, AT_FDCWD, newpath)
-}
-
-func Rmdir(path string) error {
- return Unlinkat(AT_FDCWD, path, AT_REMOVEDIR)
-}
-
-//sys Symlinkat(oldpath string, newdirfd int, newpath string) (err error)
-
-func Symlink(oldpath string, newpath string) (err error) {
- return Symlinkat(oldpath, AT_FDCWD, newpath)
-}
-
-func Unlink(path string) error {
- return Unlinkat(AT_FDCWD, path, 0)
-}
-
-//sys Unlinkat(dirfd int, path string, flags int) (err error)
-
-//sys utimes(path string, times *[2]Timeval) (err error)
-
-func Utimes(path string, tv []Timeval) error {
- if tv == nil {
- err := utimensat(AT_FDCWD, path, nil, 0)
- if err != ENOSYS {
- return err
- }
- return utimes(path, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- var ts [2]Timespec
- ts[0] = NsecToTimespec(TimevalToNsec(tv[0]))
- ts[1] = NsecToTimespec(TimevalToNsec(tv[1]))
- err := utimensat(AT_FDCWD, path, (*[2]Timespec)(unsafe.Pointer(&ts[0])), 0)
- if err != ENOSYS {
- return err
- }
- return utimes(path, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-//sys utimensat(dirfd int, path string, times *[2]Timespec, flags int) (err error)
-
-func UtimesNano(path string, ts []Timespec) error {
- if ts == nil {
- err := utimensat(AT_FDCWD, path, nil, 0)
- if err != ENOSYS {
- return err
- }
- return utimes(path, nil)
- }
- if len(ts) != 2 {
- return EINVAL
- }
- err := utimensat(AT_FDCWD, path, (*[2]Timespec)(unsafe.Pointer(&ts[0])), 0)
- if err != ENOSYS {
- return err
- }
- // If the utimensat syscall isn't available (utimensat was added to Linux
- // in 2.6.22, Released, 8 July 2007) then fall back to utimes
- var tv [2]Timeval
- for i := 0; i < 2; i++ {
- tv[i] = NsecToTimeval(TimespecToNsec(ts[i]))
- }
- return utimes(path, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-func UtimesNanoAt(dirfd int, path string, ts []Timespec, flags int) error {
- if ts == nil {
- return utimensat(dirfd, path, nil, flags)
- }
- if len(ts) != 2 {
- return EINVAL
- }
- return utimensat(dirfd, path, (*[2]Timespec)(unsafe.Pointer(&ts[0])), flags)
-}
-
-//sys futimesat(dirfd int, path *byte, times *[2]Timeval) (err error)
-
-func Futimesat(dirfd int, path string, tv []Timeval) error {
- pathp, err := BytePtrFromString(path)
- if err != nil {
- return err
- }
- if tv == nil {
- return futimesat(dirfd, pathp, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- return futimesat(dirfd, pathp, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-func Futimes(fd int, tv []Timeval) (err error) {
- // Believe it or not, this is the best we can do on Linux
- // (and is what glibc does).
- return Utimes("/proc/self/fd/"+itoa(fd), tv)
-}
-
-const ImplementsGetwd = true
-
-//sys Getcwd(buf []byte) (n int, err error)
-
-func Getwd() (wd string, err error) {
- var buf [PathMax]byte
- n, err := Getcwd(buf[0:])
- if err != nil {
- return "", err
- }
- // Getcwd returns the number of bytes written to buf, including the NUL.
- if n < 1 || n > len(buf) || buf[n-1] != 0 {
- return "", EINVAL
- }
- return string(buf[0 : n-1]), nil
-}
-
-func Getgroups() (gids []int, err error) {
- n, err := getgroups(0, nil)
- if err != nil {
- return nil, err
- }
- if n == 0 {
- return nil, nil
- }
-
- // Sanity check group count. Max is 1<<16 on Linux.
- if n < 0 || n > 1<<20 {
- return nil, EINVAL
- }
-
- a := make([]_Gid_t, n)
- n, err = getgroups(n, &a[0])
- if err != nil {
- return nil, err
- }
- gids = make([]int, n)
- for i, v := range a[0:n] {
- gids[i] = int(v)
- }
- return
-}
-
-func Setgroups(gids []int) (err error) {
- if len(gids) == 0 {
- return setgroups(0, nil)
- }
-
- a := make([]_Gid_t, len(gids))
- for i, v := range gids {
- a[i] = _Gid_t(v)
- }
- return setgroups(len(a), &a[0])
-}
-
-type WaitStatus uint32
-
-// Wait status is 7 bits at bottom, either 0 (exited),
-// 0x7F (stopped), or a signal number that caused an exit.
-// The 0x80 bit is whether there was a core dump.
-// An extra number (exit code, signal causing a stop)
-// is in the high bits. At least that's the idea.
-// There are various irregularities. For example, the
-// "continued" status is 0xFFFF, distinguishing itself
-// from stopped via the core dump bit.
-
-const (
- mask = 0x7F
- core = 0x80
- exited = 0x00
- stopped = 0x7F
- shift = 8
-)
-
-func (w WaitStatus) Exited() bool { return w&mask == exited }
-
-func (w WaitStatus) Signaled() bool { return w&mask != stopped && w&mask != exited }
-
-func (w WaitStatus) Stopped() bool { return w&0xFF == stopped }
-
-func (w WaitStatus) Continued() bool { return w == 0xFFFF }
-
-func (w WaitStatus) CoreDump() bool { return w.Signaled() && w&core != 0 }
-
-func (w WaitStatus) ExitStatus() int {
- if !w.Exited() {
- return -1
- }
- return int(w>>shift) & 0xFF
-}
-
-func (w WaitStatus) Signal() syscall.Signal {
- if !w.Signaled() {
- return -1
- }
- return syscall.Signal(w & mask)
-}
-
-func (w WaitStatus) StopSignal() syscall.Signal {
- if !w.Stopped() {
- return -1
- }
- return syscall.Signal(w>>shift) & 0xFF
-}
-
-func (w WaitStatus) TrapCause() int {
- if w.StopSignal() != SIGTRAP {
- return -1
- }
- return int(w>>shift) >> 8
-}
-
-//sys wait4(pid int, wstatus *_C_int, options int, rusage *Rusage) (wpid int, err error)
-
-func Wait4(pid int, wstatus *WaitStatus, options int, rusage *Rusage) (wpid int, err error) {
- var status _C_int
- wpid, err = wait4(pid, &status, options, rusage)
- if wstatus != nil {
- *wstatus = WaitStatus(status)
- }
- return
-}
-
-func Mkfifo(path string, mode uint32) (err error) {
- return Mknod(path, mode|S_IFIFO, 0)
-}
-
-func (sa *SockaddrInet4) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Port < 0 || sa.Port > 0xFFFF {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_INET
- p := (*[2]byte)(unsafe.Pointer(&sa.raw.Port))
- p[0] = byte(sa.Port >> 8)
- p[1] = byte(sa.Port)
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrInet4, nil
-}
-
-func (sa *SockaddrInet6) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Port < 0 || sa.Port > 0xFFFF {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_INET6
- p := (*[2]byte)(unsafe.Pointer(&sa.raw.Port))
- p[0] = byte(sa.Port >> 8)
- p[1] = byte(sa.Port)
- sa.raw.Scope_id = sa.ZoneId
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrInet6, nil
-}
-
-func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, _Socklen, error) {
- name := sa.Name
- n := len(name)
- if n >= len(sa.raw.Path) {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_UNIX
- for i := 0; i < n; i++ {
- sa.raw.Path[i] = int8(name[i])
- }
- // length is family (uint16), name, NUL.
- sl := _Socklen(2)
- if n > 0 {
- sl += _Socklen(n) + 1
- }
- if sa.raw.Path[0] == '@' {
- sa.raw.Path[0] = 0
- // Don't count trailing NUL for abstract address.
- sl--
- }
-
- return unsafe.Pointer(&sa.raw), sl, nil
-}
-
-type SockaddrLinklayer struct {
- Protocol uint16
- Ifindex int
- Hatype uint16
- Pkttype uint8
- Halen uint8
- Addr [8]byte
- raw RawSockaddrLinklayer
-}
-
-func (sa *SockaddrLinklayer) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Ifindex < 0 || sa.Ifindex > 0x7fffffff {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_PACKET
- sa.raw.Protocol = sa.Protocol
- sa.raw.Ifindex = int32(sa.Ifindex)
- sa.raw.Hatype = sa.Hatype
- sa.raw.Pkttype = sa.Pkttype
- sa.raw.Halen = sa.Halen
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrLinklayer, nil
-}
-
-type SockaddrNetlink struct {
- Family uint16
- Pad uint16
- Pid uint32
- Groups uint32
- raw RawSockaddrNetlink
-}
-
-func (sa *SockaddrNetlink) sockaddr() (unsafe.Pointer, _Socklen, error) {
- sa.raw.Family = AF_NETLINK
- sa.raw.Pad = sa.Pad
- sa.raw.Pid = sa.Pid
- sa.raw.Groups = sa.Groups
- return unsafe.Pointer(&sa.raw), SizeofSockaddrNetlink, nil
-}
-
-type SockaddrHCI struct {
- Dev uint16
- Channel uint16
- raw RawSockaddrHCI
-}
-
-func (sa *SockaddrHCI) sockaddr() (unsafe.Pointer, _Socklen, error) {
- sa.raw.Family = AF_BLUETOOTH
- sa.raw.Dev = sa.Dev
- sa.raw.Channel = sa.Channel
- return unsafe.Pointer(&sa.raw), SizeofSockaddrHCI, nil
-}
-
-// SockaddrCAN implements the Sockaddr interface for AF_CAN type sockets.
-// The RxID and TxID fields are used for transport protocol addressing in
-// (CAN_TP16, CAN_TP20, CAN_MCNET, and CAN_ISOTP), they can be left with
-// zero values for CAN_RAW and CAN_BCM sockets as they have no meaning.
-//
-// The SockaddrCAN struct must be bound to the socket file descriptor
-// using Bind before the CAN socket can be used.
-//
-// // Read one raw CAN frame
-// fd, _ := Socket(AF_CAN, SOCK_RAW, CAN_RAW)
-// addr := &SockaddrCAN{Ifindex: index}
-// Bind(fd, addr)
-// frame := make([]byte, 16)
-// Read(fd, frame)
-//
-// The full SocketCAN documentation can be found in the linux kernel
-// archives at: https://www.kernel.org/doc/Documentation/networking/can.txt
-type SockaddrCAN struct {
- Ifindex int
- RxID uint32
- TxID uint32
- raw RawSockaddrCAN
-}
-
-func (sa *SockaddrCAN) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Ifindex < 0 || sa.Ifindex > 0x7fffffff {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_CAN
- sa.raw.Ifindex = int32(sa.Ifindex)
- rx := (*[4]byte)(unsafe.Pointer(&sa.RxID))
- for i := 0; i < 4; i++ {
- sa.raw.Addr[i] = rx[i]
- }
- tx := (*[4]byte)(unsafe.Pointer(&sa.TxID))
- for i := 0; i < 4; i++ {
- sa.raw.Addr[i+4] = tx[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrCAN, nil
-}
-
-// SockaddrALG implements the Sockaddr interface for AF_ALG type sockets.
-// SockaddrALG enables userspace access to the Linux kernel's cryptography
-// subsystem. The Type and Name fields specify which type of hash or cipher
-// should be used with a given socket.
-//
-// To create a file descriptor that provides access to a hash or cipher, both
-// Bind and Accept must be used. Once the setup process is complete, input
-// data can be written to the socket, processed by the kernel, and then read
-// back as hash output or ciphertext.
-//
-// Here is an example of using an AF_ALG socket with SHA1 hashing.
-// The initial socket setup process is as follows:
-//
-// // Open a socket to perform SHA1 hashing.
-// fd, _ := unix.Socket(unix.AF_ALG, unix.SOCK_SEQPACKET, 0)
-// addr := &unix.SockaddrALG{Type: "hash", Name: "sha1"}
-// unix.Bind(fd, addr)
-// // Note: unix.Accept does not work at this time; must invoke accept()
-// // manually using unix.Syscall.
-// hashfd, _, _ := unix.Syscall(unix.SYS_ACCEPT, uintptr(fd), 0, 0)
-//
-// Once a file descriptor has been returned from Accept, it may be used to
-// perform SHA1 hashing. The descriptor is not safe for concurrent use, but
-// may be re-used repeatedly with subsequent Write and Read operations.
-//
-// When hashing a small byte slice or string, a single Write and Read may
-// be used:
-//
-// // Assume hashfd is already configured using the setup process.
-// hash := os.NewFile(hashfd, "sha1")
-// // Hash an input string and read the results. Each Write discards
-// // previous hash state. Read always reads the current state.
-// b := make([]byte, 20)
-// for i := 0; i < 2; i++ {
-// io.WriteString(hash, "Hello, world.")
-// hash.Read(b)
-// fmt.Println(hex.EncodeToString(b))
-// }
-// // Output:
-// // 2ae01472317d1935a84797ec1983ae243fc6aa28
-// // 2ae01472317d1935a84797ec1983ae243fc6aa28
-//
-// For hashing larger byte slices, or byte streams such as those read from
-// a file or socket, use Sendto with MSG_MORE to instruct the kernel to update
-// the hash digest instead of creating a new one for a given chunk and finalizing it.
-//
-// // Assume hashfd and addr are already configured using the setup process.
-// hash := os.NewFile(hashfd, "sha1")
-// // Hash the contents of a file.
-// f, _ := os.Open("/tmp/linux-4.10-rc7.tar.xz")
-// b := make([]byte, 4096)
-// for {
-// n, err := f.Read(b)
-// if err == io.EOF {
-// break
-// }
-// unix.Sendto(hashfd, b[:n], unix.MSG_MORE, addr)
-// }
-// hash.Read(b)
-// fmt.Println(hex.EncodeToString(b))
-// // Output: 85cdcad0c06eef66f805ecce353bec9accbeecc5
-//
-// For more information, see: http://www.chronox.de/crypto-API/crypto/userspace-if.html.
-type SockaddrALG struct {
- Type string
- Name string
- Feature uint32
- Mask uint32
- raw RawSockaddrALG
-}
-
-func (sa *SockaddrALG) sockaddr() (unsafe.Pointer, _Socklen, error) {
- // Leave room for NUL byte terminator.
- if len(sa.Type) > 13 {
- return nil, 0, EINVAL
- }
- if len(sa.Name) > 63 {
- return nil, 0, EINVAL
- }
-
- sa.raw.Family = AF_ALG
- sa.raw.Feat = sa.Feature
- sa.raw.Mask = sa.Mask
-
- typ, err := ByteSliceFromString(sa.Type)
- if err != nil {
- return nil, 0, err
- }
- name, err := ByteSliceFromString(sa.Name)
- if err != nil {
- return nil, 0, err
- }
-
- copy(sa.raw.Type[:], typ)
- copy(sa.raw.Name[:], name)
-
- return unsafe.Pointer(&sa.raw), SizeofSockaddrALG, nil
-}
-
-// SockaddrVM implements the Sockaddr interface for AF_VSOCK type sockets.
-// SockaddrVM provides access to Linux VM sockets: a mechanism that enables
-// bidirectional communication between a hypervisor and its guest virtual
-// machines.
-type SockaddrVM struct {
- // CID and Port specify a context ID and port address for a VM socket.
- // Guests have a unique CID, and hosts may have a well-known CID of:
- // - VMADDR_CID_HYPERVISOR: refers to the hypervisor process.
- // - VMADDR_CID_HOST: refers to other processes on the host.
- CID uint32
- Port uint32
- raw RawSockaddrVM
-}
-
-func (sa *SockaddrVM) sockaddr() (unsafe.Pointer, _Socklen, error) {
- sa.raw.Family = AF_VSOCK
- sa.raw.Port = sa.Port
- sa.raw.Cid = sa.CID
-
- return unsafe.Pointer(&sa.raw), SizeofSockaddrVM, nil
-}
-
-func anyToSockaddr(rsa *RawSockaddrAny) (Sockaddr, error) {
- switch rsa.Addr.Family {
- case AF_NETLINK:
- pp := (*RawSockaddrNetlink)(unsafe.Pointer(rsa))
- sa := new(SockaddrNetlink)
- sa.Family = pp.Family
- sa.Pad = pp.Pad
- sa.Pid = pp.Pid
- sa.Groups = pp.Groups
- return sa, nil
-
- case AF_PACKET:
- pp := (*RawSockaddrLinklayer)(unsafe.Pointer(rsa))
- sa := new(SockaddrLinklayer)
- sa.Protocol = pp.Protocol
- sa.Ifindex = int(pp.Ifindex)
- sa.Hatype = pp.Hatype
- sa.Pkttype = pp.Pkttype
- sa.Halen = pp.Halen
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
-
- case AF_UNIX:
- pp := (*RawSockaddrUnix)(unsafe.Pointer(rsa))
- sa := new(SockaddrUnix)
- if pp.Path[0] == 0 {
- // "Abstract" Unix domain socket.
- // Rewrite leading NUL as @ for textual display.
- // (This is the standard convention.)
- // Not friendly to overwrite in place,
- // but the callers below don't care.
- pp.Path[0] = '@'
- }
-
- // Assume path ends at NUL.
- // This is not technically the Linux semantics for
- // abstract Unix domain sockets--they are supposed
- // to be uninterpreted fixed-size binary blobs--but
- // everyone uses this convention.
- n := 0
- for n < len(pp.Path) && pp.Path[n] != 0 {
- n++
- }
- bytes := (*[10000]byte)(unsafe.Pointer(&pp.Path[0]))[0:n]
- sa.Name = string(bytes)
- return sa, nil
-
- case AF_INET:
- pp := (*RawSockaddrInet4)(unsafe.Pointer(rsa))
- sa := new(SockaddrInet4)
- p := (*[2]byte)(unsafe.Pointer(&pp.Port))
- sa.Port = int(p[0])<<8 + int(p[1])
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
-
- case AF_INET6:
- pp := (*RawSockaddrInet6)(unsafe.Pointer(rsa))
- sa := new(SockaddrInet6)
- p := (*[2]byte)(unsafe.Pointer(&pp.Port))
- sa.Port = int(p[0])<<8 + int(p[1])
- sa.ZoneId = pp.Scope_id
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
-
- case AF_VSOCK:
- pp := (*RawSockaddrVM)(unsafe.Pointer(rsa))
- sa := &SockaddrVM{
- CID: pp.Cid,
- Port: pp.Port,
- }
- return sa, nil
- }
- return nil, EAFNOSUPPORT
-}
-
-func Accept(fd int) (nfd int, sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- nfd, err = accept(fd, &rsa, &len)
- if err != nil {
- return
- }
- sa, err = anyToSockaddr(&rsa)
- if err != nil {
- Close(nfd)
- nfd = 0
- }
- return
-}
-
-func Accept4(fd int, flags int) (nfd int, sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- nfd, err = accept4(fd, &rsa, &len, flags)
- if err != nil {
- return
- }
- if len > SizeofSockaddrAny {
- panic("RawSockaddrAny too small")
- }
- sa, err = anyToSockaddr(&rsa)
- if err != nil {
- Close(nfd)
- nfd = 0
- }
- return
-}
-
-func Getsockname(fd int) (sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- if err = getsockname(fd, &rsa, &len); err != nil {
- return
- }
- return anyToSockaddr(&rsa)
-}
-
-func GetsockoptInet4Addr(fd, level, opt int) (value [4]byte, err error) {
- vallen := _Socklen(4)
- err = getsockopt(fd, level, opt, unsafe.Pointer(&value[0]), &vallen)
- return value, err
-}
-
-func GetsockoptIPMreq(fd, level, opt int) (*IPMreq, error) {
- var value IPMreq
- vallen := _Socklen(SizeofIPMreq)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptIPMreqn(fd, level, opt int) (*IPMreqn, error) {
- var value IPMreqn
- vallen := _Socklen(SizeofIPMreqn)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptIPv6Mreq(fd, level, opt int) (*IPv6Mreq, error) {
- var value IPv6Mreq
- vallen := _Socklen(SizeofIPv6Mreq)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptIPv6MTUInfo(fd, level, opt int) (*IPv6MTUInfo, error) {
- var value IPv6MTUInfo
- vallen := _Socklen(SizeofIPv6MTUInfo)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptICMPv6Filter(fd, level, opt int) (*ICMPv6Filter, error) {
- var value ICMPv6Filter
- vallen := _Socklen(SizeofICMPv6Filter)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptUcred(fd, level, opt int) (*Ucred, error) {
- var value Ucred
- vallen := _Socklen(SizeofUcred)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func GetsockoptTCPInfo(fd, level, opt int) (*TCPInfo, error) {
- var value TCPInfo
- vallen := _Socklen(SizeofTCPInfo)
- err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen)
- return &value, err
-}
-
-func SetsockoptIPMreqn(fd, level, opt int, mreq *IPMreqn) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(mreq), unsafe.Sizeof(*mreq))
-}
-
-func Recvmsg(fd int, p, oob []byte, flags int) (n, oobn int, recvflags int, from Sockaddr, err error) {
- var msg Msghdr
- var rsa RawSockaddrAny
- msg.Name = (*byte)(unsafe.Pointer(&rsa))
- msg.Namelen = uint32(SizeofSockaddrAny)
- var iov Iovec
- if len(p) > 0 {
- iov.Base = (*byte)(unsafe.Pointer(&p[0]))
- iov.SetLen(len(p))
- }
- var dummy byte
- if len(oob) > 0 {
- // receive at least one normal byte
- if len(p) == 0 {
- iov.Base = &dummy
- iov.SetLen(1)
- }
- msg.Control = (*byte)(unsafe.Pointer(&oob[0]))
- msg.SetControllen(len(oob))
- }
- msg.Iov = &iov
- msg.Iovlen = 1
- if n, err = recvmsg(fd, &msg, flags); err != nil {
- return
- }
- oobn = int(msg.Controllen)
- recvflags = int(msg.Flags)
- // source address is only specified if the socket is unconnected
- if rsa.Addr.Family != AF_UNSPEC {
- from, err = anyToSockaddr(&rsa)
- }
- return
-}
-
-func Sendmsg(fd int, p, oob []byte, to Sockaddr, flags int) (err error) {
- _, err = SendmsgN(fd, p, oob, to, flags)
- return
-}
-
-func SendmsgN(fd int, p, oob []byte, to Sockaddr, flags int) (n int, err error) {
- var ptr unsafe.Pointer
- var salen _Socklen
- if to != nil {
- var err error
- ptr, salen, err = to.sockaddr()
- if err != nil {
- return 0, err
- }
- }
- var msg Msghdr
- msg.Name = (*byte)(unsafe.Pointer(ptr))
- msg.Namelen = uint32(salen)
- var iov Iovec
- if len(p) > 0 {
- iov.Base = (*byte)(unsafe.Pointer(&p[0]))
- iov.SetLen(len(p))
- }
- var dummy byte
- if len(oob) > 0 {
- // send at least one normal byte
- if len(p) == 0 {
- iov.Base = &dummy
- iov.SetLen(1)
- }
- msg.Control = (*byte)(unsafe.Pointer(&oob[0]))
- msg.SetControllen(len(oob))
- }
- msg.Iov = &iov
- msg.Iovlen = 1
- if n, err = sendmsg(fd, &msg, flags); err != nil {
- return 0, err
- }
- if len(oob) > 0 && len(p) == 0 {
- n = 0
- }
- return n, nil
-}
-
-// BindToDevice binds the socket associated with fd to device.
-func BindToDevice(fd int, device string) (err error) {
- return SetsockoptString(fd, SOL_SOCKET, SO_BINDTODEVICE, device)
-}
-
-//sys ptrace(request int, pid int, addr uintptr, data uintptr) (err error)
-
-func ptracePeek(req int, pid int, addr uintptr, out []byte) (count int, err error) {
- // The peek requests are machine-size oriented, so we wrap it
- // to retrieve arbitrary-length data.
-
- // The ptrace syscall differs from glibc's ptrace.
- // Peeks returns the word in *data, not as the return value.
-
- var buf [sizeofPtr]byte
-
- // Leading edge. PEEKTEXT/PEEKDATA don't require aligned
- // access (PEEKUSER warns that it might), but if we don't
- // align our reads, we might straddle an unmapped page
- // boundary and not get the bytes leading up to the page
- // boundary.
- n := 0
- if addr%sizeofPtr != 0 {
- err = ptrace(req, pid, addr-addr%sizeofPtr, uintptr(unsafe.Pointer(&buf[0])))
- if err != nil {
- return 0, err
- }
- n += copy(out, buf[addr%sizeofPtr:])
- out = out[n:]
- }
-
- // Remainder.
- for len(out) > 0 {
- // We use an internal buffer to guarantee alignment.
- // It's not documented if this is necessary, but we're paranoid.
- err = ptrace(req, pid, addr+uintptr(n), uintptr(unsafe.Pointer(&buf[0])))
- if err != nil {
- return n, err
- }
- copied := copy(out, buf[0:])
- n += copied
- out = out[copied:]
- }
-
- return n, nil
-}
-
-func PtracePeekText(pid int, addr uintptr, out []byte) (count int, err error) {
- return ptracePeek(PTRACE_PEEKTEXT, pid, addr, out)
-}
-
-func PtracePeekData(pid int, addr uintptr, out []byte) (count int, err error) {
- return ptracePeek(PTRACE_PEEKDATA, pid, addr, out)
-}
-
-func PtracePeekUser(pid int, addr uintptr, out []byte) (count int, err error) {
- return ptracePeek(PTRACE_PEEKUSR, pid, addr, out)
-}
-
-func ptracePoke(pokeReq int, peekReq int, pid int, addr uintptr, data []byte) (count int, err error) {
- // As for ptracePeek, we need to align our accesses to deal
- // with the possibility of straddling an invalid page.
-
- // Leading edge.
- n := 0
- if addr%sizeofPtr != 0 {
- var buf [sizeofPtr]byte
- err = ptrace(peekReq, pid, addr-addr%sizeofPtr, uintptr(unsafe.Pointer(&buf[0])))
- if err != nil {
- return 0, err
- }
- n += copy(buf[addr%sizeofPtr:], data)
- word := *((*uintptr)(unsafe.Pointer(&buf[0])))
- err = ptrace(pokeReq, pid, addr-addr%sizeofPtr, word)
- if err != nil {
- return 0, err
- }
- data = data[n:]
- }
-
- // Interior.
- for len(data) > sizeofPtr {
- word := *((*uintptr)(unsafe.Pointer(&data[0])))
- err = ptrace(pokeReq, pid, addr+uintptr(n), word)
- if err != nil {
- return n, err
- }
- n += sizeofPtr
- data = data[sizeofPtr:]
- }
-
- // Trailing edge.
- if len(data) > 0 {
- var buf [sizeofPtr]byte
- err = ptrace(peekReq, pid, addr+uintptr(n), uintptr(unsafe.Pointer(&buf[0])))
- if err != nil {
- return n, err
- }
- copy(buf[0:], data)
- word := *((*uintptr)(unsafe.Pointer(&buf[0])))
- err = ptrace(pokeReq, pid, addr+uintptr(n), word)
- if err != nil {
- return n, err
- }
- n += len(data)
- }
-
- return n, nil
-}
-
-func PtracePokeText(pid int, addr uintptr, data []byte) (count int, err error) {
- return ptracePoke(PTRACE_POKETEXT, PTRACE_PEEKTEXT, pid, addr, data)
-}
-
-func PtracePokeData(pid int, addr uintptr, data []byte) (count int, err error) {
- return ptracePoke(PTRACE_POKEDATA, PTRACE_PEEKDATA, pid, addr, data)
-}
-
-func PtraceGetRegs(pid int, regsout *PtraceRegs) (err error) {
- return ptrace(PTRACE_GETREGS, pid, 0, uintptr(unsafe.Pointer(regsout)))
-}
-
-func PtraceSetRegs(pid int, regs *PtraceRegs) (err error) {
- return ptrace(PTRACE_SETREGS, pid, 0, uintptr(unsafe.Pointer(regs)))
-}
-
-func PtraceSetOptions(pid int, options int) (err error) {
- return ptrace(PTRACE_SETOPTIONS, pid, 0, uintptr(options))
-}
-
-func PtraceGetEventMsg(pid int) (msg uint, err error) {
- var data _C_long
- err = ptrace(PTRACE_GETEVENTMSG, pid, 0, uintptr(unsafe.Pointer(&data)))
- msg = uint(data)
- return
-}
-
-func PtraceCont(pid int, signal int) (err error) {
- return ptrace(PTRACE_CONT, pid, 0, uintptr(signal))
-}
-
-func PtraceSyscall(pid int, signal int) (err error) {
- return ptrace(PTRACE_SYSCALL, pid, 0, uintptr(signal))
-}
-
-func PtraceSingleStep(pid int) (err error) { return ptrace(PTRACE_SINGLESTEP, pid, 0, 0) }
-
-func PtraceAttach(pid int) (err error) { return ptrace(PTRACE_ATTACH, pid, 0, 0) }
-
-func PtraceDetach(pid int) (err error) { return ptrace(PTRACE_DETACH, pid, 0, 0) }
-
-//sys reboot(magic1 uint, magic2 uint, cmd int, arg string) (err error)
-
-func Reboot(cmd int) (err error) {
- return reboot(LINUX_REBOOT_MAGIC1, LINUX_REBOOT_MAGIC2, cmd, "")
-}
-
-func ReadDirent(fd int, buf []byte) (n int, err error) {
- return Getdents(fd, buf)
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen))
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- reclen, ok := direntReclen(buf)
- if !ok {
- return 0, false
- }
- return reclen - uint64(unsafe.Offsetof(Dirent{}.Name)), true
-}
-
-//sys mount(source string, target string, fstype string, flags uintptr, data *byte) (err error)
-
-func Mount(source string, target string, fstype string, flags uintptr, data string) (err error) {
- // Certain file systems get rather angry and EINVAL if you give
- // them an empty string of data, rather than NULL.
- if data == "" {
- return mount(source, target, fstype, flags, nil)
- }
- datap, err := BytePtrFromString(data)
- if err != nil {
- return err
- }
- return mount(source, target, fstype, flags, datap)
-}
-
-// Sendto
-// Recvfrom
-// Socketpair
-
-/*
- * Direct access
- */
-//sys Acct(path string) (err error)
-//sys Adjtimex(buf *Timex) (state int, err error)
-//sys Chdir(path string) (err error)
-//sys Chroot(path string) (err error)
-//sys ClockGettime(clockid int32, time *Timespec) (err error)
-//sys Close(fd int) (err error)
-//sys Dup(oldfd int) (fd int, err error)
-//sys Dup3(oldfd int, newfd int, flags int) (err error)
-//sysnb EpollCreate(size int) (fd int, err error)
-//sysnb EpollCreate1(flag int) (fd int, err error)
-//sysnb EpollCtl(epfd int, op int, fd int, event *EpollEvent) (err error)
-//sys Exit(code int) = SYS_EXIT_GROUP
-//sys Faccessat(dirfd int, path string, mode uint32, flags int) (err error)
-//sys Fallocate(fd int, mode uint32, off int64, len int64) (err error)
-//sys Fchdir(fd int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error)
-//sys Fchownat(dirfd int, path string, uid int, gid int, flags int) (err error)
-//sys fcntl(fd int, cmd int, arg int) (val int, err error)
-//sys Fdatasync(fd int) (err error)
-//sys Flock(fd int, how int) (err error)
-//sys Fsync(fd int) (err error)
-//sys Getdents(fd int, buf []byte) (n int, err error) = SYS_GETDENTS64
-//sysnb Getpgid(pid int) (pgid int, err error)
-
-func Getpgrp() (pid int) {
- pid, _ = Getpgid(0)
- return
-}
-
-//sysnb Getpid() (pid int)
-//sysnb Getppid() (ppid int)
-//sys Getpriority(which int, who int) (prio int, err error)
-//sys Getrandom(buf []byte, flags int) (n int, err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Getsid(pid int) (sid int, err error)
-//sysnb Gettid() (tid int)
-//sys Getxattr(path string, attr string, dest []byte) (sz int, err error)
-//sys InotifyAddWatch(fd int, pathname string, mask uint32) (watchdesc int, err error)
-//sysnb InotifyInit1(flags int) (fd int, err error)
-//sysnb InotifyRmWatch(fd int, watchdesc uint32) (success int, err error)
-//sysnb Kill(pid int, sig syscall.Signal) (err error)
-//sys Klogctl(typ int, buf []byte) (n int, err error) = SYS_SYSLOG
-//sys Listxattr(path string, dest []byte) (sz int, err error)
-//sys Mkdirat(dirfd int, path string, mode uint32) (err error)
-//sys Mknodat(dirfd int, path string, mode uint32, dev int) (err error)
-//sys Nanosleep(time *Timespec, leftover *Timespec) (err error)
-//sys PivotRoot(newroot string, putold string) (err error) = SYS_PIVOT_ROOT
-//sysnb prlimit(pid int, resource int, newlimit *Rlimit, old *Rlimit) (err error) = SYS_PRLIMIT64
-//sys Prctl(option int, arg2 uintptr, arg3 uintptr, arg4 uintptr, arg5 uintptr) (err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Removexattr(path string, attr string) (err error)
-//sys Renameat(olddirfd int, oldpath string, newdirfd int, newpath string) (err error)
-//sys Setdomainname(p []byte) (err error)
-//sys Sethostname(p []byte) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Settimeofday(tv *Timeval) (err error)
-//sys Setns(fd int, nstype int) (err error)
-
-// issue 1435.
-// On linux Setuid and Setgid only affects the current thread, not the process.
-// This does not match what most callers expect so we must return an error
-// here rather than letting the caller think that the call succeeded.
-
-func Setuid(uid int) (err error) {
- return EOPNOTSUPP
-}
-
-func Setgid(uid int) (err error) {
- return EOPNOTSUPP
-}
-
-//sys Setpriority(which int, who int, prio int) (err error)
-//sys Setxattr(path string, attr string, data []byte, flags int) (err error)
-//sys Sync()
-//sysnb Sysinfo(info *Sysinfo_t) (err error)
-//sys Tee(rfd int, wfd int, len int, flags int) (n int64, err error)
-//sysnb Tgkill(tgid int, tid int, sig syscall.Signal) (err error)
-//sysnb Times(tms *Tms) (ticks uintptr, err error)
-//sysnb Umask(mask int) (oldmask int)
-//sysnb Uname(buf *Utsname) (err error)
-//sys Unmount(target string, flags int) (err error) = SYS_UMOUNT2
-//sys Unshare(flags int) (err error)
-//sys Ustat(dev int, ubuf *Ustat_t) (err error)
-//sys write(fd int, p []byte) (n int, err error)
-//sys exitThread(code int) (err error) = SYS_EXIT
-//sys readlen(fd int, p *byte, np int) (n int, err error) = SYS_READ
-//sys writelen(fd int, p *byte, np int) (n int, err error) = SYS_WRITE
-
-// mmap varies by architecture; see syscall_linux_*.go.
-//sys munmap(addr uintptr, length uintptr) (err error)
-
-var mapper = &mmapper{
- active: make(map[*byte][]byte),
- mmap: mmap,
- munmap: munmap,
-}
-
-func Mmap(fd int, offset int64, length int, prot int, flags int) (data []byte, err error) {
- return mapper.Mmap(fd, offset, length, prot, flags)
-}
-
-func Munmap(b []byte) (err error) {
- return mapper.Munmap(b)
-}
-
-//sys Madvise(b []byte, advice int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Munlockall() (err error)
-
-// Vmsplice splices user pages from a slice of Iovecs into a pipe specified by fd,
-// using the specified flags.
-func Vmsplice(fd int, iovs []Iovec, flags int) (int, error) {
- n, _, errno := Syscall6(
- SYS_VMSPLICE,
- uintptr(fd),
- uintptr(unsafe.Pointer(&iovs[0])),
- uintptr(len(iovs)),
- uintptr(flags),
- 0,
- 0,
- )
- if errno != 0 {
- return 0, syscall.Errno(errno)
- }
-
- return int(n), nil
-}
-
-/*
- * Unimplemented
- */
-// AddKey
-// AfsSyscall
-// Alarm
-// ArchPrctl
-// Brk
-// Capget
-// Capset
-// ClockGetres
-// ClockNanosleep
-// ClockSettime
-// Clone
-// CreateModule
-// DeleteModule
-// EpollCtlOld
-// EpollPwait
-// EpollWaitOld
-// Eventfd
-// Execve
-// Fgetxattr
-// Flistxattr
-// Fork
-// Fremovexattr
-// Fsetxattr
-// Futex
-// GetKernelSyms
-// GetMempolicy
-// GetRobustList
-// GetThreadArea
-// Getitimer
-// Getpmsg
-// IoCancel
-// IoDestroy
-// IoGetevents
-// IoSetup
-// IoSubmit
-// Ioctl
-// IoprioGet
-// IoprioSet
-// KexecLoad
-// Keyctl
-// Lgetxattr
-// Llistxattr
-// LookupDcookie
-// Lremovexattr
-// Lsetxattr
-// Mbind
-// MigratePages
-// Mincore
-// ModifyLdt
-// Mount
-// MovePages
-// Mprotect
-// MqGetsetattr
-// MqNotify
-// MqOpen
-// MqTimedreceive
-// MqTimedsend
-// MqUnlink
-// Mremap
-// Msgctl
-// Msgget
-// Msgrcv
-// Msgsnd
-// Msync
-// Newfstatat
-// Nfsservctl
-// Personality
-// Pselect6
-// Ptrace
-// Putpmsg
-// QueryModule
-// Quotactl
-// Readahead
-// Readv
-// RemapFilePages
-// RequestKey
-// RestartSyscall
-// RtSigaction
-// RtSigpending
-// RtSigprocmask
-// RtSigqueueinfo
-// RtSigreturn
-// RtSigsuspend
-// RtSigtimedwait
-// SchedGetPriorityMax
-// SchedGetPriorityMin
-// SchedGetaffinity
-// SchedGetparam
-// SchedGetscheduler
-// SchedRrGetInterval
-// SchedSetaffinity
-// SchedSetparam
-// SchedYield
-// Security
-// Semctl
-// Semget
-// Semop
-// Semtimedop
-// SetMempolicy
-// SetRobustList
-// SetThreadArea
-// SetTidAddress
-// Shmat
-// Shmctl
-// Shmdt
-// Shmget
-// Sigaltstack
-// Signalfd
-// Swapoff
-// Swapon
-// Sysfs
-// TimerCreate
-// TimerDelete
-// TimerGetoverrun
-// TimerGettime
-// TimerSettime
-// Timerfd
-// Tkill (obsolete)
-// Tuxcall
-// Umount2
-// Uselib
-// Utimensat
-// Vfork
-// Vhangup
-// Vserver
-// Waitid
-// _Sysctl
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_386.go b/vendor/golang.org/x/sys/unix/syscall_linux_386.go
deleted file mode 100644
index 2b881b979..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_386.go
+++ /dev/null
@@ -1,399 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// TODO(rsc): Rewrite all nn(SP) references into name+(nn-8)(FP)
-// so that go vet can check that they are correct.
-
-// +build 386,linux
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int32(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = int32(nsec / 1e9)
- tv.Usec = int32(nsec % 1e9 / 1e3)
- return
-}
-
-//sysnb pipe(p *[2]_C_int) (err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe(&pp)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-// 64-bit file system and 32-bit uid calls
-// (386 default is 32-bit file system and 16-bit uid).
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64_64
-//sys Fchown(fd int, uid int, gid int) (err error) = SYS_FCHOWN32
-//sys Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64
-//sys Ftruncate(fd int, length int64) (err error) = SYS_FTRUNCATE64
-//sysnb Getegid() (egid int) = SYS_GETEGID32
-//sysnb Geteuid() (euid int) = SYS_GETEUID32
-//sysnb Getgid() (gid int) = SYS_GETGID32
-//sysnb Getuid() (uid int) = SYS_GETUID32
-//sysnb InotifyInit() (fd int, err error)
-//sys Ioperm(from int, num int, on int) (err error)
-//sys Iopl(level int) (err error)
-//sys Lchown(path string, uid int, gid int) (err error) = SYS_LCHOWN32
-//sys Lstat(path string, stat *Stat_t) (err error) = SYS_LSTAT64
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) = SYS_SENDFILE64
-//sys Setfsgid(gid int) (err error) = SYS_SETFSGID32
-//sys Setfsuid(uid int) (err error) = SYS_SETFSUID32
-//sysnb Setregid(rgid int, egid int) (err error) = SYS_SETREGID32
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error) = SYS_SETRESGID32
-//sysnb Setresuid(ruid int, euid int, suid int) (err error) = SYS_SETRESUID32
-//sysnb Setreuid(ruid int, euid int) (err error) = SYS_SETREUID32
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int, err error)
-//sys Stat(path string, stat *Stat_t) (err error) = SYS_STAT64
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error) = SYS_TRUNCATE64
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error) = SYS_GETGROUPS32
-//sysnb setgroups(n int, list *_Gid_t) (err error) = SYS_SETGROUPS32
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) = SYS__NEWSELECT
-
-//sys mmap2(addr uintptr, length uintptr, prot int, flags int, fd int, pageOffset uintptr) (xaddr uintptr, err error)
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Pause() (err error)
-
-func mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error) {
- page := uintptr(offset / 4096)
- if offset != int64(page)*4096 {
- return 0, EINVAL
- }
- return mmap2(addr, length, prot, flags, fd, page)
-}
-
-type rlimit32 struct {
- Cur uint32
- Max uint32
-}
-
-//sysnb getrlimit(resource int, rlim *rlimit32) (err error) = SYS_GETRLIMIT
-
-const rlimInf32 = ^uint32(0)
-const rlimInf64 = ^uint64(0)
-
-func Getrlimit(resource int, rlim *Rlimit) (err error) {
- err = prlimit(0, resource, nil, rlim)
- if err != ENOSYS {
- return err
- }
-
- rl := rlimit32{}
- err = getrlimit(resource, &rl)
- if err != nil {
- return
- }
-
- if rl.Cur == rlimInf32 {
- rlim.Cur = rlimInf64
- } else {
- rlim.Cur = uint64(rl.Cur)
- }
-
- if rl.Max == rlimInf32 {
- rlim.Max = rlimInf64
- } else {
- rlim.Max = uint64(rl.Max)
- }
- return
-}
-
-//sysnb setrlimit(resource int, rlim *rlimit32) (err error) = SYS_SETRLIMIT
-
-func Setrlimit(resource int, rlim *Rlimit) (err error) {
- err = prlimit(0, resource, rlim, nil)
- if err != ENOSYS {
- return err
- }
-
- rl := rlimit32{}
- if rlim.Cur == rlimInf64 {
- rl.Cur = rlimInf32
- } else if rlim.Cur < uint64(rlimInf32) {
- rl.Cur = uint32(rlim.Cur)
- } else {
- return EINVAL
- }
- if rlim.Max == rlimInf64 {
- rl.Max = rlimInf32
- } else if rlim.Max < uint64(rlimInf32) {
- rl.Max = uint32(rlim.Max)
- } else {
- return EINVAL
- }
-
- return setrlimit(resource, &rl)
-}
-
-// Underlying system call writes to newoffset via pointer.
-// Implemented in assembly to avoid allocation.
-func seek(fd int, offset int64, whence int) (newoffset int64, err syscall.Errno)
-
-func Seek(fd int, offset int64, whence int) (newoffset int64, err error) {
- newoffset, errno := seek(fd, offset, whence)
- if errno != 0 {
- return 0, errno
- }
- return newoffset, nil
-}
-
-// Vsyscalls on amd64.
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Time(t *Time_t) (tt Time_t, err error)
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-
-// On x86 Linux, all the socket calls go through an extra indirection,
-// I think because the 5-register system call interface can't handle
-// the 6-argument calls like sendto and recvfrom. Instead the
-// arguments to the underlying system call are the number below
-// and a pointer to an array of uintptr. We hide the pointer in the
-// socketcall assembly to avoid allocation on every system call.
-
-const (
- // see linux/net.h
- _SOCKET = 1
- _BIND = 2
- _CONNECT = 3
- _LISTEN = 4
- _ACCEPT = 5
- _GETSOCKNAME = 6
- _GETPEERNAME = 7
- _SOCKETPAIR = 8
- _SEND = 9
- _RECV = 10
- _SENDTO = 11
- _RECVFROM = 12
- _SHUTDOWN = 13
- _SETSOCKOPT = 14
- _GETSOCKOPT = 15
- _SENDMSG = 16
- _RECVMSG = 17
- _ACCEPT4 = 18
- _RECVMMSG = 19
- _SENDMMSG = 20
-)
-
-func socketcall(call int, a0, a1, a2, a3, a4, a5 uintptr) (n int, err syscall.Errno)
-func rawsocketcall(call int, a0, a1, a2, a3, a4, a5 uintptr) (n int, err syscall.Errno)
-
-func accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error) {
- fd, e := socketcall(_ACCEPT, uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen)), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error) {
- fd, e := socketcall(_ACCEPT4, uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen)), uintptr(flags), 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func getsockname(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error) {
- _, e := rawsocketcall(_GETSOCKNAME, uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen)), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func getpeername(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error) {
- _, e := rawsocketcall(_GETPEERNAME, uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen)), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func socketpair(domain int, typ int, flags int, fd *[2]int32) (err error) {
- _, e := rawsocketcall(_SOCKETPAIR, uintptr(domain), uintptr(typ), uintptr(flags), uintptr(unsafe.Pointer(fd)), 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error) {
- _, e := socketcall(_BIND, uintptr(s), uintptr(addr), uintptr(addrlen), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error) {
- _, e := socketcall(_CONNECT, uintptr(s), uintptr(addr), uintptr(addrlen), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func socket(domain int, typ int, proto int) (fd int, err error) {
- fd, e := rawsocketcall(_SOCKET, uintptr(domain), uintptr(typ), uintptr(proto), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error) {
- _, e := socketcall(_GETSOCKOPT, uintptr(s), uintptr(level), uintptr(name), uintptr(val), uintptr(unsafe.Pointer(vallen)), 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error) {
- _, e := socketcall(_SETSOCKOPT, uintptr(s), uintptr(level), uintptr(name), uintptr(val), vallen, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func recvfrom(s int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error) {
- var base uintptr
- if len(p) > 0 {
- base = uintptr(unsafe.Pointer(&p[0]))
- }
- n, e := socketcall(_RECVFROM, uintptr(s), base, uintptr(len(p)), uintptr(flags), uintptr(unsafe.Pointer(from)), uintptr(unsafe.Pointer(fromlen)))
- if e != 0 {
- err = e
- }
- return
-}
-
-func sendto(s int, p []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error) {
- var base uintptr
- if len(p) > 0 {
- base = uintptr(unsafe.Pointer(&p[0]))
- }
- _, e := socketcall(_SENDTO, uintptr(s), base, uintptr(len(p)), uintptr(flags), uintptr(to), uintptr(addrlen))
- if e != 0 {
- err = e
- }
- return
-}
-
-func recvmsg(s int, msg *Msghdr, flags int) (n int, err error) {
- n, e := socketcall(_RECVMSG, uintptr(s), uintptr(unsafe.Pointer(msg)), uintptr(flags), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func sendmsg(s int, msg *Msghdr, flags int) (n int, err error) {
- n, e := socketcall(_SENDMSG, uintptr(s), uintptr(unsafe.Pointer(msg)), uintptr(flags), 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func Listen(s int, n int) (err error) {
- _, e := socketcall(_LISTEN, uintptr(s), uintptr(n), 0, 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func Shutdown(s, how int) (err error) {
- _, e := socketcall(_SHUTDOWN, uintptr(s), uintptr(how), 0, 0, 0, 0)
- if e != 0 {
- err = e
- }
- return
-}
-
-func Fstatfs(fd int, buf *Statfs_t) (err error) {
- _, _, e := Syscall(SYS_FSTATFS64, uintptr(fd), unsafe.Sizeof(*buf), uintptr(unsafe.Pointer(buf)))
- if e != 0 {
- err = e
- }
- return
-}
-
-func Statfs(path string, buf *Statfs_t) (err error) {
- pathp, err := BytePtrFromString(path)
- if err != nil {
- return err
- }
- _, _, e := Syscall(SYS_STATFS64, uintptr(unsafe.Pointer(pathp)), unsafe.Sizeof(*buf), uintptr(unsafe.Pointer(buf)))
- if e != 0 {
- err = e
- }
- return
-}
-
-func (r *PtraceRegs) PC() uint64 { return uint64(uint32(r.Eip)) }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Eip = int32(pc) }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go b/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go
deleted file mode 100644
index 9516a3fd7..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go
+++ /dev/null
@@ -1,152 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,linux
-
-package unix
-
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, buf *Statfs_t) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Getuid() (uid int)
-//sysnb InotifyInit() (fd int, err error)
-//sys Ioperm(from int, num int, on int) (err error)
-//sys Iopl(level int) (err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Listen(s int, n int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Pause() (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error)
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, buf *Statfs_t) (err error)
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error)
-
-func Gettimeofday(tv *Timeval) (err error) {
- errno := gettimeofday(tv)
- if errno != 0 {
- return errno
- }
- return nil
-}
-
-func Getpagesize() int { return 4096 }
-
-func Time(t *Time_t) (tt Time_t, err error) {
- var tv Timeval
- errno := gettimeofday(&tv)
- if errno != 0 {
- return 0, errno
- }
- if t != nil {
- *t = Time_t(tv.Sec)
- }
- return Time_t(tv.Sec), nil
-}
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = nsec / 1e9
- tv.Usec = nsec % 1e9 / 1e3
- return
-}
-
-//sysnb pipe(p *[2]_C_int) (err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe(&pp)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-func (r *PtraceRegs) PC() uint64 { return r.Rip }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Rip = pc }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint64(length)
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_amd64_gc.go b/vendor/golang.org/x/sys/unix/syscall_linux_amd64_gc.go
deleted file mode 100644
index 21a4946ba..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_amd64_gc.go
+++ /dev/null
@@ -1,13 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,linux
-// +build !gccgo
-
-package unix
-
-import "syscall"
-
-//go:noescape
-func gettimeofday(tv *Timeval) (err syscall.Errno)
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_arm.go b/vendor/golang.org/x/sys/unix/syscall_linux_arm.go
deleted file mode 100644
index 71d870228..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_arm.go
+++ /dev/null
@@ -1,263 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build arm,linux
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int32(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = int32(nsec / 1e9)
- tv.Usec = int32(nsec % 1e9 / 1e3)
- return
-}
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, 0)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-// Underlying system call writes to newoffset via pointer.
-// Implemented in assembly to avoid allocation.
-func seek(fd int, offset int64, whence int) (newoffset int64, err syscall.Errno)
-
-func Seek(fd int, offset int64, whence int) (newoffset int64, err error) {
- newoffset, errno := seek(fd, offset, whence)
- if errno != 0 {
- return 0, errno
- }
- return newoffset, nil
-}
-
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error) = SYS_GETGROUPS32
-//sysnb setgroups(n int, list *_Gid_t) (err error) = SYS_SETGROUPS32
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb socketpair(domain int, typ int, flags int, fd *[2]int32) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-
-// 64-bit file system and 32-bit uid calls
-// (16-bit uid calls are not always supported in newer kernels)
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error) = SYS_FCHOWN32
-//sys Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64
-//sysnb Getegid() (egid int) = SYS_GETEGID32
-//sysnb Geteuid() (euid int) = SYS_GETEUID32
-//sysnb Getgid() (gid int) = SYS_GETGID32
-//sysnb Getuid() (uid int) = SYS_GETUID32
-//sysnb InotifyInit() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error) = SYS_LCHOWN32
-//sys Listen(s int, n int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error) = SYS_LSTAT64
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) = SYS_SENDFILE64
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) = SYS__NEWSELECT
-//sys Setfsgid(gid int) (err error) = SYS_SETFSGID32
-//sys Setfsuid(uid int) (err error) = SYS_SETFSUID32
-//sysnb Setregid(rgid int, egid int) (err error) = SYS_SETREGID32
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error) = SYS_SETRESGID32
-//sysnb Setresuid(ruid int, euid int, suid int) (err error) = SYS_SETRESUID32
-//sysnb Setreuid(ruid int, euid int) (err error) = SYS_SETREUID32
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int, err error)
-//sys Stat(path string, stat *Stat_t) (err error) = SYS_STAT64
-
-// Vsyscalls on amd64.
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Pause() (err error)
-
-func Time(t *Time_t) (Time_t, error) {
- var tv Timeval
- err := Gettimeofday(&tv)
- if err != nil {
- return 0, err
- }
- if t != nil {
- *t = Time_t(tv.Sec)
- }
- return Time_t(tv.Sec), nil
-}
-
-func Utime(path string, buf *Utimbuf) error {
- tv := []Timeval{
- {Sec: buf.Actime},
- {Sec: buf.Modtime},
- }
- return Utimes(path, tv)
-}
-
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Truncate(path string, length int64) (err error) = SYS_TRUNCATE64
-//sys Ftruncate(fd int, length int64) (err error) = SYS_FTRUNCATE64
-
-func Fadvise(fd int, offset int64, length int64, advice int) (err error) {
- _, _, e1 := Syscall6(SYS_ARM_FADVISE64_64, uintptr(fd), uintptr(advice), uintptr(offset), uintptr(offset>>32), uintptr(length), uintptr(length>>32))
- if e1 != 0 {
- err = errnoErr(e1)
- }
- return
-}
-
-//sys mmap2(addr uintptr, length uintptr, prot int, flags int, fd int, pageOffset uintptr) (xaddr uintptr, err error)
-
-func Fstatfs(fd int, buf *Statfs_t) (err error) {
- _, _, e := Syscall(SYS_FSTATFS64, uintptr(fd), unsafe.Sizeof(*buf), uintptr(unsafe.Pointer(buf)))
- if e != 0 {
- err = e
- }
- return
-}
-
-func Statfs(path string, buf *Statfs_t) (err error) {
- pathp, err := BytePtrFromString(path)
- if err != nil {
- return err
- }
- _, _, e := Syscall(SYS_STATFS64, uintptr(unsafe.Pointer(pathp)), unsafe.Sizeof(*buf), uintptr(unsafe.Pointer(buf)))
- if e != 0 {
- err = e
- }
- return
-}
-
-func mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error) {
- page := uintptr(offset / 4096)
- if offset != int64(page)*4096 {
- return 0, EINVAL
- }
- return mmap2(addr, length, prot, flags, fd, page)
-}
-
-type rlimit32 struct {
- Cur uint32
- Max uint32
-}
-
-//sysnb getrlimit(resource int, rlim *rlimit32) (err error) = SYS_UGETRLIMIT
-
-const rlimInf32 = ^uint32(0)
-const rlimInf64 = ^uint64(0)
-
-func Getrlimit(resource int, rlim *Rlimit) (err error) {
- err = prlimit(0, resource, nil, rlim)
- if err != ENOSYS {
- return err
- }
-
- rl := rlimit32{}
- err = getrlimit(resource, &rl)
- if err != nil {
- return
- }
-
- if rl.Cur == rlimInf32 {
- rlim.Cur = rlimInf64
- } else {
- rlim.Cur = uint64(rl.Cur)
- }
-
- if rl.Max == rlimInf32 {
- rlim.Max = rlimInf64
- } else {
- rlim.Max = uint64(rl.Max)
- }
- return
-}
-
-//sysnb setrlimit(resource int, rlim *rlimit32) (err error) = SYS_SETRLIMIT
-
-func Setrlimit(resource int, rlim *Rlimit) (err error) {
- err = prlimit(0, resource, rlim, nil)
- if err != ENOSYS {
- return err
- }
-
- rl := rlimit32{}
- if rlim.Cur == rlimInf64 {
- rl.Cur = rlimInf32
- } else if rlim.Cur < uint64(rlimInf32) {
- rl.Cur = uint32(rlim.Cur)
- } else {
- return EINVAL
- }
- if rlim.Max == rlimInf64 {
- rl.Max = rlimInf32
- } else if rlim.Max < uint64(rlimInf32) {
- rl.Max = uint32(rlim.Max)
- } else {
- return EINVAL
- }
-
- return setrlimit(resource, &rl)
-}
-
-func (r *PtraceRegs) PC() uint64 { return uint64(r.Uregs[15]) }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Uregs[15] = uint32(pc) }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go b/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go
deleted file mode 100644
index 4a136396c..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go
+++ /dev/null
@@ -1,190 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build arm64,linux
-
-package unix
-
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) = SYS_EPOLL_PWAIT
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error)
-//sys Fstatfs(fd int, buf *Statfs_t) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Getuid() (uid int)
-//sys Listen(s int, n int) (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) = SYS_PSELECT6
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-
-func Stat(path string, stat *Stat_t) (err error) {
- return Fstatat(AT_FDCWD, path, stat, 0)
-}
-
-func Lchown(path string, uid int, gid int) (err error) {
- return Fchownat(AT_FDCWD, path, uid, gid, AT_SYMLINK_NOFOLLOW)
-}
-
-func Lstat(path string, stat *Stat_t) (err error) {
- return Fstatat(AT_FDCWD, path, stat, AT_SYMLINK_NOFOLLOW)
-}
-
-//sys Statfs(path string, buf *Statfs_t) (err error)
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error)
-
-func Getpagesize() int { return 65536 }
-
-//sysnb Gettimeofday(tv *Timeval) (err error)
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = nsec / 1e9
- tv.Usec = nsec % 1e9 / 1e3
- return
-}
-
-func Time(t *Time_t) (Time_t, error) {
- var tv Timeval
- err := Gettimeofday(&tv)
- if err != nil {
- return 0, err
- }
- if t != nil {
- *t = Time_t(tv.Sec)
- }
- return Time_t(tv.Sec), nil
-}
-
-func Utime(path string, buf *Utimbuf) error {
- tv := []Timeval{
- {Sec: buf.Actime},
- {Sec: buf.Modtime},
- }
- return Utimes(path, tv)
-}
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, 0)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-func (r *PtraceRegs) PC() uint64 { return r.Pc }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Pc = pc }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint64(length)
-}
-
-func InotifyInit() (fd int, err error) {
- return InotifyInit1(0)
-}
-
-func Dup2(oldfd int, newfd int) (err error) {
- return Dup3(oldfd, newfd, 0)
-}
-
-func Pause() (err error) {
- _, _, e1 := Syscall6(SYS_PPOLL, 0, 0, 0, 0, 0, 0)
- if e1 != 0 {
- err = errnoErr(e1)
- }
- return
-}
-
-// TODO(dfc): constants that should be in zsysnum_linux_arm64.go, remove
-// these when the deprecated syscalls that the syscall package relies on
-// are removed.
-const (
- SYS_GETPGRP = 1060
- SYS_UTIMES = 1037
- SYS_FUTIMESAT = 1066
- SYS_PAUSE = 1061
- SYS_USTAT = 1070
- SYS_UTIME = 1063
- SYS_LCHOWN = 1032
- SYS_TIME = 1062
- SYS_EPOLL_CREATE = 1042
- SYS_EPOLL_WAIT = 1069
-)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- var ts *Timespec
- if timeout >= 0 {
- ts = new(Timespec)
- *ts = NsecToTimespec(int64(timeout) * 1e6)
- }
- if len(fds) == 0 {
- return ppoll(nil, 0, ts, nil)
- }
- return ppoll(&fds[0], len(fds), ts, nil)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go b/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go
deleted file mode 100644
index 8119fde37..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go
+++ /dev/null
@@ -1,208 +0,0 @@
-// Copyright 2015 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build mips64 mips64le
-
-package unix
-
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fstatfs(fd int, buf *Statfs_t) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Getuid() (uid int)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Listen(s int, n int) (err error)
-//sys Pause() (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) = SYS_PSELECT6
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-//sys Statfs(path string, buf *Statfs_t) (err error)
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error)
-
-func Getpagesize() int { return 65536 }
-
-//sysnb Gettimeofday(tv *Timeval) (err error)
-
-func Time(t *Time_t) (tt Time_t, err error) {
- var tv Timeval
- err = Gettimeofday(&tv)
- if err != nil {
- return 0, err
- }
- if t != nil {
- *t = Time_t(tv.Sec)
- }
- return Time_t(tv.Sec), nil
-}
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = nsec / 1e9
- tv.Usec = nsec % 1e9 / 1e3
- return
-}
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, 0)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-func Ioperm(from int, num int, on int) (err error) {
- return ENOSYS
-}
-
-func Iopl(level int) (err error) {
- return ENOSYS
-}
-
-type stat_t struct {
- Dev uint32
- Pad0 [3]int32
- Ino uint64
- Mode uint32
- Nlink uint32
- Uid uint32
- Gid uint32
- Rdev uint32
- Pad1 [3]uint32
- Size int64
- Atime uint32
- Atime_nsec uint32
- Mtime uint32
- Mtime_nsec uint32
- Ctime uint32
- Ctime_nsec uint32
- Blksize uint32
- Pad2 uint32
- Blocks int64
-}
-
-//sys fstat(fd int, st *stat_t) (err error)
-//sys lstat(path string, st *stat_t) (err error)
-//sys stat(path string, st *stat_t) (err error)
-
-func Fstat(fd int, s *Stat_t) (err error) {
- st := &stat_t{}
- err = fstat(fd, st)
- fillStat_t(s, st)
- return
-}
-
-func Lstat(path string, s *Stat_t) (err error) {
- st := &stat_t{}
- err = lstat(path, st)
- fillStat_t(s, st)
- return
-}
-
-func Stat(path string, s *Stat_t) (err error) {
- st := &stat_t{}
- err = stat(path, st)
- fillStat_t(s, st)
- return
-}
-
-func fillStat_t(s *Stat_t, st *stat_t) {
- s.Dev = st.Dev
- s.Ino = st.Ino
- s.Mode = st.Mode
- s.Nlink = st.Nlink
- s.Uid = st.Uid
- s.Gid = st.Gid
- s.Rdev = st.Rdev
- s.Size = st.Size
- s.Atim = Timespec{int64(st.Atime), int64(st.Atime_nsec)}
- s.Mtim = Timespec{int64(st.Mtime), int64(st.Mtime_nsec)}
- s.Ctim = Timespec{int64(st.Ctime), int64(st.Ctime_nsec)}
- s.Blksize = st.Blksize
- s.Blocks = st.Blocks
-}
-
-func (r *PtraceRegs) PC() uint64 { return r.Regs[64] }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Regs[64] = pc }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint64(length)
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go b/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go
deleted file mode 100644
index be77d24a4..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go
+++ /dev/null
@@ -1,239 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build mips mipsle
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-func Syscall9(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
-
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Ftruncate(fd int, length int64) (err error) = SYS_FTRUNCATE64
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getuid() (uid int)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Listen(s int, n int) (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) = SYS__NEWSELECT
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) = SYS_SENDFILE64
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error) = SYS_TRUNCATE64
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-
-//sysnb InotifyInit() (fd int, err error)
-//sys Ioperm(from int, num int, on int) (err error)
-//sys Iopl(level int) (err error)
-
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Time(t *Time_t) (tt Time_t, err error)
-
-//sys Lstat(path string, stat *Stat_t) (err error) = SYS_LSTAT64
-//sys Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64
-//sys Stat(path string, stat *Stat_t) (err error) = SYS_STAT64
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Pause() (err error)
-
-func Fstatfs(fd int, buf *Statfs_t) (err error) {
- _, _, e := Syscall(SYS_FSTATFS64, uintptr(fd), unsafe.Sizeof(*buf), uintptr(unsafe.Pointer(buf)))
- if e != 0 {
- err = errnoErr(e)
- }
- return
-}
-
-func Statfs(path string, buf *Statfs_t) (err error) {
- p, err := BytePtrFromString(path)
- if err != nil {
- return err
- }
- _, _, e := Syscall(SYS_STATFS64, uintptr(unsafe.Pointer(p)), unsafe.Sizeof(*buf), uintptr(unsafe.Pointer(buf)))
- if e != 0 {
- err = errnoErr(e)
- }
- return
-}
-
-func Seek(fd int, offset int64, whence int) (off int64, err error) {
- _, _, e := Syscall6(SYS__LLSEEK, uintptr(fd), uintptr(offset>>32), uintptr(offset), uintptr(unsafe.Pointer(&off)), uintptr(whence), 0)
- if e != 0 {
- err = errnoErr(e)
- }
- return
-}
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int32(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = int32(nsec / 1e9)
- tv.Usec = int32(nsec % 1e9 / 1e3)
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, 0)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sys mmap2(addr uintptr, length uintptr, prot int, flags int, fd int, pageOffset uintptr) (xaddr uintptr, err error)
-
-func mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error) {
- page := uintptr(offset / 4096)
- if offset != int64(page)*4096 {
- return 0, EINVAL
- }
- return mmap2(addr, length, prot, flags, fd, page)
-}
-
-const rlimInf32 = ^uint32(0)
-const rlimInf64 = ^uint64(0)
-
-type rlimit32 struct {
- Cur uint32
- Max uint32
-}
-
-//sysnb getrlimit(resource int, rlim *rlimit32) (err error) = SYS_GETRLIMIT
-
-func Getrlimit(resource int, rlim *Rlimit) (err error) {
- err = prlimit(0, resource, nil, rlim)
- if err != ENOSYS {
- return err
- }
-
- rl := rlimit32{}
- err = getrlimit(resource, &rl)
- if err != nil {
- return
- }
-
- if rl.Cur == rlimInf32 {
- rlim.Cur = rlimInf64
- } else {
- rlim.Cur = uint64(rl.Cur)
- }
-
- if rl.Max == rlimInf32 {
- rlim.Max = rlimInf64
- } else {
- rlim.Max = uint64(rl.Max)
- }
- return
-}
-
-//sysnb setrlimit(resource int, rlim *rlimit32) (err error) = SYS_SETRLIMIT
-
-func Setrlimit(resource int, rlim *Rlimit) (err error) {
- err = prlimit(0, resource, rlim, nil)
- if err != ENOSYS {
- return err
- }
-
- rl := rlimit32{}
- if rlim.Cur == rlimInf64 {
- rl.Cur = rlimInf32
- } else if rlim.Cur < uint64(rlimInf32) {
- rl.Cur = uint32(rlim.Cur)
- } else {
- return EINVAL
- }
- if rlim.Max == rlimInf64 {
- rl.Max = rlimInf32
- } else if rlim.Max < uint64(rlimInf32) {
- rl.Max = uint32(rlim.Max)
- } else {
- return EINVAL
- }
-
- return setrlimit(resource, &rl)
-}
-
-func (r *PtraceRegs) PC() uint64 { return uint64(r.Regs[64]) }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Regs[64] = uint32(pc) }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
-
-func Getpagesize() int { return 4096 }
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go b/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go
deleted file mode 100644
index 60770f627..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go
+++ /dev/null
@@ -1,135 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux
-// +build ppc64 ppc64le
-
-package unix
-
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, buf *Statfs_t) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getrlimit(resource int, rlim *Rlimit) (err error) = SYS_UGETRLIMIT
-//sysnb Getuid() (uid int)
-//sysnb InotifyInit() (fd int, err error)
-//sys Ioperm(from int, num int, on int) (err error)
-//sys Iopl(level int) (err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Listen(s int, n int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Pause() (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error)
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, buf *Statfs_t) (err error)
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error) = SYS_SYNC_FILE_RANGE2
-//sys Truncate(path string, length int64) (err error)
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error)
-
-func Getpagesize() int { return 65536 }
-
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Time(t *Time_t) (tt Time_t, err error)
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = nsec / 1e9
- tv.Usec = nsec % 1e9 / 1e3
- return
-}
-
-func (r *PtraceRegs) PC() uint64 { return r.Nip }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Nip = pc }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint64(length)
-}
-
-//sysnb pipe(p *[2]_C_int) (err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe(&pp)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_s390x.go b/vendor/golang.org/x/sys/unix/syscall_linux_s390x.go
deleted file mode 100644
index 1708a4bbf..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_s390x.go
+++ /dev/null
@@ -1,328 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build s390x,linux
-
-package unix
-
-import (
- "unsafe"
-)
-
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, buf *Statfs_t) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Getuid() (uid int)
-//sysnb InotifyInit() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Pause() (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error)
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, buf *Statfs_t) (err error)
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-
-func Getpagesize() int { return 4096 }
-
-//sysnb Gettimeofday(tv *Timeval) (err error)
-
-func Time(t *Time_t) (tt Time_t, err error) {
- var tv Timeval
- err = Gettimeofday(&tv)
- if err != nil {
- return 0, err
- }
- if t != nil {
- *t = Time_t(tv.Sec)
- }
- return Time_t(tv.Sec), nil
-}
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = nsec / 1e9
- tv.Usec = nsec % 1e9 / 1e3
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, 0) // pipe2 is the same as pipe when flags are set to 0.
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-func Ioperm(from int, num int, on int) (err error) {
- return ENOSYS
-}
-
-func Iopl(level int) (err error) {
- return ENOSYS
-}
-
-func (r *PtraceRegs) PC() uint64 { return r.Psw.Addr }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Psw.Addr = pc }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint64(length)
-}
-
-// Linux on s390x uses the old mmap interface, which requires arguments to be passed in a struct.
-// mmap2 also requires arguments to be passed in a struct; it is currently not exposed in .
-func mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error) {
- mmap_args := [6]uintptr{addr, length, uintptr(prot), uintptr(flags), uintptr(fd), uintptr(offset)}
- r0, _, e1 := Syscall(SYS_MMAP, uintptr(unsafe.Pointer(&mmap_args[0])), 0, 0)
- xaddr = uintptr(r0)
- if e1 != 0 {
- err = errnoErr(e1)
- }
- return
-}
-
-// On s390x Linux, all the socket calls go through an extra indirection.
-// The arguments to the underlying system call (SYS_SOCKETCALL) are the
-// number below and a pointer to an array of uintptr.
-const (
- // see linux/net.h
- netSocket = 1
- netBind = 2
- netConnect = 3
- netListen = 4
- netAccept = 5
- netGetSockName = 6
- netGetPeerName = 7
- netSocketPair = 8
- netSend = 9
- netRecv = 10
- netSendTo = 11
- netRecvFrom = 12
- netShutdown = 13
- netSetSockOpt = 14
- netGetSockOpt = 15
- netSendMsg = 16
- netRecvMsg = 17
- netAccept4 = 18
- netRecvMMsg = 19
- netSendMMsg = 20
-)
-
-func accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (int, error) {
- args := [3]uintptr{uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen))}
- fd, _, err := Syscall(SYS_SOCKETCALL, netAccept, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return 0, err
- }
- return int(fd), nil
-}
-
-func accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (int, error) {
- args := [4]uintptr{uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen)), uintptr(flags)}
- fd, _, err := Syscall(SYS_SOCKETCALL, netAccept4, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return 0, err
- }
- return int(fd), nil
-}
-
-func getsockname(s int, rsa *RawSockaddrAny, addrlen *_Socklen) error {
- args := [3]uintptr{uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen))}
- _, _, err := RawSyscall(SYS_SOCKETCALL, netGetSockName, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func getpeername(s int, rsa *RawSockaddrAny, addrlen *_Socklen) error {
- args := [3]uintptr{uintptr(s), uintptr(unsafe.Pointer(rsa)), uintptr(unsafe.Pointer(addrlen))}
- _, _, err := RawSyscall(SYS_SOCKETCALL, netGetPeerName, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func socketpair(domain int, typ int, flags int, fd *[2]int32) error {
- args := [4]uintptr{uintptr(domain), uintptr(typ), uintptr(flags), uintptr(unsafe.Pointer(fd))}
- _, _, err := RawSyscall(SYS_SOCKETCALL, netSocketPair, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func bind(s int, addr unsafe.Pointer, addrlen _Socklen) error {
- args := [3]uintptr{uintptr(s), uintptr(addr), uintptr(addrlen)}
- _, _, err := Syscall(SYS_SOCKETCALL, netBind, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func connect(s int, addr unsafe.Pointer, addrlen _Socklen) error {
- args := [3]uintptr{uintptr(s), uintptr(addr), uintptr(addrlen)}
- _, _, err := Syscall(SYS_SOCKETCALL, netConnect, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func socket(domain int, typ int, proto int) (int, error) {
- args := [3]uintptr{uintptr(domain), uintptr(typ), uintptr(proto)}
- fd, _, err := RawSyscall(SYS_SOCKETCALL, netSocket, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return 0, err
- }
- return int(fd), nil
-}
-
-func getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) error {
- args := [5]uintptr{uintptr(s), uintptr(level), uintptr(name), uintptr(val), uintptr(unsafe.Pointer(vallen))}
- _, _, err := Syscall(SYS_SOCKETCALL, netGetSockOpt, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) error {
- args := [4]uintptr{uintptr(s), uintptr(level), uintptr(name), uintptr(val)}
- _, _, err := Syscall(SYS_SOCKETCALL, netSetSockOpt, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func recvfrom(s int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (int, error) {
- var base uintptr
- if len(p) > 0 {
- base = uintptr(unsafe.Pointer(&p[0]))
- }
- args := [6]uintptr{uintptr(s), base, uintptr(len(p)), uintptr(flags), uintptr(unsafe.Pointer(from)), uintptr(unsafe.Pointer(fromlen))}
- n, _, err := Syscall(SYS_SOCKETCALL, netRecvFrom, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return 0, err
- }
- return int(n), nil
-}
-
-func sendto(s int, p []byte, flags int, to unsafe.Pointer, addrlen _Socklen) error {
- var base uintptr
- if len(p) > 0 {
- base = uintptr(unsafe.Pointer(&p[0]))
- }
- args := [6]uintptr{uintptr(s), base, uintptr(len(p)), uintptr(flags), uintptr(to), uintptr(addrlen)}
- _, _, err := Syscall(SYS_SOCKETCALL, netSendTo, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func recvmsg(s int, msg *Msghdr, flags int) (int, error) {
- args := [3]uintptr{uintptr(s), uintptr(unsafe.Pointer(msg)), uintptr(flags)}
- n, _, err := Syscall(SYS_SOCKETCALL, netRecvMsg, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return 0, err
- }
- return int(n), nil
-}
-
-func sendmsg(s int, msg *Msghdr, flags int) (int, error) {
- args := [3]uintptr{uintptr(s), uintptr(unsafe.Pointer(msg)), uintptr(flags)}
- n, _, err := Syscall(SYS_SOCKETCALL, netSendMsg, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return 0, err
- }
- return int(n), nil
-}
-
-func Listen(s int, n int) error {
- args := [2]uintptr{uintptr(s), uintptr(n)}
- _, _, err := Syscall(SYS_SOCKETCALL, netListen, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-func Shutdown(s, how int) error {
- args := [2]uintptr{uintptr(s), uintptr(how)}
- _, _, err := Syscall(SYS_SOCKETCALL, netShutdown, uintptr(unsafe.Pointer(&args)), 0)
- if err != 0 {
- return err
- }
- return nil
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go b/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go
deleted file mode 100644
index 20b7454d7..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go
+++ /dev/null
@@ -1,169 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build sparc64,linux
-
-package unix
-
-import (
- "sync/atomic"
- "syscall"
-)
-
-//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error)
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, buf *Statfs_t) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (euid int)
-//sysnb Getgid() (gid int)
-//sysnb Getrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Getuid() (uid int)
-//sysnb InotifyInit() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Listen(s int, n int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Pause() (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
-//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
-//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error)
-//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
-//sys Setfsgid(gid int) (err error)
-//sys Setfsuid(uid int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sys Shutdown(fd int, how int) (err error)
-//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, buf *Statfs_t) (err error)
-//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
-//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
-//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
-//sysnb setgroups(n int, list *_Gid_t) (err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
-//sysnb socket(domain int, typ int, proto int) (fd int, err error)
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error)
-
-func sysconf(name int) (n int64, err syscall.Errno)
-
-// pageSize caches the value of Getpagesize, since it can't change
-// once the system is booted.
-var pageSize int64 // accessed atomically
-
-func Getpagesize() int {
- n := atomic.LoadInt64(&pageSize)
- if n == 0 {
- n, _ = sysconf(_SC_PAGESIZE)
- atomic.StoreInt64(&pageSize, n)
- }
- return int(n)
-}
-
-func Ioperm(from int, num int, on int) (err error) {
- return ENOSYS
-}
-
-func Iopl(level int) (err error) {
- return ENOSYS
-}
-
-//sysnb Gettimeofday(tv *Timeval) (err error)
-
-func Time(t *Time_t) (tt Time_t, err error) {
- var tv Timeval
- err = Gettimeofday(&tv)
- if err != nil {
- return 0, err
- }
- if t != nil {
- *t = Time_t(tv.Sec)
- }
- return Time_t(tv.Sec), nil
-}
-
-//sys Utime(path string, buf *Utimbuf) (err error)
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Sec = nsec / 1e9
- tv.Usec = int32(nsec % 1e9 / 1e3)
- return
-}
-
-func (r *PtraceRegs) PC() uint64 { return r.Tpc }
-
-func (r *PtraceRegs) SetPC(pc uint64) { r.Tpc = pc }
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint64(length)
-}
-
-//sysnb pipe(p *[2]_C_int) (err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe(&pp)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sysnb pipe2(p *[2]_C_int, flags int) (err error)
-
-func Pipe2(p []int, flags int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe2(&pp, flags)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sys poll(fds *PollFd, nfds int, timeout int) (n int, err error)
-
-func Poll(fds []PollFd, timeout int) (n int, err error) {
- if len(fds) == 0 {
- return poll(nil, 0, timeout)
- }
- return poll(&fds[0], len(fds), timeout)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_netbsd.go b/vendor/golang.org/x/sys/unix/syscall_netbsd.go
deleted file mode 100644
index 01f6a48c8..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_netbsd.go
+++ /dev/null
@@ -1,476 +0,0 @@
-// Copyright 2009,2010 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// NetBSD system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and wrap
-// it in our own nicer implementation, either here or in
-// syscall_bsd.go or syscall_unix.go.
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-type SockaddrDatalink struct {
- Len uint8
- Family uint8
- Index uint16
- Type uint8
- Nlen uint8
- Alen uint8
- Slen uint8
- Data [12]int8
- raw RawSockaddrDatalink
-}
-
-func Syscall9(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
-
-func sysctlNodes(mib []_C_int) (nodes []Sysctlnode, err error) {
- var olen uintptr
-
- // Get a list of all sysctl nodes below the given MIB by performing
- // a sysctl for the given MIB with CTL_QUERY appended.
- mib = append(mib, CTL_QUERY)
- qnode := Sysctlnode{Flags: SYSCTL_VERS_1}
- qp := (*byte)(unsafe.Pointer(&qnode))
- sz := unsafe.Sizeof(qnode)
- if err = sysctl(mib, nil, &olen, qp, sz); err != nil {
- return nil, err
- }
-
- // Now that we know the size, get the actual nodes.
- nodes = make([]Sysctlnode, olen/sz)
- np := (*byte)(unsafe.Pointer(&nodes[0]))
- if err = sysctl(mib, np, &olen, qp, sz); err != nil {
- return nil, err
- }
-
- return nodes, nil
-}
-
-func nametomib(name string) (mib []_C_int, err error) {
-
- // Split name into components.
- var parts []string
- last := 0
- for i := 0; i < len(name); i++ {
- if name[i] == '.' {
- parts = append(parts, name[last:i])
- last = i + 1
- }
- }
- parts = append(parts, name[last:])
-
- // Discover the nodes and construct the MIB OID.
- for partno, part := range parts {
- nodes, err := sysctlNodes(mib)
- if err != nil {
- return nil, err
- }
- for _, node := range nodes {
- n := make([]byte, 0)
- for i := range node.Name {
- if node.Name[i] != 0 {
- n = append(n, byte(node.Name[i]))
- }
- }
- if string(n) == part {
- mib = append(mib, _C_int(node.Num))
- break
- }
- }
- if len(mib) != partno+1 {
- return nil, EINVAL
- }
- }
-
- return mib, nil
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen))
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen))
-}
-
-//sysnb pipe() (fd1 int, fd2 int, err error)
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- p[0], p[1], err = pipe()
- return
-}
-
-//sys getdents(fd int, buf []byte) (n int, err error)
-func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) {
- return getdents(fd, buf)
-}
-
-// TODO
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- return -1, ENOSYS
-}
-
-/*
- * Exposed directly
- */
-//sys Access(path string, mode uint32) (err error)
-//sys Adjtime(delta *Timeval, olddelta *Timeval) (err error)
-//sys Chdir(path string) (err error)
-//sys Chflags(path string, flags int) (err error)
-//sys Chmod(path string, mode uint32) (err error)
-//sys Chown(path string, uid int, gid int) (err error)
-//sys Chroot(path string) (err error)
-//sys Close(fd int) (err error)
-//sys Dup(fd int) (nfd int, err error)
-//sys Dup2(from int, to int) (err error)
-//sys Exit(code int)
-//sys Fchdir(fd int) (err error)
-//sys Fchflags(fd int, flags int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Flock(fd int, how int) (err error)
-//sys Fpathconf(fd int, name int) (val int, err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fsync(fd int) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (uid int)
-//sysnb Getgid() (gid int)
-//sysnb Getpgid(pid int) (pgid int, err error)
-//sysnb Getpgrp() (pgrp int)
-//sysnb Getpid() (pid int)
-//sysnb Getppid() (ppid int)
-//sys Getpriority(which int, who int) (prio int, err error)
-//sysnb Getrlimit(which int, lim *Rlimit) (err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Getsid(pid int) (sid int, err error)
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Getuid() (uid int)
-//sys Issetugid() (tainted bool)
-//sys Kill(pid int, signum syscall.Signal) (err error)
-//sys Kqueue() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Link(path string, link string) (err error)
-//sys Listen(s int, backlog int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Mkdir(path string, mode uint32) (err error)
-//sys Mkfifo(path string, mode uint32) (err error)
-//sys Mknod(path string, mode uint32, dev int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Munlockall() (err error)
-//sys Nanosleep(time *Timespec, leftover *Timespec) (err error)
-//sys Open(path string, mode int, perm uint32) (fd int, err error)
-//sys Pathconf(path string, name int) (val int, err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error)
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Readlink(path string, buf []byte) (n int, err error)
-//sys Rename(from string, to string) (err error)
-//sys Revoke(path string) (err error)
-//sys Rmdir(path string) (err error)
-//sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK
-//sys Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error)
-//sysnb Setegid(egid int) (err error)
-//sysnb Seteuid(euid int) (err error)
-//sysnb Setgid(gid int) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sys Setpriority(which int, who int, prio int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sysnb Setrlimit(which int, lim *Rlimit) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Settimeofday(tp *Timeval) (err error)
-//sysnb Setuid(uid int) (err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Symlink(path string, link string) (err error)
-//sys Sync() (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys Umask(newmask int) (oldmask int)
-//sys Unlink(path string) (err error)
-//sys Unmount(path string, flags int) (err error)
-//sys write(fd int, p []byte) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error)
-//sys munmap(addr uintptr, length uintptr) (err error)
-//sys readlen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_READ
-//sys writelen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_WRITE
-
-/*
- * Unimplemented
- */
-// ____semctl13
-// __clone
-// __fhopen40
-// __fhstat40
-// __fhstatvfs140
-// __fstat30
-// __getcwd
-// __getfh30
-// __getlogin
-// __lstat30
-// __mount50
-// __msgctl13
-// __msync13
-// __ntp_gettime30
-// __posix_chown
-// __posix_fadvise50
-// __posix_fchown
-// __posix_lchown
-// __posix_rename
-// __setlogin
-// __shmctl13
-// __sigaction_sigtramp
-// __sigaltstack14
-// __sigpending14
-// __sigprocmask14
-// __sigsuspend14
-// __sigtimedwait
-// __stat30
-// __syscall
-// __vfork14
-// _ksem_close
-// _ksem_destroy
-// _ksem_getvalue
-// _ksem_init
-// _ksem_open
-// _ksem_post
-// _ksem_trywait
-// _ksem_unlink
-// _ksem_wait
-// _lwp_continue
-// _lwp_create
-// _lwp_ctl
-// _lwp_detach
-// _lwp_exit
-// _lwp_getname
-// _lwp_getprivate
-// _lwp_kill
-// _lwp_park
-// _lwp_self
-// _lwp_setname
-// _lwp_setprivate
-// _lwp_suspend
-// _lwp_unpark
-// _lwp_unpark_all
-// _lwp_wait
-// _lwp_wakeup
-// _pset_bind
-// _sched_getaffinity
-// _sched_getparam
-// _sched_setaffinity
-// _sched_setparam
-// acct
-// aio_cancel
-// aio_error
-// aio_fsync
-// aio_read
-// aio_return
-// aio_suspend
-// aio_write
-// break
-// clock_getres
-// clock_gettime
-// clock_settime
-// compat_09_ogetdomainname
-// compat_09_osetdomainname
-// compat_09_ouname
-// compat_10_omsgsys
-// compat_10_osemsys
-// compat_10_oshmsys
-// compat_12_fstat12
-// compat_12_getdirentries
-// compat_12_lstat12
-// compat_12_msync
-// compat_12_oreboot
-// compat_12_oswapon
-// compat_12_stat12
-// compat_13_sigaction13
-// compat_13_sigaltstack13
-// compat_13_sigpending13
-// compat_13_sigprocmask13
-// compat_13_sigreturn13
-// compat_13_sigsuspend13
-// compat_14___semctl
-// compat_14_msgctl
-// compat_14_shmctl
-// compat_16___sigaction14
-// compat_16___sigreturn14
-// compat_20_fhstatfs
-// compat_20_fstatfs
-// compat_20_getfsstat
-// compat_20_statfs
-// compat_30___fhstat30
-// compat_30___fstat13
-// compat_30___lstat13
-// compat_30___stat13
-// compat_30_fhopen
-// compat_30_fhstat
-// compat_30_fhstatvfs1
-// compat_30_getdents
-// compat_30_getfh
-// compat_30_ntp_gettime
-// compat_30_socket
-// compat_40_mount
-// compat_43_fstat43
-// compat_43_lstat43
-// compat_43_oaccept
-// compat_43_ocreat
-// compat_43_oftruncate
-// compat_43_ogetdirentries
-// compat_43_ogetdtablesize
-// compat_43_ogethostid
-// compat_43_ogethostname
-// compat_43_ogetkerninfo
-// compat_43_ogetpagesize
-// compat_43_ogetpeername
-// compat_43_ogetrlimit
-// compat_43_ogetsockname
-// compat_43_okillpg
-// compat_43_olseek
-// compat_43_ommap
-// compat_43_oquota
-// compat_43_orecv
-// compat_43_orecvfrom
-// compat_43_orecvmsg
-// compat_43_osend
-// compat_43_osendmsg
-// compat_43_osethostid
-// compat_43_osethostname
-// compat_43_osetrlimit
-// compat_43_osigblock
-// compat_43_osigsetmask
-// compat_43_osigstack
-// compat_43_osigvec
-// compat_43_otruncate
-// compat_43_owait
-// compat_43_stat43
-// execve
-// extattr_delete_fd
-// extattr_delete_file
-// extattr_delete_link
-// extattr_get_fd
-// extattr_get_file
-// extattr_get_link
-// extattr_list_fd
-// extattr_list_file
-// extattr_list_link
-// extattr_set_fd
-// extattr_set_file
-// extattr_set_link
-// extattrctl
-// fchroot
-// fdatasync
-// fgetxattr
-// fktrace
-// flistxattr
-// fork
-// fremovexattr
-// fsetxattr
-// fstatvfs1
-// fsync_range
-// getcontext
-// getitimer
-// getvfsstat
-// getxattr
-// ioctl
-// ktrace
-// lchflags
-// lchmod
-// lfs_bmapv
-// lfs_markv
-// lfs_segclean
-// lfs_segwait
-// lgetxattr
-// lio_listio
-// listxattr
-// llistxattr
-// lremovexattr
-// lseek
-// lsetxattr
-// lutimes
-// madvise
-// mincore
-// minherit
-// modctl
-// mq_close
-// mq_getattr
-// mq_notify
-// mq_open
-// mq_receive
-// mq_send
-// mq_setattr
-// mq_timedreceive
-// mq_timedsend
-// mq_unlink
-// mremap
-// msgget
-// msgrcv
-// msgsnd
-// nfssvc
-// ntp_adjtime
-// pmc_control
-// pmc_get_info
-// poll
-// pollts
-// preadv
-// profil
-// pselect
-// pset_assign
-// pset_create
-// pset_destroy
-// ptrace
-// pwritev
-// quotactl
-// rasctl
-// readv
-// reboot
-// removexattr
-// sa_enable
-// sa_preempt
-// sa_register
-// sa_setconcurrency
-// sa_stacks
-// sa_yield
-// sbrk
-// sched_yield
-// semconfig
-// semget
-// semop
-// setcontext
-// setitimer
-// setxattr
-// shmat
-// shmdt
-// shmget
-// sstk
-// statvfs1
-// swapctl
-// sysarch
-// syscall
-// timer_create
-// timer_delete
-// timer_getoverrun
-// timer_gettime
-// timer_settime
-// undelete
-// utrace
-// uuidgen
-// vadvise
-// vfork
-// writev
diff --git a/vendor/golang.org/x/sys/unix/syscall_netbsd_386.go b/vendor/golang.org/x/sys/unix/syscall_netbsd_386.go
deleted file mode 100644
index afaca0983..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_netbsd_386.go
+++ /dev/null
@@ -1,42 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build 386,netbsd
-
-package unix
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int64(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = uint32(mode)
- k.Flags = uint32(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_netbsd_amd64.go b/vendor/golang.org/x/sys/unix/syscall_netbsd_amd64.go
deleted file mode 100644
index a6ff04ce5..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_netbsd_amd64.go
+++ /dev/null
@@ -1,42 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,netbsd
-
-package unix
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int64(nsec / 1e9)
- ts.Nsec = int64(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint64(fd)
- k.Filter = uint32(mode)
- k.Flags = uint32(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_netbsd_arm.go b/vendor/golang.org/x/sys/unix/syscall_netbsd_arm.go
deleted file mode 100644
index 68a6969b2..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_netbsd_arm.go
+++ /dev/null
@@ -1,42 +0,0 @@
-// Copyright 2013 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build arm,netbsd
-
-package unix
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int64(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = uint32(mode)
- k.Flags = uint32(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_no_getwd.go b/vendor/golang.org/x/sys/unix/syscall_no_getwd.go
deleted file mode 100644
index 530792ea9..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_no_getwd.go
+++ /dev/null
@@ -1,11 +0,0 @@
-// Copyright 2013 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build dragonfly freebsd netbsd openbsd
-
-package unix
-
-const ImplementsGetwd = false
-
-func Getwd() (string, error) { return "", ENOTSUP }
diff --git a/vendor/golang.org/x/sys/unix/syscall_openbsd.go b/vendor/golang.org/x/sys/unix/syscall_openbsd.go
deleted file mode 100644
index c0d2b6c80..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_openbsd.go
+++ /dev/null
@@ -1,287 +0,0 @@
-// Copyright 2009,2010 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// OpenBSD system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and wrap
-// it in our own nicer implementation, either here or in
-// syscall_bsd.go or syscall_unix.go.
-
-package unix
-
-import (
- "syscall"
- "unsafe"
-)
-
-type SockaddrDatalink struct {
- Len uint8
- Family uint8
- Index uint16
- Type uint8
- Nlen uint8
- Alen uint8
- Slen uint8
- Data [24]int8
- raw RawSockaddrDatalink
-}
-
-func Syscall9(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno)
-
-func nametomib(name string) (mib []_C_int, err error) {
-
- // Perform lookup via a binary search
- left := 0
- right := len(sysctlMib) - 1
- for {
- idx := left + (right-left)/2
- switch {
- case name == sysctlMib[idx].ctlname:
- return sysctlMib[idx].ctloid, nil
- case name > sysctlMib[idx].ctlname:
- left = idx + 1
- default:
- right = idx - 1
- }
- if left > right {
- break
- }
- }
- return nil, EINVAL
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Fileno), unsafe.Sizeof(Dirent{}.Fileno))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen))
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Namlen), unsafe.Sizeof(Dirent{}.Namlen))
-}
-
-//sysnb pipe(p *[2]_C_int) (err error)
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- err = pipe(&pp)
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return
-}
-
-//sys getdents(fd int, buf []byte) (n int, err error)
-func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) {
- return getdents(fd, buf)
-}
-
-// TODO
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- return -1, ENOSYS
-}
-
-func Getfsstat(buf []Statfs_t, flags int) (n int, err error) {
- var _p0 unsafe.Pointer
- var bufsize uintptr
- if len(buf) > 0 {
- _p0 = unsafe.Pointer(&buf[0])
- bufsize = unsafe.Sizeof(Statfs_t{}) * uintptr(len(buf))
- }
- r0, _, e1 := Syscall(SYS_GETFSSTAT, uintptr(_p0), bufsize, uintptr(flags))
- n = int(r0)
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-/*
- * Exposed directly
- */
-//sys Access(path string, mode uint32) (err error)
-//sys Adjtime(delta *Timeval, olddelta *Timeval) (err error)
-//sys Chdir(path string) (err error)
-//sys Chflags(path string, flags int) (err error)
-//sys Chmod(path string, mode uint32) (err error)
-//sys Chown(path string, uid int, gid int) (err error)
-//sys Chroot(path string) (err error)
-//sys Close(fd int) (err error)
-//sys Dup(fd int) (nfd int, err error)
-//sys Dup2(from int, to int) (err error)
-//sys Exit(code int)
-//sys Fchdir(fd int) (err error)
-//sys Fchflags(fd int, flags int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Flock(fd int, how int) (err error)
-//sys Fpathconf(fd int, name int) (val int, err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Fstatfs(fd int, stat *Statfs_t) (err error)
-//sys Fsync(fd int) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sysnb Getegid() (egid int)
-//sysnb Geteuid() (uid int)
-//sysnb Getgid() (gid int)
-//sysnb Getpgid(pid int) (pgid int, err error)
-//sysnb Getpgrp() (pgrp int)
-//sysnb Getpid() (pid int)
-//sysnb Getppid() (ppid int)
-//sys Getpriority(which int, who int) (prio int, err error)
-//sysnb Getrlimit(which int, lim *Rlimit) (err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Getsid(pid int) (sid int, err error)
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Getuid() (uid int)
-//sys Issetugid() (tainted bool)
-//sys Kill(pid int, signum syscall.Signal) (err error)
-//sys Kqueue() (fd int, err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Link(path string, link string) (err error)
-//sys Listen(s int, backlog int) (err error)
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Mkdir(path string, mode uint32) (err error)
-//sys Mkfifo(path string, mode uint32) (err error)
-//sys Mknod(path string, mode uint32, dev int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Munlockall() (err error)
-//sys Nanosleep(time *Timespec, leftover *Timespec) (err error)
-//sys Open(path string, mode int, perm uint32) (fd int, err error)
-//sys Pathconf(path string, name int) (val int, err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error)
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Readlink(path string, buf []byte) (n int, err error)
-//sys Rename(from string, to string) (err error)
-//sys Revoke(path string) (err error)
-//sys Rmdir(path string) (err error)
-//sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = SYS_LSEEK
-//sys Select(n int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (err error)
-//sysnb Setegid(egid int) (err error)
-//sysnb Seteuid(euid int) (err error)
-//sysnb Setgid(gid int) (err error)
-//sys Setlogin(name string) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sys Setpriority(which int, who int, prio int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
-//sysnb Setresuid(ruid int, euid int, suid int) (err error)
-//sysnb Setrlimit(which int, lim *Rlimit) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Settimeofday(tp *Timeval) (err error)
-//sysnb Setuid(uid int) (err error)
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Statfs(path string, stat *Statfs_t) (err error)
-//sys Symlink(path string, link string) (err error)
-//sys Sync() (err error)
-//sys Truncate(path string, length int64) (err error)
-//sys Umask(newmask int) (oldmask int)
-//sys Unlink(path string) (err error)
-//sys Unmount(path string, flags int) (err error)
-//sys write(fd int, p []byte) (n int, err error)
-//sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error)
-//sys munmap(addr uintptr, length uintptr) (err error)
-//sys readlen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_READ
-//sys writelen(fd int, buf *byte, nbuf int) (n int, err error) = SYS_WRITE
-
-/*
- * Unimplemented
- */
-// __getcwd
-// __semctl
-// __syscall
-// __sysctl
-// adjfreq
-// break
-// clock_getres
-// clock_gettime
-// clock_settime
-// closefrom
-// execve
-// faccessat
-// fchmodat
-// fchownat
-// fcntl
-// fhopen
-// fhstat
-// fhstatfs
-// fork
-// fstatat
-// futimens
-// getfh
-// getgid
-// getitimer
-// getlogin
-// getresgid
-// getresuid
-// getrtable
-// getthrid
-// ioctl
-// ktrace
-// lfs_bmapv
-// lfs_markv
-// lfs_segclean
-// lfs_segwait
-// linkat
-// mincore
-// minherit
-// mkdirat
-// mkfifoat
-// mknodat
-// mount
-// mquery
-// msgctl
-// msgget
-// msgrcv
-// msgsnd
-// nfssvc
-// nnpfspioctl
-// openat
-// poll
-// preadv
-// profil
-// pwritev
-// quotactl
-// readlinkat
-// readv
-// reboot
-// renameat
-// rfork
-// sched_yield
-// semget
-// semop
-// setgroups
-// setitimer
-// setrtable
-// setsockopt
-// shmat
-// shmctl
-// shmdt
-// shmget
-// sigaction
-// sigaltstack
-// sigpending
-// sigprocmask
-// sigreturn
-// sigsuspend
-// symlinkat
-// sysarch
-// syscall
-// threxit
-// thrsigdivert
-// thrsleep
-// thrwakeup
-// unlinkat
-// utimensat
-// vfork
-// writev
diff --git a/vendor/golang.org/x/sys/unix/syscall_openbsd_386.go b/vendor/golang.org/x/sys/unix/syscall_openbsd_386.go
deleted file mode 100644
index a66ddc59c..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_openbsd_386.go
+++ /dev/null
@@ -1,42 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build 386,openbsd
-
-package unix
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = int64(nsec / 1e9)
- ts.Nsec = int32(nsec % 1e9)
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = int32(nsec % 1e9 / 1e3)
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint32(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint32(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go
deleted file mode 100644
index 0776c1faf..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go
+++ /dev/null
@@ -1,42 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,openbsd
-
-package unix
-
-func Getpagesize() int { return 4096 }
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = nsec % 1e9 / 1e3
- tv.Sec = nsec / 1e9
- return
-}
-
-func SetKevent(k *Kevent_t, fd, mode, flags int) {
- k.Ident = uint64(fd)
- k.Filter = int16(mode)
- k.Flags = uint16(flags)
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (msghdr *Msghdr) SetControllen(length int) {
- msghdr.Controllen = uint32(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_solaris.go b/vendor/golang.org/x/sys/unix/syscall_solaris.go
deleted file mode 100644
index 3cb1d0bfe..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_solaris.go
+++ /dev/null
@@ -1,713 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Solaris system calls.
-// This file is compiled as ordinary Go code,
-// but it is also input to mksyscall,
-// which parses the //sys lines and generates system call stubs.
-// Note that sometimes we use a lowercase //sys name and wrap
-// it in our own nicer implementation, either here or in
-// syscall_solaris.go or syscall_unix.go.
-
-package unix
-
-import (
- "sync/atomic"
- "syscall"
- "unsafe"
-)
-
-// Implemented in runtime/syscall_solaris.go.
-type syscallFunc uintptr
-
-func rawSysvicall6(trap, nargs, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err syscall.Errno)
-func sysvicall6(trap, nargs, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err syscall.Errno)
-
-type SockaddrDatalink struct {
- Family uint16
- Index uint16
- Type uint8
- Nlen uint8
- Alen uint8
- Slen uint8
- Data [244]int8
- raw RawSockaddrDatalink
-}
-
-func clen(n []byte) int {
- for i := 0; i < len(n); i++ {
- if n[i] == 0 {
- return i
- }
- }
- return len(n)
-}
-
-func direntIno(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Ino), unsafe.Sizeof(Dirent{}.Ino))
-}
-
-func direntReclen(buf []byte) (uint64, bool) {
- return readInt(buf, unsafe.Offsetof(Dirent{}.Reclen), unsafe.Sizeof(Dirent{}.Reclen))
-}
-
-func direntNamlen(buf []byte) (uint64, bool) {
- reclen, ok := direntReclen(buf)
- if !ok {
- return 0, false
- }
- return reclen - uint64(unsafe.Offsetof(Dirent{}.Name)), true
-}
-
-//sysnb pipe(p *[2]_C_int) (n int, err error)
-
-func Pipe(p []int) (err error) {
- if len(p) != 2 {
- return EINVAL
- }
- var pp [2]_C_int
- n, err := pipe(&pp)
- if n != 0 {
- return err
- }
- p[0] = int(pp[0])
- p[1] = int(pp[1])
- return nil
-}
-
-func (sa *SockaddrInet4) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Port < 0 || sa.Port > 0xFFFF {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_INET
- p := (*[2]byte)(unsafe.Pointer(&sa.raw.Port))
- p[0] = byte(sa.Port >> 8)
- p[1] = byte(sa.Port)
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrInet4, nil
-}
-
-func (sa *SockaddrInet6) sockaddr() (unsafe.Pointer, _Socklen, error) {
- if sa.Port < 0 || sa.Port > 0xFFFF {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_INET6
- p := (*[2]byte)(unsafe.Pointer(&sa.raw.Port))
- p[0] = byte(sa.Port >> 8)
- p[1] = byte(sa.Port)
- sa.raw.Scope_id = sa.ZoneId
- for i := 0; i < len(sa.Addr); i++ {
- sa.raw.Addr[i] = sa.Addr[i]
- }
- return unsafe.Pointer(&sa.raw), SizeofSockaddrInet6, nil
-}
-
-func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, _Socklen, error) {
- name := sa.Name
- n := len(name)
- if n >= len(sa.raw.Path) {
- return nil, 0, EINVAL
- }
- sa.raw.Family = AF_UNIX
- for i := 0; i < n; i++ {
- sa.raw.Path[i] = int8(name[i])
- }
- // length is family (uint16), name, NUL.
- sl := _Socklen(2)
- if n > 0 {
- sl += _Socklen(n) + 1
- }
- if sa.raw.Path[0] == '@' {
- sa.raw.Path[0] = 0
- // Don't count trailing NUL for abstract address.
- sl--
- }
-
- return unsafe.Pointer(&sa.raw), sl, nil
-}
-
-//sys getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error) = libsocket.getsockname
-
-func Getsockname(fd int) (sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- if err = getsockname(fd, &rsa, &len); err != nil {
- return
- }
- return anyToSockaddr(&rsa)
-}
-
-const ImplementsGetwd = true
-
-//sys Getcwd(buf []byte) (n int, err error)
-
-func Getwd() (wd string, err error) {
- var buf [PathMax]byte
- // Getcwd will return an error if it failed for any reason.
- _, err = Getcwd(buf[0:])
- if err != nil {
- return "", err
- }
- n := clen(buf[:])
- if n < 1 {
- return "", EINVAL
- }
- return string(buf[:n]), nil
-}
-
-/*
- * Wrapped
- */
-
-//sysnb getgroups(ngid int, gid *_Gid_t) (n int, err error)
-//sysnb setgroups(ngid int, gid *_Gid_t) (err error)
-
-func Getgroups() (gids []int, err error) {
- n, err := getgroups(0, nil)
- // Check for error and sanity check group count. Newer versions of
- // Solaris allow up to 1024 (NGROUPS_MAX).
- if n < 0 || n > 1024 {
- if err != nil {
- return nil, err
- }
- return nil, EINVAL
- } else if n == 0 {
- return nil, nil
- }
-
- a := make([]_Gid_t, n)
- n, err = getgroups(n, &a[0])
- if n == -1 {
- return nil, err
- }
- gids = make([]int, n)
- for i, v := range a[0:n] {
- gids[i] = int(v)
- }
- return
-}
-
-func Setgroups(gids []int) (err error) {
- if len(gids) == 0 {
- return setgroups(0, nil)
- }
-
- a := make([]_Gid_t, len(gids))
- for i, v := range gids {
- a[i] = _Gid_t(v)
- }
- return setgroups(len(a), &a[0])
-}
-
-func ReadDirent(fd int, buf []byte) (n int, err error) {
- // Final argument is (basep *uintptr) and the syscall doesn't take nil.
- // TODO(rsc): Can we use a single global basep for all calls?
- return Getdents(fd, buf, new(uintptr))
-}
-
-// Wait status is 7 bits at bottom, either 0 (exited),
-// 0x7F (stopped), or a signal number that caused an exit.
-// The 0x80 bit is whether there was a core dump.
-// An extra number (exit code, signal causing a stop)
-// is in the high bits.
-
-type WaitStatus uint32
-
-const (
- mask = 0x7F
- core = 0x80
- shift = 8
-
- exited = 0
- stopped = 0x7F
-)
-
-func (w WaitStatus) Exited() bool { return w&mask == exited }
-
-func (w WaitStatus) ExitStatus() int {
- if w&mask != exited {
- return -1
- }
- return int(w >> shift)
-}
-
-func (w WaitStatus) Signaled() bool { return w&mask != stopped && w&mask != 0 }
-
-func (w WaitStatus) Signal() syscall.Signal {
- sig := syscall.Signal(w & mask)
- if sig == stopped || sig == 0 {
- return -1
- }
- return sig
-}
-
-func (w WaitStatus) CoreDump() bool { return w.Signaled() && w&core != 0 }
-
-func (w WaitStatus) Stopped() bool { return w&mask == stopped && syscall.Signal(w>>shift) != SIGSTOP }
-
-func (w WaitStatus) Continued() bool { return w&mask == stopped && syscall.Signal(w>>shift) == SIGSTOP }
-
-func (w WaitStatus) StopSignal() syscall.Signal {
- if !w.Stopped() {
- return -1
- }
- return syscall.Signal(w>>shift) & 0xFF
-}
-
-func (w WaitStatus) TrapCause() int { return -1 }
-
-//sys wait4(pid int32, statusp *_C_int, options int, rusage *Rusage) (wpid int32, err error)
-
-func Wait4(pid int, wstatus *WaitStatus, options int, rusage *Rusage) (int, error) {
- var status _C_int
- rpid, err := wait4(int32(pid), &status, options, rusage)
- wpid := int(rpid)
- if wpid == -1 {
- return wpid, err
- }
- if wstatus != nil {
- *wstatus = WaitStatus(status)
- }
- return wpid, nil
-}
-
-//sys gethostname(buf []byte) (n int, err error)
-
-func Gethostname() (name string, err error) {
- var buf [MaxHostNameLen]byte
- n, err := gethostname(buf[:])
- if n != 0 {
- return "", err
- }
- n = clen(buf[:])
- if n < 1 {
- return "", EFAULT
- }
- return string(buf[:n]), nil
-}
-
-//sys utimes(path string, times *[2]Timeval) (err error)
-
-func Utimes(path string, tv []Timeval) (err error) {
- if tv == nil {
- return utimes(path, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- return utimes(path, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-//sys utimensat(fd int, path string, times *[2]Timespec, flag int) (err error)
-
-func UtimesNano(path string, ts []Timespec) error {
- if ts == nil {
- return utimensat(AT_FDCWD, path, nil, 0)
- }
- if len(ts) != 2 {
- return EINVAL
- }
- return utimensat(AT_FDCWD, path, (*[2]Timespec)(unsafe.Pointer(&ts[0])), 0)
-}
-
-func UtimesNanoAt(dirfd int, path string, ts []Timespec, flags int) error {
- if ts == nil {
- return utimensat(dirfd, path, nil, flags)
- }
- if len(ts) != 2 {
- return EINVAL
- }
- return utimensat(dirfd, path, (*[2]Timespec)(unsafe.Pointer(&ts[0])), flags)
-}
-
-//sys fcntl(fd int, cmd int, arg int) (val int, err error)
-
-// FcntlFlock performs a fcntl syscall for the F_GETLK, F_SETLK or F_SETLKW command.
-func FcntlFlock(fd uintptr, cmd int, lk *Flock_t) error {
- _, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procfcntl)), 3, uintptr(fd), uintptr(cmd), uintptr(unsafe.Pointer(lk)), 0, 0, 0)
- if e1 != 0 {
- return e1
- }
- return nil
-}
-
-//sys futimesat(fildes int, path *byte, times *[2]Timeval) (err error)
-
-func Futimesat(dirfd int, path string, tv []Timeval) error {
- pathp, err := BytePtrFromString(path)
- if err != nil {
- return err
- }
- if tv == nil {
- return futimesat(dirfd, pathp, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- return futimesat(dirfd, pathp, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-// Solaris doesn't have an futimes function because it allows NULL to be
-// specified as the path for futimesat. However, Go doesn't like
-// NULL-style string interfaces, so this simple wrapper is provided.
-func Futimes(fd int, tv []Timeval) error {
- if tv == nil {
- return futimesat(fd, nil, nil)
- }
- if len(tv) != 2 {
- return EINVAL
- }
- return futimesat(fd, nil, (*[2]Timeval)(unsafe.Pointer(&tv[0])))
-}
-
-func anyToSockaddr(rsa *RawSockaddrAny) (Sockaddr, error) {
- switch rsa.Addr.Family {
- case AF_UNIX:
- pp := (*RawSockaddrUnix)(unsafe.Pointer(rsa))
- sa := new(SockaddrUnix)
- // Assume path ends at NUL.
- // This is not technically the Solaris semantics for
- // abstract Unix domain sockets -- they are supposed
- // to be uninterpreted fixed-size binary blobs -- but
- // everyone uses this convention.
- n := 0
- for n < len(pp.Path) && pp.Path[n] != 0 {
- n++
- }
- bytes := (*[10000]byte)(unsafe.Pointer(&pp.Path[0]))[0:n]
- sa.Name = string(bytes)
- return sa, nil
-
- case AF_INET:
- pp := (*RawSockaddrInet4)(unsafe.Pointer(rsa))
- sa := new(SockaddrInet4)
- p := (*[2]byte)(unsafe.Pointer(&pp.Port))
- sa.Port = int(p[0])<<8 + int(p[1])
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
-
- case AF_INET6:
- pp := (*RawSockaddrInet6)(unsafe.Pointer(rsa))
- sa := new(SockaddrInet6)
- p := (*[2]byte)(unsafe.Pointer(&pp.Port))
- sa.Port = int(p[0])<<8 + int(p[1])
- sa.ZoneId = pp.Scope_id
- for i := 0; i < len(sa.Addr); i++ {
- sa.Addr[i] = pp.Addr[i]
- }
- return sa, nil
- }
- return nil, EAFNOSUPPORT
-}
-
-//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error) = libsocket.accept
-
-func Accept(fd int) (nfd int, sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- nfd, err = accept(fd, &rsa, &len)
- if nfd == -1 {
- return
- }
- sa, err = anyToSockaddr(&rsa)
- if err != nil {
- Close(nfd)
- nfd = 0
- }
- return
-}
-
-//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error) = libsocket.recvmsg
-
-func Recvmsg(fd int, p, oob []byte, flags int) (n, oobn int, recvflags int, from Sockaddr, err error) {
- var msg Msghdr
- var rsa RawSockaddrAny
- msg.Name = (*byte)(unsafe.Pointer(&rsa))
- msg.Namelen = uint32(SizeofSockaddrAny)
- var iov Iovec
- if len(p) > 0 {
- iov.Base = (*int8)(unsafe.Pointer(&p[0]))
- iov.SetLen(len(p))
- }
- var dummy int8
- if len(oob) > 0 {
- // receive at least one normal byte
- if len(p) == 0 {
- iov.Base = &dummy
- iov.SetLen(1)
- }
- msg.Accrights = (*int8)(unsafe.Pointer(&oob[0]))
- }
- msg.Iov = &iov
- msg.Iovlen = 1
- if n, err = recvmsg(fd, &msg, flags); n == -1 {
- return
- }
- oobn = int(msg.Accrightslen)
- // source address is only specified if the socket is unconnected
- if rsa.Addr.Family != AF_UNSPEC {
- from, err = anyToSockaddr(&rsa)
- }
- return
-}
-
-func Sendmsg(fd int, p, oob []byte, to Sockaddr, flags int) (err error) {
- _, err = SendmsgN(fd, p, oob, to, flags)
- return
-}
-
-//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error) = libsocket.sendmsg
-
-func SendmsgN(fd int, p, oob []byte, to Sockaddr, flags int) (n int, err error) {
- var ptr unsafe.Pointer
- var salen _Socklen
- if to != nil {
- ptr, salen, err = to.sockaddr()
- if err != nil {
- return 0, err
- }
- }
- var msg Msghdr
- msg.Name = (*byte)(unsafe.Pointer(ptr))
- msg.Namelen = uint32(salen)
- var iov Iovec
- if len(p) > 0 {
- iov.Base = (*int8)(unsafe.Pointer(&p[0]))
- iov.SetLen(len(p))
- }
- var dummy int8
- if len(oob) > 0 {
- // send at least one normal byte
- if len(p) == 0 {
- iov.Base = &dummy
- iov.SetLen(1)
- }
- msg.Accrights = (*int8)(unsafe.Pointer(&oob[0]))
- }
- msg.Iov = &iov
- msg.Iovlen = 1
- if n, err = sendmsg(fd, &msg, flags); err != nil {
- return 0, err
- }
- if len(oob) > 0 && len(p) == 0 {
- n = 0
- }
- return n, nil
-}
-
-//sys acct(path *byte) (err error)
-
-func Acct(path string) (err error) {
- if len(path) == 0 {
- // Assume caller wants to disable accounting.
- return acct(nil)
- }
-
- pathp, err := BytePtrFromString(path)
- if err != nil {
- return err
- }
- return acct(pathp)
-}
-
-/*
- * Expose the ioctl function
- */
-
-//sys ioctl(fd int, req int, arg uintptr) (err error)
-
-func IoctlSetInt(fd int, req int, value int) (err error) {
- return ioctl(fd, req, uintptr(value))
-}
-
-func IoctlSetWinsize(fd int, req int, value *Winsize) (err error) {
- return ioctl(fd, req, uintptr(unsafe.Pointer(value)))
-}
-
-func IoctlSetTermios(fd int, req int, value *Termios) (err error) {
- return ioctl(fd, req, uintptr(unsafe.Pointer(value)))
-}
-
-func IoctlSetTermio(fd int, req int, value *Termio) (err error) {
- return ioctl(fd, req, uintptr(unsafe.Pointer(value)))
-}
-
-func IoctlGetInt(fd int, req int) (int, error) {
- var value int
- err := ioctl(fd, req, uintptr(unsafe.Pointer(&value)))
- return value, err
-}
-
-func IoctlGetWinsize(fd int, req int) (*Winsize, error) {
- var value Winsize
- err := ioctl(fd, req, uintptr(unsafe.Pointer(&value)))
- return &value, err
-}
-
-func IoctlGetTermios(fd int, req int) (*Termios, error) {
- var value Termios
- err := ioctl(fd, req, uintptr(unsafe.Pointer(&value)))
- return &value, err
-}
-
-func IoctlGetTermio(fd int, req int) (*Termio, error) {
- var value Termio
- err := ioctl(fd, req, uintptr(unsafe.Pointer(&value)))
- return &value, err
-}
-
-/*
- * Exposed directly
- */
-//sys Access(path string, mode uint32) (err error)
-//sys Adjtime(delta *Timeval, olddelta *Timeval) (err error)
-//sys Chdir(path string) (err error)
-//sys Chmod(path string, mode uint32) (err error)
-//sys Chown(path string, uid int, gid int) (err error)
-//sys Chroot(path string) (err error)
-//sys Close(fd int) (err error)
-//sys Creat(path string, mode uint32) (fd int, err error)
-//sys Dup(fd int) (nfd int, err error)
-//sys Dup2(oldfd int, newfd int) (err error)
-//sys Exit(code int)
-//sys Fchdir(fd int) (err error)
-//sys Fchmod(fd int, mode uint32) (err error)
-//sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error)
-//sys Fchown(fd int, uid int, gid int) (err error)
-//sys Fchownat(dirfd int, path string, uid int, gid int, flags int) (err error)
-//sys Fdatasync(fd int) (err error)
-//sys Fpathconf(fd int, name int) (val int, err error)
-//sys Fstat(fd int, stat *Stat_t) (err error)
-//sys Getdents(fd int, buf []byte, basep *uintptr) (n int, err error)
-//sysnb Getgid() (gid int)
-//sysnb Getpid() (pid int)
-//sysnb Getpgid(pid int) (pgid int, err error)
-//sysnb Getpgrp() (pgid int, err error)
-//sys Geteuid() (euid int)
-//sys Getegid() (egid int)
-//sys Getppid() (ppid int)
-//sys Getpriority(which int, who int) (n int, err error)
-//sysnb Getrlimit(which int, lim *Rlimit) (err error)
-//sysnb Getrusage(who int, rusage *Rusage) (err error)
-//sysnb Gettimeofday(tv *Timeval) (err error)
-//sysnb Getuid() (uid int)
-//sys Kill(pid int, signum syscall.Signal) (err error)
-//sys Lchown(path string, uid int, gid int) (err error)
-//sys Link(path string, link string) (err error)
-//sys Listen(s int, backlog int) (err error) = libsocket.listen
-//sys Lstat(path string, stat *Stat_t) (err error)
-//sys Madvise(b []byte, advice int) (err error)
-//sys Mkdir(path string, mode uint32) (err error)
-//sys Mkdirat(dirfd int, path string, mode uint32) (err error)
-//sys Mkfifo(path string, mode uint32) (err error)
-//sys Mkfifoat(dirfd int, path string, mode uint32) (err error)
-//sys Mknod(path string, mode uint32, dev int) (err error)
-//sys Mknodat(dirfd int, path string, mode uint32, dev int) (err error)
-//sys Mlock(b []byte) (err error)
-//sys Mlockall(flags int) (err error)
-//sys Mprotect(b []byte, prot int) (err error)
-//sys Munlock(b []byte) (err error)
-//sys Munlockall() (err error)
-//sys Nanosleep(time *Timespec, leftover *Timespec) (err error)
-//sys Open(path string, mode int, perm uint32) (fd int, err error)
-//sys Openat(dirfd int, path string, flags int, mode uint32) (fd int, err error)
-//sys Pathconf(path string, name int) (val int, err error)
-//sys Pause() (err error)
-//sys Pread(fd int, p []byte, offset int64) (n int, err error)
-//sys Pwrite(fd int, p []byte, offset int64) (n int, err error)
-//sys read(fd int, p []byte) (n int, err error)
-//sys Readlink(path string, buf []byte) (n int, err error)
-//sys Rename(from string, to string) (err error)
-//sys Renameat(olddirfd int, oldpath string, newdirfd int, newpath string) (err error)
-//sys Rmdir(path string) (err error)
-//sys Seek(fd int, offset int64, whence int) (newoffset int64, err error) = lseek
-//sysnb Setegid(egid int) (err error)
-//sysnb Seteuid(euid int) (err error)
-//sysnb Setgid(gid int) (err error)
-//sys Sethostname(p []byte) (err error)
-//sysnb Setpgid(pid int, pgid int) (err error)
-//sys Setpriority(which int, who int, prio int) (err error)
-//sysnb Setregid(rgid int, egid int) (err error)
-//sysnb Setreuid(ruid int, euid int) (err error)
-//sysnb Setrlimit(which int, lim *Rlimit) (err error)
-//sysnb Setsid() (pid int, err error)
-//sysnb Setuid(uid int) (err error)
-//sys Shutdown(s int, how int) (err error) = libsocket.shutdown
-//sys Stat(path string, stat *Stat_t) (err error)
-//sys Symlink(path string, link string) (err error)
-//sys Sync() (err error)
-//sysnb Times(tms *Tms) (ticks uintptr, err error)
-//sys Truncate(path string, length int64) (err error)
-//sys Fsync(fd int) (err error)
-//sys Ftruncate(fd int, length int64) (err error)
-//sys Umask(mask int) (oldmask int)
-//sysnb Uname(buf *Utsname) (err error)
-//sys Unmount(target string, flags int) (err error) = libc.umount
-//sys Unlink(path string) (err error)
-//sys Unlinkat(dirfd int, path string, flags int) (err error)
-//sys Ustat(dev int, ubuf *Ustat_t) (err error)
-//sys Utime(path string, buf *Utimbuf) (err error)
-//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error) = libsocket.bind
-//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error) = libsocket.connect
-//sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error)
-//sys munmap(addr uintptr, length uintptr) (err error)
-//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error) = libsocket.sendto
-//sys socket(domain int, typ int, proto int) (fd int, err error) = libsocket.socket
-//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error) = libsocket.socketpair
-//sys write(fd int, p []byte) (n int, err error)
-//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error) = libsocket.getsockopt
-//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error) = libsocket.getpeername
-//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error) = libsocket.setsockopt
-//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error) = libsocket.recvfrom
-
-func readlen(fd int, buf *byte, nbuf int) (n int, err error) {
- r0, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procread)), 3, uintptr(fd), uintptr(unsafe.Pointer(buf)), uintptr(nbuf), 0, 0, 0)
- n = int(r0)
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-func writelen(fd int, buf *byte, nbuf int) (n int, err error) {
- r0, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procwrite)), 3, uintptr(fd), uintptr(unsafe.Pointer(buf)), uintptr(nbuf), 0, 0, 0)
- n = int(r0)
- if e1 != 0 {
- err = e1
- }
- return
-}
-
-var mapper = &mmapper{
- active: make(map[*byte][]byte),
- mmap: mmap,
- munmap: munmap,
-}
-
-func Mmap(fd int, offset int64, length int, prot int, flags int) (data []byte, err error) {
- return mapper.Mmap(fd, offset, length, prot, flags)
-}
-
-func Munmap(b []byte) (err error) {
- return mapper.Munmap(b)
-}
-
-//sys sysconf(name int) (n int64, err error)
-
-// pageSize caches the value of Getpagesize, since it can't change
-// once the system is booted.
-var pageSize int64 // accessed atomically
-
-func Getpagesize() int {
- n := atomic.LoadInt64(&pageSize)
- if n == 0 {
- n, _ = sysconf(_SC_PAGESIZE)
- atomic.StoreInt64(&pageSize, n)
- }
- return int(n)
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go b/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go
deleted file mode 100644
index 5aff62c3b..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go
+++ /dev/null
@@ -1,35 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build amd64,solaris
-
-package unix
-
-func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
-
-func NsecToTimespec(nsec int64) (ts Timespec) {
- ts.Sec = nsec / 1e9
- ts.Nsec = nsec % 1e9
- return
-}
-
-func NsecToTimeval(nsec int64) (tv Timeval) {
- nsec += 999 // round up to microsecond
- tv.Usec = nsec % 1e9 / 1e3
- tv.Sec = int64(nsec / 1e9)
- return
-}
-
-func (iov *Iovec) SetLen(length int) {
- iov.Len = uint64(length)
-}
-
-func (cmsg *Cmsghdr) SetLen(length int) {
- cmsg.Len = uint32(length)
-}
-
-func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- // TODO(aram): implement this, see issue 5847.
- panic("unimplemented")
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_unix.go b/vendor/golang.org/x/sys/unix/syscall_unix.go
deleted file mode 100644
index 8a5237de8..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_unix.go
+++ /dev/null
@@ -1,292 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd solaris
-
-package unix
-
-import (
- "runtime"
- "sync"
- "syscall"
- "unsafe"
-)
-
-var (
- Stdin = 0
- Stdout = 1
- Stderr = 2
-)
-
-const (
- darwin64Bit = runtime.GOOS == "darwin" && sizeofPtr == 8
- dragonfly64Bit = runtime.GOOS == "dragonfly" && sizeofPtr == 8
- netbsd32Bit = runtime.GOOS == "netbsd" && sizeofPtr == 4
-)
-
-// Do the interface allocations only once for common
-// Errno values.
-var (
- errEAGAIN error = syscall.EAGAIN
- errEINVAL error = syscall.EINVAL
- errENOENT error = syscall.ENOENT
-)
-
-// errnoErr returns common boxed Errno values, to prevent
-// allocations at runtime.
-func errnoErr(e syscall.Errno) error {
- switch e {
- case 0:
- return nil
- case EAGAIN:
- return errEAGAIN
- case EINVAL:
- return errEINVAL
- case ENOENT:
- return errENOENT
- }
- return e
-}
-
-// Mmap manager, for use by operating system-specific implementations.
-
-type mmapper struct {
- sync.Mutex
- active map[*byte][]byte // active mappings; key is last byte in mapping
- mmap func(addr, length uintptr, prot, flags, fd int, offset int64) (uintptr, error)
- munmap func(addr uintptr, length uintptr) error
-}
-
-func (m *mmapper) Mmap(fd int, offset int64, length int, prot int, flags int) (data []byte, err error) {
- if length <= 0 {
- return nil, EINVAL
- }
-
- // Map the requested memory.
- addr, errno := m.mmap(0, uintptr(length), prot, flags, fd, offset)
- if errno != nil {
- return nil, errno
- }
-
- // Slice memory layout
- var sl = struct {
- addr uintptr
- len int
- cap int
- }{addr, length, length}
-
- // Use unsafe to turn sl into a []byte.
- b := *(*[]byte)(unsafe.Pointer(&sl))
-
- // Register mapping in m and return it.
- p := &b[cap(b)-1]
- m.Lock()
- defer m.Unlock()
- m.active[p] = b
- return b, nil
-}
-
-func (m *mmapper) Munmap(data []byte) (err error) {
- if len(data) == 0 || len(data) != cap(data) {
- return EINVAL
- }
-
- // Find the base of the mapping.
- p := &data[cap(data)-1]
- m.Lock()
- defer m.Unlock()
- b := m.active[p]
- if b == nil || &b[0] != &data[0] {
- return EINVAL
- }
-
- // Unmap the memory and update m.
- if errno := m.munmap(uintptr(unsafe.Pointer(&b[0])), uintptr(len(b))); errno != nil {
- return errno
- }
- delete(m.active, p)
- return nil
-}
-
-func Read(fd int, p []byte) (n int, err error) {
- n, err = read(fd, p)
- if raceenabled {
- if n > 0 {
- raceWriteRange(unsafe.Pointer(&p[0]), n)
- }
- if err == nil {
- raceAcquire(unsafe.Pointer(&ioSync))
- }
- }
- return
-}
-
-func Write(fd int, p []byte) (n int, err error) {
- if raceenabled {
- raceReleaseMerge(unsafe.Pointer(&ioSync))
- }
- n, err = write(fd, p)
- if raceenabled && n > 0 {
- raceReadRange(unsafe.Pointer(&p[0]), n)
- }
- return
-}
-
-// For testing: clients can set this flag to force
-// creation of IPv6 sockets to return EAFNOSUPPORT.
-var SocketDisableIPv6 bool
-
-type Sockaddr interface {
- sockaddr() (ptr unsafe.Pointer, len _Socklen, err error) // lowercase; only we can define Sockaddrs
-}
-
-type SockaddrInet4 struct {
- Port int
- Addr [4]byte
- raw RawSockaddrInet4
-}
-
-type SockaddrInet6 struct {
- Port int
- ZoneId uint32
- Addr [16]byte
- raw RawSockaddrInet6
-}
-
-type SockaddrUnix struct {
- Name string
- raw RawSockaddrUnix
-}
-
-func Bind(fd int, sa Sockaddr) (err error) {
- ptr, n, err := sa.sockaddr()
- if err != nil {
- return err
- }
- return bind(fd, ptr, n)
-}
-
-func Connect(fd int, sa Sockaddr) (err error) {
- ptr, n, err := sa.sockaddr()
- if err != nil {
- return err
- }
- return connect(fd, ptr, n)
-}
-
-func Getpeername(fd int) (sa Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- if err = getpeername(fd, &rsa, &len); err != nil {
- return
- }
- return anyToSockaddr(&rsa)
-}
-
-func GetsockoptInt(fd, level, opt int) (value int, err error) {
- var n int32
- vallen := _Socklen(4)
- err = getsockopt(fd, level, opt, unsafe.Pointer(&n), &vallen)
- return int(n), err
-}
-
-func Recvfrom(fd int, p []byte, flags int) (n int, from Sockaddr, err error) {
- var rsa RawSockaddrAny
- var len _Socklen = SizeofSockaddrAny
- if n, err = recvfrom(fd, p, flags, &rsa, &len); err != nil {
- return
- }
- if rsa.Addr.Family != AF_UNSPEC {
- from, err = anyToSockaddr(&rsa)
- }
- return
-}
-
-func Sendto(fd int, p []byte, flags int, to Sockaddr) (err error) {
- ptr, n, err := to.sockaddr()
- if err != nil {
- return err
- }
- return sendto(fd, p, flags, ptr, n)
-}
-
-func SetsockoptByte(fd, level, opt int, value byte) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(&value), 1)
-}
-
-func SetsockoptInt(fd, level, opt int, value int) (err error) {
- var n = int32(value)
- return setsockopt(fd, level, opt, unsafe.Pointer(&n), 4)
-}
-
-func SetsockoptInet4Addr(fd, level, opt int, value [4]byte) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(&value[0]), 4)
-}
-
-func SetsockoptIPMreq(fd, level, opt int, mreq *IPMreq) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(mreq), SizeofIPMreq)
-}
-
-func SetsockoptIPv6Mreq(fd, level, opt int, mreq *IPv6Mreq) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(mreq), SizeofIPv6Mreq)
-}
-
-func SetsockoptICMPv6Filter(fd, level, opt int, filter *ICMPv6Filter) error {
- return setsockopt(fd, level, opt, unsafe.Pointer(filter), SizeofICMPv6Filter)
-}
-
-func SetsockoptLinger(fd, level, opt int, l *Linger) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(l), SizeofLinger)
-}
-
-func SetsockoptString(fd, level, opt int, s string) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(&[]byte(s)[0]), uintptr(len(s)))
-}
-
-func SetsockoptTimeval(fd, level, opt int, tv *Timeval) (err error) {
- return setsockopt(fd, level, opt, unsafe.Pointer(tv), unsafe.Sizeof(*tv))
-}
-
-func Socket(domain, typ, proto int) (fd int, err error) {
- if domain == AF_INET6 && SocketDisableIPv6 {
- return -1, EAFNOSUPPORT
- }
- fd, err = socket(domain, typ, proto)
- return
-}
-
-func Socketpair(domain, typ, proto int) (fd [2]int, err error) {
- var fdx [2]int32
- err = socketpair(domain, typ, proto, &fdx)
- if err == nil {
- fd[0] = int(fdx[0])
- fd[1] = int(fdx[1])
- }
- return
-}
-
-func Sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) {
- if raceenabled {
- raceReleaseMerge(unsafe.Pointer(&ioSync))
- }
- return sendfile(outfd, infd, offset, count)
-}
-
-var ioSync int64
-
-func CloseOnExec(fd int) { fcntl(fd, F_SETFD, FD_CLOEXEC) }
-
-func SetNonblock(fd int, nonblocking bool) (err error) {
- flag, err := fcntl(fd, F_GETFL, 0)
- if err != nil {
- return err
- }
- if nonblocking {
- flag |= O_NONBLOCK
- } else {
- flag &= ^O_NONBLOCK
- }
- _, err = fcntl(fd, F_SETFL, flag)
- return err
-}
diff --git a/vendor/golang.org/x/sys/unix/syscall_unix_gc.go b/vendor/golang.org/x/sys/unix/syscall_unix_gc.go
deleted file mode 100644
index 4cb8e8edf..000000000
--- a/vendor/golang.org/x/sys/unix/syscall_unix_gc.go
+++ /dev/null
@@ -1,15 +0,0 @@
-// Copyright 2016 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build darwin dragonfly freebsd linux netbsd openbsd solaris
-// +build !gccgo
-
-package unix
-
-import "syscall"
-
-func Syscall(trap, a1, a2, a3 uintptr) (r1, r2 uintptr, err syscall.Errno)
-func Syscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err syscall.Errno)
-func RawSyscall(trap, a1, a2, a3 uintptr) (r1, r2 uintptr, err syscall.Errno)
-func RawSyscall6(trap, a1, a2, a3, a4, a5, a6 uintptr) (r1, r2 uintptr, err syscall.Errno)
diff --git a/vendor/golang.org/x/sys/unix/types_darwin.go b/vendor/golang.org/x/sys/unix/types_darwin.go
deleted file mode 100644
index a3508174e..000000000
--- a/vendor/golang.org/x/sys/unix/types_darwin.go
+++ /dev/null
@@ -1,250 +0,0 @@
-// Copyright 2009 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build ignore
-
-/*
-Input to cgo -godefs. See README.md
-*/
-
-// +godefs map struct_in_addr [4]byte /* in_addr */
-// +godefs map struct_in6_addr [16]byte /* in6_addr */
-
-package unix
-
-/*
-#define __DARWIN_UNIX03 0
-#define KERNEL
-#define _DARWIN_USE_64_BIT_INODE
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include