1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00
occt/tests/bugs/modalg_6/bug26393
emv 4f7d41eac3 0029604: Uniform mechanism providing History of shape's modifications for OCCT algorithms in DRAW
Implementation of the mechanism for unification of the history commands for all OCCT algorithms.
The following Draw commands should be used to track the history of shapes modifications of any operation:
- modified - to find the shapes modified from the given shape in the given history.
- generated - to find the shapes generated from the given shape in the given history.
- isdeleted - to check if the given shape has been deleted during operation.

The mechanism allows fast & easy enabling of the DRAW history support for the algorithms supporting the history on the API level (i.e. the algorithm should have the methods Modified(), Generated() and IsDeleted()).
To enable the draw history support it is necessary to store the history of the algorithm into the session. For instance:

TopTools_ListOfShape Objects = ...; // Objects
TopTools_ListOfShape Tools = ...; // Tools

BRepAlgoAPI_Cut aCut(Objects, Tools); // Boolean cut operation

BRepTest_Objects::SetHistory(Objects, aCut); // Store the history for the Objects (overwrites the history in the session)
BRepTest_Objects::AddHistory(Tools, aCut);   // Add the history for the Tools

To get the stored history in draw the command "savehistory" should be used. It saves the history kept in session into a Drawable object with the given name:

# perform cut
bcut r s1 s2

# save history of cut
savehistory cut_history

explode s1 f
modified m cut_history s1_1

The Draw History commands of the following algorithms have been removed:
- Boolean Operations;
- Defeaturing;
- Unify same domain;
- Sweep;
- Thrusections;

All these algorithms have been switched to support the new Draw history mechanism.

The Fillet and Blend algorithms have been also enabled to support history commands.
2018-04-12 13:30:56 +03:00

93 lines
2.6 KiB
Plaintext

puts "========"
puts "OCC26393"
puts "========"
puts ""
#################################################################
# Add draw commands to evaluate history of modifications of BOP
#################################################################
restore [locate_data_file OCC26393-w.brep] w
restore [locate_data_file OCC26393-v1.brep] v0
restore [locate_data_file OCC26393-v2.brep] v1
bclearobjects
bcleartools
baddobjects w
baddtools v0 v1
bfillds
bbuild r
savehistory gf_hist
set bug_info [modified v0m gf_hist v0]
if {$bug_info != "The shape has not been modified."} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work."
}
set bug_info [modified v1m gf_hist v1]
if {$bug_info != "The shape has not been modified."} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work."
}
set bug_info [isdeleted gf_hist v0]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}
set bug_info [isdeleted gf_hist v1]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}
explode w e
set bug_info [modified w1m gf_hist w_1]
if {$bug_info != ""} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work correctly."
}
set bug_info [isdeleted gf_hist w_1]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}
set bug_info [modified w2m gf_hist w_2]
if {$bug_info != "The shape has not been modified."} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work."
}
set bug_info [isdeleted gf_hist w_2]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}
set bug_info [modified w3m gf_hist w_3]
if {$bug_info != "The shape has not been modified."} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work."
}
set bug_info [isdeleted gf_hist w_3]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}
set bug_info [modified w4m gf_hist w_4]
if {$bug_info != ""} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work correctly."
}
set bug_info [isdeleted gf_hist w_4]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}
set bug_info [modified w5m gf_hist w_5]
if {$bug_info != "The shape has not been modified."} {
puts "ERROR: OCC26393 is reproduced. Command modified does not work."
}
set bug_info [isdeleted gf_hist w_5]
if {$bug_info != "Not deleted."} {
puts "ERROR: OCC26393 is reproduced. Command isdeleted does not work."
}