mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0031972: Application Framework, FSD_CmpFile - exception on reading file in old persistence format with Windows EOL
FSD_CmpFile::ReadLine()/FSD_CmpFile::ReadString() now use TCollection_AsciiString::Trunc() instead of ill-formed character assignment to '\0'.
This commit is contained in:
parent
716cf4d96b
commit
6078550944
@ -145,7 +145,9 @@ void FSD_CmpFile::ReadLine(TCollection_AsciiString& buffer)
|
||||
TCollection_AsciiString aBuf('\0');
|
||||
FSD_File::ReadLine(aBuf);
|
||||
for (Standard_Integer lv = aBuf.Length(); lv >= 1 && (aBuf.Value(lv) == '\r' || (aBuf.Value(lv) == '\n')); lv--)
|
||||
aBuf.SetValue(lv, '\0');
|
||||
{
|
||||
aBuf.Trunc (lv - 1);
|
||||
}
|
||||
buffer = aBuf;
|
||||
}
|
||||
|
||||
@ -214,7 +216,9 @@ void FSD_CmpFile::ReadString(TCollection_AsciiString& buffer)
|
||||
TCollection_AsciiString aBuf('\0');
|
||||
FSD_File::ReadString(aBuf);
|
||||
for (Standard_Integer lv = aBuf.Length(); lv >= 1 && (aBuf.Value(lv) == '\r' || (aBuf.Value(lv) == '\n')); lv--)
|
||||
aBuf.SetValue(lv, '\0');
|
||||
{
|
||||
aBuf.Trunc (lv - 1);
|
||||
}
|
||||
buffer = aBuf;
|
||||
}
|
||||
|
||||
|
54
tests/caf/basic/W12
Normal file
54
tests/caf/basic/W12
Normal file
@ -0,0 +1,54 @@
|
||||
puts "0031972: Application Framework, FSD_CmpFile - e x c e p t i o n on reading file in old persistence format with Windows EOL"
|
||||
set QA_DUP 0
|
||||
|
||||
# write text document with Windows EOLs
|
||||
set aRefFilePath [locate_data_file caf001_refList.std]
|
||||
set aTmpFilePath "${imagedir}/${casename}.std"
|
||||
|
||||
set aFileIn [open "$aRefFilePath" r]
|
||||
set aLines [split [read $aFileIn] "\n"]
|
||||
close $aFileIn
|
||||
set aFileOut [open "$aTmpFilePath" w]
|
||||
fconfigure $aFileOut -translation crlf
|
||||
foreach aLineIter $aLines {
|
||||
puts $aFileIn $aLineIter
|
||||
}
|
||||
close $aFileOut
|
||||
|
||||
Open ${aTmpFilePath} D
|
||||
|
||||
# Add an attribute to a data framework
|
||||
set aSetAttr1 {0:1:5 0:1:3 0:1:2 0:1:1 0:1:4}
|
||||
set aLabel 0:1
|
||||
|
||||
# Get a value of the attribute
|
||||
set IsGood 1
|
||||
set aMessage1 "Add TDataStd_ReferenceList attribute: Error"
|
||||
set aGetAttr1 [GetReferenceList D ${aLabel}]
|
||||
set aLenRead [llength ${aGetAttr1}]
|
||||
set aLenSet [llength ${aSetAttr1}]
|
||||
|
||||
if { ${aLenRead} != ${aLenSet} } {
|
||||
set IsGood 0
|
||||
puts "aLenRead=${aLenRead}"
|
||||
puts ${aMessage1}
|
||||
}
|
||||
|
||||
if { ${IsGood} == 0} { return }
|
||||
|
||||
for {set i 0} {$i < $aLenRead} {incr i} {
|
||||
set aGetAttr11 [lindex ${aGetAttr1} $i]
|
||||
set aGetAttr21 [lindex ${aSetAttr1} $i]
|
||||
if { ${aGetAttr11} != ${aGetAttr21} } {
|
||||
set IsGood 0;puts "i=${i}"
|
||||
puts "aGetAttr11=${aGetAttr11}"
|
||||
puts "aGetAttr21=${aGetAttr21}"
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
if { ${IsGood} == 0} {
|
||||
puts ${aMessage1}
|
||||
} else {
|
||||
puts "Add TDataStd_ReferenceList attribute: OK"
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user