mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0026846: Configuration, genproj.tcl - create hardlinks instead for header redirection
Build guides updated accordingly Update genconf screenshot for Linux
This commit is contained in:
parent
5950d7816e
commit
5951a08873
@ -371,8 +371,8 @@ entry .myFrame.myVcVarsEntry -textvariable VCVARS -width 70
|
|||||||
ttk::button .myFrame.myVcBrowseBtn -text "Browse" -command wokdep:gui:BrowseVcVars
|
ttk::button .myFrame.myVcBrowseBtn -text "Browse" -command wokdep:gui:BrowseVcVars
|
||||||
|
|
||||||
#
|
#
|
||||||
checkbutton .myFrame.myHxxChecks.myScutsCheck -offvalue "false" -onvalue "true" -variable SHORTCUT_HEADERS
|
ttk::combobox .myFrame.myHxxChecks.myScutsCombo -values { {ShortCut} {Copy} {HardLink} } -textvariable SHORTCUT_HEADERS -state readonly -width 12
|
||||||
ttk::label .myFrame.myHxxChecks.myScutsLbl -text "Create short-cuts to headers in inc folder instead of copying"
|
ttk::label .myFrame.myHxxChecks.myScutsLbl -text "Strategy for filling headers folder inc:"
|
||||||
|
|
||||||
#
|
#
|
||||||
ttk::label .myFrame.mySrchLbl -text "3rd-parties search path:" -padding {5 5 80 5}
|
ttk::label .myFrame.mySrchLbl -text "3rd-parties search path:" -padding {5 5 80 5}
|
||||||
@ -465,8 +465,8 @@ if { "$tcl_platform(platform)" == "windows" } {
|
|||||||
|
|
||||||
#
|
#
|
||||||
grid .myFrame.myHxxChecks -row $aRowIter -column 0 -columnspan 10 -sticky w
|
grid .myFrame.myHxxChecks -row $aRowIter -column 0 -columnspan 10 -sticky w
|
||||||
grid .myFrame.myHxxChecks.myScutsCheck -row 0 -column 0
|
grid .myFrame.myHxxChecks.myScutsLbl -row 0 -column 0
|
||||||
grid .myFrame.myHxxChecks.myScutsLbl -row 0 -column 1
|
grid .myFrame.myHxxChecks.myScutsCombo -row 0 -column 1
|
||||||
incr aRowIter
|
incr aRowIter
|
||||||
#
|
#
|
||||||
grid .myFrame.mySrchLbl -row $aRowIter -column 0 -columnspan 10 -sticky w
|
grid .myFrame.mySrchLbl -row $aRowIter -column 0 -columnspan 10 -sticky w
|
||||||
|
@ -41,7 +41,7 @@ if { "$tcl_platform(platform)" == "unix" } {
|
|||||||
set VCVARS ""
|
set VCVARS ""
|
||||||
}
|
}
|
||||||
|
|
||||||
set SHORTCUT_HEADERS "true"
|
set SHORTCUT_HEADERS "ShortCut"
|
||||||
|
|
||||||
set HAVE_FREEIMAGE "false"
|
set HAVE_FREEIMAGE "false"
|
||||||
set HAVE_GL2PS "false"
|
set HAVE_GL2PS "false"
|
||||||
@ -72,6 +72,9 @@ if { [info exists ::env(VCVARS)] } {
|
|||||||
}
|
}
|
||||||
if { [info exists ::env(SHORTCUT_HEADERS)] } {
|
if { [info exists ::env(SHORTCUT_HEADERS)] } {
|
||||||
set SHORTCUT_HEADERS "$::env(SHORTCUT_HEADERS)"
|
set SHORTCUT_HEADERS "$::env(SHORTCUT_HEADERS)"
|
||||||
|
if { $SHORTCUT_HEADERS == "true" } {
|
||||||
|
set SHORTCUT_HEADERS "ShortCut"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if { [info exists ::env(HAVE_FREEIMAGE)] } {
|
if { [info exists ::env(HAVE_FREEIMAGE)] } {
|
||||||
set HAVE_FREEIMAGE "$::env(HAVE_FREEIMAGE)"
|
set HAVE_FREEIMAGE "$::env(HAVE_FREEIMAGE)"
|
||||||
|
@ -639,16 +639,27 @@ proc osutils:collectinc {theModules theIncPath} {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
lsort -unique $anUsedToolKits
|
set anUsedToolKits [lsort -unique $anUsedToolKits]
|
||||||
|
|
||||||
set anUnits {}
|
set anUnits {}
|
||||||
foreach anUsedToolKit $anUsedToolKits {
|
foreach anUsedToolKit $anUsedToolKits {
|
||||||
set anUnits [concat $anUnits [osutils:tk:units $anUsedToolKit]]
|
set anUnits [concat $anUnits [osutils:tk:units $anUsedToolKit]]
|
||||||
}
|
}
|
||||||
lsort -unique $anUnits
|
set anUnits [lsort -unique $anUnits]
|
||||||
|
|
||||||
if { [info exists ::env(SHORTCUT_HEADERS)] &&
|
# define copying style
|
||||||
$::env(SHORTCUT_HEADERS) == "true" } {
|
set aCopyType "copy"
|
||||||
|
if { [info exists ::env(SHORTCUT_HEADERS)] } {
|
||||||
|
if { [string equal -nocase $::env(SHORTCUT_HEADERS) "hard"]
|
||||||
|
|| [string equal -nocase $::env(SHORTCUT_HEADERS) "hardlink"] } {
|
||||||
|
set aCopyType "hardlink"
|
||||||
|
} elseif { [string equal -nocase $::env(SHORTCUT_HEADERS) "true"]
|
||||||
|
|| [string equal -nocase $::env(SHORTCUT_HEADERS) "shortcut"] } {
|
||||||
|
set aCopyType "shortcut"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if { $aCopyType == "shortcut" } {
|
||||||
# template preparation
|
# template preparation
|
||||||
if { ![file exists $::THE_CASROOT/adm/templates/header.in] } {
|
if { ![file exists $::THE_CASROOT/adm/templates/header.in] } {
|
||||||
puts "template file does not exist: $::THE_CASROOT/adm/templates/header.in"
|
puts "template file does not exist: $::THE_CASROOT/adm/templates/header.in"
|
||||||
@ -683,6 +694,7 @@ proc osutils:collectinc {theModules theIncPath} {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
file delete -force "$theIncPath/$aHeaderFileName"
|
||||||
}
|
}
|
||||||
|
|
||||||
set aShortCutHeaderFile [open "$theIncPath/$aHeaderFileName" "w"]
|
set aShortCutHeaderFile [open "$theIncPath/$aHeaderFileName" "w"]
|
||||||
@ -700,14 +712,20 @@ proc osutils:collectinc {theModules theIncPath} {
|
|||||||
|
|
||||||
# copy file only if target does not exist or is older than original
|
# copy file only if target does not exist or is older than original
|
||||||
set torig [file mtime $aHeaderFile]
|
set torig [file mtime $aHeaderFile]
|
||||||
if { ! [file isfile $anIncPath/$aHeaderFileName] } {
|
set tcopy 0
|
||||||
set tcopy 0
|
if { [file isfile $anIncPath/$aHeaderFileName] } {
|
||||||
} else {
|
|
||||||
set tcopy [file mtime $anIncPath/$aHeaderFileName]
|
set tcopy [file mtime $anIncPath/$aHeaderFileName]
|
||||||
}
|
}
|
||||||
if { $tcopy < $torig } {
|
if { $tcopy < $torig } {
|
||||||
incr nbcopied
|
incr nbcopied
|
||||||
file copy -force $aHeaderFile $anIncPath/$aHeaderFileName
|
if { $aCopyType == "hardlink" } {
|
||||||
|
if { $tcopy != 0 } {
|
||||||
|
file delete -force "$theIncPath/$aHeaderFileName"
|
||||||
|
}
|
||||||
|
file link -hard $anIncPath/$aHeaderFileName $aHeaderFile
|
||||||
|
} else {
|
||||||
|
file copy -force $aHeaderFile $anIncPath/$aHeaderFileName
|
||||||
|
}
|
||||||
} elseif { $tcopy != $torig } {
|
} elseif { $tcopy != $torig } {
|
||||||
puts "Warning: file $anIncPath/$aHeaderFileName is newer than $aHeaderFile, not changed!"
|
puts "Warning: file $anIncPath/$aHeaderFileName is newer than $aHeaderFile, not changed!"
|
||||||
}
|
}
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 157 KiB After Width: | Height: | Size: 42 KiB |
Binary file not shown.
Before Width: | Height: | Size: 48 KiB After Width: | Height: | Size: 60 KiB |
@ -20,7 +20,10 @@ The environment is defined in the file *custom.sh* (on Linux and OS X) or *custo
|
|||||||
|
|
||||||
* Add paths to includes of used third-party libraries in variable *CSF_OPT_INC*.
|
* Add paths to includes of used third-party libraries in variable *CSF_OPT_INC*.
|
||||||
* Add paths to their binary libraries in variable *CSF_OPT_LIB64*.
|
* Add paths to their binary libraries in variable *CSF_OPT_LIB64*.
|
||||||
* Set variable *SHORTCUT_HEADERS* to "true" to have folder *inc* populated by short-cut files pointing to actual headers located in *src*; otherwise, header files will be copied to *inc*.
|
* Set variable *SHORTCUT_HEADERS* to specify a method for population of folder *inc* by header files. Supported methods are:
|
||||||
|
* *Copy* - headers will be copied from *src*;
|
||||||
|
* *ShortCut* - short-cut header files will be created, redirecting to same-named header located in *src*;
|
||||||
|
* "HardLink* - hard links to headers located in *src* will be created.
|
||||||
* For optional third-party libraries, set corresponding environment variable <i>HAVE_<LIBRARY_NAME></i> to either *false*, e.g.:
|
* For optional third-party libraries, set corresponding environment variable <i>HAVE_<LIBRARY_NAME></i> to either *false*, e.g.:
|
||||||
~~~~~
|
~~~~~
|
||||||
export HAVE_GL2PS=false
|
export HAVE_GL2PS=false
|
||||||
|
@ -30,13 +30,16 @@ If you have Visual Studio projects already available (pre-installed or generated
|
|||||||
* *ARCH* -- architecture (32 or 64), affects only *PATH* variable for execution
|
* *ARCH* -- architecture (32 or 64), affects only *PATH* variable for execution
|
||||||
* <i>HAVE_*</i> -- flags to enable or disable use of optional third-party products
|
* <i>HAVE_*</i> -- flags to enable or disable use of optional third-party products
|
||||||
* <i>CSF_OPT_*</i> -- paths to search for includes and binaries of all used third-party products
|
* <i>CSF_OPT_*</i> -- paths to search for includes and binaries of all used third-party products
|
||||||
* *SHORTCUT_HEADERS* -- if set to "true", folder *inc* will be populated by short-cut files pointing to actual headers located in *src*; otherwise, header files will be copied to *inc*.
|
* *SHORTCUT_HEADERS* -- defines method for population of folder *inc* by header files. Supported methods are:
|
||||||
|
* *Copy* - headers will be copied from *src*;
|
||||||
|
* *ShortCut* - short-cut header files will be created, redirecting to same-named header located in *src*;
|
||||||
|
* "HardLink* - hard links to headers located in *src* will be created.
|
||||||
|
|
||||||
Alternatively, you can launch **genconf**, a GUI tool allowing to configure build options interactively.
|
Alternatively, you can launch **genconf**, a GUI tool allowing to configure build options interactively.
|
||||||
That tool will analyze your environment and propose you to choose available options:
|
That tool will analyze your environment and propose you to choose available options:
|
||||||
|
|
||||||
* Version of Visual Studio to be used (from the list of installed ones, detected by presence of environment variables like *VS100COMNTOOLS*)
|
* Version of Visual Studio to be used (from the list of installed ones, detected by presence of environment variables like *VS100COMNTOOLS*)
|
||||||
* Option to use short-cuts to header files in folder *inc* (enabled by default).
|
* Method to populate folder *inc* (short-cuts by default).
|
||||||
* Location of third-party libraries (usually downloaded from OCCT web site, see above).
|
* Location of third-party libraries (usually downloaded from OCCT web site, see above).
|
||||||
* Path to common directory where third-party libraries are located (optional)
|
* Path to common directory where third-party libraries are located (optional)
|
||||||
* Paths to headers and binaries of the third-party libraries (found automatically basing on previous options; click button "Reset" to update).
|
* Paths to headers and binaries of the third-party libraries (found automatically basing on previous options; click button "Reset" to update).
|
||||||
|
@ -21,7 +21,10 @@ The environment is defined in the file *custom.sh* which can be edited directly:
|
|||||||
|
|
||||||
* Add paths to includes of used third-party libraries in variable *CSF_OPT_INC* (use colon ":" as path separator).
|
* Add paths to includes of used third-party libraries in variable *CSF_OPT_INC* (use colon ":" as path separator).
|
||||||
* Add paths to their binary libraries in variable *CSF_OPT_LIB64*.
|
* Add paths to their binary libraries in variable *CSF_OPT_LIB64*.
|
||||||
* Set variable *SHORTCUT_HEADERS* to "true" to have folder *inc* populated by short-cut files pointing to actual headers located in *src*; otherwise, header files will be copied to *inc*.
|
* Set variable *SHORTCUT_HEADERS* to specify a method for population of folder *inc* by header files. Supported methods are:
|
||||||
|
* *Copy* - headers will be copied from *src*;
|
||||||
|
* *ShortCut* - short-cut header files will be created, redirecting to same-named header located in *src*;
|
||||||
|
* "HardLink* - hard links to headers located in *src* will be created.
|
||||||
* For optional third-party libraries, set corresponding environment variable <i>HAVE_<LIBRARY_NAME></i> to either *false*, e.g.:
|
* For optional third-party libraries, set corresponding environment variable <i>HAVE_<LIBRARY_NAME></i> to either *false*, e.g.:
|
||||||
~~~~~
|
~~~~~
|
||||||
export HAVE_GL2PS=false
|
export HAVE_GL2PS=false
|
||||||
|
Loading…
x
Reference in New Issue
Block a user