docs: adds readme
This commit is contained in:
parent
c4c26b4028
commit
493cc21d7e
BIN
README.gif
Normal file
BIN
README.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.6 MiB |
81
README.md
Normal file
81
README.md
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
# protoc-gen-go-value-scan
|
||||||
|
|
||||||
|
Implements scanner and valuer interfaces for proto messages.
|
||||||
|
|
||||||
|
![README](./README.gif)
|
||||||
|
|
||||||
|
## What it does
|
||||||
|
|
||||||
|
Takes this proto
|
||||||
|
|
||||||
|
```proto
|
||||||
|
syntax = "proto3";
|
||||||
|
|
||||||
|
package foo.v1;
|
||||||
|
|
||||||
|
option go_package = "git.wobcom.de/smartmetering/protoc-gen-go-value-scan/test/go/foo/v1;foov1";
|
||||||
|
|
||||||
|
message Foo {
|
||||||
|
string bar = 1;
|
||||||
|
string zonk = 2;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
and creates this go code
|
||||||
|
|
||||||
|
```go
|
||||||
|
// Code generated by protoc-gen-go-value-scan. DO NOT EDIT.
|
||||||
|
|
||||||
|
package foov1
|
||||||
|
|
||||||
|
import (
|
||||||
|
"database/sql/driver"
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
protojson "google.golang.org/protobuf/encoding/protojson"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (x Foo) Value() (driver.Value, error) {
|
||||||
|
f := &x
|
||||||
|
|
||||||
|
opts := protojson.MarshalOptions{}
|
||||||
|
opts.UseProtoNames = false
|
||||||
|
opts.EmitUnpopulated = true
|
||||||
|
|
||||||
|
return opts.Marshal(f)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (x *Foo) Scan(value interface{}) error {
|
||||||
|
switch v := value.(type) {
|
||||||
|
case []byte:
|
||||||
|
return protojson.Unmarshal(v, x)
|
||||||
|
case string:
|
||||||
|
return protojson.Unmarshal([]byte(v), x)
|
||||||
|
default:
|
||||||
|
return fmt.Errorf("type assertion failed")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
| Option | Meaning | Default |
|
||||||
|
| ------------------ | -------------------------------------------------------------------------------------- | ------- |
|
||||||
|
| `use_proto_names` | UseProtoNames uses proto field name instead of lowerCamelCase name in JSON field names | `true` |
|
||||||
|
| `emit_unpopulated` | EmitUnpopulated specifies whether to emit unpopulated fields | `true` |
|
||||||
|
| `exclude` | Takes a message identifier. Can be multiple identifier delimited by `,` | none |
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
version: v1
|
||||||
|
plugins:
|
||||||
|
- name: go
|
||||||
|
out: go/
|
||||||
|
opt:
|
||||||
|
- paths=source_relative
|
||||||
|
- name: go-value-scan
|
||||||
|
out: go/
|
||||||
|
opt:
|
||||||
|
- paths=source_relative,use_proto_names=false,emit_unpopulated=true,exclude=git.wobcom.de/smartmetering/protoc-gen-go-value-scan/test/go/foo/v1.ExcludeThis
|
||||||
|
```
|
Loading…
Reference in New Issue
Block a user