Skip to content

Commit

Permalink
Merge branch 'master' into feature/1153-offline-capability
Browse files Browse the repository at this point in the history
  • Loading branch information
hohwille authored Jan 18, 2024
2 parents dcf49e8 + a7769d0 commit 9c82f57
Show file tree
Hide file tree
Showing 7 changed files with 144 additions and 28 deletions.
2 changes: 1 addition & 1 deletion .mvn/maven.config
Original file line number Diff line number Diff line change
@@ -1 +1 @@
-Drevision=2023.10.001-SNAPSHOT
-Drevision=2024.01.001-SNAPSHOT
11 changes: 9 additions & 2 deletions CHANGELOG.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,18 @@

This file documents all notable changes to https://github.com/devonfw/ide[devonfw-ide].

== 2023.10.001
== 2024.01.001

Release with new features and bugfixes:

* TODO
The full list of changes for this release can be found in https://github.com/devonfw/ide/milestone/50?closed=1[milestone 2024.01.001].

== 2023.12.001

Release with new features and bugfixes:

* https://github.com/devonfw/ide/issues/1370[#1370]: Release broken: system folder empty
* https://github.com/devonfw/ide/issues/1362[#1362]: use devonfw-ide branch for ide-settings as default

The full list of changes for this release can be found in https://github.com/devonfw/ide/milestone/49?closed=1[milestone 2023.10.001].

Expand Down
6 changes: 4 additions & 2 deletions documentation/functions.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -342,9 +342,12 @@ Determines whether the actual version is contained in the security file for the
=== doCheckVersionRange
Determines whether a version is in a version range.

=== doGetLatestSoftwareVersion
=== doGetAnyLatestSoftwareVersion
Determines the latest available version of software and returns it. If a prefix is given, it will be taken into account.

=== doGetLatestSoftwareVersion
Determines the latest stable available version of software and returns it. If a prefix is given, it will be taken into account.

=== doGetNextVersion
A version number is passed to the function doGetNextVersion as an argument and the next version number is generated from this by incrementing the last digit by one and outputs it.

Expand Down Expand Up @@ -432,4 +435,3 @@ In this case, it does the handling to `list`, `get`, or `set` the version and ex

If -- is passed, a variable is set that prevents further calls of this function and ends with the return value 0.
If none of these options are passed, the return value is 255.

7 changes: 7 additions & 0 deletions scripts/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,13 @@
<exclude>system/**/*</exclude>
</excludes>
</resource>
<resource>
<directory>src/main/resources</directory>
<filtering>false</filtering>
<includes>
<include>system/**/*</include>
</includes>
</resource>
</resources>
<plugins>
<plugin>
Expand Down
2 changes: 1 addition & 1 deletion scripts/src/main/resources/scripts/command/ide
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ function doUpdateScripts() {
}

