]> www.infradead.org Git - users/sagi/nvme-cli.git/commitdiff
build: Update libnvme version dependency on release
authorDaniel Wagner <dwagner@suse.de>
Fri, 27 Jan 2023 13:18:38 +0000 (14:18 +0100)
committerDaniel Wagner <dwagner@suse.de>
Fri, 27 Jan 2023 13:18:38 +0000 (14:18 +0100)
The release script should also update the dependency on libnvme. Use the
libnvme.wrap information as base.

Signed-off-by: Daniel Wagner <dwagner@suse.de>
release.sh

index 320da46a348753a9d2763edbef9c87b5e6a7db8f..b4ae81c9c648a215128177e126e0823580d8c6af 100755 (executable)
@@ -6,6 +6,7 @@ usage() {
     echo "The script does all necessary steps to create a new release."
     echo ""
     echo " -d:  no documentation update"
+    echo " -n:  dry run"
     echo ""
     echo "Note: The version number needs to be exactly"
     echo "      '^v[\d]+.[\d]+(.[\d\]+(-rc[0-9]+)?$'"
@@ -16,12 +17,16 @@ usage() {
 }
 
 build_doc=true
+dry_run=false
 
-while getopts "d" o; do
+while getopts "dn" o; do
     case "${o}" in
         d)
             build_doc=false
             ;;
+        n)
+            dry_run=true
+            ;;
         *)
             usage
             ;;
@@ -36,23 +41,41 @@ if [ -z "$VERSION" ] ; then
     exit 1
 fi
 
-ver=""
-
+# expected version regex
 re='^v([0-9]+\.[0-9]+(\.[0-9]+)?)(-rc[0-9]+)?$'
-if [[ "$VERSION" =~ $re ]]; then
-    echo "Valid version $VERSION string"
+
+# use the version string provided from the command line for nvme-cli
+if [[ "$VERSION" =~ ${re} ]]; then
+    echo "nvme-cli: valid version $VERSION string"
+
     # remove the leading 'v'
-    ver=${VERSION#v}
+    ver="${VERSION#v}"
 else
-    echo "Invalid version string $VERSION"
+    echo "nvme-cli: invalid version string ${VERSION}"
     exit 1
 fi
 
-if [[ -n $(git status -s) ]]; then
-    echo "tree is dirty. abort."
+# extract the vesion string from libnvme by using the ref
+# defined in libnvme.wrap.
+libnvme_ref=$(sed -n "s/revision = \([0-9a-z]\+\)/\1/p" subprojects/libnvme.wrap)
+libnvme_VERSION=$(git -C subprojects/libnvme describe "${libnvme_ref}")
+if [[ "${libnvme_VERSION}" =~ ${re} ]]; then
+    echo "libnvme: valid version ${libnvme_VERSION} string"
+
+    # remove the leading 'v'
+    libnvme_ver="${libnvme_VERSION#v}"
+else
+    echo "libnvme: invalid version string ${libnvme_VERSION}"
     exit 1
 fi
 
+if [[ -n $(git status -s) ]]; then
+    echo "tree is dirty."
+    if [[ "${dry_run}" = false ]]; then
+        exit 1
+    fi
+fi
+
 if [ "$(git rev-parse --abbrev-ref HEAD)" != "master" ] ; then
     echo "currently not on master branch. abort."
     exit 1
@@ -71,14 +94,23 @@ fi
 
 # update meson.build
 sed -i -e "0,/[ \t]version: /s/\([ \t]version: \).*/\1\'$ver\',/" meson.build
-git add meson.build
-git commit -s -m "build: Update version to $VERSION"
+sed -i -e "s/\(dependency('libnvme', version: '>=\)\([\.1-9]\+\)/\1$libnvme_ver/" meson.build
+if [[ "${dry_run}" = false ]]; then
+    git add meson.build
+    git commit -s -m "build: Update version to $VERSION"
+fi
 
 if [ "$build_doc" = true ]; then
     # update documentation
     ./$doc_dir/update-docs.sh
-    git add $doc_dir
-    git commit -s -m "doc: Regenerate all docs for $VERSION"
+    if [[ "${dry_run}" = false ]]; then
+        git add $doc_dir
+        git commit -s -m "doc: Regenerate all docs for $VERSION"
+    fi
+fi
+
+if [[ "${dry_run}" = true ]]; then
+    exit 0
 fi
 
 git tag -s -m "Release $VERSION" "$VERSION"