From 536832dcac156a88c2162de056786d9ec2241953 Mon Sep 17 00:00:00 2001 From: Benoit Marty Date: Thu, 23 Jan 2025 11:10:53 +0100 Subject: [PATCH 1/2] Migrate to CalVer-like versioning --- plugins/src/main/kotlin/Versions.kt | 45 +++++++++-------------------- 1 file changed, 13 insertions(+), 32 deletions(-) diff --git a/plugins/src/main/kotlin/Versions.kt b/plugins/src/main/kotlin/Versions.kt index 058ba2f606..a9902cd3ac 100644 --- a/plugins/src/main/kotlin/Versions.kt +++ b/plugins/src/main/kotlin/Versions.kt @@ -9,49 +9,30 @@ import org.gradle.api.JavaVersion import org.gradle.jvm.toolchain.JavaLanguageVersion /** - * Version codes are quite sensitive, because there is a mix between bundle and APKs, and we have to take into - * account the future upgrade of Element Android. + * Version codes are quite sensitive, because there is a mix between bundle and APKs. * Max versionCode allowed by the PlayStore (for information): * 2_100_000_000 - * Current version code of EAx on the PlayStore, for the first uploaded beta (we cannot go below): - * ----1_001_000 - * Current version code of EAx on the nightly: - * ----1_001_000 - * Current version of Element Android (at some point EAx will replace this app) (v1.6.3) - * ----40_106_03a where a stands for the architecture: 1, 2, 3, 4 and 0 for the universal APK - * Current version of EAx distributed with Firebase app distribution: - * ----1_002_000 - * Latest version of EAx distributed with Firebase app distribution (downgrading, so that's a problem) - * -------10_200 - * Version when running the current debug build - * -------10_200 * - * So adding 4_000_000 to the current version Code computed here should be fine, and since the versionCode - * is multiplied by 10 in app/build.gradle.kts#L168: + * Also note that the versionCode is multiplied by 10 in app/build.gradle.kts#L168: * ``` * output.versionCode.set((output.versionCode.get() ?: 0) * 10 + abiCode)) * ``` - * we will have: - * Release version: - * ---40_001_020 - * Nightly version: - * ---40_001_020 - * Debug version: - * ---40_010_200 + * We are using a CalVer-like approach to version the application. The version code is calculated as follows: + * - 4 digits for the year + * - 2 digits for the month + * - 2 digits for the release number + * So for instance, the first release of Jan 2025 will have the version code: 20250100 (20_250_100) */ -// Note: 2 digits max for each value -private const val versionMajor = 0 -private const val versionMinor = 7 +private const val versionYear = 2025 +private const val versionMonth = 1 -// Note: even values are reserved for regular release, odd values for hotfix release. -// When creating a hotfix, you should decrease the value, since the current value -// is the value for the next regular release. -private const val versionPatch = 7 +// Note: must be in [0,99] +private const val versionReleaseNumber = 0 object Versions { - const val VERSION_CODE = 4_000_000 + versionMajor * 1_00_00 + versionMinor * 1_00 + versionPatch - const val VERSION_NAME = "$versionMajor.$versionMinor.$versionPatch" + const val VERSION_CODE = versionYear * 10_000 + versionMonth * 100 + versionReleaseNumber + const val VERSION_NAME = "$versionYear.$versionMonth.$versionReleaseNumber" const val COMPILE_SDK = 35 const val TARGET_SDK = 35 From 90af82562163a2a12d45e340c3a7fb361d750aa3 Mon Sep 17 00:00:00 2001 From: Benoit Marty Date: Thu, 23 Jan 2025 11:30:27 +0100 Subject: [PATCH 2/2] Migrate to CalVer-like versioning - update release script. --- tools/release/release.sh | 49 ++++++++++++++++------------------------ 1 file changed, 20 insertions(+), 29 deletions(-) diff --git a/tools/release/release.sh b/tools/release/release.sh index 9b3bfcf3cb..1bd8dd6053 100755 --- a/tools/release/release.sh +++ b/tools/release/release.sh @@ -94,19 +94,25 @@ git pull printf "\n================================================================================\n" # Guessing version to propose a default version versionsFile="./plugins/src/main/kotlin/Versions.kt" -versionMajorCandidate=$(grep "val versionMajor" ${versionsFile} | cut -d " " -f6) -versionMinorCandidate=$(grep "val versionMinor" ${versionsFile} | cut -d " " -f6) -versionPatchCandidate=$(grep "val versionPatch" ${versionsFile} | cut -d " " -f6) -versionCandidate="${versionMajorCandidate}.${versionMinorCandidate}.${versionPatchCandidate}" +versionYearCandidate=$(date +%Y) +currentVersionMonth=$(grep "val versionMonth" ${versionsFile} | cut -d " " -f6) +versionMonthCandidate=$(date +%-m) +currentVersionReleaseNumber=$(grep "val versionReleaseNumber" ${versionsFile} | cut -d " " -f6) +# if the current month is the same as the current version, we increment the release number, else we reset it to 0 +if [[ ${currentVersionMonth} -eq ${versionMonthCandidate} ]]; then + versionReleaseNumberCandidate=$((currentVersionReleaseNumber + 1)) +else + versionReleaseNumberCandidate=0 +fi +versionCandidate="${versionYearCandidate}.${versionMonthCandidate}.${versionReleaseNumberCandidate}" read -p "Please enter the release version (example: ${versionCandidate}). Just press enter if ${versionCandidate} is correct. " version version=${version:-${versionCandidate}} # extract major, minor and patch for future use -versionMajor=$(echo "${version}" | cut -d "." -f1) -versionMinor=$(echo "${version}" | cut -d "." -f2) -versionPatch=$(echo "${version}" | cut -d "." -f3) -nextPatchVersion=$((versionPatch + 1)) +versionYear=$(echo "${version}" | cut -d "." -f1) +versionMonth=$(echo "${version}" | cut -d "." -f2) +versionReleaseNumber=$(echo "${version}" | cut -d "." -f3) printf "\n================================================================================\n" printf "Starting the release ${version}\n" @@ -122,20 +128,18 @@ fi # Ensure version is OK versionsFileBak="${versionsFile}.bak" cp ${versionsFile} ${versionsFileBak} -sed "s/private const val versionMajor = .*/private const val versionMajor = ${versionMajor}/" ${versionsFileBak} > ${versionsFile} -sed "s/private const val versionMinor = .*/private const val versionMinor = ${versionMinor}/" ${versionsFile} > ${versionsFileBak} -sed "s/private const val versionPatch = .*/private const val versionPatch = ${versionPatch}/" ${versionsFileBak} > ${versionsFile} +sed "s/private const val versionYear = .*/private const val versionYear = ${versionYear}/" ${versionsFileBak} > ${versionsFile} +sed "s/private const val versionMonth = .*/private const val versionMonth = ${versionMonth}/" ${versionsFile} > ${versionsFileBak} +sed "s/private const val versionReleaseNumber = .*/private const val versionReleaseNumber = ${versionReleaseNumber}/" ${versionsFileBak} > ${versionsFile} rm ${versionsFileBak} -# This commit may have no effect because generally we do not change the version during the release. git commit -a -m "Setting version for the release ${version}" printf "\n================================================================================\n" printf "Creating fastlane file...\n" -printf -v versionMajor2Digits "%02d" "${versionMajor}" -printf -v versionMinor2Digits "%02d" "${versionMinor}" -printf -v versionPatch2Digits "%02d" "${versionPatch}" -fastlaneFile="4${versionMajor2Digits}${versionMinor2Digits}${versionPatch2Digits}0.txt" +printf -v versionMonth2Digits "%02d" "${versionMonth}" +printf -v versionReleaseNumber2Digits "%02d" "${versionReleaseNumber}" +fastlaneFile="${versionYear}${versionMonth2Digits}${versionReleaseNumber2Digits}0.txt" fastlanePathFile="./fastlane/metadata/android/en-US/changelogs/${fastlaneFile}" printf "Main changes in this version: TODO.\nFull changelog: https://github.com/element-hq/element-x-android/releases" > "${fastlanePathFile}" @@ -163,19 +167,6 @@ printf "\n====================================================================== printf "Checking out develop...\n" git checkout develop -# Set next version -printf "\n================================================================================\n" -printf "Setting next version on file '${versionsFile}'...\n" -cp ${versionsFile} ${versionsFileBak} -sed "s/private const val versionPatch = .*/private const val versionPatch = ${nextPatchVersion}/" ${versionsFileBak} > ${versionsFile} -rm ${versionsFileBak} - -printf "\n================================================================================\n" -read -p "I have updated the versions to prepare the next release, please check that the change are correct and press enter so I can commit. " - -printf "Committing...\n" -git commit -a -m 'version++' - printf "\n================================================================================\n" printf "The GitHub action https://github.com/element-hq/element-x-android/actions/workflows/release.yml?query=branch%%3Amain should have start a new run.\n" read -p "Please enter the url of the run, no need to wait for it to complete (example: https://github.com/element-hq/element-x-android/actions/runs/9065756777): " runUrl