1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

Configuration - TCL OCCT version extraction issue #337

Enhance version detection in OCCDoc_DetectCasVersion
Refactor documentation build workflow and integrate into multiplatform CI
This commit is contained in:
Pasukhin Dmitry 2025-02-03 23:25:29 +01:00 committed by GitHub
parent cc30b93700
commit bfb00b243e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 46 additions and 29 deletions

View File

@ -1,27 +1,14 @@
# This workflow builds the OCCT reference manual and overview documentations.
# It is triggered on pushes to the 'master' branch.
# The workflow includes steps to checkout the repository, install dependencies, build the documentation, and upload the generated documentation and logs as artifacts.
name: Build Documentation name: Build Documentation
description: 'Build OCCT documentation using doxygen'
on: runs:
push: using: composite
branches: steps:
- 'master'
jobs:
build:
name: Build Refman Documentation
runs-on: windows-2022
steps:
- name: Checkout repository
uses: actions/checkout@v4.2.1
- name: Install dependencies - name: Install dependencies
run: | run: |
choco install -y graphviz choco install -y graphviz
choco install -y doxygen.install choco install -y doxygen.install
shell: pwsh
- name: Build refman documentation - name: Build refman documentation
run: | run: |

View File

@ -33,6 +33,17 @@ jobs:
with: with:
base-ref: ${{ github.event.pull_request.base.ref || 'master' }} base-ref: ${{ github.event.pull_request.base.ref || 'master' }}
documentation:
name: Build Documentation
runs-on: windows-2022
steps:
- name: Checkout repository
uses: actions/checkout@v4.2.1
- name: Build documentation
uses: ./.github/actions/build-docs
prepare-and-build-windows-x64: prepare-and-build-windows-x64:
name: Prepare and Build on Windows with MSVC (x64) name: Prepare and Build on Windows with MSVC (x64)
runs-on: windows-2022 runs-on: windows-2022

View File

@ -144,20 +144,39 @@ proc OCCDoc_GetRelPath {thePathFrom thePathTo} {
# Returns OCCT version string from version.cmake (if available) # Returns OCCT version string from version.cmake (if available)
proc OCCDoc_DetectCasVersion {} { proc OCCDoc_DetectCasVersion {} {
# Default version in case the file is not found or readable
set occt_ver "7.8.0" set occt_ver "7.8.0"
set occt_ver_add "" set occt_ver_add ""
set filename "[OCCDoc_GetSourceDir]/../adm/cmake/version.cmake"
if { [file exists $filename] } { # Construct path to version.cmake relative to script location
set fh [open $filename "r"] set filename "[file normalize [file dirname [info script]]/cmake/version.cmake]"
set fh_loaded [read $fh]
close $fh if { [file exists $filename] && [file readable $filename] } {
regexp {set\s+OCC_VERSION_MAJOR\s+([0-9]+)} $fh_loaded dummy major if {[catch {
regexp {set\s+OCC_VERSION_MINOR\s+([0-9]+)} $fh_loaded dummy minor set fh [open $filename "r"]
regexp {set\s+OCC_VERSION_MAINTENANCE\s+([0-9]+)} $fh_loaded dummy maint set fh_loaded [read $fh]
regexp {set\s+OCC_VERSION_DEVELOPMENT\s+\"([^\"]+)\"} $fh_loaded dummy occt_ver_add close $fh
set occt_ver "$major.$minor.$maint"
if { "$occt_ver_add" != "" } { set occt_ver ${occt_ver}.$occt_ver_add } # Use more robust regular expressions
regexp {OCC_VERSION_MAJOR\s+(\d+)} $fh_loaded -> major
regexp {OCC_VERSION_MINOR\s+(\d+)} $fh_loaded -> minor
regexp {OCC_VERSION_MAINTENANCE\s+(\d+)} $fh_loaded -> maint
regexp {OCC_VERSION_DEVELOPMENT\s+\"([^\"]+)\"} $fh_loaded -> occt_ver_add
if {[info exists major] && [info exists minor] && [info exists maint]} {
puts "Info: Open CASCADE Technology version $major.$minor.$maint"
set occt_ver "$major.$minor.$maint"
if { [info exists occt_ver_add] && $occt_ver_add != "" } {
set occt_ver ${occt_ver}.$occt_ver_add
}
}
} err]} {
puts "Warning: Error reading version from $filename: $err"
}
} else {
puts "Warning: Version file $filename not found or not readable"
} }
return $occt_ver return $occt_ver
} }