1
0
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:
Pawel Kowalski 2012-08-03 13:28:27 +04:00
parent 3b4c36f540
commit d33dea30d5
4 changed files with 29 additions and 48 deletions

View File

@ -29,6 +29,7 @@
#include <TCollection_AsciiString.hxx>
#include <TCollection_ExtendedString.hxx>
#include <OSD_Path.hxx>
#include <string.h>
#include <tcl.h>
@ -375,36 +376,23 @@ void Draw_Interpretor::Add(const Standard_CString n,
if (myInterp==NULL) Init();
CData* C = new CData(f,this);
Standard_Size length, num_slashes, ii, jj, kk;
Tcl_CreateCommand(myInterp,pN,CommandCmd, (ClientData) C, CommandDelete);
// add the help
Tcl_SetVar2(myInterp,"Draw_Helps",pN,pHelp,TCL_GLOBAL_ONLY);
Tcl_SetVar2(myInterp,"Draw_Groups",pGroup,pN,
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);
}

View File

@ -96,17 +96,16 @@ proc getsourcefile {{command ""}} {
global Draw_Helps Draw_Groups Draw_Files
set out {}
if {$command == ""} {
# help general
foreach h [lsort [array names Draw_Groups]] {
puts ""
puts ""
puts $h
lappend out "" "" "$h"
set i 0
foreach f [lsort $Draw_Groups($h)] {
if {$i == 0} {
puts " "
lappend out ""
}
incr i
#
@ -114,18 +113,7 @@ proc getsourcefile {{command ""}} {
#
foreach command_that_has_file [array names Draw_Files] {
if {($command_that_has_file == $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) "
}
lappend out [format {%-20s %s} $f $Draw_Files($f)]
}
}
}
@ -136,17 +124,12 @@ proc getsourcefile {{command ""}} {
append command "*"
foreach f [lsort [array names Draw_Files]] {
if {[string match $command $f]} {
puts -nonewline $f
for {set j [string length $f]} {$j < 15} {incr j} {
puts -nonewline " "
}
puts " $Draw_Files($f)"
lappend out [format {%-20s %s} $f $Draw_Files($f)]
}
}
}
flush stdout
return [join $out "\n"]
}
help getsourcefile {getsourcefile, or getsourcefile command } {DRAW General Commands}

View File

@ -496,8 +496,8 @@ proc _run_test {scriptsdir group gridname casefile} {
# log only output to stdout and stderr, not to file!
if {[llength $args] > 1} {
set optvarg [lindex $args end-1]
if { $optarg == stdout || $optarg == stderr || $optarg == -newline } {
set optarg [lindex $args end-1]
if { $optarg == "stdout" || $optarg == "stderr" || $optarg == "-newline" } {
dlog add [lindex $args end]
}
} else {

10
tests/demo/draw/getsource Normal file
View 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"