include/rtl/string.h | 5 include/rtl/ustring.h | 5 sal/qa/OStringBuffer/rtl_OStringBuffer.cxx | 378 ---------------------- sal/qa/rtl/oustring/rtl_OUString2.cxx | 2 sal/rtl/strtmpl.cxx | 19 - sw/source/core/text/porfld.cxx | 2 sw/source/core/txtnode/ndtxt.cxx | 3 vcl/source/control/tabctrl.cxx | 3 writerfilter/source/dmapper/DomainMapper_Impl.cxx | 12 9 files changed, 34 insertions(+), 395 deletions(-)
New commits: commit 2f3684b2289a8c46dc6144064a452cc529400f28 Author: Noel Grandin <noel.gran...@collabora.co.uk> AuthorDate: Tue Jul 31 16:00:02 2018 +0200 Commit: Noel Grandin <noel.gran...@collabora.co.uk> CommitDate: Thu Aug 2 11:07:55 2018 +0200 [API CHANGE] add some more asserts to the string functions rtl_[u]String_alloc now requires that the length be >= 0. Since this function is only @since Libreoffice 4.1, it is unlikely to be widely used externally. Removed some unit tests that were testing invalid or out of range paramers, which are already not allowed according to the documented contract of those functions. The change in writerfilter is because the new asserts triggered when running testFdo74745 The change in SwTextNode::EraseText is because testFdo60842 triggered the assert in replaceAt. The change in SwFieldSlot::SwFieldSlot is because testMoveRange::Import_Export_Import triggered the assert in replaceAt. The changes in SwFieldSlot::SwFieldSlot and TabControl::ImplGetItemSize are due to failures in the uitests. Change-Id: Ib317261067649b0de96df12873ce31360cd24681 Reviewed-on: https://gerrit.libreoffice.org/58390 Reviewed-by: Noel Grandin <noel.gran...@collabora.co.uk> Tested-by: Noel Grandin <noel.gran...@collabora.co.uk> diff --git a/include/rtl/string.h b/include/rtl/string.h index ecf4704b0999..17ab629005b3 100644 --- a/include/rtl/string.h +++ b/include/rtl/string.h @@ -886,7 +886,7 @@ SAL_DLLPUBLIC void SAL_CALL rtl_string_new( rtl_String ** newStr ) SAL_THROW_EXT The reference count of the new string will be 1. The length of the string will be nLen. This function does not handle out-of-memory conditions. - For nLen < 0 or failed allocation this method returns NULL. + For failed allocation this method returns NULL. The characters of the capacity are not cleared, and the length is set to nLen, unlike the similar method of rtl_String_new_WithLength which @@ -897,7 +897,8 @@ SAL_DLLPUBLIC void SAL_CALL rtl_string_new( rtl_String ** newStr ) SAL_THROW_EXT alternatively pass ownership to an OUString with rtl::OUString(newStr, SAL_NO_ACQUIRE); - @param[out] nLen the number of characters. + @param[out] nLen the number of characters. Must be >= 0. + @return pointer to the new string. @since LibreOffice 4.1 diff --git a/include/rtl/ustring.h b/include/rtl/ustring.h index e46e646c9c71..cd6f75e889db 100644 --- a/include/rtl/ustring.h +++ b/include/rtl/ustring.h @@ -1219,7 +1219,7 @@ SAL_DLLPUBLIC void SAL_CALL rtl_uString_new( The reference count of the new string will be 1. The length of the string will be nLen. This function does not handle out-of-memory conditions. - For nLen < 0 or failed allocation this method returns NULL. + For failed allocation this method returns NULL. The characters of the capacity are not cleared, and the length is set to nLen, unlike the similar method of rtl_uString_new_WithLength which @@ -1230,7 +1230,8 @@ SAL_DLLPUBLIC void SAL_CALL rtl_uString_new( alternatively pass ownership to an OUString with rtl::OUString(newStr, SAL_NO_ACQUIRE); - @param[in] nLen the number of characters. + @param[in] nLen the number of characters. Must be >= 0. + @return pointer to the new string. @since LibreOffice 4.1 diff --git a/sal/qa/OStringBuffer/rtl_OStringBuffer.cxx b/sal/qa/OStringBuffer/rtl_OStringBuffer.cxx index 3afd07f8dcab..46ed91ecfa99 100644 --- a/sal/qa/OStringBuffer/rtl_OStringBuffer.cxx +++ b/sal/qa/OStringBuffer/rtl_OStringBuffer.cxx @@ -34,7 +34,6 @@ using ::rtl::OString; // OString and OStringBuffer classes // testing constructors - namespace rtl_OStringBuffer { class ctors : public CppUnit::TestFixture @@ -134,31 +133,6 @@ namespace rtl_OStringBuffer } - void ctor_003_1() - { - // StringBuffer with created negative size are the - // same as empty StringBuffers - ::rtl::OStringBuffer aStrBuf3(kNonSInt32Max); - - const sal_Char* pStr = aStrBuf3.getStr(); - - CPPUNIT_ASSERT_MESSAGE - ( - "New OStringBuffer containing no characters and contain assigned capacity", - aStrBuf3.isEmpty() - ); - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "New OStringBuffer containing no characters and contain assigned capacity", - '\0', *pStr - ); - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "New OStringBuffer containing no characters and contain assigned capacity", - kNonSInt32Max, aStrBuf3.getCapacity() - ); - } - void ctor_004() { ::rtl::OString aStrtmp( kTestStr1 ); @@ -214,7 +188,6 @@ namespace rtl_OStringBuffer CPPUNIT_TEST(ctor_001); CPPUNIT_TEST(ctor_002); CPPUNIT_TEST(ctor_003); - CPPUNIT_TEST(ctor_003_1); CPPUNIT_TEST(ctor_004); CPPUNIT_TEST(ctor_005); CPPUNIT_TEST(ctor_006); @@ -662,18 +635,6 @@ namespace rtl_OStringBuffer ); } - void getCapacity_009() - { - ::rtl::OStringBuffer aStrBuf( kNonSInt32Max ); - sal_Int32 expVal = kNonSInt32Max; - - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "capacity of empty string (with capacity -2147483648)", - expVal, aStrBuf.getCapacity() - ); - } - void getCapacity_010() { ::rtl::OStringBuffer aStrBuf( 16 ); @@ -710,18 +671,6 @@ namespace rtl_OStringBuffer ); } - void getCapacity_013() - { - ::rtl::OStringBuffer aStrBuf( -2 ); - sal_Int32 expVal = -2; - - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "capacity of empty string (with capacity -2)", - expVal, aStrBuf.getCapacity() - ); - } - CPPUNIT_TEST_SUITE( getCapacity ); CPPUNIT_TEST( getCapacity_001 ); CPPUNIT_TEST( getCapacity_002 ); @@ -730,11 +679,9 @@ namespace rtl_OStringBuffer CPPUNIT_TEST( getCapacity_005 ); CPPUNIT_TEST( getCapacity_006 ); CPPUNIT_TEST( getCapacity_007 ); - CPPUNIT_TEST( getCapacity_009 ); CPPUNIT_TEST( getCapacity_010 ); CPPUNIT_TEST( getCapacity_011 ); CPPUNIT_TEST( getCapacity_012 ); - CPPUNIT_TEST( getCapacity_013 ); CPPUNIT_TEST_SUITE_END(); }; @@ -932,70 +879,6 @@ namespace rtl_OStringBuffer } - void ensureCapacity_018() - { - sal_Int32 expVal = 65535; - ::rtl::OStringBuffer aStrBuf( kNonSInt32Max ); - sal_Int32 input = 65535; - - aStrBuf.ensureCapacity( input ); - - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "capacity equal to -2147483648, minimum is 65535", - expVal, aStrBuf.getCapacity() - ); - - } - - void ensureCapacity_020() - { - sal_Int32 expVal = 2; - ::rtl::OStringBuffer aStrBuf( kNonSInt32Max ); - sal_Int32 input = -1; - - aStrBuf.ensureCapacity( input ); - - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "capacity equal to -2147483648, minimum is -1", - expVal, aStrBuf.getCapacity() - ); - - } - - void ensureCapacity_021() - { - sal_Int32 expVal = 2; - ::rtl::OStringBuffer aStrBuf( kNonSInt32Max ); - sal_Int32 input = 0; - - aStrBuf.ensureCapacity( input ); - - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "capacity equal to -2147483648, minimum is 0", - expVal, aStrBuf.getCapacity() - ); - - } - - void ensureCapacity_022() - { - sal_Int32 expVal = kNonSInt32Max; - ::rtl::OStringBuffer aStrBuf( kNonSInt32Max ); - sal_Int32 input = kNonSInt32Max; - - aStrBuf.ensureCapacity( input ); - - CPPUNIT_ASSERT_EQUAL_MESSAGE - ( - "capacity equal to -2147483648, minimum is -2147483648", - expVal, aStrBuf.getCapacity() - ); - - } - CPPUNIT_TEST_SUITE( ensureCapacity ); CPPUNIT_TEST( ensureCapacity_001 ); CPPUNIT_TEST( ensureCapacity_002 ); @@ -1009,10 +892,6 @@ namespace rtl_OStringBuffer CPPUNIT_TEST( ensureCapacity_010 ); CPPUNIT_TEST( ensureCapacity_011 ); CPPUNIT_TEST( ensureCapacity_012 ); - CPPUNIT_TEST( ensureCapacity_018 ); - CPPUNIT_TEST( ensureCapacity_020 ); - CPPUNIT_TEST( ensureCapacity_021 ); - CPPUNIT_TEST( ensureCapacity_022 ); CPPUNIT_TEST_SUITE_END(); }; @@ -8276,135 +8155,6 @@ namespace rtl_OStringBuffer CPPUNIT_TEST_SUITE_END(); }; -// testing the method append( sal_Int32 i, sal_Int16 radix ) where radix = -5 - - class append_006_Int32_WrongRadix : public CppUnit::TestFixture - { - OString* arrOUS[5]; - static const sal_Int32 intVal = 11; - - public: - void setUp() override - { - arrOUS[0] = new OString( kTestStr7 ); - arrOUS[1] = new OString( ); - arrOUS[2] = new OString( kTestStr25 ); - arrOUS[3] = new OString( "" ); - arrOUS[4] = new OString( kTestStr28 ); - } - - void tearDown() override - { - delete arrOUS[0]; delete arrOUS[1]; delete arrOUS[2]; - delete arrOUS[3]; delete arrOUS[4]; - } - - void append_001() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[0] ); - OString expVal( kTestStr59 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[0]", - aStrBuf.getStr()== expVal && - aStrBuf.getLength() == expVal.getLength() - ); - } - - void append_002() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[1] ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[1]", - aStrBuf.getStr()== expVal && - aStrBuf.getLength() == expVal.getLength() - ); - } - - void append_003() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[2] ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[2]", - aStrBuf.getStr()== expVal && - aStrBuf.getLength() == expVal.getLength() - ); - - } - - void append_004() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[3] ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[3]", - aStrBuf.getStr()== expVal && - aStrBuf.getLength() == expVal.getLength() - ); - - } - - void append_005() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[4] ); - OString expVal( kTestStr61 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[4]", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } -#ifdef WITH_CORE - void append_006() - { - ::rtl::OStringBuffer aStrBuf( kSInt32Max ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer(with INT_MAX)", - aStrBuf.getStr()== expVal && - aStrBuf.getLength() == expVal.getLength() - ); - - } -#endif - - CPPUNIT_TEST_SUITE( append_006_Int32_WrongRadix ); - CPPUNIT_TEST( append_001 ); - CPPUNIT_TEST( append_002 ); - CPPUNIT_TEST( append_003 ); - CPPUNIT_TEST( append_004 ); - CPPUNIT_TEST( append_005 ); -#ifdef WITH_CORE - CPPUNIT_TEST( append_006 ); -#endif - CPPUNIT_TEST_SUITE_END(); - }; - class append_006_Int32_defaultParam : public CppUnit::TestFixture { OString* arrOUS[5]; @@ -14026,132 +13776,6 @@ namespace rtl_OStringBuffer CPPUNIT_TEST_SUITE_END(); }; -// testing the method append( sal_Int64 i, sal_Int16 radix ) where radix = -5 - - class append_007_Int64_WrongRadix : public CppUnit::TestFixture - { - OString* arrOUS[5]; - static const sal_Int64 intVal = 11; - - public: - void setUp() override - { - arrOUS[0] = new OString( kTestStr7 ); - arrOUS[1] = new OString( ); - arrOUS[2] = new OString( kTestStr25 ); - arrOUS[3] = new OString( "" ); - arrOUS[4] = new OString( kTestStr28 ); - } - - void tearDown() override - { - delete arrOUS[0]; delete arrOUS[1]; delete arrOUS[2]; - delete arrOUS[3]; delete arrOUS[4]; - } - - void append_001() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[0] ); - OString expVal( kTestStr59 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[0]", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } - - void append_002() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[1] ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[1]", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } - - void append_003() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[2] ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[2]", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } - - void append_004() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[3] ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[3]", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } - - void append_005() - { - ::rtl::OStringBuffer aStrBuf( *arrOUS[4] ); - OString expVal( kTestStr61 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer arrOUS[4]", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } -#ifdef WITH_CORE - void append_006() - { - ::rtl::OStringBuffer aStrBuf( kSInt64Max ); - OString expVal( kTestStr60 ); - - aStrBuf.append( intVal, -5 ); - - CPPUNIT_ASSERT_MESSAGE - ( - "Appends the WrongRadix to the string buffer(with INT_MAX)", - (aStrBuf.toString() == expVal && - aStrBuf.getLength() == expVal.getLength()) - ); - } -#endif - - CPPUNIT_TEST_SUITE( append_007_Int64_WrongRadix ); - CPPUNIT_TEST( append_001 ); - CPPUNIT_TEST( append_002 ); - CPPUNIT_TEST( append_003 ); - CPPUNIT_TEST( append_004 ); - CPPUNIT_TEST( append_005 ); -#ifdef WITH_CORE - CPPUNIT_TEST( append_006 ); -#endif - CPPUNIT_TEST_SUITE_END(); - }; - class append_007_Int64_defaultParam : public CppUnit::TestFixture { OString* arrOUS[5]; @@ -16076,12 +15700,10 @@ CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_005); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_006_Int32); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_006_Int32_Bounderies); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_006_Int32_Negative); -CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_006_Int32_WrongRadix); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_006_Int32_defaultParam); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_007_Int64); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_007_Int64_Bounderies); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_007_Int64_Negative); -CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_007_Int64_WrongRadix); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_007_Int64_defaultParam); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_008_float); CPPUNIT_TEST_SUITE_REGISTRATION(rtl_OStringBuffer::append_008_Float_Negative); diff --git a/sal/qa/rtl/oustring/rtl_OUString2.cxx b/sal/qa/rtl/oustring/rtl_OUString2.cxx index 426834b88f5f..7dce206300a2 100644 --- a/sal/qa/rtl/oustring/rtl_OUString2.cxx +++ b/sal/qa/rtl/oustring/rtl_OUString2.cxx @@ -584,7 +584,7 @@ public: // search for sun, start at the end, found (pos==0) rtl::OUString aStr("sun java system"); rtl::OUString aSearchStr("sun"); - lastIndexOf_oustring_offset(aStr, aSearchStr, -1, -1); + lastIndexOf_oustring_offset(aStr, aSearchStr, -1, 1); } void lastIndexOf_test_oustring_001() diff --git a/sal/rtl/strtmpl.cxx b/sal/rtl/strtmpl.cxx index c4f8fa605efa..e4ccb80b68f4 100644 --- a/sal/rtl/strtmpl.cxx +++ b/sal/rtl/strtmpl.cxx @@ -562,7 +562,7 @@ sal_Int32 SAL_CALL IMPL_RTL_STRNAME( lastIndexOfStr_WithLength )( const IMPL_RTL sal_Int32 nSubLen ) SAL_THROW_EXTERN_C() { -// assert(nStrLen >= 0); + assert(nStrLen >= 0); assert(nSubLen >= 0); /* faster search for a single character */ if ( nSubLen < 2 ) @@ -809,6 +809,7 @@ sal_Int32 SAL_CALL IMPL_RTL_STRNAME( valueOfInt32 )( IMPL_RTL_STRCODE* pStr, SAL_THROW_EXTERN_C() { assert(pStr); + assert( nRadix >= RTL_STR_MIN_RADIX && nRadix <= RTL_STR_MAX_RADIX ); sal_Char aBuf[RTL_STR_MAX_VALUEOFINT32]; sal_Char* pBuf = aBuf; sal_Int32 nLen = 0; @@ -864,6 +865,7 @@ sal_Int32 SAL_CALL IMPL_RTL_STRNAME( valueOfInt64 )( IMPL_RTL_STRCODE* pStr, SAL_THROW_EXTERN_C() { assert(pStr); + assert( nRadix >= RTL_STR_MIN_RADIX && nRadix <= RTL_STR_MAX_RADIX ); sal_Char aBuf[RTL_STR_MAX_VALUEOFINT64]; sal_Char* pBuf = aBuf; sal_Int32 nLen = 0; @@ -919,6 +921,7 @@ sal_Int32 SAL_CALL IMPL_RTL_STRNAME( valueOfUInt64 )( IMPL_RTL_STRCODE* pStr, SAL_THROW_EXTERN_C() { assert(pStr); + assert( nRadix >= RTL_STR_MIN_RADIX && nRadix <= RTL_STR_MAX_RADIX ); sal_Char aBuf[RTL_STR_MAX_VALUEOFUINT64]; sal_Char* pBuf = aBuf; sal_Int32 nLen = 0; @@ -990,6 +993,7 @@ namespace { sal_Int16 nRadix ) { static_assert(std::numeric_limits<T>::is_signed, "is signed"); + assert( nRadix >= RTL_STR_MIN_RADIX && nRadix <= RTL_STR_MAX_RADIX ); bool bNeg; sal_Int16 nDigit; U n = 0; @@ -1080,6 +1084,7 @@ namespace { sal_Int16 nRadix ) { static_assert(!std::numeric_limits<T>::is_signed, "is not signed"); + assert( nRadix >= RTL_STR_MIN_RADIX && nRadix <= RTL_STR_MAX_RADIX ); sal_Int16 nDigit; T n = 0; @@ -1237,10 +1242,8 @@ void SAL_CALL IMPL_RTL_STRINGNAME( new )( IMPL_RTL_STRINGDATA** ppThis ) IMPL_RTL_STRINGDATA* SAL_CALL IMPL_RTL_STRINGNAME( alloc )( sal_Int32 nLen ) SAL_THROW_EXTERN_C() { - if ( nLen < 0 ) - return nullptr; - else - return IMPL_RTL_STRINGNAME( ImplAlloc )( nLen ); + assert(nLen >= 0); + return IMPL_RTL_STRINGNAME( ImplAlloc )( nLen ); } /* ----------------------------------------------------------------------- */ @@ -1249,6 +1252,7 @@ void SAL_CALL IMPL_RTL_STRINGNAME( new_WithLength )( IMPL_RTL_STRINGDATA** ppThi SAL_THROW_EXTERN_C() { assert(ppThis); + assert(nLen >= 0); if ( nLen <= 0 ) IMPL_RTL_STRINGNAME( new )( ppThis ); else @@ -1334,6 +1338,7 @@ void SAL_CALL IMPL_RTL_STRINGNAME( newFromStr_WithLength )( IMPL_RTL_STRINGDATA* SAL_THROW_EXTERN_C() { assert(ppThis); + assert(nLen >= 0); IMPL_RTL_STRINGDATA* pOrg; if ( !pCharStr || (nLen <= 0) ) @@ -1532,7 +1537,9 @@ void SAL_CALL IMPL_RTL_STRINGNAME( newReplaceStrAt )( IMPL_RTL_STRINGDATA** ppTh SAL_THROW_EXTERN_C() { assert(ppThis); -// assert(nCount >= 0); + assert(nIndex >= 0 && nIndex <= pStr->length); + assert(nCount >= 0); + assert(nCount <= pStr->length - nIndex); /* Append? */ if ( nIndex >= pStr->length ) { diff --git a/sw/source/core/text/porfld.cxx b/sw/source/core/text/porfld.cxx index a3cb46ea7f68..d76a1d94c053 100644 --- a/sw/source/core/text/porfld.cxx +++ b/sw/source/core/text/porfld.cxx @@ -171,7 +171,7 @@ SwFieldSlot::SwFieldSlot( const SwTextFormatInfo* pNew, const SwFieldPortion *pP pInf->SetFakeLineStart( nIdx > pInf->GetLineStart() ); pInf->SetIdx(TextFrameIndex(0)); } - else + else if(nIdx < pOldText->getLength()) { aText = (*pOldText).replaceAt(sal_Int32(nIdx), 1, aText); } diff --git a/sw/source/core/txtnode/ndtxt.cxx b/sw/source/core/txtnode/ndtxt.cxx index e8106bb859fe..4f1b12610b1b 100644 --- a/sw/source/core/txtnode/ndtxt.cxx +++ b/sw/source/core/txtnode/ndtxt.cxx @@ -2344,7 +2344,8 @@ void SwTextNode::EraseText(const SwIndex &rIdx, const sal_Int32 nCount, const sal_Int32 nCnt = (nCount==SAL_MAX_INT32) ? m_Text.getLength() - nStartIdx : nCount; const sal_Int32 nEndIdx = nStartIdx + nCnt; - m_Text = m_Text.replaceAt(nStartIdx, nCnt, ""); + if (nEndIdx <= m_Text.getLength()) + m_Text = m_Text.replaceAt(nStartIdx, nCnt, ""); // GCAttr(); don't remove all empty ones, just the ones that are in the // range but not at the end of the range. diff --git a/vcl/source/control/tabctrl.cxx b/vcl/source/control/tabctrl.cxx index 1c42ba9d081a..a7082008eeb3 100644 --- a/vcl/source/control/tabctrl.cxx +++ b/vcl/source/control/tabctrl.cxx @@ -256,7 +256,8 @@ Size TabControl::ImplGetItemSize( ImplTabItem* pItem, long nMaxWidth ) pItem->maFormatText += aAppendStr; do { - pItem->maFormatText = pItem->maFormatText.replaceAt( pItem->maFormatText.getLength()-aAppendStr.getLength()-1, 1, "" ); + if (pItem->maFormatText.getLength() > aAppendStr.getLength()) + pItem->maFormatText = pItem->maFormatText.replaceAt( pItem->maFormatText.getLength()-aAppendStr.getLength()-1, 1, "" ); aSize.setWidth( GetCtrlTextWidth( pItem->maFormatText ) ); aSize.AdjustWidth(aImageSize.Width() ); aSize.AdjustWidth(TAB_TABOFFSET_X*2 ); diff --git a/writerfilter/source/dmapper/DomainMapper_Impl.cxx b/writerfilter/source/dmapper/DomainMapper_Impl.cxx index 0bee265b0187..636153e8633f 100644 --- a/writerfilter/source/dmapper/DomainMapper_Impl.cxx +++ b/writerfilter/source/dmapper/DomainMapper_Impl.cxx @@ -2626,11 +2626,17 @@ style::NumberingType:: static OUString lcl_ParseFormat( const OUString& rCommand ) { - // The command looks like: " DATE \@"dd MMMM yyyy" + // The command looks like: " DATE \@"dd MMMM yyyy" or "09/02/2014" // Remove whitespace permitted by standard between \@ and " + OUString command; sal_Int32 delimPos = rCommand.indexOf("\\@"); - sal_Int32 wsChars = rCommand.indexOf('\"') - delimPos - 2; - OUString command = rCommand.replaceAt(delimPos+2, wsChars, ""); + if (delimPos != -1) + { + sal_Int32 wsChars = rCommand.indexOf('\"') - delimPos - 2; + command = rCommand.replaceAt(delimPos+2, wsChars, ""); + } + else + command = rCommand; return msfilter::util::findQuotedText(command, "\\@\"", '\"'); } _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits