mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-14 17:02:49 +03:00
b704192268
PR-URL: https://github.com/hasura/graphql-engine-mono/pull/4841 Co-authored-by: awjchen <13142944+awjchen@users.noreply.github.com> GitOrigin-RevId: ce47b1290fefb07f3f800c6c62120437c02086e5
51 lines
2.3 KiB
Plaintext
51 lines
2.3 KiB
Plaintext
-- This is the local cabal configuration file used by the `scripts/dev.sh`
|
|
-- development script, which uses `... --project-file=cabal/dev-sh.project`
|
|
-- which in turn consults this file.
|
|
--
|
|
-- You can temporarily override values here rather than modifying 'dev.sh'
|
|
-- during development (although that might break certain things).
|
|
|
|
package *
|
|
documentation: true
|
|
-- build with DWARF support. This may not be very useful yet, but we want
|
|
-- to be able to experiment with it, and turning it from off to on requires
|
|
-- a massive rebuild. To start, see:
|
|
-- https://www.haskell.org/ghc/blog/20200403-dwarf-1.html
|
|
debug-info: 2
|
|
|
|
-- For compile-time performance (see cabal.project.ci.local):
|
|
ghc-options:
|
|
-- We compile with package-level parallelism, so just use a small amount
|
|
-- of module-level parallelism for dependencies:
|
|
-j2
|
|
+RTS -A64m -n2m -RTS
|
|
|
|
-- Modify this to '+optimize-hasura' to enable optimizations. Be sure also to comment
|
|
-- 'coverage: true' below for full prod performance.
|
|
--
|
|
-- NOTE: new-build may report a misleading 'Build profile: -O1'
|
|
-- See:https://github.com/haskell/cabal/issues/6221
|
|
flags: -optimize-hasura
|
|
|
|
package graphql-engine
|
|
documentation: false
|
|
-- NOTE: 'cabal new-build --enable-coverage' seems to rebuild all deps with coverage
|
|
-- which is not what we originally wanted. But building the test modules
|
|
-- themselves with coverage is actually nice for validation.
|
|
coverage: true
|
|
-- to match CI:
|
|
ghc-options: -Werror
|
|
-- For compile-time performance (see cabal.project.ci.local):
|
|
ghc-options: -j
|
|
-- By default GHC is dynamically linked, so to run TemplateHaskell you need dynamic versions of
|
|
-- libraries. But, also by default, cabal links executables statically, which requires static
|
|
-- versions of the libraries. Therefore, by default, cabal builds with -dynamic-too to generate
|
|
-- static and dynamic versions of all object files.
|
|
-- Setting executable-dynamic: True forces cabal to build a dynamic executable; but it's not
|
|
-- enough on its own: since library-vanilla defaults to True, cabal would still build a static
|
|
-- library. With those two flags together, we can finally only build one version of the library,
|
|
-- which substentially improves compilation time.
|
|
executable-dynamic: True
|
|
library-vanilla: False
|
|
|