Merge branch 'armv7-aarch64'
This commit is contained in:
		
						commit
						823458910b
					
				| @ -12,6 +12,8 @@ task: | |||||||
|     GITHUB_WORKSPACE: ${CIRRUS_WORKING_DIR} |     GITHUB_WORKSPACE: ${CIRRUS_WORKING_DIR} | ||||||
|     JSON_VERSION: "0.0.7" |     JSON_VERSION: "0.0.7" | ||||||
|     CIRRUS_CLONE_SUBMODULES: true |     CIRRUS_CLONE_SUBMODULES: true | ||||||
|  |     AWS_ACCESS_KEY_ID: ENCRYPTED[3e99c4ac040871f213abd616ec66952d954dc289cdd97772f88e58a74d08a2250133437780fe98b7aedf7ef1fb32f5eb] | ||||||
|  |     AWS_SECRET_ACCESS_KEY: ENCRYPTED[5910cfd77a922ff7fc06eeb6a6b9f79d4867863e541f06eb2c4cfecae0613650e3e0588373fa8d9249d295d76cf9cb3b] | ||||||
|   install_script: pkg install -y ghc hs-cabal-install git bash misc/compat10x misc/compat11x misc/compat12x gmake |   install_script: pkg install -y ghc hs-cabal-install git bash misc/compat10x misc/compat11x misc/compat12x gmake | ||||||
|   script: |   script: | ||||||
|     - bash .github/scripts/build.sh |     - bash .github/scripts/build.sh | ||||||
|  | |||||||
							
								
								
									
										70
									
								
								.github/scripts/build.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										70
									
								
								.github/scripts/build.sh
									
									
									
									
										vendored
									
									
								
							| @ -3,60 +3,78 @@ | |||||||
| set -eux | set -eux | ||||||
| 
 | 
 | ||||||
| . .github/scripts/prereq.sh | . .github/scripts/prereq.sh | ||||||
|  | . .github/scripts/common.sh | ||||||
| 
 | 
 | ||||||
| if ! command -v ghcup && [ "${RUNNER_OS}" != "FreeBSD" ] ; then | 
 | ||||||
| 	find "$GHCUP_INSTALL_BASE_PREFIX" | # ensure ghcup | ||||||
| 	mkdir -p "$GHCUP_BIN" | if ! command -v ghcup ; then | ||||||
| 	mkdir -p "$GHCUP_BIN"/../cache | 	install_ghcup | ||||||
| 	curl --proto '=https' --tlsv1.2 -sSf https://get-ghcup.haskell.org | BOOTSTRAP_HASKELL_NONINTERACTIVE=1 BOOTSTRAP_HASKELL_MINIMAL=1 sh |  | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | # ensure cabal-cache | ||||||
|  | if ! cabal-cache version ; then | ||||||
|  | 	download_cabal_cache "$HOME/.local/bin/cabal-cache" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # ensure ghc | ||||||
| if [ "${RUNNER_OS}" != "FreeBSD" ] ; then | if [ "${RUNNER_OS}" != "FreeBSD" ] ; then | ||||||
| 	ghcup install ghc --set --isolate="$HOME/.local"     --force "$GHC_VER" | 	if [ "${DISTRO}" != "Debian" ] ; then # ! armv7 or aarch64 linux | ||||||
| 	ghcup install cabal     --isolate="$HOME/.local/bin" --force "$CABAL_VER" | 		if ! "ghc-${GHC_VER}" --numeric-version ; then | ||||||
|  | 			ghcup -v install ghc --set --force "$GHC_VER" | ||||||
|  | 		fi | ||||||
|  | 		if [ "$(cabal --numeric-version || true)" != "${CABAL_VER}" ] ; then | ||||||
|  | 			ghcup -v install cabal --force "$CABAL_VER" | ||||||
|  | 		fi | ||||||
| 		ghc --version | 		ghc --version | ||||||
| 		cabal --version | 		cabal --version | ||||||
| 		GHC="ghc-${GHC_VER}" | 		GHC="ghc-${GHC_VER}" | ||||||
| 	else | 	else | ||||||
|  | 		if [ "$(cabal --numeric-version || true)" != "${CABAL_VER}" ] ; then | ||||||
|  | 			ghcup -v install cabal --force "$CABAL_VER" | ||||||
|  | 		fi | ||||||
|  | 		cabal --version | ||||||
|  | 		GHC="ghc" | ||||||
|  | 	fi | ||||||
|  | else | ||||||
|  | 	ghc --version | ||||||
|  | 	cabal --version | ||||||
| 	GHC="ghc" | 	GHC="ghc" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| git describe --all | git_describe | ||||||
| 
 | 
 | ||||||
| ecabal() { |  | ||||||
| 	cabal "$@" |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| # build | # build | ||||||
| ecabal update | ecabal update | ||||||
| 
 | 
 | ||||||
|  | if ! cabal-cache version ; then | ||||||
|  | 	build_cabal_cache "$HOME/.local/bin" | ||||||
|  | fi | ||||||
| 
 | 
 | ||||||
| if [ "${RUNNER_OS}" = "Linux" ] ; then | if [ "${RUNNER_OS}" = "Linux" ] ; then | ||||||
| 	if [ "${ARCH}" = "32" ] ; then | 	if [ "${ARCH}" = "32" ] ; then | ||||||
| 		ecabal build -w "${GHC}" --ghc-options='-split-sections -optl-static' -ftui | 		build_with_cache -w "${GHC}" --ghc-options='-split-sections -optl-static' -ftui --enable-tests | ||||||
| 	elif [ "${ARCH}" = "64" ] ; then | 	elif [ "${ARCH}" = "64" ] ; then | ||||||
| 		ecabal build -w "${GHC}" --ghc-options='-split-sections -optl-static' -ftui | 		build_with_cache -w "${GHC}" --ghc-options='-split-sections -optl-static' -ftui --enable-tests | ||||||
| 	else | 	else | ||||||
| 		ecabal build -w "${GHC}" -ftui | 		build_with_cache -w "${GHC}" -ftui --enable-tests | ||||||
| 	fi | 	fi | ||||||
| elif [ "${RUNNER_OS}" = "FreeBSD" ] ; then | elif [ "${RUNNER_OS}" = "FreeBSD" ] ; then | ||||||
| 	ecabal build -w "${GHC}" --ghc-options='-split-sections' --constraint="zlib +bundled-c-zlib" --constraint="zip +disable-zstd" -ftui | 	build_with_cache -w "${GHC}" --ghc-options='-split-sections' --constraint="zlib +bundled-c-zlib" --constraint="zip +disable-zstd" -ftui --enable-tests | ||||||
| elif [ "${RUNNER_OS}" = "Windows" ] ; then | elif [ "${RUNNER_OS}" = "Windows" ] ; then | ||||||
| 	ecabal build -w "${GHC}" --constraint="zlib +bundled-c-zlib" --constraint="lzma +static" | 	build_with_cache -w "${GHC}" --constraint="zlib +bundled-c-zlib" --constraint="lzma +static" --enable-tests | ||||||
| else | else | ||||||
| 	ecabal build -w "${GHC}" --constraint="zlib +bundled-c-zlib" --constraint="lzma +static" -ftui | 	build_with_cache -w "${GHC}" --constraint="zlib +bundled-c-zlib" --constraint="lzma +static" -ftui --enable-tests | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| mkdir out | 
 | ||||||
| binary=$(ecabal new-exec -w "${GHC}" --verbose=0 --offline sh -- -c 'command -v ghcup') | # set up artifacts | ||||||
|  | mkdir -p out | ||||||
|  | binary=$(cabal list-bin ghcup) | ||||||
|  | binary_test=$(cabal list-bin ghcup-test) | ||||||
| ver=$("${binary}" --numeric-version) | ver=$("${binary}" --numeric-version) | ||||||
| if [ "${RUNNER_OS}" = "macOS" ] ; then | strip_binary "${binary}" | ||||||
| 	strip "${binary}" |  | ||||||
| else |  | ||||||
| 	if [ "${RUNNER_OS}" != "Windows" ] ; then |  | ||||||
| 		strip -s "${binary}" |  | ||||||
| 	fi |  | ||||||
| fi |  | ||||||
| cp "${binary}" "out/${ARTIFACT}-${ver}" | cp "${binary}" "out/${ARTIFACT}-${ver}" | ||||||
|  | cp "${binary_test}" "out/test-${ARTIFACT}-${ver}" | ||||||
| cp ./dist-newstyle/cache/plan.json "out/${ARTIFACT}.plan.json" | cp ./dist-newstyle/cache/plan.json "out/${ARTIFACT}.plan.json" | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										187
									
								
								.github/scripts/common.sh
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										187
									
								
								.github/scripts/common.sh
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,187 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | if [ "${RUNNER_OS}" = "Windows" ] ; then | ||||||
|  | 	ext=".exe" | ||||||
|  | else | ||||||
|  | 	ext='' | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | ecabal() { | ||||||
|  | 	cabal "$@" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | sync_from() { | ||||||
|  | 	if [ "${RUNNER_OS}" != "Windows" ] ; then | ||||||
|  | 		cabal_store_path="$(dirname "$(cabal help user-config | tail -n 1 | xargs)")/store" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	cabal-cache sync-from-archive \ | ||||||
|  | 		--host-name-override=s3.us-west-004.backblazeb2.com \ | ||||||
|  | 		--host-port-override=443 \ | ||||||
|  | 		--host-ssl-override=True \ | ||||||
|  | 		--region us-west-2 \ | ||||||
|  | 		$([ "${RUNNER_OS}" != "Windows" ] && echo --store-path="$cabal_store_path") \ | ||||||
|  | 		--archive-uri "s3://ghcup-hs/${RUNNER_OS}-${ARCH}-${DISTRO}" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | sync_to() { | ||||||
|  | 	if [ "${RUNNER_OS}" != "Windows" ] ; then | ||||||
|  | 		cabal_store_path="$(dirname "$(cabal help user-config | tail -n 1 | xargs)")/store" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	cabal-cache sync-to-archive \ | ||||||
|  | 		--host-name-override=s3.us-west-004.backblazeb2.com \ | ||||||
|  | 		--host-port-override=443 \ | ||||||
|  | 		--host-ssl-override=True \ | ||||||
|  | 		--region us-west-2 \ | ||||||
|  | 		$([ "${RUNNER_OS}" != "Windows" ] && echo --store-path="$cabal_store_path") \ | ||||||
|  | 		--archive-uri "s3://ghcup-hs/${RUNNER_OS}-${ARCH}-${DISTRO}" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | raw_eghcup() { | ||||||
|  | 	"$GHCUP_BIN/ghcup${ext}" -v -c "$@" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | eghcup() { | ||||||
|  | 	if [ "${OS}" = "Windows" ] ; then | ||||||
|  | 		"$GHCUP_BIN/ghcup${ext}" -c -s "file:/$CI_PROJECT_DIR/data/metadata/ghcup-${JSON_VERSION}.yaml" "$@" | ||||||
|  | 	else | ||||||
|  | 		"$GHCUP_BIN/ghcup${ext}" -c -s "file://$CI_PROJECT_DIR/data/metadata/ghcup-${JSON_VERSION}.yaml" "$@" | ||||||
|  | 	fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | sha_sum() { | ||||||
|  | 	if [ "${OS}" = "FreeBSD" ] ; then | ||||||
|  | 		sha256 "$@" | ||||||
|  | 	else | ||||||
|  | 		sha256sum "$@" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | git_describe() { | ||||||
|  | 	git config --global --get-all safe.directory | grep '^\*$' || git config --global --add safe.directory "*" | ||||||
|  | 	git describe --always | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | download_cabal_cache() { | ||||||
|  | 	( | ||||||
|  | 	set -e | ||||||
|  | 	dest="$HOME/.local/bin/cabal-cache" | ||||||
|  |     url="" | ||||||
|  | 	exe="" | ||||||
|  | 	cd /tmp | ||||||
|  | 	case "${RUNNER_OS}" in | ||||||
|  | 		"Linux") | ||||||
|  | 			case "${DISTRO}" in | ||||||
|  | 				"Alpine") | ||||||
|  | 					case "${ARCH}" in | ||||||
|  | 						"32") url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/i386-linux-alpine-cabal-cache-1.0.5.1 | ||||||
|  | 							;; | ||||||
|  | 						"64") url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/x86_64-linux-alpine-cabal-cache-1.0.5.1 | ||||||
|  | 							;; | ||||||
|  | 					esac | ||||||
|  | 					;; | ||||||
|  | 				*) | ||||||
|  | 					case "${ARCH}" in | ||||||
|  | 						"64") url=https://github.com/haskell-works/cabal-cache/releases/download/v1.0.5.1/cabal-cache-x86_64-linux.gz | ||||||
|  | 							;; | ||||||
|  | 						"ARM64") url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/aarch64-linux-cabal-cache-1.0.5.1 | ||||||
|  | 							;; | ||||||
|  | 						"ARM") url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/armv7-linux-cabal-cache-1.0.5.1 | ||||||
|  | 							;; | ||||||
|  | 					esac | ||||||
|  | 					;; | ||||||
|  | 			esac | ||||||
|  | 			;; | ||||||
|  | 		"FreeBSD") | ||||||
|  | 			;; | ||||||
|  | 		"Windows") | ||||||
|  | 			exe=".exe" | ||||||
|  | 			url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/x86_64-mingw64-cabal-cache-1.0.5.1.exe | ||||||
|  | 			;; | ||||||
|  | 		"macOS") | ||||||
|  | 			case "${ARCH}" in | ||||||
|  | 				"ARM64") url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/aarch64-apple-darwin-cabal-cache-1.0.5.1 | ||||||
|  | 					;; | ||||||
|  | 				"64") url=https://downloads.haskell.org/~ghcup/unofficial-bindists/cabal-cache/1.0.5.1/x86_64-apple-darwin-cabal-cache-1.0.5.1 | ||||||
|  | 					;; | ||||||
|  | 			esac | ||||||
|  | 			;; | ||||||
|  | 	esac | ||||||
|  | 
 | ||||||
|  | 	if [ -n "${url}" ] ; then | ||||||
|  | 		case "${url##*.}" in | ||||||
|  | 			"gz") | ||||||
|  | 				curl -L -o - "${url}" | gunzip > cabal-cache${exe} | ||||||
|  | 				;; | ||||||
|  | 			*) | ||||||
|  | 				curl -o cabal-cache${exe} -L "${url}" | ||||||
|  | 				;; | ||||||
|  | 		esac | ||||||
|  | 		chmod +x cabal-cache${exe} | ||||||
|  | 		cp "cabal-cache${exe}" "${dest}${exe}" | ||||||
|  | 	fi | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | build_cabal_cache() { | ||||||
|  | 	( | ||||||
|  | 	set -e | ||||||
|  | 	GHC_CABAL_CACHE=ghc-8.10.7 | ||||||
|  | 	dest="$1" | ||||||
|  | 
 | ||||||
|  | 	if [ "${GHC_CABAL_CACHE}" != "ghc" ] && [ "${GHC_CABAL_CACHE}" != "ghc-${GHC_VER}" ] ; then | ||||||
|  | 		if ! ${GHC_CABAL_CACHE} --numeric-version ; then | ||||||
|  | 			ghcup -v install ghc --force ${GHC_CABAL_CACHE#ghc-} | ||||||
|  | 		fi | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	cd /tmp | ||||||
|  | 	ecabal install -w "${GHC_CABAL_CACHE}" --overwrite-policy=always --install-method=copy --installdir="$dest" cabal-cache | ||||||
|  | 	mkdir -p "${CI_PROJECT_DIR}/out" | ||||||
|  | 	cp "$dest/cabal-cache" "${CI_PROJECT_DIR}/out/cabal-cache-${RUNNER_OS}-${DISTRO}-${ARCH}" | ||||||
|  | 
 | ||||||
|  | 	if [ "${GHC_CABAL_CACHE}" != "ghc" ] && [ "${GHC_CABAL_CACHE}" != "ghc-${GHC_VER}" ] ; then | ||||||
|  | 		ghcup -v rm ghc ${GHC_CABAL_CACHE#ghc-} | ||||||
|  | 	fi | ||||||
|  | 	) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | build_with_cache() { | ||||||
|  | 	ecabal configure "$@" | ||||||
|  | 	ecabal build --dependencies-only "$@" --dry-run | ||||||
|  | 	sync_from | ||||||
|  | 	ecabal build --dependencies-only "$@" || sync_to | ||||||
|  | 	sync_to | ||||||
|  | 	ecabal build "$@" | ||||||
|  | 	sync_to | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | install_ghcup() { | ||||||
|  | 	find "$GHCUP_INSTALL_BASE_PREFIX" | ||||||
|  | 	mkdir -p "$GHCUP_BIN" | ||||||
|  | 	mkdir -p "$GHCUP_BIN"/../cache | ||||||
|  | 
 | ||||||
|  | 	if [ "${RUNNER_OS}" = "FreeBSD" ] ; then | ||||||
|  | 		curl -o ghcup https://downloads.haskell.org/ghcup/tmp/x86_64-portbld-freebsd-ghcup-0.1.18.1 | ||||||
|  | 		chmod +x ghcup | ||||||
|  | 		mv ghcup "$HOME/.local/bin/ghcup" | ||||||
|  | 	else | ||||||
|  | 		curl --proto '=https' --tlsv1.2 -sSf https://get-ghcup.haskell.org | BOOTSTRAP_HASKELL_NONINTERACTIVE=1 BOOTSTRAP_HASKELL_MINIMAL=1 sh | ||||||
|  | 	fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | strip_binary() { | ||||||
|  | 	( | ||||||
|  | 	set -e | ||||||
|  | 	binary=$1 | ||||||
|  | 	if [ "${RUNNER_OS}" = "macOS" ] ; then | ||||||
|  | 		strip "${binary}" | ||||||
|  | 	else | ||||||
|  | 		if [ "${RUNNER_OS}" != "Windows" ] ; then | ||||||
|  | 			strip -s "${binary}" | ||||||
|  | 		fi | ||||||
|  | 	fi | ||||||
|  | 	) | ||||||
|  | } | ||||||
							
								
								
									
										58
									
								
								.github/scripts/hls.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58
									
								
								.github/scripts/hls.sh
									
									
									
									
										vendored
									
									
								
							| @ -3,35 +3,13 @@ | |||||||
| set -eux | set -eux | ||||||
| 
 | 
 | ||||||
| . .github/scripts/prereq.sh | . .github/scripts/prereq.sh | ||||||
|  | . .github/scripts/common.sh | ||||||
| 
 | 
 | ||||||
| mkdir -p "$CI_PROJECT_DIR"/.local/bin | mkdir -p "$CI_PROJECT_DIR"/.local/bin | ||||||
| 
 | 
 | ||||||
| ### build | ### build | ||||||
| 
 | 
 | ||||||
| ecabal() { |  | ||||||
| 	cabal "$@" |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| raw_eghcup() { |  | ||||||
| 	"$GHCUP_BIN/ghcup${ext}" -v -c "$@" |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| eghcup() { |  | ||||||
| 	if [ "${OS}" = "Windows" ] ; then |  | ||||||
| 		"$GHCUP_BIN/ghcup${ext}" -v -c -s file:/$CI_PROJECT_DIR/data/metadata/ghcup-${JSON_VERSION}.yaml "$@" |  | ||||||
| 	else |  | ||||||
| 		"$GHCUP_BIN/ghcup${ext}" -v -c -s file://$CI_PROJECT_DIR/data/metadata/ghcup-${JSON_VERSION}.yaml "$@" |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sha_sum() { |  | ||||||
| 	if [ "${OS}" = "FreeBSD" ] ; then |  | ||||||
| 		sha256 "$@" |  | ||||||
| 	else |  | ||||||
| 		sha256sum "$@" |  | ||||||
| 	fi |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| if [ "${OS}" = "Windows" ] ; then | if [ "${OS}" = "Windows" ] ; then | ||||||
| 	GHCUP_DIR="${GHCUP_INSTALL_BASE_PREFIX}"/ghcup | 	GHCUP_DIR="${GHCUP_INSTALL_BASE_PREFIX}"/ghcup | ||||||
| @ -42,11 +20,6 @@ fi | |||||||
| rm -rf "${GHCUP_DIR}" | rm -rf "${GHCUP_DIR}" | ||||||
| mkdir -p "${GHCUP_BIN}" | mkdir -p "${GHCUP_BIN}" | ||||||
| 
 | 
 | ||||||
| if [ "${OS}" = "Windows" ] ; then |  | ||||||
| 	ext=".exe" |  | ||||||
| else |  | ||||||
| 	ext='' |  | ||||||
| fi |  | ||||||
| ls -lah out | ls -lah out | ||||||
| find out | find out | ||||||
| cp "out/${ARTIFACT}"-* "$GHCUP_BIN/ghcup${ext}" | cp "out/${ARTIFACT}"-* "$GHCUP_BIN/ghcup${ext}" | ||||||
| @ -58,18 +31,41 @@ eghcup --version | |||||||
| sha_sum "$GHCUP_BIN/ghcup${ext}" | sha_sum "$GHCUP_BIN/ghcup${ext}" | ||||||
| sha_sum "$(raw_eghcup --offline whereis ghcup)" | sha_sum "$(raw_eghcup --offline whereis ghcup)" | ||||||
| 
 | 
 | ||||||
| git describe --always | git_describe | ||||||
| 
 | 
 | ||||||
| eghcup install ghc "${GHC_VERSION}" | eghcup install ghc "${GHC_VERSION}" | ||||||
| eghcup install cabal | eghcup install cabal | ||||||
| 
 | 
 | ||||||
| ecabal update | ecabal update | ||||||
| 
 | 
 | ||||||
|  | if ! command -v cabal-cache ; then | ||||||
|  | 	download_cabal_cache "$HOME/.local/bin/cabal-cache" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if ! cabal-cache version ; then | ||||||
|  | 	build_cabal_cache "$HOME/.local/bin" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| eghcup debug-info | eghcup debug-info | ||||||
| 
 | 
 | ||||||
| eghcup compile hls -j $(nproc) -g ${HLS_TARGET_VERSION} --ghc ${GHC_VERSION} | ( | ||||||
|  | 	cd /tmp | ||||||
|  | 	git clone --depth 1 --branch "${HLS_TARGET_VERSION}" \ | ||||||
|  | 		https://github.com/haskell/haskell-language-server.git \ | ||||||
|  | 		"haskell-language-server-${HLS_TARGET_VERSION}" | ||||||
|  | 	cd "haskell-language-server-${HLS_TARGET_VERSION}/" | ||||||
|  | 	ecabal configure -w "ghc-${GHC_VERSION}" --disable-profiling --disable-tests --jobs="$(nproc)" | ||||||
|  | 	ecabal build --dependencies-only -w "ghc-${GHC_VERSION}" --disable-profiling --disable-tests --jobs="$(nproc)" --dry-run | ||||||
|  | 	sync_from | ||||||
|  | 	ecabal build --dependencies-only -w "ghc-${GHC_VERSION}" --disable-profiling --disable-tests --jobs="$(nproc)" || sync_to | ||||||
|  | 	sync_to | ||||||
|  | ) | ||||||
| 
 | 
 | ||||||
| [ `$(eghcup whereis hls ${HLS_TARGET_VERSION}) --numeric-version` = "${HLS_TARGET_VERSION}" ] || [ `$(eghcup whereis hls ${HLS_TARGET_VERSION}) --numeric-version | sed 's/.0$//'` = "${HLS_TARGET_VERSION}" ] | eghcup -v compile hls -j "$(nproc)" -g "${HLS_TARGET_VERSION}" --ghc "${GHC_VERSION}" | ||||||
|  | 
 | ||||||
|  | [ "$($(eghcup whereis hls "${HLS_TARGET_VERSION}") --numeric-version)" = "${HLS_TARGET_VERSION}" ] || | ||||||
|  | 	[ "$($(eghcup whereis hls "${HLS_TARGET_VERSION}") --numeric-version | sed 's/.0$//')" = "${HLS_TARGET_VERSION}" ] | ||||||
| 
 | 
 | ||||||
| # nuke | # nuke | ||||||
| eghcup nuke | eghcup nuke | ||||||
|  | |||||||
							
								
								
									
										58
									
								
								.github/scripts/prereq.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58
									
								
								.github/scripts/prereq.sh
									
									
									
									
										vendored
									
									
								
							| @ -4,6 +4,7 @@ mkdir -p "$HOME"/.local/bin | |||||||
| 
 | 
 | ||||||
| export OS="$RUNNER_OS" | export OS="$RUNNER_OS" | ||||||
| export PATH="$HOME/.local/bin:$PATH" | export PATH="$HOME/.local/bin:$PATH" | ||||||
|  | : "${APT_GET:=apt-get}" | ||||||
| 
 | 
 | ||||||
| if [ "${RUNNER_OS}" = "Windows" ] ; then | if [ "${RUNNER_OS}" = "Windows" ] ; then | ||||||
| 	# on windows use pwd to get unix style path | 	# on windows use pwd to get unix style path | ||||||
| @ -12,6 +13,7 @@ if [ "${RUNNER_OS}" = "Windows" ] ; then | |||||||
|     export GHCUP_INSTALL_BASE_PREFIX="/c" |     export GHCUP_INSTALL_BASE_PREFIX="/c" | ||||||
|     export GHCUP_BIN="$GHCUP_INSTALL_BASE_PREFIX/ghcup/bin" |     export GHCUP_BIN="$GHCUP_INSTALL_BASE_PREFIX/ghcup/bin" | ||||||
|     export PATH="$GHCUP_BIN:$PATH" |     export PATH="$GHCUP_BIN:$PATH" | ||||||
|  | 	export CABAL_DIR="C:\\Users\\runneradmin\\AppData\\Roaming\\cabal" | ||||||
| else | else | ||||||
| 	export CI_PROJECT_DIR="${GITHUB_WORKSPACE}" | 	export CI_PROJECT_DIR="${GITHUB_WORKSPACE}" | ||||||
|     export GHCUP_INSTALL_BASE_PREFIX="$CI_PROJECT_DIR" |     export GHCUP_INSTALL_BASE_PREFIX="$CI_PROJECT_DIR" | ||||||
| @ -23,41 +25,19 @@ fi | |||||||
| 
 | 
 | ||||||
| if [ "${RUNNER_OS}" = "Linux" ] ; then | if [ "${RUNNER_OS}" = "Linux" ] ; then | ||||||
| 	if [ "${DISTRO}" = "Alpine" ] ; then | 	if [ "${DISTRO}" = "Alpine" ] ; then | ||||||
|           apk add --no-cache \ | 		: | ||||||
|             curl \ |  | ||||||
|             gcc \ |  | ||||||
|             g++ \ |  | ||||||
|             binutils \ |  | ||||||
|             binutils-gold \ |  | ||||||
|             bsd-compat-headers \ |  | ||||||
|             gmp-dev \ |  | ||||||
|             ncurses-dev \ |  | ||||||
|             libffi-dev \ |  | ||||||
|             make \ |  | ||||||
|             xz \ |  | ||||||
|             tar \ |  | ||||||
|             perl \ |  | ||||||
|             bash \ |  | ||||||
|             diffutils \ |  | ||||||
|             git |  | ||||||
| 
 |  | ||||||
|           apk add --no-cache \ |  | ||||||
|             zlib \ |  | ||||||
|             zlib-dev \ |  | ||||||
|             zlib-static \ |  | ||||||
|             bzip2 \ |  | ||||||
|             bzip2-dev \ |  | ||||||
|             bzip2-static \ |  | ||||||
|             gmp \ |  | ||||||
|             gmp-dev \ |  | ||||||
|             openssl-dev \ |  | ||||||
|             openssl-libs-static \ |  | ||||||
|             xz \ |  | ||||||
|             xz-dev \ |  | ||||||
|             ncurses-static |  | ||||||
| 	elif [ "${DISTRO}" = "Ubuntu" ] ; then | 	elif [ "${DISTRO}" = "Ubuntu" ] ; then | ||||||
| 		sudo apt-get update -y | 		export DEBIAN_FRONTEND=noninteractive | ||||||
| 		sudo apt-get install -y libnuma-dev zlib1g-dev libgmp-dev libgmp10 libssl-dev liblzma-dev libbz2-dev git wget lsb-release software-properties-common gnupg2 apt-transport-https gcc autoconf automake build-essential | 		export TZ=Asia/Singapore | ||||||
|  | 		if [ "${ARCH}" = "ARM64" ] || [ "${ARCH}" = "ARM" ] ; then | ||||||
|  | 			: | ||||||
|  | 		else | ||||||
|  | 			${APT_GET} install -y libnuma-dev zlib1g-dev libgmp-dev libgmp10 libssl-dev liblzma-dev libbz2-dev git wget lsb-release software-properties-common gnupg2 apt-transport-https gcc autoconf automake build-essential curl gzip | ||||||
|  | 		fi | ||||||
|  | 	elif [ "${DISTRO}" = "Debian" ] ; then | ||||||
|  | 		export DEBIAN_FRONTEND=noninteractive | ||||||
|  | 		export TZ=Asia/Singapore | ||||||
|  | 		${APT_GET} install -y libnuma-dev zlib1g-dev libgmp-dev libgmp10 libssl-dev liblzma-dev libbz2-dev git wget lsb-release software-properties-common gnupg2 apt-transport-https gcc autoconf automake build-essential curl ghc gzip | ||||||
| 	fi | 	fi | ||||||
| elif [ "${RUNNER_OS}" = "macOS" ] ; then | elif [ "${RUNNER_OS}" = "macOS" ] ; then | ||||||
| 	if ! command -v brew ; then | 	if ! command -v brew ; then | ||||||
| @ -72,5 +52,15 @@ elif [ "${RUNNER_OS}" = "macOS" ] ; then | |||||||
| 	if ! command -v realpath ; then | 	if ! command -v realpath ; then | ||||||
| 		brew install coreutils | 		brew install coreutils | ||||||
| 	fi | 	fi | ||||||
|  | 
 | ||||||
|  |     if [ "${ARCH}" = "ARM64" ] ; then | ||||||
|  | 		brew install llvm@11 autoconf automake | ||||||
|  | 		export PATH="$HOME/.brew/opt/llvm@11/bin:$PATH" | ||||||
|  | 		export CC="$HOME/.brew/opt/llvm@11/bin/clang" | ||||||
|  | 		export CXX="$HOME/.brew/opt/llvm@11/bin/clang++" | ||||||
|  | 		export LD=ld | ||||||
|  | 		export AR="$HOME/.brew/opt/llvm@11/bin/llvm-ar" | ||||||
|  | 		export RANLIB="$HOME/.brew/opt/llvm@11/bin/llvm-ranlib" | ||||||
|  | 	fi | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										47
									
								
								.github/scripts/test.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										47
									
								
								.github/scripts/test.sh
									
									
									
									
										vendored
									
									
								
							| @ -3,31 +3,8 @@ | |||||||
| set -eux | set -eux | ||||||
| 
 | 
 | ||||||
| . .github/scripts/prereq.sh | . .github/scripts/prereq.sh | ||||||
|  | . .github/scripts/common.sh | ||||||
| 
 | 
 | ||||||
| ecabal() { |  | ||||||
| 	cabal "$@" |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| raw_eghcup() { |  | ||||||
| 	"$GHCUP_BIN/ghcup${ext}" -v -c "$@" |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| eghcup() { |  | ||||||
| 	if [ "${OS}" = "Windows" ] ; then |  | ||||||
| 		"$GHCUP_BIN/ghcup${ext}" -v -c -s file:/$CI_PROJECT_DIR/data/metadata/ghcup-${JSON_VERSION}.yaml "$@" |  | ||||||
| 	else |  | ||||||
| 		"$GHCUP_BIN/ghcup${ext}" -v -c -s file://$CI_PROJECT_DIR/data/metadata/ghcup-${JSON_VERSION}.yaml "$@" |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sha_sum() { |  | ||||||
| 	if [ "${OS}" = "FreeBSD" ] ; then |  | ||||||
| 		sha256 "$@" |  | ||||||
| 	else |  | ||||||
| 		sha256sum "$@" |  | ||||||
| 	fi |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| if [ "${OS}" = "Windows" ] ; then | if [ "${OS}" = "Windows" ] ; then | ||||||
| 	GHCUP_DIR="${GHCUP_INSTALL_BASE_PREFIX}"/ghcup | 	GHCUP_DIR="${GHCUP_INSTALL_BASE_PREFIX}"/ghcup | ||||||
| @ -35,28 +12,26 @@ else | |||||||
| 	GHCUP_DIR="${GHCUP_INSTALL_BASE_PREFIX}"/.ghcup | 	GHCUP_DIR="${GHCUP_INSTALL_BASE_PREFIX}"/.ghcup | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| git describe --always | git_describe | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| rm -rf "${GHCUP_DIR}" | rm -rf "${GHCUP_DIR}" | ||||||
| mkdir -p "${GHCUP_BIN}" | mkdir -p "${GHCUP_BIN}" | ||||||
| 
 | 
 | ||||||
| if [ "${OS}" = "Windows" ] ; then |  | ||||||
| 	ext=".exe" |  | ||||||
| else |  | ||||||
| 	ext='' |  | ||||||
| fi |  | ||||||
| ls -lah out |  | ||||||
| find out |  | ||||||
| cp "out/${ARTIFACT}"-* "$GHCUP_BIN/ghcup${ext}" | cp "out/${ARTIFACT}"-* "$GHCUP_BIN/ghcup${ext}" | ||||||
|  | cp "out/test-${ARTIFACT}"-* "ghcup-test${ext}" | ||||||
| chmod +x "$GHCUP_BIN/ghcup${ext}" | chmod +x "$GHCUP_BIN/ghcup${ext}" | ||||||
| echo "$PATH" | chmod +x "ghcup-test${ext}" | ||||||
| 
 | 
 | ||||||
| "$GHCUP_BIN/ghcup${ext}" --version | "$GHCUP_BIN/ghcup${ext}" --version | ||||||
| eghcup --version | eghcup --version | ||||||
| sha_sum "$GHCUP_BIN/ghcup${ext}" | sha_sum "$GHCUP_BIN/ghcup${ext}" | ||||||
| sha_sum "$(raw_eghcup --offline whereis ghcup)" | sha_sum "$(raw_eghcup --offline whereis ghcup)" | ||||||
| 
 | 
 | ||||||
|  | ### Haskell test suite | ||||||
|  | 
 | ||||||
|  | ./ghcup-test${ext} | ||||||
|  | rm ghcup-test${ext} | ||||||
|  | 
 | ||||||
| ### manual cli based testing | ### manual cli based testing | ||||||
| 
 | 
 | ||||||
| eghcup --numeric-version | eghcup --numeric-version | ||||||
| @ -116,6 +91,10 @@ fi | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| if [ "${OS}" = "macOS" ] && [ "${ARCH}" = "ARM64" ] ; then | if [ "${OS}" = "macOS" ] && [ "${ARCH}" = "ARM64" ] ; then | ||||||
|  | 	# missing bindists | ||||||
|  | 	echo | ||||||
|  | elif [ "${OS}" = "FreeBSD" ] ; then | ||||||
|  | 	# not enough space | ||||||
| 	echo | 	echo | ||||||
| else | else | ||||||
| 	# test installing new ghc doesn't mess with currently set GHC | 	# test installing new ghc doesn't mess with currently set GHC | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/bootstrap.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/bootstrap.yaml
									
									
									
									
										vendored
									
									
								
							| @ -18,7 +18,9 @@ jobs: | |||||||
|       BOOTSTRAP_HASKELL_CABAL_VERSION: 3.6.2.0 |       BOOTSTRAP_HASKELL_CABAL_VERSION: 3.6.2.0 | ||||||
|       BOOTSTRAP_HASKELL_GHC_VERSION: 8.10.7 |       BOOTSTRAP_HASKELL_GHC_VERSION: 8.10.7 | ||||||
|       BOOTSTRAP_HASKELL_NONINTERACTIVE: yes |       BOOTSTRAP_HASKELL_NONINTERACTIVE: yes | ||||||
|  |       ARCH: 64 | ||||||
|       JSON_VERSION: "0.0.7" |       JSON_VERSION: "0.0.7" | ||||||
|  |       APT_GET: "sudo apt-get" | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         include: |         include: | ||||||
|  | |||||||
							
								
								
									
										67
									
								
								.github/workflows/docker.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								.github/workflows/docker.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,67 @@ | |||||||
|  | name: Docker image builds | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   workflow_dispatch: | ||||||
|  |   schedule: | ||||||
|  |     - cron: '0 0 * * *' | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   docker-alpine: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Set up QEMU | ||||||
|  |         uses: docker/setup-qemu-action@v2 | ||||||
|  |       - name: Set up Docker Buildx | ||||||
|  |         uses: docker/setup-buildx-action@v2 | ||||||
|  |       - name: Login to Docker Hub | ||||||
|  |         uses: docker/login-action@v2 | ||||||
|  |         with: | ||||||
|  |           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|  |           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  |       - name: Build and push (alpine 32bit) | ||||||
|  |         uses: docker/build-push-action@v3 | ||||||
|  |         with: | ||||||
|  |           context: ./docker/alpine32 | ||||||
|  |           push: true | ||||||
|  |           tags: hasufell/i386-alpine-haskell:3.12 | ||||||
|  |           platforms: linux/i386 | ||||||
|  |       - name: Build and push (alpine 64bit) | ||||||
|  |         uses: docker/build-push-action@v3 | ||||||
|  |         with: | ||||||
|  |           context: ./docker/alpine64 | ||||||
|  |           push: true | ||||||
|  |           tags: hasufell/alpine-haskell:3.12 | ||||||
|  |           platforms: linux/amd64 | ||||||
|  | 
 | ||||||
|  |   docker-arm: | ||||||
|  |     runs-on: [self-hosted, Linux, aarch64] | ||||||
|  |     steps: | ||||||
|  |       - uses: docker://arm64v8/ubuntu:focal | ||||||
|  |         name: Cleanup | ||||||
|  |         with: | ||||||
|  |           args: rm -rf .ghcup/ | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Set up Docker Buildx | ||||||
|  |         uses: docker/setup-buildx-action@v2 | ||||||
|  |       - name: Login to Docker Hub | ||||||
|  |         uses: docker/login-action@v2 | ||||||
|  |         with: | ||||||
|  |           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|  |           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  |       - name: Build and push (arm64v8) | ||||||
|  |         uses: docker/build-push-action@v3 | ||||||
|  |         with: | ||||||
|  |           context: ./docker/arm64v8/ | ||||||
|  |           push: true | ||||||
|  |           tags: hasufell/arm64v8-ubuntu-haskell:focal | ||||||
|  |           platforms: linux/arm64 | ||||||
|  |       - name: Build and push (arm32v7) | ||||||
|  |         uses: docker/build-push-action@v3 | ||||||
|  |         with: | ||||||
|  |           context: ./docker/arm32v7 | ||||||
|  |           push: true | ||||||
|  |           tags: hasufell/arm32v7-ubuntu-haskell:focal | ||||||
|  |           platforms: linux/arm | ||||||
							
								
								
									
										315
									
								
								.github/workflows/release.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										315
									
								
								.github/workflows/release.yaml
									
									
									
									
										vendored
									
									
								
							| @ -9,17 +9,20 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|     branches: |     branches: | ||||||
|       - master |       - master | ||||||
|  |   schedule: | ||||||
|  |     - cron: '0 2 * * *' | ||||||
| 
 | 
 | ||||||
| jobs: | jobs: | ||||||
|   build: |   build-alpine: | ||||||
|     name: Build binary |     name: Build static linux binary | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     env: |     env: | ||||||
|       CABAL_VER: 3.6.2.0 |       CABAL_VER: 3.6.2.0 | ||||||
|       CACHE_VER: 1 |  | ||||||
|       MACOSX_DEPLOYMENT_TARGET: 10.13 |  | ||||||
|       JSON_VERSION: "0.0.7" |       JSON_VERSION: "0.0.7" | ||||||
|  |       AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |       AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|     strategy: |     strategy: | ||||||
|  |       fail-fast: true | ||||||
|       matrix: |       matrix: | ||||||
|         include: |         include: | ||||||
|           - os: ubuntu-latest |           - os: ubuntu-latest | ||||||
| @ -30,6 +33,130 @@ jobs: | |||||||
|             ARTIFACT: "x86_64-linux-ghcup" |             ARTIFACT: "x86_64-linux-ghcup" | ||||||
|             GHC_VER: 8.10.7 |             GHC_VER: 8.10.7 | ||||||
|             ARCH: 64 |             ARCH: 64 | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout code | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           submodules: 'true' | ||||||
|  | 
 | ||||||
|  |       - if: matrix.ARCH == '32' | ||||||
|  |         name: Run build (32 bit linux) | ||||||
|  |         uses: docker://hasufell/i386-alpine-haskell:3.12 | ||||||
|  |         with: | ||||||
|  |           args: sh .github/scripts/build.sh | ||||||
|  |         env: | ||||||
|  |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|  |           ARCH: ${{ matrix.ARCH }} | ||||||
|  |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|  |           DISTRO: Alpine | ||||||
|  |           AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |           AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }} | ||||||
|  | 
 | ||||||
|  |       - if: matrix.ARCH == '64' | ||||||
|  |         name: Run build (64 bit linux) | ||||||
|  |         uses: docker://hasufell/alpine-haskell:3.12 | ||||||
|  |         with: | ||||||
|  |           args: sh .github/scripts/build.sh | ||||||
|  |         env: | ||||||
|  |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|  |           ARCH: ${{ matrix.ARCH }} | ||||||
|  |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|  |           DISTRO: Alpine | ||||||
|  |           AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |           AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }} | ||||||
|  | 
 | ||||||
|  |       - if: always() | ||||||
|  |         name: Upload artifact | ||||||
|  |         uses: actions/upload-artifact@v3 | ||||||
|  |         with: | ||||||
|  |           name: artifacts | ||||||
|  |           path: | | ||||||
|  |             ./out/* | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |   build-arm: | ||||||
|  |     name: Build ARM binary | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     env: | ||||||
|  |       CABAL_VER: 3.6.2.0 | ||||||
|  |       JSON_VERSION: "0.0.7" | ||||||
|  |       AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |       AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: true | ||||||
|  |       matrix: | ||||||
|  |         include: | ||||||
|  |           - os: [self-hosted, Linux, aarch64] | ||||||
|  |             ARTIFACT: "armv7-linux-ghcup" | ||||||
|  |             GHC_VER: 8.10.7 | ||||||
|  |             ARCH: ARM | ||||||
|  |           - os: [self-hosted, Linux, aarch64] | ||||||
|  |             ARTIFACT: "aarch64-linux-ghcup" | ||||||
|  |             GHC_VER: 8.10.7 | ||||||
|  |             ARCH: ARM64 | ||||||
|  |     steps: | ||||||
|  |       - uses: docker://arm64v8/ubuntu:focal | ||||||
|  |         name: Cleanup (aarch64 linux) | ||||||
|  |         with: | ||||||
|  |           args: rm -rf .ghcup/ cabal/ dist-newstyle/ out/ | ||||||
|  | 
 | ||||||
|  |       - name: git config | ||||||
|  |         run: | | ||||||
|  |           git config --global --get-all safe.directory | grep '^\*$' || git config --global --add safe.directory "*" | ||||||
|  |         shell: bash | ||||||
|  | 
 | ||||||
|  |       - name: Checkout code | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           submodules: 'true' | ||||||
|  | 
 | ||||||
|  |       - if: matrix.ARCH == 'ARM' | ||||||
|  |         uses: docker://hasufell/arm32v7-ubuntu-haskell:focal | ||||||
|  |         name: Run build (armv7 linux) | ||||||
|  |         with: | ||||||
|  |           args: sh .github/scripts/build.sh | ||||||
|  |         env: | ||||||
|  |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|  |           ARCH: ${{ matrix.ARCH }} | ||||||
|  |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|  |           DISTRO: Ubuntu | ||||||
|  |           AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |           AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }} | ||||||
|  | 
 | ||||||
|  |       - if: matrix.ARCH == 'ARM64' | ||||||
|  |         uses: docker://hasufell/arm64v8-ubuntu-haskell:focal | ||||||
|  |         name: Run build (aarch64 linux) | ||||||
|  |         with: | ||||||
|  |           args: sh .github/scripts/build.sh | ||||||
|  |         env: | ||||||
|  |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|  |           ARCH: ${{ matrix.ARCH }} | ||||||
|  |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|  |           DISTRO: Ubuntu | ||||||
|  |           AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |           AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }} | ||||||
|  | 
 | ||||||
|  |       - if: always() | ||||||
|  |         name: Upload artifact | ||||||
|  |         uses: actions/upload-artifact@v3 | ||||||
|  |         with: | ||||||
|  |           name: artifacts | ||||||
|  |           path: | | ||||||
|  |             ./out/* | ||||||
|  | 
 | ||||||
|  |   build-macwin: | ||||||
|  |     name: Build binary (Mac/Win) | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     env: | ||||||
|  |       CABAL_VER: 3.6.2.0 | ||||||
|  |       MACOSX_DEPLOYMENT_TARGET: 10.13 | ||||||
|  |       JSON_VERSION: "0.0.7" | ||||||
|  |       AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |       AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         include: | ||||||
|           - os: [self-hosted, macOS, aarch64] |           - os: [self-hosted, macOS, aarch64] | ||||||
|             ARTIFACT: "aarch64-apple-darwin-ghcup" |             ARTIFACT: "aarch64-apple-darwin-ghcup" | ||||||
|             GHC_VER: 9.2.5 |             GHC_VER: 9.2.5 | ||||||
| @ -48,36 +175,16 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           submodules: 'true' |           submodules: 'true' | ||||||
| 
 | 
 | ||||||
|       - if: matrix.ARCH == '32' && runner.os == 'Linux' |       - name: Run build (windows/mac) | ||||||
|         name: Run build (32 bit linux) |  | ||||||
|         uses: docker://i386/alpine:3.12 |  | ||||||
|         with: |  | ||||||
|           args: sh .github/scripts/build.sh |  | ||||||
|         env: |  | ||||||
|           ARTIFACT: ${{ matrix.ARTIFACT }} |  | ||||||
|           ARCH: ${{ matrix.ARCH }} |  | ||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |  | ||||||
|           DISTRO: Alpine |  | ||||||
| 
 |  | ||||||
|       - if: matrix.ARCH == '64' && runner.os == 'Linux' |  | ||||||
|         name: Run build (64 bit linux) |  | ||||||
|         uses: docker://alpine:3.12 |  | ||||||
|         with: |  | ||||||
|           args: sh .github/scripts/build.sh |  | ||||||
|         env: |  | ||||||
|           ARTIFACT: ${{ matrix.ARTIFACT }} |  | ||||||
|           ARCH: ${{ matrix.ARCH }} |  | ||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |  | ||||||
|           DISTRO: Alpine |  | ||||||
| 
 |  | ||||||
|       - if: runner.os != 'Linux' |  | ||||||
|         name: Run build (windows/mac) |  | ||||||
|         run: bash .github/scripts/build.sh |         run: bash .github/scripts/build.sh | ||||||
|         env: |         env: | ||||||
|           ARTIFACT: ${{ matrix.ARTIFACT }} |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|           ARCH: ${{ matrix.ARCH }} |           ARCH: ${{ matrix.ARCH }} | ||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|           DISTRO: na |           DISTRO: na | ||||||
|  |           AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |           AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }} | ||||||
|  |           HOMEBREW_CHANGE_ARCH_TO_ARM: 1 | ||||||
| 
 | 
 | ||||||
|       - if: always() |       - if: always() | ||||||
|         name: Upload artifact |         name: Upload artifact | ||||||
| @ -87,14 +194,13 @@ jobs: | |||||||
|           path: | |           path: | | ||||||
|             ./out/* |             ./out/* | ||||||
| 
 | 
 | ||||||
|   test: | 
 | ||||||
|     name: Test |   test-alpine: | ||||||
|     needs: build |     name: Test linux | ||||||
|  |     needs: "build-alpine" | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     env: |     env: | ||||||
|       CABAL_VER: 3.6.2.0 |       CABAL_VER: 3.6.2.0 | ||||||
|       CACHE_VER: 1 |  | ||||||
|       MACOSX_DEPLOYMENT_TARGET: 10.13 |  | ||||||
|       JSON_VERSION: "0.0.7" |       JSON_VERSION: "0.0.7" | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
| @ -114,21 +220,7 @@ jobs: | |||||||
|             GHC_VER: 8.10.7 |             GHC_VER: 8.10.7 | ||||||
|             ARCH: 64 |             ARCH: 64 | ||||||
|             DISTRO: Ubuntu |             DISTRO: Ubuntu | ||||||
|           - os: [self-hosted, macOS, aarch64] | 
 | ||||||
|             ARTIFACT: "aarch64-apple-darwin-ghcup" |  | ||||||
|             GHC_VER: 9.2.5 |  | ||||||
|             ARCH: ARM64 |  | ||||||
|             DISTRO: na |  | ||||||
|           - os: macOS-10.15 |  | ||||||
|             ARTIFACT: "x86_64-apple-darwin-ghcup" |  | ||||||
|             GHC_VER: 9.2.5 |  | ||||||
|             ARCH: 64 |  | ||||||
|             DISTRO: na |  | ||||||
|           - os: windows-latest |  | ||||||
|             ARTIFACT: "x86_64-mingw64-ghcup" |  | ||||||
|             GHC_VER: 8.10.7 |  | ||||||
|             ARCH: 64 |  | ||||||
|             DISTRO: na |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout code |       - name: Checkout code | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -140,9 +232,9 @@ jobs: | |||||||
|           name: artifacts |           name: artifacts | ||||||
|           path: ./out |           path: ./out | ||||||
| 
 | 
 | ||||||
|       - if: matrix.ARCH == '32' && runner.os == 'Linux' && matrix.DISTRO == 'Alpine' |       - if: matrix.ARCH == '32' && matrix.DISTRO == 'Alpine' | ||||||
|         name: Run build (32 bit linux Alpine) |         name: Run test (32 bit linux Alpine) | ||||||
|         uses: docker://i386/alpine:3.12 |         uses: docker://hasufell/i386-alpine-haskell:3.12 | ||||||
|         with: |         with: | ||||||
|           args: sh .github/scripts/test.sh |           args: sh .github/scripts/test.sh | ||||||
|         env: |         env: | ||||||
| @ -151,9 +243,9 @@ jobs: | |||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|           DISTRO: ${{ matrix.DISTRO }} |           DISTRO: ${{ matrix.DISTRO }} | ||||||
| 
 | 
 | ||||||
|       - if: matrix.ARCH == '64' && runner.os == 'Linux' && matrix.DISTRO == 'Alpine' |       - if: matrix.ARCH == '64' && matrix.DISTRO == 'Alpine' | ||||||
|         name: Run build (64 bit linux Alpine) |         name: Run test (64 bit linux Alpine) | ||||||
|         uses: docker://alpine:3.12 |         uses: docker://hasufell/alpine-haskell:3.12 | ||||||
|         with: |         with: | ||||||
|           args: sh .github/scripts/test.sh |           args: sh .github/scripts/test.sh | ||||||
|         env: |         env: | ||||||
| @ -162,26 +254,124 @@ jobs: | |||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|           DISTRO: ${{ matrix.DISTRO }} |           DISTRO: ${{ matrix.DISTRO }} | ||||||
| 
 | 
 | ||||||
|       - if: runner.os == 'Linux' && matrix.DISTRO != 'Alpine' |       - if: matrix.DISTRO != 'Alpine' | ||||||
|         name: Run build (64 bit linux) |         name: Run test (64 bit linux) | ||||||
|         run: sh .github/scripts/test.sh |         run: sh .github/scripts/test.sh | ||||||
|         env: |         env: | ||||||
|           ARTIFACT: ${{ matrix.ARTIFACT }} |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|           ARCH: ${{ matrix.ARCH }} |           ARCH: ${{ matrix.ARCH }} | ||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|           DISTRO: ${{ matrix.DISTRO }} |           DISTRO: ${{ matrix.DISTRO }} | ||||||
|  |           APT_GET: "sudo apt-get" | ||||||
| 
 | 
 | ||||||
|       - if: runner.os != 'Linux' |   test-arm: | ||||||
|         name: Run build (windows/mac) |     name: Test ARM | ||||||
|  |     needs: "build-arm" | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     env: | ||||||
|  |       CABAL_VER: 3.6.2.0 | ||||||
|  |       JSON_VERSION: "0.0.7" | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         include: | ||||||
|  |           - os: [self-hosted, Linux, aarch64] | ||||||
|  |             ARTIFACT: "armv7-linux-ghcup" | ||||||
|  |             GHC_VER: 8.10.7 | ||||||
|  |             ARCH: ARM | ||||||
|  |             DISTRO: Ubuntu | ||||||
|  |           - os: [self-hosted, Linux, aarch64] | ||||||
|  |             ARTIFACT: "aarch64-linux-ghcup" | ||||||
|  |             GHC_VER: 8.10.7 | ||||||
|  |             ARCH: ARM64 | ||||||
|  |             DISTRO: Ubuntu | ||||||
|  | 
 | ||||||
|  |     steps: | ||||||
|  |       - uses: docker://arm64v8/ubuntu:focal | ||||||
|  |         name: Cleanup (aarch64 linux) | ||||||
|  |         with: | ||||||
|  |           args: rm -rf .ghcup/ cabal/ dist-newstyle/ out/ | ||||||
|  | 
 | ||||||
|  |       - name: Checkout code | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           submodules: 'true' | ||||||
|  | 
 | ||||||
|  |       - uses: actions/download-artifact@v3 | ||||||
|  |         with: | ||||||
|  |           name: artifacts | ||||||
|  |           path: ./out | ||||||
|  | 
 | ||||||
|  |       - if: matrix.ARCH == 'ARM' | ||||||
|  |         uses: docker://hasufell/arm32v7-ubuntu-haskell:focal | ||||||
|  |         name: Run build (armv7 linux) | ||||||
|  |         with: | ||||||
|  |           run: sh .github/scripts/test.sh | ||||||
|  |         env: | ||||||
|  |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|  |           ARCH: ${{ matrix.ARCH }} | ||||||
|  |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|  |           DISTRO: Ubuntu | ||||||
|  | 
 | ||||||
|  |       - if: matrix.ARCH == 'ARM64' | ||||||
|  |         uses: docker://hasufell/arm64v8-ubuntu-haskell:focal | ||||||
|  |         name: Run build (aarch64 linux) | ||||||
|  |         with: | ||||||
|  |           run: sh .github/scripts/test.sh | ||||||
|  |         env: | ||||||
|  |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|  |           ARCH: ${{ matrix.ARCH }} | ||||||
|  |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|  |           DISTRO: Ubuntu | ||||||
|  | 
 | ||||||
|  |   test-macwin: | ||||||
|  |     name: Test Mac/Win | ||||||
|  |     needs: "build-macwin" | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     env: | ||||||
|  |       CABAL_VER: 3.6.2.0 | ||||||
|  |       MACOSX_DEPLOYMENT_TARGET: 10.13 | ||||||
|  |       JSON_VERSION: "0.0.7" | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         include: | ||||||
|  |           - os: [self-hosted, macOS, aarch64] | ||||||
|  |             ARTIFACT: "aarch64-apple-darwin-ghcup" | ||||||
|  |             GHC_VER: 9.2.5 | ||||||
|  |             ARCH: ARM64 | ||||||
|  |             DISTRO: na | ||||||
|  |           - os: macOS-10.15 | ||||||
|  |             ARTIFACT: "x86_64-apple-darwin-ghcup" | ||||||
|  |             GHC_VER: 9.2.5 | ||||||
|  |             ARCH: 64 | ||||||
|  |             DISTRO: na | ||||||
|  |           - os: windows-latest | ||||||
|  |             ARTIFACT: "x86_64-mingw64-ghcup" | ||||||
|  |             GHC_VER: 8.10.7 | ||||||
|  |             ARCH: 64 | ||||||
|  |             DISTRO: na | ||||||
|  | 
 | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout code | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           submodules: 'true' | ||||||
|  | 
 | ||||||
|  |       - uses: actions/download-artifact@v3 | ||||||
|  |         with: | ||||||
|  |           name: artifacts | ||||||
|  |           path: ./out | ||||||
|  | 
 | ||||||
|  |       - name: Run test (windows/mac) | ||||||
|         run: bash .github/scripts/test.sh |         run: bash .github/scripts/test.sh | ||||||
|         env: |         env: | ||||||
|           ARTIFACT: ${{ matrix.ARTIFACT }} |           ARTIFACT: ${{ matrix.ARTIFACT }} | ||||||
|           ARCH: ${{ matrix.ARCH }} |           ARCH: ${{ matrix.ARCH }} | ||||||
|           GHC_VER: ${{ matrix.GHC_VER }} |           GHC_VER: ${{ matrix.GHC_VER }} | ||||||
|           DISTRO: ${{ matrix.DISTRO }} |           DISTRO: ${{ matrix.DISTRO }} | ||||||
|  |           HOMEBREW_CHANGE_ARCH_TO_ARM: 1 | ||||||
|   hls: |   hls: | ||||||
|     name: hls |     name: hls | ||||||
|     needs: build |     needs: build-alpine | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     env: |     env: | ||||||
|       GHC_VERSION: "8.10.7" |       GHC_VERSION: "8.10.7" | ||||||
| @ -190,6 +380,9 @@ jobs: | |||||||
|       JSON_VERSION: "0.0.7" |       JSON_VERSION: "0.0.7" | ||||||
|       ARTIFACT: "x86_64-linux-ghcup" |       ARTIFACT: "x86_64-linux-ghcup" | ||||||
|       DISTRO: Ubuntu |       DISTRO: Ubuntu | ||||||
|  |       ARCH: 64 | ||||||
|  |       AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |       AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout code |       - name: Checkout code | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @ -203,10 +396,12 @@ jobs: | |||||||
| 
 | 
 | ||||||
|       - name: Run hls build |       - name: Run hls build | ||||||
|         run: sh .github/scripts/hls.sh |         run: sh .github/scripts/hls.sh | ||||||
|  |         env: | ||||||
|  |           APT_GET: "sudo apt-get" | ||||||
| 
 | 
 | ||||||
|   release: |   release: | ||||||
|     name: release |     name: release | ||||||
|     needs: [build, test, hls] |     needs: ["test-alpine", "test-arm", "test-macwin", "hls"] | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     if: startsWith(github.ref, 'refs/tags/v') |     if: startsWith(github.ref, 'refs/tags/v') | ||||||
|     steps: |     steps: | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| #ifndef POSIXPATHS_CBITS_DIRUTILS_H | #ifndef POSIXPATHS_CBITS_DIRUTILS_H | ||||||
| #define POSIXPATHS_CBITS_DIRUTILS_H | #define POSIXPATHS_CBITS_DIRUTILS_H | ||||||
| 
 | 
 | ||||||
|  | #include <HsFFI.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <dirent.h> | #include <dirent.h> | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  | |||||||
							
								
								
									
										71
									
								
								docker/alpine32/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								docker/alpine32/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,71 @@ | |||||||
|  | FROM i386/alpine:3.12 | ||||||
|  | 
 | ||||||
|  | ENV LANG C.UTF-8 | ||||||
|  | 
 | ||||||
|  | RUN apk add --no-cache \ | ||||||
|  |             curl \ | ||||||
|  |             gcc \ | ||||||
|  |             g++ \ | ||||||
|  |             binutils \ | ||||||
|  |             binutils-gold \ | ||||||
|  | 			coreutils \ | ||||||
|  |             bsd-compat-headers \ | ||||||
|  |             gmp-dev \ | ||||||
|  |             ncurses-dev \ | ||||||
|  |             libffi-dev \ | ||||||
|  |             make \ | ||||||
|  |             xz \ | ||||||
|  |             tar \ | ||||||
|  |             perl \ | ||||||
|  |             bash \ | ||||||
|  |             diffutils \ | ||||||
|  |             git \ | ||||||
|  | 			gzip \ | ||||||
|  | 			gnupg && \ | ||||||
|  |     apk add --no-cache \ | ||||||
|  |             zlib \ | ||||||
|  |             zlib-dev \ | ||||||
|  |             zlib-static \ | ||||||
|  |             bzip2 \ | ||||||
|  |             bzip2-dev \ | ||||||
|  |             bzip2-static \ | ||||||
|  |             gmp \ | ||||||
|  |             gmp-dev \ | ||||||
|  |             openssl-dev \ | ||||||
|  |             openssl-libs-static \ | ||||||
|  |             xz \ | ||||||
|  |             xz-dev \ | ||||||
|  |             ncurses-static | ||||||
|  | 
 | ||||||
|  | ARG GHCUP_VERSION=0.1.18.0 | ||||||
|  | ARG GPG_KEY=7784930957807690A66EBDBE3786C5262ECB4A3F | ||||||
|  | 
 | ||||||
|  | # install ghcup | ||||||
|  | RUN gpg --batch --keyserver keys.openpgp.org --recv-keys $GPG_KEY && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/i386-linux-ghcup-$GHCUP_VERSION && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS.sig && \ | ||||||
|  |     gpg --verify SHA256SUMS.sig SHA256SUMS && \ | ||||||
|  |     sha256sum -c --ignore-missing SHA256SUMS && \ | ||||||
|  |     mv i386-linux-ghcup-$GHCUP_VERSION /usr/bin/ghcup && \ | ||||||
|  |     chmod +x /usr/bin/ghcup && \ | ||||||
|  |     rm -rf SHA256SUMS SHA256SUMS.sig | ||||||
|  | 
 | ||||||
|  | ARG GHC=8.10.7 | ||||||
|  | ARG CABAL_INSTALL=3.6.2.0 | ||||||
|  | ARG STACK=2.9.1 | ||||||
|  | 
 | ||||||
|  | ENV GHCUP_CURL_OPTS="--silent" | ||||||
|  | ENV NO_COLOR=1 | ||||||
|  | 
 | ||||||
|  | # install haskell toolchain | ||||||
|  | RUN ghcup config set gpg-setting GPGStrict && \ | ||||||
|  | 	ghcup --verbose install ghc   --isolate=/usr     --force ${GHC} && \ | ||||||
|  | 	ghcup --verbose install cabal --isolate=/usr/bin --force ${CABAL_INSTALL} && \ | ||||||
|  | 	find "/usr/lib/ghc-${GHC}/" \( -name "*_p.a" -o -name "*.p_hi" \) -type f -delete && \ | ||||||
|  | 	rm -r "/usr/share/doc/ghc-${GHC}" && \ | ||||||
|  | 	rm -rf /tmp/ghcup* && \ | ||||||
|  | 	ghcup gc -p -s -c -t | ||||||
|  | 
 | ||||||
|  | ENV PATH /root/.cabal/bin:/root/.ghcup:/root/.local/bin:$PATH | ||||||
|  | 
 | ||||||
							
								
								
									
										71
									
								
								docker/alpine64/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								docker/alpine64/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,71 @@ | |||||||
|  | FROM alpine:3.12 | ||||||
|  | 
 | ||||||
|  | ENV LANG C.UTF-8 | ||||||
|  | 
 | ||||||
|  | RUN apk add --no-cache \ | ||||||
|  |             curl \ | ||||||
|  |             gcc \ | ||||||
|  |             g++ \ | ||||||
|  |             binutils \ | ||||||
|  |             binutils-gold \ | ||||||
|  | 			coreutils \ | ||||||
|  |             bsd-compat-headers \ | ||||||
|  |             gmp-dev \ | ||||||
|  |             ncurses-dev \ | ||||||
|  |             libffi-dev \ | ||||||
|  |             make \ | ||||||
|  |             xz \ | ||||||
|  |             tar \ | ||||||
|  |             perl \ | ||||||
|  |             bash \ | ||||||
|  |             diffutils \ | ||||||
|  |             git \ | ||||||
|  | 			gzip \ | ||||||
|  | 			gnupg && \ | ||||||
|  |     apk add --no-cache \ | ||||||
|  |             zlib \ | ||||||
|  |             zlib-dev \ | ||||||
|  |             zlib-static \ | ||||||
|  |             bzip2 \ | ||||||
|  |             bzip2-dev \ | ||||||
|  |             bzip2-static \ | ||||||
|  |             gmp \ | ||||||
|  |             gmp-dev \ | ||||||
|  |             openssl-dev \ | ||||||
|  |             openssl-libs-static \ | ||||||
|  |             xz \ | ||||||
|  |             xz-dev \ | ||||||
|  |             ncurses-static | ||||||
|  | 
 | ||||||
|  | ARG GHCUP_VERSION=0.1.18.0 | ||||||
|  | ARG GPG_KEY=7784930957807690A66EBDBE3786C5262ECB4A3F | ||||||
|  | 
 | ||||||
|  | # install ghcup | ||||||
|  | RUN gpg --batch --keyserver keys.openpgp.org --recv-keys $GPG_KEY && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/x86_64-linux-ghcup-$GHCUP_VERSION && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS.sig && \ | ||||||
|  |     gpg --verify SHA256SUMS.sig SHA256SUMS && \ | ||||||
|  |     sha256sum -c --ignore-missing SHA256SUMS && \ | ||||||
|  |     mv x86_64-linux-ghcup-$GHCUP_VERSION /usr/bin/ghcup && \ | ||||||
|  |     chmod +x /usr/bin/ghcup && \ | ||||||
|  |     rm -rf SHA256SUMS SHA256SUMS.sig | ||||||
|  | 
 | ||||||
|  | ARG GHC=8.10.7 | ||||||
|  | ARG CABAL_INSTALL=3.6.2.0 | ||||||
|  | ARG STACK=2.9.1 | ||||||
|  | 
 | ||||||
|  | ENV GHCUP_CURL_OPTS="--silent" | ||||||
|  | ENV NO_COLOR=1 | ||||||
|  | 
 | ||||||
|  | # install haskell toolchain | ||||||
|  | RUN ghcup config set gpg-setting GPGStrict && \ | ||||||
|  | 	ghcup --verbose install ghc   --isolate=/usr     --force ${GHC} && \ | ||||||
|  | 	ghcup --verbose install cabal --isolate=/usr/bin --force ${CABAL_INSTALL} && \ | ||||||
|  | 	find "/usr/lib/ghc-${GHC}/" \( -name "*_p.a" -o -name "*.p_hi" \) -type f -delete && \ | ||||||
|  | 	rm -r "/usr/share/doc/ghc-${GHC}" && \ | ||||||
|  | 	rm -rf /tmp/ghcup* && \ | ||||||
|  | 	ghcup gc -p -s -c -t | ||||||
|  | 
 | ||||||
|  | ENV PATH /root/.cabal/bin:/root/.ghcup:/root/.local/bin:$PATH | ||||||
|  | 
 | ||||||
							
								
								
									
										64
									
								
								docker/arm32v7/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								docker/arm32v7/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,64 @@ | |||||||
|  | FROM arm32v7/ubuntu:focal | ||||||
|  | 
 | ||||||
|  | ENV LANG C.UTF-8 | ||||||
|  | ENV DEBIAN_FRONTEND=noninteractive | ||||||
|  | ENV TZ=Asia/Singapore | ||||||
|  | 
 | ||||||
|  | COPY update_opt.sh /usr/bin/update_opt.sh | ||||||
|  | RUN chmod +x /usr/bin/update_opt.sh | ||||||
|  | 
 | ||||||
|  | RUN apt-get update && \ | ||||||
|  |     apt-get install -y --no-install-recommends \ | ||||||
|  |         ca-certificates \ | ||||||
|  |         curl \ | ||||||
|  |         dirmngr \ | ||||||
|  |         g++ \ | ||||||
|  |         git \ | ||||||
|  |         gnupg \ | ||||||
|  |         libsqlite3-dev \ | ||||||
|  |         libtinfo-dev \ | ||||||
|  |         libgmp-dev \ | ||||||
|  |         make \ | ||||||
|  |         netbase \ | ||||||
|  |         openssh-client \ | ||||||
|  |         xz-utils \ | ||||||
|  |         zlib1g-dev \ | ||||||
|  | 		libnuma-dev libgmp10 libssl-dev liblzma-dev libbz2-dev wget lsb-release software-properties-common apt-transport-https gcc autoconf automake build-essential gzip \ | ||||||
|  | 		llvm-9 clang-9 && \ | ||||||
|  |     rm -rf /var/lib/apt/lists/* | ||||||
|  | 
 | ||||||
|  | RUN update_opt.sh 9 1 | ||||||
|  | 
 | ||||||
|  | ARG GHCUP_VERSION=0.1.17.8 | ||||||
|  | ARG GPG_KEY=7784930957807690A66EBDBE3786C5262ECB4A3F | ||||||
|  | 
 | ||||||
|  | # install ghcup | ||||||
|  | RUN gpg --batch --keyserver keys.openpgp.org --recv-keys $GPG_KEY && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/armv7-linux-ghcup-$GHCUP_VERSION && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS.sig && \ | ||||||
|  |     gpg --verify SHA256SUMS.sig SHA256SUMS && \ | ||||||
|  |     sha256sum -c --ignore-missing SHA256SUMS && \ | ||||||
|  |     mv armv7-linux-ghcup-$GHCUP_VERSION /usr/bin/ghcup && \ | ||||||
|  |     chmod +x /usr/bin/ghcup && \ | ||||||
|  |     rm -rf SHA256SUMS SHA256SUMS.sig | ||||||
|  | 
 | ||||||
|  | ARG GHC=8.10.7 | ||||||
|  | ARG CABAL_INSTALL=3.6.2.0 | ||||||
|  | ARG STACK=2.9.1 | ||||||
|  | 
 | ||||||
|  | ENV GHCUP_CURL_OPTS="--silent" | ||||||
|  | ENV NO_COLOR=1 | ||||||
|  | 
 | ||||||
|  | # install haskell toolchain | ||||||
|  | RUN ghcup config set gpg-setting GPGStrict && \ | ||||||
|  | 	ghcup --verbose install ghc   --isolate=/usr     --force ${GHC} && \ | ||||||
|  | 	ghcup --verbose install cabal --isolate=/usr/bin --force ${CABAL_INSTALL} && \ | ||||||
|  | 	find "/usr/lib/ghc-${GHC}/" \( -name "*_p.a" -o -name "*.p_hi" \) -type f -delete && \ | ||||||
|  | 	rm -r "/usr/share/doc/ghc-${GHC}" && \ | ||||||
|  | 	rm -rf /tmp/ghcup* && \ | ||||||
|  | 	ghcup gc -p -s -c -t | ||||||
|  | 
 | ||||||
|  | ENV PATH /root/.cabal/bin:/root/.ghcup/bin:/root/.local/bin:$PATH | ||||||
|  | 
 | ||||||
|  | CMD ["ghci"] | ||||||
							
								
								
									
										36
									
								
								docker/arm32v7/update_opt.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										36
									
								
								docker/arm32v7/update_opt.sh
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,36 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | # update_alternatives.sh | ||||||
|  | 
 | ||||||
|  | update_alternatives() { | ||||||
|  |     local version=${1} | ||||||
|  |     local priority=${2} | ||||||
|  |     local master=${3} | ||||||
|  |     local slaves=${4} | ||||||
|  |     local path=${5} | ||||||
|  |     local cmdln | ||||||
|  | 
 | ||||||
|  |     cmdln="--verbose --install ${path}${master} ${master} ${path}${master}-${version} ${priority}" | ||||||
|  |     for slave in ${slaves}; do | ||||||
|  |         cmdln="${cmdln} --slave ${path}${slave} ${slave} ${path}${slave}-${version}" | ||||||
|  |     done | ||||||
|  |     update-alternatives ${cmdln} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | if [[ ${#} -ne 2 ]]; then | ||||||
|  |     echo usage: "${0}" clang_version priority | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | version=${1} | ||||||
|  | priority=${2} | ||||||
|  | path="/usr/bin/" | ||||||
|  | 
 | ||||||
|  | master="llvm-config" | ||||||
|  | slaves="llvm-addr2line llvm-ar llvm-as llvm-bcanalyzer llvm-bitcode-strip llvm-cat llvm-cfi-verify llvm-cov llvm-c-test llvm-cvtres llvm-cxxdump llvm-cxxfilt llvm-cxxmap llvm-debuginfod llvm-debuginfod-find llvm-diff llvm-dis llvm-dlltool llvm-dwarfdump llvm-dwarfutil llvm-dwp llvm-exegesis llvm-extract llvm-gsymutil llvm-ifs llvm-install-name-tool llvm-jitlink llvm-jitlink-executor llvm-lib llvm-libtool-darwin llvm-link llvm-lipo llvm-lto llvm-lto2 llvm-mc llvm-mca llvm-ml llvm-modextract llvm-mt llvm-nm llvm-objcopy llvm-objdump llvm-omp-device-info llvm-opt-report llvm-otool llvm-pdbutil llvm-PerfectShuffle llvm-profdata llvm-profgen llvm-ranlib llvm-rc llvm-readelf llvm-readobj llvm-reduce llvm-remark-size-diff llvm-rtdyld llvm-sim llvm-size llvm-split llvm-stress llvm-strings llvm-strip llvm-symbolizer llvm-tapi-diff llvm-tblgen llvm-tli-checker llvm-undname llvm-windres llvm-xray" | ||||||
|  | 
 | ||||||
|  | update_alternatives "${version}" "${priority}" "${master}" "${slaves}" "${path}" | ||||||
|  | 
 | ||||||
|  | master="clang" | ||||||
|  | slaves="analyze-build asan_symbolize bugpoint c-index-test clang++ clang-apply-replacements clang-change-namespace clang-check clang-cl clang-cpp clangd clang-doc clang-extdef-mapping clang-format clang-format-diff clang-include-fixer clang-linker-wrapper clang-move clang-nvlink-wrapper clang-offload-bundler clang-offload-packager clang-offload-wrapper clang-pseudo clang-query clang-refactor clang-rename clang-reorder-fields clang-repl clang-scan-deps clang-tidy count diagtool dsymutil FileCheck find-all-symbols git-clang-format hmaptool hwasan_symbolize intercept-build ld64.lld ld.lld llc lld lldb lldb-argdumper lldb-instr lldb-server lldb-vscode lld-link lli lli-child-target modularize not obj2yaml opt pp-trace run-clang-tidy sancov sanstats scan-build scan-build-py scan-view split-file UnicodeNameMappingGenerator verify-uselistorder wasm-ld yaml2obj yaml-bench" | ||||||
|  | 
 | ||||||
|  | update_alternatives "${version}" "${priority}" "${master}" "${slaves}" "${path}" | ||||||
							
								
								
									
										64
									
								
								docker/arm64v8/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								docker/arm64v8/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,64 @@ | |||||||
|  | FROM arm64v8/ubuntu:focal | ||||||
|  | 
 | ||||||
|  | ENV LANG C.UTF-8 | ||||||
|  | ENV DEBIAN_FRONTEND=noninteractive | ||||||
|  | ENV TZ=Asia/Singapore | ||||||
|  | 
 | ||||||
|  | COPY update_opt.sh /usr/bin/update_opt.sh | ||||||
|  | RUN chmod +x /usr/bin/update_opt.sh | ||||||
|  | 
 | ||||||
|  | RUN apt-get update && \ | ||||||
|  |     apt-get install -y --no-install-recommends \ | ||||||
|  |         ca-certificates \ | ||||||
|  |         curl \ | ||||||
|  |         dirmngr \ | ||||||
|  |         g++ \ | ||||||
|  |         git \ | ||||||
|  |         gnupg \ | ||||||
|  |         libsqlite3-dev \ | ||||||
|  |         libtinfo-dev \ | ||||||
|  |         libgmp-dev \ | ||||||
|  |         make \ | ||||||
|  |         netbase \ | ||||||
|  |         openssh-client \ | ||||||
|  |         xz-utils \ | ||||||
|  |         zlib1g-dev \ | ||||||
|  | 		libnuma-dev libgmp10 libssl-dev liblzma-dev libbz2-dev wget lsb-release software-properties-common apt-transport-https gcc autoconf automake build-essential gzip \ | ||||||
|  | 		llvm-9 clang-9 && \ | ||||||
|  |     rm -rf /var/lib/apt/lists/* | ||||||
|  | 
 | ||||||
|  | RUN update_opt.sh 9 1 | ||||||
|  | 
 | ||||||
|  | ARG GHCUP_VERSION=0.1.18.0 | ||||||
|  | ARG GPG_KEY=7784930957807690A66EBDBE3786C5262ECB4A3F | ||||||
|  | 
 | ||||||
|  | # install ghcup | ||||||
|  | RUN gpg --batch --keyserver keys.openpgp.org --recv-keys $GPG_KEY && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/aarch64-linux-ghcup-$GHCUP_VERSION && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS && \ | ||||||
|  |     curl -sSfL -O https://downloads.haskell.org/~ghcup/$GHCUP_VERSION/SHA256SUMS.sig && \ | ||||||
|  |     gpg --verify SHA256SUMS.sig SHA256SUMS && \ | ||||||
|  |     sha256sum -c --ignore-missing SHA256SUMS && \ | ||||||
|  |     mv aarch64-linux-ghcup-$GHCUP_VERSION /usr/bin/ghcup && \ | ||||||
|  |     chmod +x /usr/bin/ghcup && \ | ||||||
|  |     rm -rf SHA256SUMS SHA256SUMS.sig | ||||||
|  | 
 | ||||||
|  | ARG GHC=8.10.7 | ||||||
|  | ARG CABAL_INSTALL=3.6.2.0 | ||||||
|  | ARG STACK=2.9.1 | ||||||
|  | 
 | ||||||
|  | ENV GHCUP_CURL_OPTS="--silent" | ||||||
|  | ENV NO_COLOR=1 | ||||||
|  | 
 | ||||||
|  | # install haskell toolchain | ||||||
|  | RUN ghcup config set gpg-setting GPGStrict && \ | ||||||
|  | 	ghcup --verbose install ghc   --isolate=/usr     --force ${GHC} && \ | ||||||
|  | 	ghcup --verbose install cabal --isolate=/usr/bin --force ${CABAL_INSTALL} && \ | ||||||
|  | 	find "/usr/lib/ghc-${GHC}/" \( -name "*_p.a" -o -name "*.p_hi" \) -type f -delete && \ | ||||||
|  | 	rm -r "/usr/share/doc/ghc-${GHC}" && \ | ||||||
|  | 	rm -rf /tmp/ghcup* && \ | ||||||
|  | 	ghcup gc -p -s -c -t | ||||||
|  | 
 | ||||||
|  | ENV PATH /root/.cabal/bin:/root/.ghcup/bin:/root/.local/bin:$PATH | ||||||
|  | 
 | ||||||
|  | CMD ["ghci"] | ||||||
							
								
								
									
										36
									
								
								docker/arm64v8/update_opt.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										36
									
								
								docker/arm64v8/update_opt.sh
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,36 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | # update_alternatives.sh | ||||||
|  | 
 | ||||||
|  | update_alternatives() { | ||||||
|  |     local version=${1} | ||||||
|  |     local priority=${2} | ||||||
|  |     local master=${3} | ||||||
|  |     local slaves=${4} | ||||||
|  |     local path=${5} | ||||||
|  |     local cmdln | ||||||
|  | 
 | ||||||
|  |     cmdln="--verbose --install ${path}${master} ${master} ${path}${master}-${version} ${priority}" | ||||||
|  |     for slave in ${slaves}; do | ||||||
|  |         cmdln="${cmdln} --slave ${path}${slave} ${slave} ${path}${slave}-${version}" | ||||||
|  |     done | ||||||
|  |     update-alternatives ${cmdln} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | if [[ ${#} -ne 2 ]]; then | ||||||
|  |     echo usage: "${0}" clang_version priority | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | version=${1} | ||||||
|  | priority=${2} | ||||||
|  | path="/usr/bin/" | ||||||
|  | 
 | ||||||
|  | master="llvm-config" | ||||||
|  | slaves="llvm-addr2line llvm-ar llvm-as llvm-bcanalyzer llvm-bitcode-strip llvm-cat llvm-cfi-verify llvm-cov llvm-c-test llvm-cvtres llvm-cxxdump llvm-cxxfilt llvm-cxxmap llvm-debuginfod llvm-debuginfod-find llvm-diff llvm-dis llvm-dlltool llvm-dwarfdump llvm-dwarfutil llvm-dwp llvm-exegesis llvm-extract llvm-gsymutil llvm-ifs llvm-install-name-tool llvm-jitlink llvm-jitlink-executor llvm-lib llvm-libtool-darwin llvm-link llvm-lipo llvm-lto llvm-lto2 llvm-mc llvm-mca llvm-ml llvm-modextract llvm-mt llvm-nm llvm-objcopy llvm-objdump llvm-omp-device-info llvm-opt-report llvm-otool llvm-pdbutil llvm-PerfectShuffle llvm-profdata llvm-profgen llvm-ranlib llvm-rc llvm-readelf llvm-readobj llvm-reduce llvm-remark-size-diff llvm-rtdyld llvm-sim llvm-size llvm-split llvm-stress llvm-strings llvm-strip llvm-symbolizer llvm-tapi-diff llvm-tblgen llvm-tli-checker llvm-undname llvm-windres llvm-xray" | ||||||
|  | 
 | ||||||
|  | update_alternatives "${version}" "${priority}" "${master}" "${slaves}" "${path}" | ||||||
|  | 
 | ||||||
|  | master="clang" | ||||||
|  | slaves="analyze-build asan_symbolize bugpoint c-index-test clang++ clang-apply-replacements clang-change-namespace clang-check clang-cl clang-cpp clangd clang-doc clang-extdef-mapping clang-format clang-format-diff clang-include-fixer clang-linker-wrapper clang-move clang-nvlink-wrapper clang-offload-bundler clang-offload-packager clang-offload-wrapper clang-pseudo clang-query clang-refactor clang-rename clang-reorder-fields clang-repl clang-scan-deps clang-tidy count diagtool dsymutil FileCheck find-all-symbols git-clang-format hmaptool hwasan_symbolize intercept-build ld64.lld ld.lld llc lld lldb lldb-argdumper lldb-instr lldb-server lldb-vscode lld-link lli lli-child-target modularize not obj2yaml opt pp-trace run-clang-tidy sancov sanstats scan-build scan-build-py scan-view split-file UnicodeNameMappingGenerator verify-uselistorder wasm-ld yaml2obj yaml-bench" | ||||||
|  | 
 | ||||||
|  | update_alternatives "${version}" "${priority}" "${master}" "${slaves}" "${path}" | ||||||
							
								
								
									
										17
									
								
								ghcup.cabal
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								ghcup.cabal
									
									
									
									
									
								
							| @ -25,7 +25,10 @@ extra-source-files: | |||||||
|   cbits/dirutils.h |   cbits/dirutils.h | ||||||
|   data/build_mk/cross |   data/build_mk/cross | ||||||
|   data/build_mk/default |   data/build_mk/default | ||||||
|   test/golden/GHCupInfo.json |   test/golden/unix/GHCupInfo.json | ||||||
|  |   test/golden/windows/GHCupInfo.json | ||||||
|  |   test/data/file | ||||||
|  |   test/data/dir/.keep | ||||||
| 
 | 
 | ||||||
| source-repository head | source-repository head | ||||||
|   type:     git |   type:     git | ||||||
| @ -180,9 +183,10 @@ library | |||||||
|     other-modules: |     other-modules: | ||||||
|       GHCup.Prelude.File.Posix |       GHCup.Prelude.File.Posix | ||||||
|       GHCup.Prelude.File.Posix.Foreign |       GHCup.Prelude.File.Posix.Foreign | ||||||
|       GHCup.Prelude.File.Posix.Traversals |  | ||||||
|       GHCup.Prelude.Posix |       GHCup.Prelude.Posix | ||||||
|       GHCup.Prelude.Process.Posix |       GHCup.Prelude.Process.Posix | ||||||
|  |     exposed-modules: | ||||||
|  |       GHCup.Prelude.File.Posix.Traversals | ||||||
| 
 | 
 | ||||||
|     include-dirs:     cbits |     include-dirs:     cbits | ||||||
|     includes:         dirutils.h |     includes:         dirutils.h | ||||||
| @ -301,6 +305,7 @@ test-suite ghcup-test | |||||||
|     GHCup.ArbitraryTypes |     GHCup.ArbitraryTypes | ||||||
|     GHCup.Types.JSONSpec |     GHCup.Types.JSONSpec | ||||||
|     GHCup.Utils.FileSpec |     GHCup.Utils.FileSpec | ||||||
|  |     GHCup.Prelude.File.Posix.TraversalsSpec | ||||||
|     Spec |     Spec | ||||||
| 
 | 
 | ||||||
|   default-language:   Haskell2010 |   default-language:   Haskell2010 | ||||||
| @ -324,7 +329,7 @@ test-suite ghcup-test | |||||||
|     , filepath                  ^>=1.4.2.1 |     , filepath                  ^>=1.4.2.1 | ||||||
|     , generic-arbitrary         >=0.1.0   && <0.2.1 || >=0.2.2 && <0.3 |     , generic-arbitrary         >=0.1.0   && <0.2.1 || >=0.2.2 && <0.3 | ||||||
|     , ghcup |     , ghcup | ||||||
|     , hspec                     >=2.7.10  && <2.10 |     , hspec                     >=2.7.10  && <2.11 | ||||||
|     , hspec-golden-aeson        ^>=0.9 |     , hspec-golden-aeson        ^>=0.9 | ||||||
|     , QuickCheck                ^>=2.14.1 |     , QuickCheck                ^>=2.14.1 | ||||||
|     , quickcheck-arbitrary-adt  ^>=0.3.1.0 |     , quickcheck-arbitrary-adt  ^>=0.3.1.0 | ||||||
| @ -332,3 +337,9 @@ test-suite ghcup-test | |||||||
|     , text                      ^>=1.2.4.0 |     , text                      ^>=1.2.4.0 | ||||||
|     , uri-bytestring            ^>=0.3.2.2 |     , uri-bytestring            ^>=0.3.2.2 | ||||||
|     , versions                  >=4.0.1   && <5.1 |     , versions                  >=4.0.1   && <5.1 | ||||||
|  | 
 | ||||||
|  |   if os(windows) | ||||||
|  |     cpp-options: -DIS_WINDOWS | ||||||
|  |   else | ||||||
|  |     build-depends: | ||||||
|  |       , unix             ^>=2.7 | ||||||
|  | |||||||
| @ -36,8 +36,8 @@ import System.Posix.Internals (peekFilePath) | |||||||
| ---------------------------------------------------------- | ---------------------------------------------------------- | ||||||
| -- dodgy stuff | -- dodgy stuff | ||||||
| 
 | 
 | ||||||
| type CDir = () | data {-# CTYPE "DIR" #-} CDir | ||||||
| type CDirent = () | data {-# CTYPE "struct dirent" #-} CDirent | ||||||
| 
 | 
 | ||||||
| -- Posix doesn't export DirStream, so to re-use that type we need to use | -- Posix doesn't export DirStream, so to re-use that type we need to use | ||||||
| -- unsafeCoerce.  It's just a newtype, so this is a legitimate usage. | -- unsafeCoerce.  It's just a newtype, so this is a legitimate usage. | ||||||
| @ -56,7 +56,7 @@ foreign import ccall unsafe "__hscore_free_dirent" | |||||||
| foreign import ccall unsafe "__hscore_d_name" | foreign import ccall unsafe "__hscore_d_name" | ||||||
|   c_name :: Ptr CDirent -> IO CString |   c_name :: Ptr CDirent -> IO CString | ||||||
| 
 | 
 | ||||||
| foreign import ccall unsafe "__posixdir_d_type" | foreign import capi unsafe "dirutils.h __posixdir_d_type" | ||||||
|   c_type :: Ptr CDirent -> IO DirType |   c_type :: Ptr CDirent -> IO DirType | ||||||
| 
 | 
 | ||||||
| ---------------------------------------------------------- | ---------------------------------------------------------- | ||||||
|  | |||||||
							
								
								
									
										40
									
								
								test/GHCup/Prelude/File/Posix/TraversalsSpec.hs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								test/GHCup/Prelude/File/Posix/TraversalsSpec.hs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | |||||||
|  | {-# LANGUAGE CPP #-} | ||||||
|  | 
 | ||||||
|  | module GHCup.Prelude.File.Posix.TraversalsSpec where | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #if !defined(IS_WINDOWS) | ||||||
|  | import           GHCup.Prelude.File.Posix.Traversals | ||||||
|  | 
 | ||||||
|  | import           Control.Monad.IO.Class (liftIO) | ||||||
|  | import           Data.List | ||||||
|  | import           System.Posix.Directory | ||||||
|  | import           Unsafe.Coerce | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | import           Test.Hspec | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | spec :: Spec | ||||||
|  | spec = do | ||||||
|  | #if defined(IS_WINDOWS) | ||||||
|  |   pure () | ||||||
|  | #else | ||||||
|  |   -- https://github.com/haskell/ghcup-hs/issues/415 | ||||||
|  |   describe "GHCup.Prelude.File.Posix.Traversals" $ do | ||||||
|  |     it "readDirEnt" $ do | ||||||
|  |       dirstream <- liftIO $ openDirStream "test/data" | ||||||
|  |       (dt1, fp1) <- readDirEnt dirstream | ||||||
|  |       (dt2, fp2) <- readDirEnt dirstream | ||||||
|  |       (dt3, fp3) <- readDirEnt dirstream | ||||||
|  |       (dt4, fp4) <- readDirEnt dirstream | ||||||
|  |       let xs = sortOn snd [ (dt1, fp1), (dt2, fp2) | ||||||
|  |                           , (dt3, fp3), (dt4, fp4) | ||||||
|  |                           ] | ||||||
|  |       xs `shouldBe` [(unsafeCoerce (4 :: Int),".") | ||||||
|  |                     ,(unsafeCoerce (4 :: Int),"..") | ||||||
|  |                     ,(unsafeCoerce (4 :: Int),"dir") | ||||||
|  |                     ,(unsafeCoerce (8 :: Int),"file") | ||||||
|  |                     ] | ||||||
|  | #endif | ||||||
| @ -5,6 +5,7 @@ module GHCup.Types.JSONSpec where | |||||||
| import           GHCup.ArbitraryTypes () | import           GHCup.ArbitraryTypes () | ||||||
| import           GHCup.Types hiding ( defaultSettings ) | import           GHCup.Types hiding ( defaultSettings ) | ||||||
| import           GHCup.Types.JSON () | import           GHCup.Types.JSON () | ||||||
|  | import           GHCup.Prelude | ||||||
| 
 | 
 | ||||||
| import           Test.Aeson.GenericSpecs | import           Test.Aeson.GenericSpecs | ||||||
| import           Test.Hspec | import           Test.Hspec | ||||||
| @ -13,5 +14,9 @@ import           Test.Hspec | |||||||
| 
 | 
 | ||||||
| spec :: Spec | spec :: Spec | ||||||
| spec = do | spec = do | ||||||
|   roundtripAndGoldenSpecsWithSettings (defaultSettings { goldenDirectoryOption = CustomDirectoryName "test/golden" }) (Proxy @GHCupInfo) |   roundtripAndGoldenSpecsWithSettings (defaultSettings { goldenDirectoryOption = CustomDirectoryName goldenDir }) (Proxy @GHCupInfo) | ||||||
|  |  where | ||||||
|  |   goldenDir | ||||||
|  |     | isWindows = "test/golden/windows" | ||||||
|  |     | otherwise = "test/golden/unix" | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								test/data/dir/.keep
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								test/data/dir/.keep
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								test/data/file
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								test/data/file
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										16041
									
								
								test/golden/windows/GHCupInfo.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16041
									
								
								test/golden/windows/GHCupInfo.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user