bencode alternatives and similar packages
Based on the "Text and Numbers" category.
Alternatively, view bencode alternatives based on common mentions on social networks and blogs.
-
money
Elixir library for working with Money safer, easier, and fun... Is an interpretation of the Fowler's Money pattern in fun.prog. -
nanoid
Elixir port of NanoID, a secure and URL-friendly unique ID generator. https://hex.pm/packages/nanoid -
secure_random
Convenience library for random base64 strings modeled after my love for Ruby's SecureRandom -
chinese_translation
An elixir module to translate simplified Chinese to traditional Chinese, and vice versa, based on wikipedia data -
inet_cidr
CIDR library for Elixir that is compatible with Erlang's :inet and supports both IPv4 and IPv6 -
Ex_Cldr_Units
Unit formatting (volume, area, length, ...) functions for the Common Locale Data Repository (CLDR) -
minigen
Pure random data generation library, appropriate for realistic simulations in the Erlang ecosystem
CodeRabbit: AI Code Reviews for Developers

Do you think we are missing an alternative of bencode or a related project?
Popular Comparisons
README
Bencode
A complete and correct Bencode encoder and decoder written in pure Elixir.
The encoder is implemented as a protocol, allowing implementations for custom structs.
The decoder should handle malformed data, either by raising an error, or returning an 2-tuple with status, both containing detailed information about the error. The decoder is also capable of calculating the hash of the info dictionary.
API
Bencode.encode/1
will encode a given data structure to the b-code representation and return a{:ok, data}
-tuple on success, or an{:error, reason}
-tuple if the data was invalid.Bencode.encode!/1
will encode a given data structure to the b-code representation; it will raise an error if the given input is invalid.Bencode.decode/1
will decode a b-code encoded string and return a 2-tuple; containing the status (:ok
) and its Elixir data structure representation. Should the data be invalid a 2-tuple will get returned with{:error, reason}
Bencode.decode!/1
will decode a b-code encoded string and return the decoded result as a Elixir data structure; if the input is invalid an it will raise with the reason.Bencode.decode_with_info_hash/1
will decode a b-code encoded string and return a 3-tuple; containing the status (:ok
), its Elixir data structure representation along with the checksum of the info dictionary. If no info-dictionary was found the last value will benil
.{:error, reason}
will get returned if the input data was invalid b-code.Bencode.decode_with_info_hash!/1
will do the same as theBencode.decode_with_info_hash/1
function, but will raise if the given input is malformed.
Installation
Bencode is available in Hex, and can be installed by adding it to the list of dependencies in mix.exs
:
def deps do
[{:bencode, "~> 0.3.0"}]
end
Notice that there are other bencode implementations on hex. Please check them out:
bento by Rodney Folz
Bento is the fastest option, but Bencode has arguably better error reporting during decoding.
Thanks
Thanks to the following for their contributions to the project:
License
Copyright 2016 Martin Gausby
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.
*Note that all licence references and agreements mentioned in the bencode README section above
are relevant to that project's source code only.