CI: update script path

This commit is contained in:
Ștefan Talpalaru 2019-08-24 05:14:20 +02:00
parent 5ef8130c79
commit 43ff99a809
No known key found for this signature in database
GPG Key ID: CBF7934204F1B6F9
4 changed files with 46 additions and 9 deletions

37
.appveyor.yml Normal file
View 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

View File

@ -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

View File

@ -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

View File

@ -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"]