mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-19 18:40:01 +02:00

- removed getClientServerAPIVersion in server (not used) - removed rxr side (clientversion compatibility check), removed enum as well as it is now done on the client side. - versionAPI.h - GITBRANCH changed to RELEASE - dates for all API changed to "sem_version date". Scripts to compile servers modified for this. Empty "branch" name will end up with developer for sem_version. - Version class with constructor taking in the long version (APILIB date). Other member functions including concise(to get sem_version for new releases and date for old releases), - bypassing initial tests, also now bypasses the client-rxr compatibility check (at rx_hostname command) - previously, compatibility between client-det was ensuring both had the same detector API (eg. same APIJUNGFRAU) - Now, compatibility only checks APILIB (client side) and detector API(eg. APIJUNGFRAU) (detector side) have same major version. It only does backward compatibility test. Rest is upto user to ensure. - If server is from an older release, it will compare dates like previous implementation (APIJUNGFRAU from both client and det) - - previously, compatibility between client-rxr was ensuring both had the same APIRECEIVER - Now, compatibility only checks APILIB (client side) and APIRECEIVER (rxr side) have same major version. It only does backward compatibility test. Rest is upto user to ensure. - If rxr is from an older release, it will compare dates like previous implementation (APIRECEIVER from both client and rxr) - removed APIGUI, evalVersionVariables.sh, genVersionHeader.sh (not needed or not used) - clientVersion, rxrversion and detectorserverversion all return strings and not integers (in hex) anymore. Depending if it has semantic versioning, it will print that or the date if it is too old. - fixed in python (strings for versions) - check_version function in detector server changed to "initial checks" as it only checks server-firmware compatibility and initial server checks. Client compatibilities are moved to client side. - --version gives sem_version and date? Is date needed as well. The clientversion, detserverversion and rxrversion API gives only sem_version (no date) - - formatting
60 lines
1.4 KiB
Bash
Executable File
60 lines
1.4 KiB
Bash
Executable File
# SPDX-License-Identifier: LGPL-3.0-or-other
|
|
# Copyright (C) 2021 Contributors to the SLS Detector Package
|
|
branch=""
|
|
client_list=("slsDetectorSoftware" "slsReceiverSoftware")
|
|
usage="\nUsage: updateClientAPI.sh [all|slsDetectorSoftware|slsReceiverSoftware] [branch]. \n\tNo arguments means all with 'developer' branch. \n\tNo 'branch' input means 'developer branch'"
|
|
|
|
# arguments
|
|
if [ $# -eq 0 ]; then
|
|
declare -a client=${client_list[@]}
|
|
echo "API Versioning all"
|
|
elif [ $# -eq 1 ] || [ $# -eq 2 ]; then
|
|
# 'all' client
|
|
if [[ $1 == "all" ]]; then
|
|
declare -a client=${client_list[@]}
|
|
echo "API Versioning all"
|
|
else
|
|
# only one server
|
|
if [[ $client_list != *$1* ]]; then
|
|
echo -e "Invalid argument 1: $1. $usage"
|
|
return -1
|
|
fi
|
|
declare -a client=("${1}")
|
|
#echo "Versioning only $1"
|
|
fi
|
|
if [ $# -eq 2 ]; then
|
|
if [[ $client_list == *$2* ]]; then
|
|
echo -e "Invalid argument 2: $2. $usage"
|
|
return -1
|
|
fi
|
|
branch+=$2
|
|
#echo "with branch $branch"
|
|
fi
|
|
else
|
|
echo -e "Too many arguments.$usage"
|
|
return -1
|
|
fi
|
|
|
|
#echo "list is: ${client[@]}"
|
|
|
|
# versioning each client
|
|
for i in ${client[@]}
|
|
do
|
|
dir=$i
|
|
case $dir in
|
|
slsDetectorSoftware)
|
|
declare -a name=APILIB
|
|
;;
|
|
slsReceiverSoftware)
|
|
declare -a name=APIRECEIVER
|
|
;;
|
|
*)
|
|
echo -n "unknown client argument $i"
|
|
return -1
|
|
;;
|
|
esac
|
|
echo -e "Versioning $dir [$name]"
|
|
./updateAPIVersion.sh $name $dir $branch
|
|
done
|
|
|