Popularity
2.6
Declining
Activity
0.0
Stable
17
2
2

Monthly Downloads: 42
Programming language: Elixir
License: Apache License 2.0
Tags: Text And Numbers    
Latest version: v0.3.2

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.

Do you think we are missing an alternative of bencode or a related project?

Add another 'Text and Numbers' Package

README

Bencode

Hex.pm Hex version

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 be nil. {:error, reason} will get returned if the input data was invalid b-code.

  • Bencode.decode_with_info_hash!/1 will do the same as the Bencode.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 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.