mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
Progress indication mechanism is refactored to support incrementing progress within multithreaded algorithms. The class Message_ProgressIndicator is only an interface to the user application. It accumulates the progress provided by progress scopes. The counter is protected by mutex for thread-safety. The new class Message_ProgressScope replacing Message_ProgressSentry should be used to advance the progress. The scopes are nested to each other to reflect the nested nature of operations. The new class Message_ProgressRange should be used to pass the progress to sub-scopes. All OCCT algorithms involving progress indication have been updated to new API. Improvements in Draw_ProgressIndicator: - Separate console mode has been added in order to make possible to put the progress into std::cout instead or in addition to the draw interpreter, instead of trigger option "-tclOutput". - Treatment of Ctrl-Break signal has been added. Now any operation can be aborted by Ctrl-C or Ctrl-Break keystroke. Added new test case 'perf fclasses progr_par' for testing of parallel work of the progress.
38 lines
946 B
Plaintext
38 lines
946 B
Plaintext
puts "============"
|
|
puts "OCC22747"
|
|
puts "============"
|
|
puts ""
|
|
###########################################################################
|
|
# Progress indicator in sewing algorithm
|
|
###########################################################################
|
|
|
|
set BugNumber OCC22747
|
|
|
|
pload XSDRAW
|
|
|
|
restore [locate_data_file OCC22765.brep] a
|
|
vinit
|
|
XProgress -t
|
|
set List1 [sewing result 0.1 a]
|
|
if { [string compare $List1 ""] != 0 } {
|
|
puts "Error: XProgress should not have any DRAW output in this mode"
|
|
} else {
|
|
puts "Mode -t works properly"
|
|
}
|
|
|
|
puts "----------------------"
|
|
XProgress +t
|
|
set List2 [sewing result 0.1 a]
|
|
if { [regexp "Progress:" $List2] != 1 } {
|
|
puts "Error: XProgress should have output in this mode"
|
|
} else {
|
|
puts "Mode +t works properly"
|
|
}
|
|
|
|
checkmaxtol result -ref 1.0000280013370991e-005
|
|
checknbshapes result -shell 1
|
|
checkfreebounds result 456
|
|
|
|
checkview -display result -2d -path ${imagedir}/${test_image}.png
|
|
|