mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0023348: Expression 'ii >= 0' is always true. Unsigned type value is always >= 0.
Redesigned the loop to work correctly with unsigned variables. Treatment of path to source file is rewritten using OSD_Path for more clarity Command getsourcefile corrected to return its result as Tcl string, and simplified Error in treatment of optional arguments in substituted puts is fixed in src/DrawResources/TestCommands.tcl Test case added: demo draw getsource
This commit is contained in:
parent
3b4c36f540
commit
d33dea30d5
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
#include <TCollection_AsciiString.hxx>
|
#include <TCollection_AsciiString.hxx>
|
||||||
#include <TCollection_ExtendedString.hxx>
|
#include <TCollection_ExtendedString.hxx>
|
||||||
|
#include <OSD_Path.hxx>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <tcl.h>
|
#include <tcl.h>
|
||||||
@ -375,36 +376,23 @@ void Draw_Interpretor::Add(const Standard_CString n,
|
|||||||
if (myInterp==NULL) Init();
|
if (myInterp==NULL) Init();
|
||||||
|
|
||||||
CData* C = new CData(f,this);
|
CData* C = new CData(f,this);
|
||||||
Standard_Size length, num_slashes, ii, jj, kk;
|
|
||||||
Tcl_CreateCommand(myInterp,pN,CommandCmd, (ClientData) C, CommandDelete);
|
Tcl_CreateCommand(myInterp,pN,CommandCmd, (ClientData) C, CommandDelete);
|
||||||
|
|
||||||
// add the help
|
// add the help
|
||||||
Tcl_SetVar2(myInterp,"Draw_Helps",pN,pHelp,TCL_GLOBAL_ONLY);
|
Tcl_SetVar2(myInterp,"Draw_Helps",pN,pHelp,TCL_GLOBAL_ONLY);
|
||||||
Tcl_SetVar2(myInterp,"Draw_Groups",pGroup,pN,
|
Tcl_SetVar2(myInterp,"Draw_Groups",pGroup,pN,
|
||||||
TCL_GLOBAL_ONLY|TCL_APPEND_VALUE|TCL_LIST_ELEMENT);
|
TCL_GLOBAL_ONLY|TCL_APPEND_VALUE|TCL_LIST_ELEMENT);
|
||||||
length = strlen(pFileName) ;
|
|
||||||
char * a_string =
|
|
||||||
new char[length + 1] ;
|
|
||||||
jj = 0 ;
|
|
||||||
num_slashes = 0 ;
|
|
||||||
ii = length ;
|
|
||||||
while (num_slashes < 3 && ii >= 0) {
|
|
||||||
if (file_name[ii] == '/') {
|
|
||||||
num_slashes += 1 ;
|
|
||||||
}
|
|
||||||
ii -= 1 ;
|
|
||||||
}
|
|
||||||
jj = 0 ;
|
|
||||||
for (kk = ii+2 , jj =0 ; kk < length ; kk++) {
|
|
||||||
a_string[jj] = file_name[kk] ;
|
|
||||||
jj += 1 ;
|
|
||||||
}
|
|
||||||
a_string[jj] = '\0' ;
|
|
||||||
|
|
||||||
Tcl_SetVar2(myInterp,"Draw_Files",pN,a_string,TCL_GLOBAL_ONLY);
|
|
||||||
|
|
||||||
delete [] a_string;
|
|
||||||
|
|
||||||
|
// add path to source file (keep not more than two last subdirectories)
|
||||||
|
OSD_Path aPath (pFileName);
|
||||||
|
Standard_Integer nbTrek = aPath.TrekLength();
|
||||||
|
for (Standard_Integer i = 2; i < nbTrek; i++)
|
||||||
|
aPath.RemoveATrek (1);
|
||||||
|
aPath.SetDisk("");
|
||||||
|
aPath.SetNode("");
|
||||||
|
TCollection_AsciiString aSrcPath;
|
||||||
|
aPath.SystemName (aSrcPath);
|
||||||
|
Tcl_SetVar2(myInterp,"Draw_Files",pN,aSrcPath.ToCString(),TCL_GLOBAL_ONLY);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -96,17 +96,16 @@ proc getsourcefile {{command ""}} {
|
|||||||
|
|
||||||
global Draw_Helps Draw_Groups Draw_Files
|
global Draw_Helps Draw_Groups Draw_Files
|
||||||
|
|
||||||
|
set out {}
|
||||||
if {$command == ""} {
|
if {$command == ""} {
|
||||||
|
|
||||||
# help general
|
# help general
|
||||||
foreach h [lsort [array names Draw_Groups]] {
|
foreach h [lsort [array names Draw_Groups]] {
|
||||||
puts ""
|
lappend out "" "" "$h"
|
||||||
puts ""
|
|
||||||
puts $h
|
|
||||||
set i 0
|
set i 0
|
||||||
foreach f [lsort $Draw_Groups($h)] {
|
foreach f [lsort $Draw_Groups($h)] {
|
||||||
if {$i == 0} {
|
if {$i == 0} {
|
||||||
puts " "
|
lappend out ""
|
||||||
}
|
}
|
||||||
incr i
|
incr i
|
||||||
#
|
#
|
||||||
@ -114,18 +113,7 @@ proc getsourcefile {{command ""}} {
|
|||||||
#
|
#
|
||||||
foreach command_that_has_file [array names Draw_Files] {
|
foreach command_that_has_file [array names Draw_Files] {
|
||||||
if {($command_that_has_file == $f)} {
|
if {($command_that_has_file == $f)} {
|
||||||
#
|
lappend out [format {%-20s %s} $f $Draw_Files($f)]
|
||||||
# compute the length of the string to have the right spacing
|
|
||||||
# with tabs
|
|
||||||
#
|
|
||||||
set ll [string length $f]
|
|
||||||
if {($ll >= 1) && ($ll < 8)} {
|
|
||||||
puts "$f\t\t: $Draw_Files($f) "
|
|
||||||
}
|
|
||||||
if {($ll >= 8)} {
|
|
||||||
puts "$f\t: $Draw_Files($f) "
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -136,17 +124,12 @@ proc getsourcefile {{command ""}} {
|
|||||||
append command "*"
|
append command "*"
|
||||||
foreach f [lsort [array names Draw_Files]] {
|
foreach f [lsort [array names Draw_Files]] {
|
||||||
if {[string match $command $f]} {
|
if {[string match $command $f]} {
|
||||||
puts -nonewline $f
|
lappend out [format {%-20s %s} $f $Draw_Files($f)]
|
||||||
for {set j [string length $f]} {$j < 15} {incr j} {
|
|
||||||
puts -nonewline " "
|
|
||||||
}
|
|
||||||
|
|
||||||
puts " $Draw_Files($f)"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
flush stdout
|
return [join $out "\n"]
|
||||||
}
|
}
|
||||||
|
|
||||||
help getsourcefile {getsourcefile, or getsourcefile command } {DRAW General Commands}
|
help getsourcefile {getsourcefile, or getsourcefile command } {DRAW General Commands}
|
||||||
|
@ -496,8 +496,8 @@ proc _run_test {scriptsdir group gridname casefile} {
|
|||||||
|
|
||||||
# log only output to stdout and stderr, not to file!
|
# log only output to stdout and stderr, not to file!
|
||||||
if {[llength $args] > 1} {
|
if {[llength $args] > 1} {
|
||||||
set optvarg [lindex $args end-1]
|
set optarg [lindex $args end-1]
|
||||||
if { $optarg == stdout || $optarg == stderr || $optarg == -newline } {
|
if { $optarg == "stdout" || $optarg == "stderr" || $optarg == "-newline" } {
|
||||||
dlog add [lindex $args end]
|
dlog add [lindex $args end]
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
10
tests/demo/draw/getsource
Normal file
10
tests/demo/draw/getsource
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# test for command getsource
|
||||||
|
|
||||||
|
# check that path returned for command pload is as expected
|
||||||
|
set expected src/Draw/Draw_PloadCommands.cxx
|
||||||
|
set path [lindex [getsourcefile pload] 1]
|
||||||
|
if { [string compare $path $expected] } {
|
||||||
|
puts "Error: command 'getsourcefile pload' returned '$path' while expected '$expected'"
|
||||||
|
}
|
||||||
|
|
||||||
|
puts "TEST COMPLETED"
|
Loading…
x
Reference in New Issue
Block a user