summaryrefslogtreecommitdiffstats
path: root/desktop/source
diff options
context:
space:
mode:
authorMike Kaganski <mike.kaganski@collabora.com>2017-07-12 16:07:50 +0300
committerMike Kaganski <mike.kaganski@collabora.com>2017-07-12 17:59:40 +0200
commitf19fbadd00370820d026d9c29a7bc231e6fa49f0 (patch)
treee250a5e62ac9f5c79762c3dd27ce4158372331fb /desktop/source
parenttdf#108928 Branding 6.0 (diff)
downloadcore-f19fbadd00370820d026d9c29a7bc231e6fa49f0.tar.gz
core-f19fbadd00370820d026d9c29a7bc231e6fa49f0.zip
tdf#106359: use SvFileStream to read iqy; fixes *nix compatibility
Change-Id: I42dc6559a57eaedcc64d2a4e59e16677b9dfeb1c Reviewed-on: https://gerrit.libreoffice.org/39862 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Mike Kaganski <mike.kaganski@collabora.com>
Diffstat (limited to 'desktop/source')
-rw-r--r--desktop/source/app/cmdlineargs.cxx64
1 files changed, 27 insertions, 37 deletions
diff --git a/desktop/source/app/cmdlineargs.cxx b/desktop/source/app/cmdlineargs.cxx
index b15706046f50..6011b262a5ac 100644
--- a/desktop/source/app/cmdlineargs.cxx
+++ b/desktop/source/app/cmdlineargs.cxx
@@ -37,7 +37,6 @@
#include <svl/documentlockfile.hxx>
-#include <ucbhelper/content.hxx>
#include <rtl/strbuf.hxx>
#include <osl/file.hxx>
@@ -170,14 +169,14 @@ CommandLineEvent CheckOfficeURI(/* in,out */ OUString& arg, CommandLineEvent cur
// Skip single newline (be it *NIX LF, MacOS CR, of Win CRLF)
// Changes the offset, and returns true if moved
-bool SkipNewline(const char* pStr, sal_Int32& rOffset)
+bool SkipNewline(const char* & pStr)
{
- if ((pStr[rOffset] != '\r') && (pStr[rOffset] != '\n'))
+ if ((*pStr != '\r') && (*pStr != '\n'))
return false;
- if (pStr[rOffset] == '\r')
- ++rOffset;
- if (pStr[rOffset] == '\n')
- ++rOffset;
+ if (*pStr == '\r')
+ ++pStr;
+ if (*pStr == '\n')
+ ++pStr;
return true;
}
@@ -194,52 +193,43 @@ CommandLineEvent CheckWebQuery(/* in,out */ OUString& arg, CommandLineEvent curE
try
{
OUString sFileURL;
+ // Cannot use translateExternalUris yet, because process service factory is not yet available
if (osl::FileBase::getFileURLFromSystemPath(arg, sFileURL) != osl::FileBase::RC::E_None)
return curEvt;
- css::uno::Reference < css::ucb::XCommandEnvironment > xEnv;
- ucbhelper::Content aSourceContent(sFileURL, xEnv, comphelper::getProcessComponentContext());
-
- // the file can be opened readonly, no locking will be done
- css::uno::Reference< css::io::XInputStream > xInput = aSourceContent.openStream();
- if (!xInput.is())
- return curEvt;
+ SvFileStream stream(sFileURL, StreamMode::READ);
const sal_Int32 nBufLen = 32000;
- css::uno::Sequence< sal_Int8 > aBuffer(nBufLen);
- sal_Int32 nRead = xInput->readBytes(aBuffer, nBufLen);
+ char sBuffer[nBufLen];
+ size_t nRead = stream.ReadBytes(sBuffer, nBufLen);
if (nRead < 8) // WEB\n1\n...
return curEvt;
- const char* sBuf = reinterpret_cast<const char*>(aBuffer.getConstArray());
- sal_Int32 nOffset = 0;
- if (strncmp(sBuf+nOffset, "WEB", 3) != 0)
+ const char* pPos = sBuffer;
+ if (strncmp(pPos, "WEB", 3) != 0)
return curEvt;
- nOffset += 3;
- if (!SkipNewline(sBuf, nOffset))
+ pPos += 3;
+ if (!SkipNewline(pPos))
return curEvt;
- if (sBuf[nOffset] != '1')
+ if (*pPos != '1')
return curEvt;
- ++nOffset;
- if (!SkipNewline(sBuf, nOffset))
+ ++pPos;
+ if (!SkipNewline(pPos))
return curEvt;
- rtl::OStringBuffer aResult(nRead);
+ rtl::OStringBuffer aResult(static_cast<unsigned int>(nRead));
do
{
- // xInput->readBytes() can relocate buffer
- sBuf = reinterpret_cast<const char*>(aBuffer.getConstArray());
- const char* sPos = sBuf + nOffset;
- const char* sPos1 = sPos;
- const char* sEnd = sBuf + nRead;
- while ((sPos1 < sEnd) && (*sPos1 != '\r') && (*sPos1 != '\n'))
- ++sPos1;
- aResult.append(sPos, sPos1 - sPos);
- if (sPos1 < sEnd) // newline
+ const char* pPos1 = pPos;
+ const char* pEnd = sBuffer + nRead;
+ while ((pPos1 < pEnd) && (*pPos1 != '\r') && (*pPos1 != '\n'))
+ ++pPos1;
+ aResult.append(pPos, pPos1 - pPos);
+ if (pPos1 < pEnd) // newline
break;
- nOffset = 0;
- } while ((nRead = xInput->readBytes(aBuffer, nBufLen)) > 0);
+ pPos = sBuffer;
+ } while ((nRead = stream.ReadBytes(sBuffer, nBufLen)) > 0);
- xInput->closeInput();
+ stream.Close();
arg = OUString::createFromAscii(aResult.getStr());
return CommandLineEvent::ForceNew;