Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
G
ghcup
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package Registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Richard Marmorstein
ghcup
Commits
010b140c
Unverified
Commit
010b140c
authored
6 years ago
by
Julian Ospald
Browse files
Options
Downloads
Patches
Plain Diff
Introduce major version symlinks wrt #101
parent
62d9606d
No related branches found
No related tags found
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
ghcup
+80
-7
80 additions, 7 deletions
ghcup
with
80 additions
and
7 deletions
ghcup
+
80
−
7
View file @
010b140c
...
...
@@ -1319,6 +1319,50 @@ show_cabal_installed() {
}
# @FUNCTION: get_full_ghc_ver
# @USAGE: <ghcmajorversion>
# @DESCRIPTION:
# Get the latest full GHC version .
get_full_ghc_ver
()
{
[
-z
"
$1
"
]
&&
die
"Internal error: no argument given to get_full_ghc_ver"
mymajorghcver
=
$1
latest_ghc
=
0
for
current_ghc
in
"
${
BIN_LOCATION
}
/ghc-
${
mymajorghcver
}
."
*
;
do
[
-e
"
${
current_ghc
}
"
]
||
break
real_ghc
=
$(
posix_realpath
"
${
current_ghc
}
"
)
real_ghc
=
"
$(
basename
"
${
real_ghc
}
"
|
sed
's#ghc-##'
)
"
if
[
"
$(
expr
"
${
real_ghc
}
"
\>
"
${
latest_ghc
}
"
)
"
=
1
]
;
then
latest_ghc
=
${
real_ghc
}
fi
done
if
[
"
${
latest_ghc
}
"
!=
0
]
;
then
printf
"%s"
"
${
latest_ghc
}
"
fi
unset
mymajorghcver latest_ghc real_ghc current_ghc
}
# @FUNCTION: set_ghc_major
# @USAGE: <ghcversion>
# @DESCRIPTION:
# Sets a ghc-x.y major version to the latest ghc-x.y.z if any is installed.
set_ghc_major
()
{
[
-z
"
$1
"
]
&&
die
"Internal error: no argument given to set_ghc_major"
full_ghc_ver
=
"
$(
get_full_ghc_ver
"
${
1
%.*
}
"
)
"
if
[
-z
"
${
full_ghc_ver
}
"
]
;
then
die
"Could not set GHC major symlink"
fi
set_ghc
"
${
full_ghc_ver
}
"
"-
${
1
%.*
}
"
unset
full_ghc_ver
}
############################
...
...
@@ -1406,9 +1450,14 @@ install_ghc() {
# shellcheck disable=SC2046
edo
ln
$(
optionv
"-v"
)
-sf
../ghc/
"
${
myghcver
}
"
/bin/runhaskell
"
${
BIN_LOCATION
}
/runhaskell-
${
myghcver
}
"
status_message
"Done installing, run
\"
ghci-
${
myghcver
}
\"
or set up your current GHC via:
${
SCRIPT
}
set
${
myghcver
}
"
unset
myghcver inst_location f download_url download_tarball_name first_install tmp_dir
unset
inst_location f download_url download_tarball_name first_install tmp_dir
set_ghc_major
"
${
myghcver
}
"
unset
myghcver
}
...
...
@@ -1419,13 +1468,14 @@ install_ghc() {
# @FUNCTION: set_ghc
# @USAGE: <ghcversion>
# @USAGE: <ghcversion>
[target-suffix]
# @DESCRIPTION:
# Sets the current ghc version by creating symlinks.
set_ghc
()
{
[
-z
"
$1
"
]
&&
die
"Internal error: no argument given to set_ghc"
myghcver
=
$1
target_suffix
=
$2
inst_location
=
$(
get_ghc_location
"
$1
"
)
[
-z
"
${
inst_location
}
"
]
&&
die
"failed to get install location"
...
...
@@ -1436,23 +1486,24 @@ set_ghc() {
for
f
in
"
${
inst_location
}
"
/bin/
*
-
"
${
myghcver
}
"
;
do
[
-e
"
${
f
}
"
]
||
die
"Something went wrong,
${
f
}
does not exist!"
source_fn
=
$(
basename
"
${
f
}
"
)
target_fn
=
$(
echo
"
${
source_fn
}
"
|
sed
"s#-
${
myghcver
}
##"
)
target_fn
=
"
$(
echo
"
${
source_fn
}
"
|
sed
"s#-
${
myghcver
}
##"
)
${
target_suffix
}
"
# shellcheck disable=SC2046
edo
ln
$(
optionv
"-v"
)
-sf
../ghc/
"
${
myghcver
}
/bin/
${
source_fn
}
"
"
${
BIN_LOCATION
}
/
${
target_fn
}
"
unset
source_fn target_fn
done
# shellcheck disable=SC2046
edo
ln
$(
optionv
"-v"
)
-sf
runghc
"
${
BIN_LOCATION
}
"
/runhaskell
edo
ln
$(
optionv
"-v"
)
-sf
"
runghc
${
target_suffix
}
"
"
${
BIN_LOCATION
}
/runhaskell
${
target_suffix
}
"
# shellcheck disable=SC2046
edo
ln
$(
optionv
"-v"
)
-sf
haddock-ghc
"
${
BIN_LOCATION
}
"
/haddock
edo
ln
$(
optionv
"-v"
)
-sf
"
haddock-ghc
${
target_suffix
}
"
"
${
BIN_LOCATION
}
/haddock
${
target_suffix
}
"
status_message
"Done, make sure
\"
${
BIN_LOCATION
}
\"
is in your PATH!"
unset
myghcver inst_location f
unset
myghcver inst_location f
target_suffix
}
############################
#--[ Subcommand upgrade ]--#
############################
...
...
@@ -1526,6 +1577,24 @@ rm_ghc() {
status_message
"Successfully removed GHC
${
myghcver
}
."
# Only run set_ghc_major if there is at least one 8.6.x version left for 8.6.
if
[
-n
"
$(
get_full_ghc_ver
"
${
myghcver
%.*
}
"
)
"
]
;
then
set_ghc_major
"
${
myghcver
}
"
fi
if
[
-h
"
${
BIN_LOCATION
}
/ghc-
${
myghcver
%.*
}
"
]
&&
[
!
-e
"
${
BIN_LOCATION
}
/ghc-
${
myghcver
%.*
}
"
]
;
then
# TODO: known_tools is not very robust, but we want to avoid accidentially deleting
# unrelated things (even if those are dangling symlinks)
known_tools
=
"ghc ghci ghc-pkg haddock haddock-ghc runghc runhaskell"
# remove dangling symlinks for ghc, ghci, ...
for
t
in
${
known_tools
}
;
do
if
[
-h
"
${
BIN_LOCATION
}
/
${
t
}
-
${
myghcver
%.*
}
"
]
&&
[
!
-e
"
${
BIN_LOCATION
}
/
${
t
}
-
${
myghcver
%.*
}
"
]
;
then
edo
rm
"
${
BIN_LOCATION
}
/
${
t
}
-
${
myghcver
%.*
}
"
fi
done
unset
t known_tools
fi
if
[
-h
"
${
BIN_LOCATION
}
/ghc"
]
&&
[
!
-e
"
${
BIN_LOCATION
}
/ghc"
]
;
then
warning_message
"Currently active GHC is a dangling symlink, removing..."
...
...
@@ -1705,7 +1774,11 @@ Also check https://ghc.haskell.org/trac/ghc/wiki/Building/Preparation/Linux for
status_message
"Done installing, run
\"
ghci-
${
myghcver
}
\"
or set up your current GHC via:
${
SCRIPT
}
set
${
myghcver
}
"
unset
myghcver bootstrap_ghc inst_location f download_url download_tarball_name tmp_dir
unset
bootstrap_ghc inst_location f download_url download_tarball_name tmp_dir
set_ghc_major
"
${
myghcver
}
"
unset
myghcver
}
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment