mirror of
https://github.com/status-im/nim-serialization.git
synced 2025-01-12 04:44:27 +00:00
CI: update script path
This commit is contained in:
parent
5ef8130c79
commit
43ff99a809
37
.appveyor.yml
Normal file
37
.appveyor.yml
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
version: '{build}'
|
||||||
|
|
||||||
|
image: Visual Studio 2015
|
||||||
|
|
||||||
|
cache:
|
||||||
|
- NimBinaries
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
# We always want 32 and 64-bit compilation
|
||||||
|
fast_finish: false
|
||||||
|
|
||||||
|
platform:
|
||||||
|
- x86
|
||||||
|
- x64
|
||||||
|
|
||||||
|
# when multiple CI builds are queued, the tested commit needs to be in the last X commits cloned with "--depth X"
|
||||||
|
clone_depth: 10
|
||||||
|
|
||||||
|
install:
|
||||||
|
# use the newest versions documented here: https://www.appveyor.com/docs/windows-images-software/#mingw-msys-cygwin
|
||||||
|
- IF "%PLATFORM%" == "x86" SET PATH=C:\mingw-w64\i686-6.3.0-posix-dwarf-rt_v5-rev1\mingw32\bin;%PATH%
|
||||||
|
- IF "%PLATFORM%" == "x64" SET PATH=C:\mingw-w64\x86_64-8.1.0-posix-seh-rt_v6-rev0\mingw64\bin;%PATH%
|
||||||
|
|
||||||
|
# build nim from our own branch - this to avoid the day-to-day churn and
|
||||||
|
# regressions of the fast-paced Nim development while maintaining the
|
||||||
|
# flexibility to apply patches
|
||||||
|
- curl -O -L -s -S https://raw.githubusercontent.com/status-im/nimbus-build-system/master/scripts/build_nim.sh
|
||||||
|
- env MAKE="mingw32-make -j2" ARCH_OVERRIDE=%PLATFORM% bash build_nim.sh Nim csources dist/nimble NimBinaries
|
||||||
|
- SET PATH=%CD%\Nim\bin;%PATH%
|
||||||
|
|
||||||
|
build_script:
|
||||||
|
- nimble install -y
|
||||||
|
|
||||||
|
test_script:
|
||||||
|
- nimble test
|
||||||
|
|
||||||
|
deploy: off
|
@ -17,7 +17,7 @@ install:
|
|||||||
# build nim from our own branch - this to avoid the day-to-day churn and
|
# build nim from our own branch - this to avoid the day-to-day churn and
|
||||||
# regressions of the fast-paced Nim development while maintaining the
|
# regressions of the fast-paced Nim development while maintaining the
|
||||||
# flexibility to apply patches
|
# flexibility to apply patches
|
||||||
- curl -O -L -s -S https://raw.githubusercontent.com/status-im/nimbus/devel/build_nim.sh
|
- curl -O -L -s -S https://raw.githubusercontent.com/status-im/nimbus-build-system/master/scripts/build_nim.sh
|
||||||
- env MAKE="make -j2" bash build_nim.sh Nim csources dist/nimble NimBinaries
|
- env MAKE="make -j2" bash build_nim.sh Nim csources dist/nimble NimBinaries
|
||||||
- export PATH=$PWD/Nim/bin:$PATH
|
- export PATH=$PWD/Nim/bin:$PATH
|
||||||
|
|
||||||
|
@ -57,15 +57,15 @@ macro enumAllSerializedFieldsImpl(T: type, body: untyped): untyped =
|
|||||||
## * `FieldType`
|
## * `FieldType`
|
||||||
## Type alias for the field type
|
## Type alias for the field type
|
||||||
##
|
##
|
||||||
## * `fieldCaseDisciminator`
|
## * `fieldCaseDiscriminator`
|
||||||
## String literal denoting the name of the case object
|
## String literal denoting the name of the case object
|
||||||
## discrimator under which the visited field is nested.
|
## discriminator under which the visited field is nested.
|
||||||
## If the field is not nested in a specific case branch,
|
## If the field is not nested in a specific case branch,
|
||||||
## this will be an empty string.
|
## this will be an empty string.
|
||||||
##
|
##
|
||||||
## * `fieldCaseBranches`
|
## * `fieldCaseBranches`
|
||||||
## A set literal node denoting the possible values of the
|
## A set literal node denoting the possible values of the
|
||||||
## case object discrimator which make this field accessible.
|
## case object discriminator which make this field accessible.
|
||||||
##
|
##
|
||||||
## The order of visited fields matches the order of the fields in
|
## The order of visited fields matches the order of the fields in
|
||||||
## the object definition unless `serialziedFields` is used to specify
|
## the object definition unless `serialziedFields` is used to specify
|
||||||
@ -92,7 +92,7 @@ macro enumAllSerializedFieldsImpl(T: type, body: untyped): untyped =
|
|||||||
fieldType = field.typ
|
fieldType = field.typ
|
||||||
fieldIdent = field.name
|
fieldIdent = field.name
|
||||||
fieldName = newLit($fieldIdent)
|
fieldName = newLit($fieldIdent)
|
||||||
discrimator = newLit(if field.caseField == nil: ""
|
discriminator = newLit(if field.caseField == nil: ""
|
||||||
else: $field.caseField[0])
|
else: $field.caseField[0])
|
||||||
branches = field.caseBranch
|
branches = field.caseBranch
|
||||||
fieldIndex = newLit(i)
|
fieldIndex = newLit(i)
|
||||||
@ -116,7 +116,7 @@ macro enumAllSerializedFieldsImpl(T: type, body: untyped): untyped =
|
|||||||
result.add quote do:
|
result.add quote do:
|
||||||
block:
|
block:
|
||||||
`fieldNameVarTemplate`
|
`fieldNameVarTemplate`
|
||||||
template fieldCaseDisciminator: auto = `discrimator`
|
template fieldCaseDiscriminator: auto = `discriminator`
|
||||||
template fieldCaseBranches: auto = `branches`
|
template fieldCaseBranches: auto = `branches`
|
||||||
|
|
||||||
# type `fieldTypeVar` = `fieldType`
|
# type `fieldTypeVar` = `fieldType`
|
||||||
@ -136,7 +136,7 @@ template enumAllSerializedFields*(T: type, body): untyped =
|
|||||||
func isCaseObject*(T: type): bool {.compileTime.} =
|
func isCaseObject*(T: type): bool {.compileTime.} =
|
||||||
genExpr:
|
genExpr:
|
||||||
enumAllSerializedFields(T):
|
enumAllSerializedFields(T):
|
||||||
if fieldCaseDisciminator != "":
|
if fieldCaseDiscriminator != "":
|
||||||
return newLit(true)
|
return newLit(true)
|
||||||
|
|
||||||
newLit(false)
|
newLit(false)
|
||||||
@ -273,7 +273,7 @@ macro setSerializedFields*(T: typedesc, fields: varargs[untyped]): untyped =
|
|||||||
const fieldNameVar = fieldName
|
const fieldNameVar = fieldName
|
||||||
type fieldTypeVar = type(default(typ).field)
|
type fieldTypeVar = type(default(typ).field)
|
||||||
|
|
||||||
template fieldCaseDisciminator: auto = ""
|
template fieldCaseDiscriminator: auto = ""
|
||||||
template fieldCaseBranches: auto = nil
|
template fieldCaseBranches: auto = nil
|
||||||
|
|
||||||
body
|
body
|
||||||
|
@ -10,7 +10,7 @@ suite "object serialization":
|
|||||||
|
|
||||||
test "custom fields order":
|
test "custom fields order":
|
||||||
enumAllSerializedFields(Simple):
|
enumAllSerializedFields(Simple):
|
||||||
fieldsList.add(name(FieldType) & " " & fieldName & fieldCaseDisciminator)
|
fieldsList.add(name(FieldType) & " " & fieldName & fieldCaseDiscriminator)
|
||||||
|
|
||||||
check fieldsList == @["Meter distance", "int x", "string y"]
|
check fieldsList == @["Meter distance", "int x", "string y"]
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user