function doUpdateSettings() {
local defaultSettingsUrl="https://github.com/devonfw/ide-settings.git"
local defaultSettingsUrl="https://github.com/devonfw/ide-settings.git#devonfw-ide"
if [ ! -d "${SETTINGS_PATH}" ]
then
if [ -n "${1}" ]
Expand Down
139 changes: 117 additions & 22 deletions scripts/src/main/resources/scripts/functions
Original file line number Diff line number Diff line change
Expand Up @@ -522,7 +522,7 @@ function doDownload() {

if [ ! -f "${url_file}" ]
then
if doIsMacOs
if doIsMacOs
then
if [ "${arch}" = "arm64" ]
then
Expand All @@ -536,14 +536,14 @@ function doDownload() {
then
url_file="${urls_software_dir}/${os}.urls"
if [ ! -f "${url_file}" ]
then
then
url_file="${urls_software_dir}/urls"
fi
fi
if [ ! -f "${url_file}" ]
then
doFail "No url file found at ${urls_software_dir}"
fi
fi

local url
declare -a urls
Expand All @@ -553,7 +553,7 @@ function doDownload() {
((++i))
done < "${url_file}"

# suffle urls to choose urls in random order and distribute load
# shuffle urls to choose urls in random order and distribute load
local size="${#urls[*]}"
local rand
local tmp
Expand Down Expand Up @@ -612,7 +612,7 @@ function doDownload() {
local checksum
checksum="$(cat "${url_file}".sha256)"
doVerifyChecksums "${target_dir}"/"${filename}" "${checksum}" "${url_file}"
else
else
if [ "${version}" != "latest" ]
then
doEcho "No checksum found at ${url_file}.sha256"
Expand Down Expand Up @@ -700,7 +700,7 @@ function doDownloadInternal() {
fi
}

# $1: filename (potentiall including absolute or relative path)
# $1: filename (potentially including absolute or relative path)
# echos the file extension
function doGetExtension() {
local filename="${1/*\//}"
Expand Down Expand Up @@ -809,7 +809,7 @@ function doExtract() {
fi
}

# $n: the executable to run (may be expaneded glob pattern(s))
# $n: the executable to run (may be expanded glob pattern(s))
function doRunFirstExecutable() {
local installer="$1"
while [ -n "$1" ]
Expand Down Expand Up @@ -855,7 +855,7 @@ function doUnzip() {
}

function doInstallWithPackageManager() {
local first
local first
for installString in "${@}"
do
first="${installString/ */}"
Expand Down Expand Up @@ -1015,7 +1015,7 @@ function doArrayContainsItemWithPrefix() {

# $1: java package
# $2: optional groupId
# $3: optional artifactId
# $3: optional artifactId
function doMavenArchetype() {
if [ -z "${1}" ]
then
Expand Down Expand Up @@ -1173,7 +1173,7 @@ function doUpgradeMavenArtifact() {
fi
fi
if [[ "${target_version}" =~ alpha|beta|rc|pre|test ]]
then
then
doAskToContinue "Latest version seems unstable: ${target_version}\nAre you sure you want to install this version?"
fi
url="${url}/${target_version}/${artifact_id}-${target_version}${suffix}"
Expand Down Expand Up @@ -1223,7 +1223,7 @@ function doGitPullOrClone() {
doFail "${message}See above error for details - check your network connectivity and retry."
fi
fi
popd > /dev/null || exit 255
popd > /dev/null || exit 255
if [ "${result}" = 0 ]
then
return
Expand All @@ -1238,12 +1238,12 @@ function doGitPullOrClone() {
doFail "Not a git repository: ${dir}"
else
mkdir -p "${dir}"
pushd "${dir}" > /dev/null || exit 255
pushd "${dir}" > /dev/null || exit 255
if doIsQuiet
then
git_opts="-q"
else
doEcho "Cloning git repositroy from ${url}"
doEcho "Cloning git repository from ${url}"
fi
local branch="${url/*#/}"
url="${url%#*}"
Expand All @@ -1252,7 +1252,7 @@ function doGitPullOrClone() {
then
doRunCommand "git checkout ${git_opts} ${branch}"
fi
popd > /dev/null || exit 255
popd > /dev/null || exit 255
fi
fi
}
Expand Down Expand Up @@ -1316,7 +1316,19 @@ function doInstall() {
if [ -z "${version}" ]
then
version=$(doGetLatestSoftwareVersion "${software}")
doDebug "Resolved latest version of ${software} to ${version}"
doDebug "Resolved latest stable version of ${software} to ${version}"
elif [ "${version:${#version}-2}" = "*!" ]
then
doDebug "Resolving version prefix ${version}"
edition=$(doGetSoftwareEdition "${software}")
resolved_version=$(doGetAnyLatestSoftwareVersion "${software}" "${version}")
if [ -n "${resolved_version}" ]
then
doDebug "Resolved version prefix ${version} to ${resolved_version}"
version="${resolved_version}"
else
doFail "Could not resolve version prefix ${version} : no matching version found in ${DEVON_IDE_HOME}/urls/${software}/${edition}/"
fi
elif [ "${version:${#version}-1}" = "*" ]
then
doDebug "Resolving version prefix ${version}"
Expand Down Expand Up @@ -1455,7 +1467,7 @@ function doInstall() {
# doGetFirstExistingPath does not have options
# shellcheck disable=SC2035
contents="$(doGetFirstExistingPath *.app/Contents)"
popd > /dev/null || exit 255
popd > /dev/null || exit 255
fi
if [ -n "${contents}" ] && [ -d "${target_path}/${contents}" ]
then
Expand Down Expand Up @@ -1566,7 +1578,7 @@ function doConfigureWorkspace() {
fi
if [ ${result} = 0 ]
then
doSuccess "Your workspace ${WORKSPACE} has been ${action}"
doSuccess "Your workspace ${WORKSPACE} has been ${action}"
else
doFail "Your workspace ${WORKSPACE} could not be ${action}"
fi
Expand Down Expand Up @@ -1623,6 +1635,20 @@ function doVersionCompare() {
then
local p1="${v1/[^0-9]*/}"
local p2="${v2/[^0-9]*/}"

# java versions may contain "_" indicating probably a build number
# let the major version be x and the build number y then the desired behaviour is x_y < x.0.1
if [ "${p1}" = "${p2}" ]
then
if [[ "${s1}" =~ "_" ]] && ! [[ "${s2}" =~ "_" ]]
then
return 2
fi
if [[ "${s2}" =~ "_" ]] && ! [[ "${s1}" =~ "_" ]]
then
return 1
fi
fi
local n1="${p1}"
local n2="${p2}"
if [ -z "${n1}" ]
Expand Down Expand Up @@ -1795,7 +1821,7 @@ function doBrewInstall() {
function doRequireWsl() {
local error
if ! command -v wsl &> /dev/null
then
then
error="WSL 2 is not installed.\nPlease install WSL 2."
elif wsl -l > /dev/null
then
Expand Down Expand Up @@ -1858,7 +1884,7 @@ function doGetSoftwareEdition() {

# $1: software
# $2: optional prefix
function doGetLatestSoftwareVersion() {
function doGetAnyLatestSoftwareVersion() {
local software="${1}"
local prefix="${2}"
local edition
Expand All @@ -1868,12 +1894,81 @@ function doGetLatestSoftwareVersion() {
then
version="$(find "${DEVON_IDE_HOME}"/urls/"${software}"/"${edition}" -mindepth 1 -maxdepth 1 -print | awk -F'/' '{print $NF}' | sort -rV | head -1)"
else
prefix="${prefix:0:${#prefix}-1}"
prefix="${prefix:0:${#prefix}-2}" # 2 for "*!"
prefix="${prefix/./[.]}"
version="$(find "${DEVON_IDE_HOME}"/urls/"${software}"/"${edition}" -mindepth 1 -maxdepth 1 -print | awk -F'/' '{print $NF}' | grep "^${prefix}" | sort -rV | head -1)"
fi
echo "${version}"
}
}

# $1: software
# $2: optional prefix
function doGetLatestSoftwareVersion() {
local software="${1}"
local prefix="${2}"
local edition
local version
edition=$(doGetSoftwareEdition "${software}")
if [ -z "${prefix}" ]
then
versions=()
while IFS= read -r line; do
versions+=("${line}")
done < <(find "${DEVON_IDE_HOME}"/urls/"${software}"/"${edition}" -mindepth 1 -maxdepth 1 -print | awk -F'/' '{print $NF}' | sort -rV)
else
prefix="${prefix:0:${#prefix}-1}" # 1 for "*"
prefix="${prefix/./[.]}"
versions=()
while IFS= read -r line; do
versions+=("${line}")
done < <(find "${DEVON_IDE_HOME}"/urls/"${software}"/"${edition}" -mindepth 1 -maxdepth 1 -print | awk -F'/' '{print $NF}' | grep "^${prefix}" | sort -rV)
fi

# version is not considered stable (see IDEasy VersionSegment) if:
# VersionSegment.letters starts with "pre"

# or the letters are a development phase and unstable phase. This is the case if:
# 1. development phase:
# - not UNDEFINED, not NONE, not REVISION, not BUILD
# 2. unstable phase, e.i. small ordinal in enum VersionPhase:
# - UNDEFINED, REVISION, SNAPSHOT, NIGHTLY, ALPHA, BETA, BETA_OR_BUILD, BUILD, MILESTONE, RELEASE_CANDIDATE
# keywords for every phase:
# snapshot nightly alpha beta b build milestone rc
# dev nb alph bet m release-candidate
# ci alp test candidate
# a
# unstable

words_with_digits=("snapshot" "dev" "nightly" "nb" "ci" "alpha" "alph" "alp" "a" "unstable" "beta" "bet" "test" "b" "milestone" "m" "rc" "releasecandidate" "candidate")
pattern="^pre.*$"
for word in "${words_with_digits[@]}"; do
pattern+="|^${word}[0-9]*$" # this tries to mimic the behavior of VersionSegment
done
for version in "${versions[@]}"; do
# since we later split the version based on ".", "-", or "_", we need to replace "release-candidate" with "releasecandidate"
version_RC="${version/release-candidate/releasecandidate}"
version_RC="${version/release_candidate/releasecandidate}"
version_RC_lower=$(echo "${version_RC}" | tr '[:upper:]' '[:lower:]')

# Split the version based on ".", "-", or "_"
IFS='._-' read -ra segments <<< "${version_RC_lower}"

# Check if any segment matches unwanted keywords
unwanted_segment=false
for segment in "${segments[@]}"; do
if echo "${segment}" | grep -Eq "${pattern}"; then
unwanted_segment=true
break
fi
done

# If no unwanted segments were found, then we have the version we want, i.e. the latest stable version
if [ "${unwanted_segment}" = false ]; then
echo "${version}"
break
fi
done
}

# $1: software
# $2: selected version
Expand Down Expand Up @@ -1928,7 +2023,7 @@ function doListSoftwareVersions() {
}

# $@: CLI args
# returns 0 if a standard option was detected and handled, 255 otherwise (regular argument to be handeled by CLI parser)
# returns 0 if a standard option was detected and handled, 255 otherwise (regular argument to be handled by CLI parser)
function doParseOption() {
if [ "${1}" = "--" ]
then
Expand Down
5 changes: 5 additions & 0 deletions scripts/src/test/bash/test-version-compare
Original file line number Diff line number Diff line change
Expand Up @@ -59,5 +59,10 @@ doTestVersionCompare 3.0.0-beta17 '>' 3.0.0-beta11-SNAPSHOT
doTestVersionCompare 3.0.0.11 '>' 3.0.0-beta11-SNAPSHOT
doTestVersionCompare 2020.04.001 '>' 3.3.1
doTestVersionCompare "11*" '>' "11u0"
doTestVersionCompare 21.0.1_12 '>' 21_35
doTestVersionCompare 21_35 '<' 21.0.1_12
doTestVersionCompare 21_35 '<' 21
doTestVersionCompare 21_35 '<' 21_36
doTestVersionCompare 21_35 '<' 21_36.2

exit "${exitcode}"

0 comments on commit 9c82f57

Please sign in to comment.