summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--oox/source/drawingml/customshapepresetdata.cxx322
1 files changed, 166 insertions, 156 deletions
diff --git a/oox/source/drawingml/customshapepresetdata.cxx b/oox/source/drawingml/customshapepresetdata.cxx
index 4e93f4f76a06..3215b9834a42 100644
--- a/oox/source/drawingml/customshapepresetdata.cxx
+++ b/oox/source/drawingml/customshapepresetdata.cxx
@@ -38,19 +38,19 @@ void lcl_parseAdjustmentValue(
OString aToken(o3tl::trim(o3tl::getToken(rValue, 0, ',', nIndex)));
static const char aNamePrefix[] = "Name = \"";
static const char aValuePrefix[] = "Value = (any) { (long) ";
- if (aToken.startsWith(aNamePrefix))
+ if (o3tl::starts_with(aToken, aNamePrefix))
{
OString aName = aToken.copy(strlen(aNamePrefix),
aToken.getLength() - strlen(aNamePrefix) - strlen("\""));
aAdjustmentValue.Name = OUString::fromUtf8(aName);
}
- else if (aToken.startsWith(aValuePrefix))
+ else if (o3tl::starts_with(aToken, aValuePrefix))
{
OString aValue = aToken.copy(strlen(aValuePrefix),
aToken.getLength() - strlen(aValuePrefix) - strlen(" }"));
aAdjustmentValue.Value <<= aValue.toInt32();
}
- else if (!aToken.startsWith("State = "))
+ else if (!o3tl::starts_with(aToken, "State = "))
SAL_WARN("oox", "lcl_parseAdjustmentValue: unexpected prefix: " << aToken);
} while (nIndex >= 0);
rAdjustmentValues.push_back(aAdjustmentValue);
@@ -59,11 +59,11 @@ void lcl_parseAdjustmentValue(
// Parses a string like: { Value = (any) { (long) 19098 }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE, Name = "adj" }, { Value = ..., State = ..., Name = ... }
void lcl_parseAdjustmentValues(
std::vector<drawing::EnhancedCustomShapeAdjustmentValue>& rAdjustmentValues,
- const OString& rValue)
+ std::string_view rValue)
{
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -78,7 +78,7 @@ void lcl_parseAdjustmentValues(
{
lcl_parseAdjustmentValue(
rAdjustmentValues,
- rValue.subView(nStart + strlen("{ "), i - nStart - strlen(" },")));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },")));
}
}
}
@@ -179,13 +179,13 @@ awt::Size lcl_parseSize(std::string_view rValue)
return aSize;
}
-drawing::EnhancedCustomShapeTextFrame lcl_parseEnhancedCustomShapeTextFrame(const OString& rValue)
+drawing::EnhancedCustomShapeTextFrame lcl_parseEnhancedCustomShapeTextFrame(std::string_view rValue)
{
drawing::EnhancedCustomShapeTextFrame aTextFrame;
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -201,13 +201,13 @@ drawing::EnhancedCustomShapeTextFrame lcl_parseEnhancedCustomShapeTextFrame(cons
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[]
= "TopLeft = (com.sun.star.drawing.EnhancedCustomShapeParameterPair) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" }"));
aTextFrame.TopLeft = lcl_parseEnhancedCustomShapeParameterPair(aToken);
}
else
@@ -217,13 +217,13 @@ drawing::EnhancedCustomShapeTextFrame lcl_parseEnhancedCustomShapeTextFrame(cons
}
}
- OString aToken = rValue.copy(nStart);
+ std::string_view aToken = rValue.substr(nStart);
static const char aExpectedPrefix[]
= "BottomRight = (com.sun.star.drawing.EnhancedCustomShapeParameterPair) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" }"));
aTextFrame.BottomRight = lcl_parseEnhancedCustomShapeParameterPair(aToken);
}
else
@@ -235,12 +235,12 @@ drawing::EnhancedCustomShapeTextFrame lcl_parseEnhancedCustomShapeTextFrame(cons
// Parses a string like: Name = "Position", Handle = (long) 0, Value = (any) { ... }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE
// where "{ ... }" may contain "," as well.
-void lcl_parseHandlePosition(std::vector<beans::PropertyValue>& rHandle, const OString& rValue)
+void lcl_parseHandlePosition(std::vector<beans::PropertyValue>& rHandle, std::string_view rValue)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -256,20 +256,20 @@ void lcl_parseHandlePosition(std::vector<beans::PropertyValue>& rHandle, const O
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[]
= "Value = (any) { (com.sun.star.drawing.EnhancedCustomShapeParameterPair) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" } }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" } }"));
beans::PropertyValue aPropertyValue;
aPropertyValue.Name = "Position";
aPropertyValue.Value <<= lcl_parseEnhancedCustomShapeParameterPair(aToken);
rHandle.push_back(aPropertyValue);
}
- else if (!aToken.startsWith("Name =") && !aToken.startsWith("Handle ="))
+ else if (!o3tl::starts_with(aToken, "Name =") && !o3tl::starts_with(aToken, "Handle ="))
SAL_WARN("oox", "lcl_parseHandlePosition: unexpected token: " << aToken);
nStart = i + strlen(", ");
}
@@ -278,13 +278,13 @@ void lcl_parseHandlePosition(std::vector<beans::PropertyValue>& rHandle, const O
// Parses a string like: Name = "RangeYMaximum", Handle = (long) 0, Value = (any) { ... }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE
// where "{ ... }" may contain "," as well.
-void lcl_parseHandleRange(std::vector<beans::PropertyValue>& rHandle, const OString& rValue,
+void lcl_parseHandleRange(std::vector<beans::PropertyValue>& rHandle, std::string_view rValue,
const OUString& rName)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -302,18 +302,18 @@ void lcl_parseHandleRange(std::vector<beans::PropertyValue>& rHandle, const OStr
{
static const char aExpectedPrefix[]
= "Value = (any) { (com.sun.star.drawing.EnhancedCustomShapeParameter) { ";
- if (rValue.match(aExpectedPrefix, nStart))
+ if (o3tl::starts_with(rValue.substr(nStart), aExpectedPrefix))
{
drawing::EnhancedCustomShapeParameter aParameter;
sal_Int32 nIndex{ nStart + static_cast<sal_Int32>(strlen(aExpectedPrefix)) };
// We expect the following here: Value and Type
static const char aExpectedVPrefix[] = "Value = (any) { (long) ";
- assert(rValue.match(aExpectedVPrefix, nIndex));
+ assert(o3tl::starts_with(rValue.substr(nIndex), aExpectedVPrefix));
nIndex += strlen(aExpectedVPrefix);
aParameter.Value <<= o3tl::toInt32(o3tl::getToken(rValue, 0, '}', nIndex));
static const char aExpectedTPrefix[] = ", Type = (short) ";
- assert(nIndex >= 0 && rValue.match(aExpectedTPrefix, nIndex));
+ assert(nIndex >= 0 && o3tl::starts_with(rValue.substr(nIndex), aExpectedTPrefix));
nIndex += strlen(aExpectedTPrefix);
aParameter.Type
= static_cast<sal_Int16>(o3tl::toInt32(o3tl::getToken(rValue, 0, '}', nIndex)));
@@ -323,22 +323,23 @@ void lcl_parseHandleRange(std::vector<beans::PropertyValue>& rHandle, const OStr
aPropertyValue.Value <<= aParameter;
rHandle.push_back(aPropertyValue);
}
- else if (!rValue.match("Name =", nStart) && !rValue.match("Handle =", nStart))
+ else if (!o3tl::starts_with(rValue.substr(nStart), "Name =")
+ && !o3tl::starts_with(rValue.substr(nStart), "Handle ="))
SAL_WARN("oox", "lcl_parseHandleRange: unexpected token: "
- << rValue.copy(nStart, i - nStart));
+ << rValue.substr(nStart, i - nStart));
nStart = i + strlen(", ");
}
}
}
// Parses a string like: Name = "RefY", Handle = (long) 0, Value = (any) { (long) 0 }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE
-void lcl_parseHandleRef(std::vector<beans::PropertyValue>& rHandle, const OString& rValue,
+void lcl_parseHandleRef(std::vector<beans::PropertyValue>& rHandle, std::string_view rValue,
const OUString& rName)
{
static constexpr std::string_view aPrefix = "\", Handle = (long) 0, Value = (any) { (long) ";
const sal_Int32 nStart = SAL_N_ELEMENTS("Name = \"") - 1 + rName.getLength();
- if (rValue.subView(nStart, aPrefix.size()) == aPrefix)
+ if (rValue.substr(nStart, aPrefix.size()) == aPrefix)
{
sal_Int32 nIndex = nStart + aPrefix.size();
beans::PropertyValue aPropertyValue;
@@ -351,12 +352,12 @@ void lcl_parseHandleRef(std::vector<beans::PropertyValue>& rHandle, const OStrin
SAL_WARN("oox", "lcl_parseHandleRef: unexpected value: " << rValue);
}
-uno::Sequence<beans::PropertyValue> lcl_parseHandle(const OString& rValue)
+uno::Sequence<beans::PropertyValue> lcl_parseHandle(std::string_view rValue)
{
std::vector<beans::PropertyValue> aRet;
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -369,28 +370,29 @@ uno::Sequence<beans::PropertyValue> lcl_parseHandle(const OString& rValue)
nLevel--;
if (!nLevel)
{
- OString aToken = rValue.copy(nStart + strlen("{ "), i - nStart - strlen(" },"));
- if (aToken.startsWith("Name = \"Position\""))
+ std::string_view aToken
+ = rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"));
+ if (o3tl::starts_with(aToken, "Name = \"Position\""))
lcl_parseHandlePosition(aRet, aToken);
- else if (aToken.startsWith("Name = \"RangeXMaximum\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RangeXMaximum\""))
lcl_parseHandleRange(aRet, aToken, "RangeXMaximum");
- else if (aToken.startsWith("Name = \"RangeXMinimum\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RangeXMinimum\""))
lcl_parseHandleRange(aRet, aToken, "RangeXMinimum");
- else if (aToken.startsWith("Name = \"RangeYMaximum\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RangeYMaximum\""))
lcl_parseHandleRange(aRet, aToken, "RangeYMaximum");
- else if (aToken.startsWith("Name = \"RangeYMinimum\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RangeYMinimum\""))
lcl_parseHandleRange(aRet, aToken, "RangeYMinimum");
- else if (aToken.startsWith("Name = \"RadiusRangeMaximum\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RadiusRangeMaximum\""))
lcl_parseHandleRange(aRet, aToken, "RadiusRangeMaximum");
- else if (aToken.startsWith("Name = \"RadiusRangeMinimum\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RadiusRangeMinimum\""))
lcl_parseHandleRange(aRet, aToken, "RadiusRangeMinimum");
- else if (aToken.startsWith("Name = \"RefX\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RefX\""))
lcl_parseHandleRef(aRet, aToken, "RefX");
- else if (aToken.startsWith("Name = \"RefY\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RefY\""))
lcl_parseHandleRef(aRet, aToken, "RefY");
- else if (aToken.startsWith("Name = \"RefR\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RefR\""))
lcl_parseHandleRef(aRet, aToken, "RefR");
- else if (aToken.startsWith("Name = \"RefAngle\""))
+ else if (o3tl::starts_with(aToken, "Name = \"RefAngle\""))
lcl_parseHandleRef(aRet, aToken, "RefAngle");
else
SAL_WARN("oox", "lcl_parseHandle: unexpected token: " << aToken);
@@ -401,11 +403,11 @@ uno::Sequence<beans::PropertyValue> lcl_parseHandle(const OString& rValue)
}
void lcl_parseHandles(std::vector<uno::Sequence<beans::PropertyValue>>& rHandles,
- const OString& rValue)
+ std::string_view rValue)
{
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -419,18 +421,18 @@ void lcl_parseHandles(std::vector<uno::Sequence<beans::PropertyValue>>& rHandles
if (!nLevel)
{
uno::Sequence<beans::PropertyValue> aHandle = lcl_parseHandle(
- rValue.copy(nStart + strlen("{ "), i - nStart - strlen(" },")));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },")));
rHandles.push_back(aHandle);
}
}
}
}
-void lcl_parseEquations(std::vector<OUString>& rEquations, const OString& rValue)
+void lcl_parseEquations(std::vector<OUString>& rEquations, std::string_view rValue)
{
bool bInString = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '"' && !bInString)
{
@@ -441,17 +443,18 @@ void lcl_parseEquations(std::vector<OUString>& rEquations, const OString& rValue
{
bInString = false;
rEquations.push_back(OUString::fromUtf8(
- rValue.subView(nStart + strlen("\""), i - nStart - strlen("\""))));
+ rValue.substr(nStart + strlen("\""), i - nStart - strlen("\""))));
}
}
}
-void lcl_parsePathCoordinateValues(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathCoordinateValues(std::vector<beans::PropertyValue>& rPath,
+ std::string_view rValue)
{
std::vector<drawing::EnhancedCustomShapeParameterPair> aPairs;
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -464,7 +467,7 @@ void lcl_parsePathCoordinateValues(std::vector<beans::PropertyValue>& rPath, con
nLevel--;
if (!nLevel)
aPairs.push_back(lcl_parseEnhancedCustomShapeParameterPair(
- rValue.subView(nStart + strlen("{ "), i - nStart - strlen(" },"))));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"))));
}
}
@@ -476,12 +479,12 @@ void lcl_parsePathCoordinateValues(std::vector<beans::PropertyValue>& rPath, con
// Parses a string like: Name = "Coordinates", Handle = (long) 0, Value = (any) { ... }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE
// where "{ ... }" may contain "," as well.
-void lcl_parsePathCoordinates(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathCoordinates(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -497,28 +500,29 @@ void lcl_parsePathCoordinates(std::vector<beans::PropertyValue>& rPath, const OS
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[]
= "Value = (any) { ([]com.sun.star.drawing.EnhancedCustomShapeParameterPair) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" } }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" } }"));
lcl_parsePathCoordinateValues(rPath, aToken);
}
- else if (!aToken.startsWith("Name =") && !aToken.startsWith("Handle ="))
+ else if (!o3tl::starts_with(aToken, "Name =") && !o3tl::starts_with(aToken, "Handle ="))
SAL_WARN("oox", "lcl_parsePathCoordinates: unexpected token: " << aToken);
nStart = i + strlen(", ");
}
}
}
-void lcl_parsePathGluePointsValues(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathGluePointsValues(std::vector<beans::PropertyValue>& rPath,
+ std::string_view rValue)
{
std::vector<drawing::EnhancedCustomShapeParameterPair> aPairs;
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -531,7 +535,7 @@ void lcl_parsePathGluePointsValues(std::vector<beans::PropertyValue>& rPath, con
nLevel--;
if (!nLevel)
aPairs.push_back(lcl_parseEnhancedCustomShapeParameterPair(
- rValue.subView(nStart + strlen("{ "), i - nStart - strlen(" },"))));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"))));
}
}
@@ -541,12 +545,12 @@ void lcl_parsePathGluePointsValues(std::vector<beans::PropertyValue>& rPath, con
rPath.push_back(aPropertyValue);
}
-void lcl_parsePathGluePoints(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathGluePoints(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -562,28 +566,28 @@ void lcl_parsePathGluePoints(std::vector<beans::PropertyValue>& rPath, const OSt
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[]
= "Value = (any) { ([]com.sun.star.drawing.EnhancedCustomShapeParameterPair) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" } }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" } }"));
lcl_parsePathGluePointsValues(rPath, aToken);
}
- else if (!aToken.startsWith("Name =") && !aToken.startsWith("Handle ="))
+ else if (!o3tl::starts_with(aToken, "Name =") && !o3tl::starts_with(aToken, "Handle ="))
SAL_WARN("oox", "lcl_parsePathGluePoints: unexpected token: " << aToken);
nStart = i + strlen(", ");
}
}
}
-void lcl_parsePathSegmentValues(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathSegmentValues(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
std::vector<drawing::EnhancedCustomShapeSegment> aSegments;
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -596,7 +600,7 @@ void lcl_parsePathSegmentValues(std::vector<beans::PropertyValue>& rPath, const
nLevel--;
if (!nLevel)
aSegments.push_back(lcl_parseEnhancedCustomShapeSegment(
- rValue.subView(nStart + strlen("{ "), i - nStart - strlen(" },"))));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"))));
}
}
@@ -608,12 +612,12 @@ void lcl_parsePathSegmentValues(std::vector<beans::PropertyValue>& rPath, const
// Parses a string like: Name = "Segments", Handle = (long) 0, Value = (any) { ... }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE
// where "{ ... }" may contain "," as well.
-void lcl_parsePathSegments(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathSegments(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -629,28 +633,28 @@ void lcl_parsePathSegments(std::vector<beans::PropertyValue>& rPath, const OStri
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[]
= "Value = (any) { ([]com.sun.star.drawing.EnhancedCustomShapeSegment) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" } }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" } }"));
lcl_parsePathSegmentValues(rPath, aToken);
}
- else if (!aToken.startsWith("Name =") && !aToken.startsWith("Handle ="))
+ else if (!o3tl::starts_with(aToken, "Name =") && !o3tl::starts_with(aToken, "Handle ="))
SAL_WARN("oox", "lcl_parsePathSegments: unexpected token: " << aToken);
nStart = i + strlen(", ");
}
}
}
-void lcl_parsePathTextFrameValues(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathTextFrameValues(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
std::vector<drawing::EnhancedCustomShapeTextFrame> aTextFrames;
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -663,7 +667,7 @@ void lcl_parsePathTextFrameValues(std::vector<beans::PropertyValue>& rPath, cons
nLevel--;
if (!nLevel)
aTextFrames.push_back(lcl_parseEnhancedCustomShapeTextFrame(
- rValue.copy(nStart + strlen("{ "), i - nStart - strlen(" },"))));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"))));
}
}
@@ -675,12 +679,12 @@ void lcl_parsePathTextFrameValues(std::vector<beans::PropertyValue>& rPath, cons
// Parses a string like: Name = "TextFrames", Handle = (long) 0, Value = (any) { ... }, State = (com.sun.star.beans.PropertyState) DIRECT_VALUE
// where "{ ... }" may contain "," as well.
-void lcl_parsePathTextFrames(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathTextFrames(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -696,28 +700,29 @@ void lcl_parsePathTextFrames(std::vector<beans::PropertyValue>& rPath, const OSt
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[]
= "Value = (any) { ([]com.sun.star.drawing.EnhancedCustomShapeTextFrame) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" } }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" } }"));
lcl_parsePathTextFrameValues(rPath, aToken);
}
- else if (!aToken.startsWith("Name =") && !aToken.startsWith("Handle ="))
+ else if (!o3tl::starts_with(aToken, "Name =") && !o3tl::starts_with(aToken, "Handle ="))
SAL_WARN("oox", "lcl_parsePathTextFrames: unexpected token: " << aToken);
nStart = i + strlen(", ");
}
}
}
-void lcl_parsePathSubViewSizeValues(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathSubViewSizeValues(std::vector<beans::PropertyValue>& rPath,
+ std::string_view rValue)
{
std::vector<awt::Size> aSizes;
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -730,7 +735,7 @@ void lcl_parsePathSubViewSizeValues(std::vector<beans::PropertyValue>& rPath, co
nLevel--;
if (!nLevel)
aSizes.push_back(lcl_parseSize(
- rValue.subView(nStart + strlen("{ "), i - nStart - strlen(" },"))));
+ rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"))));
}
}
@@ -740,12 +745,12 @@ void lcl_parsePathSubViewSizeValues(std::vector<beans::PropertyValue>& rPath, co
rPath.push_back(aPropertyValue);
}
-void lcl_parsePathSubViewSize(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePathSubViewSize(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
sal_Int32 nLevel = 0;
bool bIgnore = false;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -761,26 +766,26 @@ void lcl_parsePathSubViewSize(std::vector<beans::PropertyValue>& rPath, const OS
}
else if (rValue[i] == ',' && !bIgnore)
{
- OString aToken = rValue.copy(nStart, i - nStart);
+ std::string_view aToken = rValue.substr(nStart, i - nStart);
static const char aExpectedPrefix[] = "Value = (any) { ([]com.sun.star.awt.Size) { ";
- if (aToken.startsWith(aExpectedPrefix))
+ if (o3tl::starts_with(aToken, aExpectedPrefix))
{
- aToken = aToken.copy(strlen(aExpectedPrefix),
- aToken.getLength() - strlen(aExpectedPrefix) - strlen(" } }"));
+ aToken = aToken.substr(strlen(aExpectedPrefix),
+ aToken.size() - strlen(aExpectedPrefix) - strlen(" } }"));
lcl_parsePathSubViewSizeValues(rPath, aToken);
}
- else if (!aToken.startsWith("Name =") && !aToken.startsWith("Handle ="))
+ else if (!o3tl::starts_with(aToken, "Name =") && !o3tl::starts_with(aToken, "Handle ="))
SAL_WARN("oox", "lcl_parsePathSubViewSize: unexpected token: " << aToken);
nStart = i + strlen(", ");
}
}
}
-void lcl_parsePath(std::vector<beans::PropertyValue>& rPath, const OString& rValue)
+void lcl_parsePath(std::vector<beans::PropertyValue>& rPath, std::string_view rValue)
{
sal_Int32 nLevel = 0;
sal_Int32 nStart = 0;
- for (sal_Int32 i = 0; i < rValue.getLength(); ++i)
+ for (size_t i = 0; i < rValue.size(); ++i)
{
if (rValue[i] == '{')
{
@@ -793,16 +798,17 @@ void lcl_parsePath(std::vector<beans::PropertyValue>& rPath, const OString& rVal
nLevel--;
if (!nLevel)
{
- OString aToken = rValue.copy(nStart + strlen("{ "), i - nStart - strlen(" },"));
- if (aToken.startsWith("Name = \"Coordinates\""))
+ std::string_view aToken
+ = rValue.substr(nStart + strlen("{ "), i - nStart - strlen(" },"));
+ if (o3tl::starts_with(aToken, "Name = \"Coordinates\""))
lcl_parsePathCoordinates(rPath, aToken);
- else if (aToken.startsWith("Name = \"GluePoints\""))
+ else if (o3tl::starts_with(aToken, "Name = \"GluePoints\""))
lcl_parsePathGluePoints(rPath, aToken);
- else if (aToken.startsWith("Name = \"Segments\""))
+ else if (o3tl::starts_with(aToken, "Name = \"Segments\""))
lcl_parsePathSegments(rPath, aToken);
- else if (aToken.startsWith("Name = \"TextFrames\""))
+ else if (o3tl::starts_with(aToken, "Name = \"TextFrames\""))
lcl_parsePathTextFrames(rPath, aToken);
- else if (aToken.startsWith("Name = \"SubViewSize\""))
+ else if (o3tl::starts_with(aToken, "Name = \"SubViewSize\""))
lcl_parsePathSubViewSize(rPath, aToken);
else
SAL_WARN("oox", "lcl_parsePath: unexpected token: " << aToken);
@@ -821,7 +827,7 @@ void CustomShapeProperties::initializePresetDataMap()
SvFileStream aStream(aPath, StreamMode::READ);
if (aStream.GetError() != ERRCODE_NONE)
SAL_WARN("oox", "failed to open oox-drawingml-cs-presets");
- OString aLine;
+ OStringBuffer aLine;
OUString aName;
bool bNotDone = aStream.ReadLine(aLine);
PropertyMap aPropertyMap;
@@ -829,31 +835,32 @@ void CustomShapeProperties::initializePresetDataMap()
while (bNotDone)
{
static const char aCommentPrefix[] = "/* ";
- if (aLine.startsWith(aCommentPrefix))
+ if (o3tl::starts_with(aLine, aCommentPrefix))
{
if (bFirst)
bFirst = false;
else
maPresetDataMap[TokenMap::getTokenFromUnicode(aName)] = aPropertyMap;
- aName = OUString::fromUtf8(
- aLine.subView(strlen(aCommentPrefix),
- aLine.getLength() - strlen(aCommentPrefix) - strlen(" */")));
+ aName = OUString::fromUtf8(std::string_view(aLine).substr(
+ strlen(aCommentPrefix),
+ aLine.getLength() - strlen(aCommentPrefix) - strlen(" */")));
}
else
{
- if (aLine == "AdjustmentValues")
+ if (std::string_view(aLine) == "AdjustmentValues")
{
aStream.ReadLine(aLine);
- if (aLine != "([]com.sun.star.drawing.EnhancedCustomShapeAdjustmentValue) {}")
+ if (std::string_view(aLine)
+ != "([]com.sun.star.drawing.EnhancedCustomShapeAdjustmentValue) {}")
{
std::vector<drawing::EnhancedCustomShapeAdjustmentValue> aAdjustmentValues;
- OString aExpectedPrefix(
+ static constexpr std::string_view aExpectedPrefix(
"([]com.sun.star.drawing.EnhancedCustomShapeAdjustmentValue) { ");
- assert(aLine.startsWith(aExpectedPrefix));
+ assert(o3tl::starts_with(aLine, aExpectedPrefix));
- OString aValue = aLine.copy(aExpectedPrefix.getLength(),
- aLine.getLength() - aExpectedPrefix.getLength()
- - strlen(" }"));
+ std::string_view aValue = std::string_view(aLine).substr(
+ aExpectedPrefix.size(),
+ aLine.getLength() - aExpectedPrefix.size() - strlen(" }"));
lcl_parseAdjustmentValues(aAdjustmentValues, aValue);
aPropertyMap.setProperty(PROP_AdjustmentValues,
comphelper::containerToSequence(aAdjustmentValues));
@@ -861,18 +868,18 @@ void CustomShapeProperties::initializePresetDataMap()
else
aPropertyMap.setProperty(PROP_AdjustmentValues, uno::Sequence<OUString>(0));
}
- else if (aLine == "Equations")
+ else if (std::string_view(aLine) == "Equations")
{
aStream.ReadLine(aLine);
- if (aLine != "([]string) {}")
+ if (std::string_view(aLine) != "([]string) {}")
{
std::vector<OUString> aEquations;
- OString aExpectedPrefix("([]string) { ");
- assert(aLine.startsWith(aExpectedPrefix));
+ static constexpr std::string_view aExpectedPrefix("([]string) { ");
+ assert(o3tl::starts_with(aLine, aExpectedPrefix));
- OString aValue = aLine.copy(aExpectedPrefix.getLength(),
- aLine.getLength() - aExpectedPrefix.getLength()
- - strlen(" }"));
+ std::string_view aValue = std::string_view(aLine).substr(
+ aExpectedPrefix.size(),
+ aLine.getLength() - aExpectedPrefix.size() - strlen(" }"));
lcl_parseEquations(aEquations, aValue);
aPropertyMap.setProperty(PROP_Equations,
comphelper::containerToSequence(aEquations));
@@ -880,18 +887,19 @@ void CustomShapeProperties::initializePresetDataMap()
else
aPropertyMap.setProperty(PROP_Equations, uno::Sequence<OUString>(0));
}
- else if (aLine == "Handles")
+ else if (std::string_view(aLine) == "Handles")
{
aStream.ReadLine(aLine);
- if (aLine != "([][]com.sun.star.beans.PropertyValue) {}")
+ if (std::string_view(aLine) != "([][]com.sun.star.beans.PropertyValue) {}")
{
std::vector<uno::Sequence<beans::PropertyValue>> aHandles;
- OString aExpectedPrefix("([][]com.sun.star.beans.PropertyValue) { ");
- assert(aLine.startsWith(aExpectedPrefix));
+ static constexpr std::string_view aExpectedPrefix(
+ "([][]com.sun.star.beans.PropertyValue) { ");
+ assert(o3tl::starts_with(aLine, aExpectedPrefix));
- OString aValue = aLine.copy(aExpectedPrefix.getLength(),
- aLine.getLength() - aExpectedPrefix.getLength()
- - strlen(" }"));
+ std::string_view aValue = std::string_view(aLine).substr(
+ aExpectedPrefix.size(),
+ aLine.getLength() - aExpectedPrefix.size() - strlen(" }"));
lcl_parseHandles(aHandles, aValue);
aPropertyMap.setProperty(PROP_Handles,
comphelper::containerToSequence(aHandles));
@@ -899,61 +907,63 @@ void CustomShapeProperties::initializePresetDataMap()
else
aPropertyMap.setProperty(PROP_Handles, uno::Sequence<OUString>(0));
}
- else if (aLine == "MirroredX")
+ else if (std::string_view(aLine) == "MirroredX")
{
aStream.ReadLine(aLine);
- if (aLine == "true" || aLine == "false")
+ if (std::string_view(aLine) == "true" || std::string_view(aLine) == "false")
{
- aPropertyMap.setProperty(PROP_MirroredX, aLine == "true");
+ aPropertyMap.setProperty(PROP_MirroredX, std::string_view(aLine) == "true");
}
else
SAL_WARN("oox", "CustomShapeProperties::initializePresetDataMap: unexpected "
"MirroredX parameter");
}
- else if (aLine == "MirroredY")
+ else if (std::string_view(aLine) == "MirroredY")
{
aStream.ReadLine(aLine);
- if (aLine == "true" || aLine == "false")
+ if (std::string_view(aLine) == "true" || std::string_view(aLine) == "false")
{
- aPropertyMap.setProperty(PROP_MirroredY, aLine == "true");
+ aPropertyMap.setProperty(PROP_MirroredY, std::string_view(aLine) == "true");
}
else
SAL_WARN("oox", "CustomShapeProperties::initializePresetDataMap: unexpected "
"MirroredY parameter");
}
- else if (aLine == "Path")
+ else if (std::string_view(aLine) == "Path")
{
aStream.ReadLine(aLine);
- OString aExpectedPrefix("([]com.sun.star.beans.PropertyValue) { ");
- assert(aLine.startsWith(aExpectedPrefix));
+ static constexpr std::string_view aExpectedPrefix(
+ "([]com.sun.star.beans.PropertyValue) { ");
+ assert(o3tl::starts_with(aLine, aExpectedPrefix));
std::vector<beans::PropertyValue> aPathValue;
- OString aValue
- = aLine.copy(aExpectedPrefix.getLength(),
- aLine.getLength() - aExpectedPrefix.getLength() - strlen(" }"));
+ std::string_view aValue = std::string_view(aLine).substr(
+ aExpectedPrefix.size(),
+ aLine.getLength() - aExpectedPrefix.size() - strlen(" }"));
lcl_parsePath(aPathValue, aValue);
aPropertyMap.setProperty(PROP_Path, comphelper::containerToSequence(aPathValue));
}
- else if (aLine == "Type")
+ else if (std::string_view(aLine) == "Type")
{
// Just ignore the line here, we already know the correct type.
aStream.ReadLine(aLine);
aPropertyMap.setProperty(PROP_Type, "ooxml-" + aName);
}
- else if (aLine == "ViewBox")
+ else if (std::string_view(aLine) == "ViewBox")
{
aStream.ReadLine(aLine);
- OString aExpectedPrefix("(com.sun.star.awt.Rectangle) { ");
- assert(aLine.startsWith(aExpectedPrefix));
+ static constexpr std::string_view aExpectedPrefix(
+ "(com.sun.star.awt.Rectangle) { ");
+ assert(o3tl::starts_with(aLine, aExpectedPrefix));
- OString aValue
- = aLine.copy(aExpectedPrefix.getLength(),
- aLine.getLength() - aExpectedPrefix.getLength() - strlen(" }"));
+ std::string_view aValue = std::string_view(aLine).substr(
+ aExpectedPrefix.size(),
+ aLine.getLength() - aExpectedPrefix.size() - strlen(" }"));
aPropertyMap.setProperty(PROP_ViewBox, lcl_parseRectangle(aValue));
}
else
SAL_WARN("oox", "CustomShapeProperties::initializePresetDataMap: unhandled line: "
- << aLine);
+ << std::string_view(aLine));
}
bNotDone = aStream.ReadLine(aLine);
}