Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add startup callback to settings for httpbeast + fix CI #320

Closed
wants to merge 3 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ jobs:
matrix:
nimversion:
- 1.4.8
- git:6b97889f44d06f66
- 1.6.0
os:
- ubuntu-latest
- macOS-latest
Expand All @@ -22,11 +22,11 @@ jobs:
- uses: actions/checkout@v1
with:
submodules: true
- uses: iffy/install-nim@v3.2.0
- uses: iffy/install-nim@v4
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
nimversion: ${{ matrix.nimversion }}
version: ${{ matrix.nimversion }}
- name: Test
run: |
nimble test
Expand Down
14 changes: 11 additions & 3 deletions jester.nim
Original file line number Diff line number Diff line change
Expand Up @@ -83,8 +83,14 @@ type
of RouteCode:
data: ResponseData

Startup = proc () {.closure, gcsafe.}

const jesterVer = "0.6.0"

proc doNothing(): Startup {.gcsafe.} =
result = proc () {.closure, gcsafe.} =
discard

proc toStr(headers: Option[RawHeaders]): string =
return $newHttpHeaders(headers.get(@({:})))

Expand Down Expand Up @@ -421,7 +427,8 @@ proc handleRequest(jes: Jester, httpReq: NativeRequest): Future[void] =
proc newSettings*(
port = Port(5000), staticDir = getCurrentDir() / "public",
appName = "", bindAddr = "", reusePort = false, maxBody = 8388608, numThreads = 0,
futureErrorHandler: proc (fut: Future[void]) {.closure, gcsafe.} = nil
futureErrorHandler: proc (fut: Future[void]) {.closure, gcsafe.} = nil,
startup: Startup = doNothing()
): Settings =
result = Settings(
staticDir: normalizedPath(staticDir),
Expand All @@ -431,7 +438,8 @@ proc newSettings*(
reusePort: reusePort,
maxBody: maxBody,
numThreads: numThreads,
futureErrorHandler: futureErrorHandler
futureErrorHandler: futureErrorHandler,
startup: startup
)

proc register*(self: var Jester, matcher: MatchProc) =
Expand Down Expand Up @@ -529,7 +537,7 @@ proc serve*(
proc (req: httpbeast.Request): Future[void] =
{.gcsafe.}:
result = handleRequest(jes, req),
httpbeast.initSettings(self.settings.port, self.settings.bindAddr, self.settings.numThreads)
httpbeast.initSettings(self.settings.port, self.settings.bindAddr, self.settings.numThreads, startup = self.settings.startup)
)
else:
self.httpServer = newAsyncHttpServer(reusePort=self.settings.reusePort, maxBody=self.settings.maxBody)
Expand Down
1 change: 1 addition & 0 deletions jester/private/utils.nim
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ type
maxBody*: int
futureErrorHandler*: proc (fut: Future[void]) {.closure, gcsafe.}
numThreads*: int # Only available with Httpbeast (`useHttpBeast = true`)
startup*: proc () {.closure, gcsafe.} # Only available with Httpbeast (`useHttpBeast = true`)

JesterError* = object of Exception

Expand Down