run.sh 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. #!/bin/bash
  2. # Convert version number to comparable numeric value
  3. version_to_number() {
  4. local version="$1"
  5. local IFS='.'
  6. local parts=($version)
  7. # Ensure we have 3 parts
  8. while [ ${#parts[@]} -lt 3 ]; do
  9. parts+=(0)
  10. done
  11. # Extract X,Y,Z
  12. local X=${parts[0]}
  13. local Y=${parts[1]}
  14. local Z=${parts[2]}
  15. # Validate each part is a 1-2 digit number
  16. if ! [[ "$X" =~ ^[0-9]{1,2}$ ]] || ! [[ "$Y" =~ ^[0-9]{1,2}$ ]] || ! [[ "$Z" =~ ^[0-9]{1,2}$ ]]; then
  17. echo "Error: Invalid version format. Expected X.Y.Z where X/Y/Z are 1-2 digit numbers" >&2
  18. return 1
  19. fi
  20. # Format each part as 2-digit numbers and concatenate
  21. local number=$(printf "%02d%02d%02d" "$X" "$Y" "$Z")
  22. # Remove leading zeros to avoid octal interpretation and return the value
  23. echo $((10#$number))
  24. return 0
  25. }
  26. RTT_PATH=$(realpath $(dirname $0)/..)
  27. RTT_DOC_PATH=$RTT_PATH/documentation
  28. rm -rf $RTT_DOC_PATH/html
  29. cd $RTT_DOC_PATH
  30. doxygen_version=$(doxygen --version 2>/dev/null)
  31. if [ -z "$doxygen_version" ]; then
  32. echo "Error: doxygen command not found. Please ensure doxygen is installed." >&2
  33. exit 1
  34. fi
  35. doxygen_version_number=$(version_to_number "$doxygen_version")
  36. if [ $? -ne 0 ]; then
  37. echo "Error: Failed to convert version to number!" >&2
  38. exit 2
  39. fi
  40. if [ $doxygen_version_number -lt 10901 ]; then
  41. echo "Error: Doxygen version must be at least 1.9.1. Current version is $doxygen_version." >&2
  42. exit 1
  43. fi
  44. if [ $doxygen_version_number -eq 10901 ]; then
  45. echo "Info: Doxygen version is 1.9.1" >&2
  46. config_file="Doxyfile.1.9.1"
  47. elif [ $doxygen_version_number -gt 10901 ] && [ $doxygen_version_number -lt 10908 ]; then
  48. echo "Info: Doxygen version is greater than 1.9.1 but less than 1.9.8, Using configuration for 1.9.1." >&2
  49. config_file="Doxyfile.1.9.1"
  50. elif [ $doxygen_version_number -eq 10908 ]; then
  51. echo "Info: Doxygen version is 1.9.8" >&2
  52. config_file="Doxyfile.1.9.8"
  53. elif [ $doxygen_version_number -gt 10908 ]; then
  54. echo "Warning: Doxygen version is greater than 1.9.8. Using configuration for 1.9.8." >&2
  55. config_file="Doxyfile.1.9.8"
  56. fi
  57. if [ ! -f "$config_file" ]; then
  58. echo "Error: Configuration file $config_file does not exist." >&2
  59. exit 3
  60. fi
  61. echo "Running doxygen $doxygen_version with $config_file..."
  62. doxygen "$config_file"
  63. if [ $? -ne 0 ]; then
  64. echo ""
  65. echo "OOPS: Something error/warning occurred during Doxygen building, please check it out!"
  66. echo ""
  67. exit 1
  68. fi
  69. pushd $RTT_DOC_PATH/html
  70. python3 -m http.server