Skip to content
Snippets Groups Projects
This project is mirrored from https://github.com/haskell/Cabal. Pull mirroring updated .
  1. Feb 18, 2024
    • mergify[bot]'s avatar
      Merge pull request #9706 from andreabedini/refactor/cmd-install · ccab6d15
      mergify[bot] authored
      Refactor CmdInstall / fix bug in #9697
    • Andrea Bedini's avatar
      Refactor CmdInstall · 7b1746f7
      Andrea Bedini authored
      CmdInstall.installAction is ~300 lines long and full of nested scopes
      and ad-hoc logic. This change hopes to make it more readable and
      understandable.
      
      - Lift withProject and withoutProject out of installAction and split
        their relative concerns. E.g. not parsing URIs is installAction's
        concern not withProject's (which would just return a constant []).
      - Split an intermediate step into a separate function, resolveTargetSelectorsInProjectBaseContext.
      - Reuse withGlobalConfig and specFromPkgId (renamed from pidPackageSpecifiers).
      - Avoid trying withProject a second time in case no target is specified.
      - Fix a bug introduced in 802a326f where
        establishProjectBaseContext is called in a non-project setting. Also
        simplify its original implementation by moving the change into
        withProject rather than calling establishProjectBaseContext a second
        time.
      - Document the interaction between cabal v2-install and local configuration
        and add few comments.
      7b1746f7
  2. Feb 17, 2024
  3. Feb 13, 2024
  4. Feb 11, 2024
  5. Feb 10, 2024
  6. Feb 09, 2024
    • mergify[bot]'s avatar
      Merge pull request #9697 from alt-romes/wip/romes/7297-8909-7236 · f1da5d86
      mergify[bot] authored
      Apply local configuration to install targets
    • Rodrigo Mesquita's avatar
      Apply local configuration to install targets · 802a326f
      Rodrigo Mesquita authored
      The target of `cabal install` is not considered to be a local package,
      which means local configuration (e.g. in cabal.project, or flags like
      --enable-profiling) does not apply to it.
      
      In 76670ebd, we changed the behaviour to
      applying the local flags to cabal install targets, but it used the
      literal target string as a package name to which the flags were
      additionally applied.
      
      However, `cabal install` targets are NOT necessarily package names, so,
      e.g., if we did `cabal install exe:mycomp`, the local flags would not
      apply since "exe:mycomp" is not a recognized /package/.
      
      The solution is to parse the target selectors first, and apply the local
      flags to the package of the resolved targets.
      
      Fixes #7297, #8909, the install part of #7236, #8529, #7832
      802a326f
  7. Feb 08, 2024
  8. Feb 07, 2024
  9. Feb 03, 2024
  10. Feb 01, 2024
    • mergify[bot]'s avatar
      Merge pull request #9680 from cabalism/test/project-hop-imports · 663e98f8
      mergify[bot] authored
      Add tests for project imports and constraint version conflicts
    • mergify[bot]'s avatar
      Merge pull request #9635 from mpickering/wip/test-runner-env · bd0dae73
      mergify[bot] authored
      Don't inherit package database to tests
    • Matthew Pickering's avatar
      testsuite: Fix Executable-Relocatable test package database location · b39b94b5
      Matthew Pickering authored
      We were attempting to register a package into the global package
      database, which then triggered some other check to do with relocatable
      packages to fail.
      
      The fix is to initialise and use a local package database, so the
      package would be built and installed into the local package database.
      b39b94b5
    • Matthew Pickering's avatar
      Don't inherit package database to tests · dbe5cf42
      Matthew Pickering authored
      I can't think of a reason why it would be desirable to expose the user's
      cabal store or local dist-newstyle to the test runner. In fact, this can
      break test output in certain situations depending on what is in your
      store.
      
      Tests should run in as hemertic environment as possible and not
      depend on anything to do with external system configuration.
      
      I have introduced a Note [Testsuite package environments] which explains
      what the environments are for the three different components of the
      testsuite.
      
      {- Note [Testsuite package environments]
      
      There are three different package environments which are used when running the
      testsuite.
      
      1. Environment used to compile `cabal-tests` executable
      2. Environment used to run test scripts "setup.test.hs"
      3. Environment made available to tests themselves via `./Setup configure`
      
      These are all distinct from each other and should be specified separately.
      
      Where are these environments specified:
      
      1. The build-depends on `cabal-tests` executable in `cabal-testsuite.cabal`
      2. The build-depends of `test-runtime-deps` executable in `cabal-testsuite.cabal`
         These dependencies are injected in a special module (`Test.Cabal.ScriptEnv0`) which
         then is consulted in `Test.Cabal.Monad` in order to pass the right environmnet.
         This is mechanism by which the `./Setup` tests have access to the in-tree `Cabal`
         and `Cabal-syntax` libraries.
      3. No specification, only the `GlobalPackageDb` is available (see
         `testPackageDBStack`) unless the test itself augments the environment with
         `withPackageDb`.
      
      At the moment, `cabal-install` tests always use the bootstrap cabal, which is a
      bit confusing but `cabal-install` is not flexible enough to be given additional
      package databases (yet).
      
      -}
      dbe5cf42
    • Phil de Joux's avatar
      Add noncyclical tests that hop over folders · 78fcdc68
      Phil de Joux authored
      - Allow for bad behaviour of master branch
      - Add cyclical checks with same file names and hops
      - Add cyclical import tests with 1 and 2 hops in cycle
      - Expected output has project with full project path
      - Add newlines at EOF
  11. Jan 31, 2024
  12. Jan 30, 2024
  13. Jan 29, 2024
Loading