Commit Graph

54 Commits

Author SHA1 Message Date
Jacek Sieka 7950ac1e8c
return serializer table directly (#74)
This allows it to be captured in a const instead of relying on a
threadvar
2024-09-30 15:09:29 +02:00
Etan Kissling 005ee90cb6
Work around Nim bug that erases type `{.pragma.}` when making alias (#71)
Replaces `type` with inlined `template` because assigning to a new type
drops pragma annotations in some situations.
2024-06-13 13:34:04 +02:00
jangko afae13adac
Silence the infamous Conversion from itself warnings 2024-02-16 08:05:48 +07:00
Zahary Karadjov 68722b14fc
Basic support for serialization flavours without default object serialization 2023-12-19 02:52:22 +02:00
Etan Kissling 4bdbc29e54
add `{.raises.}` annotation to `writeValue` (#62)
Tag `writeValue` overrides with `{.raises: [IOError].}`.
2023-08-19 12:24:46 +02:00
Etan Kissling 384eb2561e
workaround for `NimYAML` issue (#61)
Somehow, creating the `FieldType` as a type messes with the macros used
in `NimYAML`. Inline `GetFieldType` to avoid the problem.

https://github.com/status-im/nimbus-eth2/pull/5043#issuecomment-1584219098

```
./nimbus-eth2/tests/consensus_spec/test_fixture_light_client_sync.nim(126, 8) template/generic instantiation of `test` from here
./nimbus-eth2/tests/consensus_spec/test_fixture_light_client_sync.nim(146, 20) template/generic instantiation of `load` from here
./nimbus-eth2/vendor/NimYAML/yaml/serialization.nim(1368, 14) template/generic instantiation of `construct` from here
./nimbus-eth2/vendor/NimYAML/yaml/serialization.nim(1343, 19) template/generic instantiation of `constructChild` from here
./nimbus-eth2/vendor/NimYAML/yaml/serialization.nim(1168, 20) template/generic instantiation of `constructObject` from here
./nimbus-eth2/vendor/NimYAML/yaml/serialization.nim(927, 25) template/generic instantiation of `constructObjectDefault` from here
./nimbus-eth2/vendor/NimYAML/yaml/serialization.nim(921, 31) template/generic instantiation of `ensureAllFieldsPresent` from here
./nimbus-eth2/vendor/NimYAML/yaml/serialization.nim(681, 29) Error: type mismatch: got <NimNode>
but expected one of:
proc none(T: typedesc): Option[T]
  first type mismatch at position: 1
  required type for T: typedesc
  but expression 'nil' is of type: NimNode
proc none[T](): Option[T]
  first type mismatch at position: 1
  extra argument given
template none(O: type Opt; T: type): Opt[T]
  first type mismatch at position: 1
  required type for O: typedesc[Opt]
  but expression 'nil' is of type: NimNode

expression: none(nil)
make: *** [consensus_spec_tests_minimal] Error 1
```
2023-06-16 07:44:39 +02:00
Etan Kissling c23b49910d
avoid implicit synthesis of `CaseTransition` (#59)
Transitioning the case of a case object without full reinitialization
leads to undefined behaviour. Don't do such transitions implicitly,
and require explicit `readValue` override for such types in those cases.
2023-06-12 21:17:15 +00:00
jangko 9f56a0738c
More fix to exception tracking and generic_suite
This fixes required by nim-json-serialization to pass test
with nim devel since we drop support for nim 1.2 and 1.4
2023-06-05 15:18:52 +07:00
jangko 09b131c919
another attempt to reduce compiler warnings 2023-06-05 11:43:19 +07:00
jangko b7c085fc5c
remove Defect raises from makeFieldReadersTable 2023-06-05 09:01:07 +07:00
jangko bc46b4c1c1
readFieldIMPL workaround when orc enabled 2023-04-17 09:23:17 +07:00
jangko 4959f1f983
fix makeFieldReadersTable crash when orc enabled.
also remove duplicated readFieldIMPL template
see https://github.com/status-im/nim-toml-serialization/issues/62
and https://github.com/status-im/nim-toml-serialization/issues/63
2023-04-14 21:18:23 +07:00
jangko 257e2e02eb
nim devel workaround 2023-01-31 08:59:43 +07:00
Tanguy 60a5bd8ac0
Fix for nim devel (#44) 2022-11-07 16:42:48 +01:00
Zahary Karadjov 493d18b829
Add findFieldIdx 2022-07-14 15:08:22 +03:00
Zahary Karadjov 1d33fa3ced
Fix the build on Nim 1.6 (which doesn't allow derefencing nil) 2022-06-19 13:04:38 +03:00
jangko 90276771dc
workaround to allow compile time deserialization
with this refactoring, deserialization can be enabled for VM context
see toml-serialization for example
2022-06-19 15:18:55 +07:00
Etan Kissling d856d6ece5
Update readme for current API
The README file was describing an outdated way of defining serialization
formats. It was updated accordingly to match the current API.

- New format declaration using `setReader` and `setWriter`
  and mandatory `PreferredOutput` type declaration,
  as introduced in f9a1121b87.
- Removal of `fileExt` declaration, which was never implemented.
- Removal of format-specific `dontSerialize` pragma
  as well as the `serialize` pragma, which were never implemented.
- Rename `serializedFields` macro to `setSerializedFields`,
  to keep up with 60613bac5d.
- Remove rename functionality in `setSerializedFields`,
  which was never implemented.
- A couple updated argument lists and typo corrections.
2022-06-19 15:18:41 +07:00
Zahary Karadjov 7d64c0d843
FieldTag no longer requires specifying the FieldType 2022-06-18 13:29:32 +03:00
Ștefan Talpalaru 37bc0db558
CI: test with multiple Nim versions (#39) 2022-01-06 19:36:22 +01:00
Jacek Sieka 11a8aa64d2 enable --styleCheck:usages 2021-12-07 00:33:04 +02:00
Jacek Sieka fcd0eadadd clean up imports, unittest2 2021-08-16 15:09:31 +03:00
Zahary Karadjov f9a1121b87
Make the flavors support optional when defining formats
Other changes:

* The format declarations have been broken down in multiple
  parts. This makes it possible to structure the implementation
  libraries in a way such that the format name is accessible even
  when importing only reader or writer modules.

* Flavors lead to more complicated Reader and Writer types.
  Instead of requiring the user to write down long type names
  such as `JsonReader[DefaultFlavor]`, it's now possible to refer
  to the reader and writer type of each format using expressions
  such as `Json.Reader` and `Json.Writer`.

* Fixed a typo (PreferredOutput)
2021-03-19 04:04:14 +02:00
Zahary Karadjov 84ffa54554
Add support for Format flavors 2021-03-18 12:55:50 +02:00
Zahary Karadjov 261de741b7
Revert "Handle record types with when statements"
This reverts commit dfd6e349a6.
2021-02-18 23:08:21 +02:00
Zahary Karadjov 32fce5df8d
Revert "Support when statements in records that reuse the same field name in different branches"
This reverts commit 4e2ffe3f6d.
2021-02-18 23:07:52 +02:00
Jacek Sieka 293a987c51 work around broken gc during global init 2021-02-18 22:31:23 +02:00
Zahary Karadjov 4e2ffe3f6d
Support when statements in records that reuse the same field name in different branches 2021-01-06 15:27:28 +02:00
Zahary Karadjov dfd6e349a6
Handle record types with when statements 2020-12-22 20:24:54 +02:00
jangko 474bdbf49c silence declared but not used warning 2020-08-05 10:08:27 +03:00
Zahary Karadjov 5b11c41731
Handle updates in nim-stew 2020-07-08 00:31:20 +03:00
Zahary Karadjov e0e51015b7
Handle pragma-annotated field names; Fix #28 2020-06-24 14:08:56 +03:00
Zahary Karadjov 5498b62dbd
Stricter error handling 2020-06-16 00:59:35 +03:00
Zahary Karadjov d8ca3daf3a
raises annotations for some generated procs 2020-05-30 22:37:23 +03:00
Zahary Karadjov 8a013591bd
Add a pragma for customizing the field names in formats such as Json 2020-05-20 13:48:14 +03:00
Zahary Karadjov b61fcb51ad
Work-around a scary issue affecting the SSZ serialization 2020-05-19 13:42:56 +03:00
Zahary Karadjov 1989a55145
Remove a warning triggered by not nil types 2020-04-23 01:50:25 +03:00
Zahary Karadjov 68e9ef7901 More comprehensive test suite; Depends on Fixes in Nim 1.2 2020-04-09 19:25:07 +03:00
Zahary Karadjov ae60eef4e8
Reduce warnings in Nim 1.0.2; Fix #16 2019-11-04 18:55:12 +00:00
Ștefan Talpalaru 43ff99a809
CI: update script path 2019-08-24 05:14:20 +02:00
Alexander Ivanov 034a6c8efe
Implement unnamed tuple support 2019-08-08 23:18:36 +03:00
Zahary Karadjov b42502b512
Some needed support for custom field serialization in Json 2019-08-07 01:19:32 +03:00
Zahary Karadjov 56ad4b18de
Transfer some of the complexity in handling case objects from SSZ to the general serialization lib 2019-08-05 16:54:17 +03:00
Zahary Karadjov 8e907c46fc
Fix a build issue affecting Nim 0.20.2 2019-08-05 16:54:17 +03:00
Zahary Karadjov 99daa96284
Custom serialization for object fields (initial version) 2019-08-05 16:54:17 +03:00
Zahary Karadjov e126d48e6c
Use the new fixed hasCustomPragma definition 2019-08-05 16:54:17 +03:00
Zahary Karadjov 60613bac5d
Better support for case objects; Some internal documentation 2019-08-05 16:54:17 +03:00
Jacek Sieka 5c2d0c7253
std_shims -> stew 2019-07-07 11:50:26 +02:00
Zahary Karadjov 6804ea2537 Improved custom serialization error handling 2019-03-20 03:16:27 +02:00
Zahary Karadjov 030c8e2cbe Use the latest OutputStream; Needed helpers for the SSZ support 2019-03-11 11:34:04 +02:00