- 
                Notifications
    You must be signed in to change notification settings 
- Fork 104
Closed
Description
-  Replace net.IPand*net.IPNetwithnetip.Addrandnetip.Prefix
-  Update naming and docs to more closely align with net/netip
-  Make SkipAliasedNetworksthe default when traversing a tree. Almost no one wants the IPv4 information to be repeated in several spots. We will need to deal with SkipAliasedNetworks produces unexpected results on IPv6 trees without an IPv4 subtree #79 when doing this.
-  Replace LookupOffsetwith method that returns a struct rather than auintptr. The returned value would have aDecode(any)method to replace the current use of(*Reader).Decode. Beyond the type safety and reducing the risk of a panic due to programmer error, this would provide the ability to do things like aDecodePath(result any, path ...any)that could avoid most of the use of reflection and creating a struct to decode to when looking up a single value.
-  (*Reader) Decodeis removed. See above.
-  After the above changes, reexamine the Lookup*methods. Do we really needLookup,LookupNetwork, andLookupOffset(or whatever the above replacement will be called)? Maybe theLookupOffsetreplacement method from above could replace all of them, although we would have to think about how error handling would work so as not to make it more verbose (e.g., defer returning error from the tree lookup).
-  Maybe rename FromBytestoOpenBytesor something as many people seem to overlook it.
-  Move decoder to a separate package to make PRs like this one more viable without creating a mess of the maxminddbpackage.
-  Maybe replace the existing Networks*traversal with an iterator.
-  Revisit the API forThis is necessary. If someone wants to know this, they can decode to a nilable value.DecodePath. Right now, it is hard to tell between a successful lookup and one that didn't find anything. The function could return a sentinel error, but that would be confusing as the other functions do not return that for not-found. Alternatively(bool, error)might be sufficient.
-  Add configuration options to Open. I plan to add some caching options in the future, after the v2 release, but for those to not be breaking, we need to add the support for options now. It might make sense to add an option immediately that forces the file to be opened in memory or via mmap, similar to the file-mode options in the Python and Java readers.
hayden-pan
Metadata
Metadata
Assignees
Labels
No labels