OpenDAL provides a pre-configured dev container that could be used in GitHub Codespaces, VSCode, JetBrains, JupyterLab. Please pick up your favourite runtime environment.
The fastest way is:
The haskell binding requires haskell and cabal to be built. We recommend using the latest stable version for development.
If you are new to haskell, we recommend using GHCup to install haskell and cabal.
For Unix-like systems:
curl --proto '=https' --tlsv1.2 -sSf https://get-ghcup.haskell.org | sh
For Windows:
Set-ExecutionPolicy Bypass -Scope Process -Force;[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; try { Invoke-Command -ScriptBlock ([ScriptBlock]::Create((Invoke-WebRequest https://www.haskell.org/ghcup/sh/bootstrap-haskell.ps1 -UseBasicParsing))) -ArgumentList $true } catch { Write-Error $_ }
Setup ghc version to 9.4.8
ghcup install ghc 9.4.8 --set ghcup install cabal --set cabal update
To verify that everything is working properly, run ghc -V and cabal -V:
> ghc -V The Glorious Glasgow Haskell Compilation System, version 9.4.8 > cabal -V cabal-install version 3.6.2.0 compiled using version 3.6.2.0 of the Cabal library
cabal build
To clean up the build:
cargo clean
cabal clean
We use tasty as the test framework. To run the tests:
cabal test
...(Build Info) Test suite opendal-test: RUNNING... Test suite opendal-test: PASS Test suite logged to: ...(Log Path) 1 of 1 test suites (1 of 1 test cases) passed.
To generate the documentation:
cabal haddock
If your cabal version is greater than 3.8, you can use cabal haddock --open to open the documentation in your browser. Otherwise, you can visit the documentation from dist-newstyle/build/$ARCH/ghc-$VERSION/opendal-$VERSION/doc/html/opendal/index.html.