Compare commits

..

No commits in common. "master" and "v0.1.2" have entirely different histories.

3 changed files with 6 additions and 36 deletions

View file

@ -2,30 +2,6 @@
Command-line tool to encode and decode arbitrary protobuf data. Command-line tool to encode and decode arbitrary protobuf data.
## Installation
This program requires Crystal. See: https://crystal-lang.org/install/
### Standalone
1. Clone: `git clone https://github.com/iv-org/protodec && cd protodec`
2. Build: `crystal build src/protodec.cr`
3. See [Usage](#Usage) below
### As a Crystal library
Add this to your application's `shard.yml`:
```yaml
dependencies:
protodec:
github: iv-org/protodec
version: ~> 0.1.5
```
## Usage ## Usage
``` ```
@ -81,13 +57,9 @@ $ echo 'CkEKCeOCj+OBn+OBlxDSCSIQWmQ730+N8z8tsp3vp8YJQCoSCAESBzA4MDAwMDAaBQ26sSZE
} }
``` ```
## Windows
Windows users can run the binaries in a linux-on-windows tool (like Git bash or WSL) or use the official [protobuf binaries](https://github.com/protocolbuffers/protobuf/releases) to encode/decode protobuf data.
## Contributing ## Contributing
1. Fork it (<https://github.com/iv-org/protodec/fork>) 1. Fork it (<https://github.com/omarroth/protodec/fork>)
2. Create your feature branch (`git checkout -b my-new-feature`) 2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`) 3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`) 4. Push to the branch (`git push origin my-new-feature`)

View file

@ -1,14 +1,13 @@
name: protodec name: protodec
version: 0.1.5 version: 0.1.2
authors: authors:
- Omar Roth <omarroth@protonmail.com> - Omar Roth <omarroth@protonmail.com>
- Invidous team
targets: targets:
protodec: protodec:
main: src/protodec.cr main: src/protodec.cr
crystal: ">= 0.34.0, < 2.0.0" crystal: 0.31.1
license: GPLv3 license: GPLv3

View file

@ -213,9 +213,6 @@ module Protodec
when "bytes" when "bytes"
VarLong.to_io(io, value.size.to_i64) VarLong.to_io(io, value.size.to_i64)
value.as_a.each { |byte| io.write_byte byte.as_i.to_u8 } value.as_a.each { |byte| io.write_byte byte.as_i.to_u8 }
else # "string"
VarLong.to_io(io, value.to_s.bytesize.to_i64)
io.print value.to_s
end end
end end
else else
@ -468,7 +465,9 @@ module Protodec
Any.new(raw.clone) Any.new(raw.clone)
end end
def self.cast_json(object : Hash) def self.cast_json(object)
raise "Invalid type" if !object.is_a?(Hash)
JSON::Any.new(object.transform_values do |value| JSON::Any.new(object.transform_values do |value|
case value case value
when .is_a?(Hash) when .is_a?(Hash)