1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
23 #define WIN32_LEAN_AND_MEAN
27 #define MY_LENGTH(s) (sizeof (s) / sizeof *(s) - 1)
28 #define MY_STRING(s) (s), MY_LENGTH(s)
30 namespace desktop_win32
{
32 inline WCHAR
* commandLineAppend(
33 WCHAR
* buffer
, WCHAR
const * text
, std::size_t length
)
35 wcsncpy(buffer
, text
, length
+ 1); // trailing null
36 return buffer
+ length
;
39 inline WCHAR
* commandLineAppend(WCHAR
* buffer
, WCHAR
const * text
) {
40 return commandLineAppend(buffer
, text
, wcslen(text
));
43 inline WCHAR
* commandLineAppendEncoded(WCHAR
* buffer
, WCHAR
const * text
) {
49 } else if (c
== L
'$') {
50 buffer
= commandLineAppend(buffer
, MY_STRING(L
"\\$"));
52 } else if (c
== L
'\\') {
53 buffer
= commandLineAppend(buffer
, MY_STRING(L
"\\\\"));
60 // The command line will continue with a double quote, so double any
61 // preceding backslashes as required by Windows:
62 for (std::size_t i
= 0; i
< n
; ++i
) {
69 // Set the PATH environment variable in the current (loader) process, so that a
70 // following CreateProcess has the necessary environment:
72 // Must point to an array of size at least MAX_PATH. Is filled with the null
73 // terminated full path to the "bin" file corresponding to the current
75 // @param iniDirectory
76 // Must point to an array of size at least MAX_PATH. Is filled with the null
77 // terminated full directory path (ending in "\") to the "ini" file
78 // corresponding to the current executable.
79 void extendLoaderEnvironment(WCHAR
* binPath
, WCHAR
* iniDirectory
);
81 // Implementation of the process guarding soffice.bin
82 int officeloader_impl(bool bAllowConsole
);
84 // Implementation of the process guarding unopkg.bin
85 int unopkgloader_impl(bool bAllowConsole
);
89 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */