Skip to content

Commit

Permalink
ci: add windows CI for nimskull (#102)
Browse files Browse the repository at this point in the history
Add CI for 64-bit Windows on NimSkull. Coming with this is a couple fixes to handle duplicate enum fields on NimSkull.
  • Loading branch information
alaviss authored Sep 1, 2024
1 parent f578b77 commit a257158
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 7 deletions.
4 changes: 3 additions & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -64,10 +64,12 @@ jobs:
- target: macos
arch: i386

# TODO: a handful of problems with SSL must be solved before this
# 32-bit OpenSSL is a pain, so skip
- target: windows
arch: i386
compiler:
name: nimskull

name:
${{ matrix.target }} on ${{ matrix.arch }} (${{ matrix.compiler.name }}
${{ matrix.compiler.version }})
Expand Down
12 changes: 6 additions & 6 deletions src/sys/private/paths_windows.nim
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ const
ValidSeparatorsImpl = {SeparatorImpl, '/'}

type
PathParseState = enum
PathParseState {.pure.} = enum
Start
MaybeRoot
FoundPrefix
Expand All @@ -22,7 +22,7 @@ type
AtRoot
PathElement

PathState = enum
PathState {.pure.} = enum
UncNeedHost
UncNeedShare
AtRoot
Expand Down Expand Up @@ -154,11 +154,11 @@ template joinImpl() {.dirty.} =
else:
discard "This is a DOS drive"
of UncNeedShare:
state = AtRoot
of UncNeedHost, AtRoot:
state = PathState.AtRoot
of UncNeedHost, PathState.AtRoot:
discard "These states cannot be reached from the start"
of Root:
state = AtRoot
state = PathState.AtRoot
else:
state = Normal
break
Expand All @@ -176,7 +176,7 @@ template joinImpl() {.dirty.} =
discard "Nothing to do"

of PreviousDir:
if state == AtRoot:
if state == PathState.AtRoot:
continue

else:
Expand Down

0 comments on commit a257158

Please sign in to comment.