fix baseline build (old cairo) - 'cairo_rectangle_int_t' does not name a type
[LibreOffice.git] / desktop / win32 / source / loader.hxx
blobe8a987650036ff1e5db53740c2e0a9bd4b406467
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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 .
20 #ifndef INCLUDED_DESKTOP_WIN32_SOURCE_LOADER_HXX
21 #define INCLUDED_DESKTOP_WIN32_SOURCE_LOADER_HXX
23 #include <sal/config.h>
25 #include <cstddef>
27 #include <tchar.h>
29 #define MY_LENGTH(s) (sizeof (s) / sizeof *(s) - 1)
30 #define MY_STRING(s) (s), MY_LENGTH(s)
32 namespace desktop_win32 {
34 inline WCHAR * commandLineAppend(
35 WCHAR * buffer, WCHAR const * text, std::size_t length)
37 wcsncpy(buffer, text, length + 1); // trailing null
38 return buffer + length;
41 inline WCHAR * commandLineAppend(WCHAR * buffer, WCHAR const * text) {
42 return commandLineAppend(buffer, text, wcslen(text));
45 inline WCHAR * commandLineAppendEncoded(WCHAR * buffer, WCHAR const * text) {
46 std::size_t n = 0;
47 for (;;) {
48 WCHAR c = *text++;
49 if (c == L'\0') {
50 break;
51 } else if (c == L'$') {
52 buffer = commandLineAppend(buffer, MY_STRING(L"\\$"));
53 n = 0;
54 } else if (c == L'\\') {
55 buffer = commandLineAppend(buffer, MY_STRING(L"\\\\"));
56 n += 2;
57 } else {
58 *buffer++ = c;
59 n = 0;
62 // The command line will continue with a double quote, so double any
63 // preceding backslashes as required by Windows:
64 for (std::size_t i = 0; i < n; ++i) {
65 *buffer++ = L'\\';
67 *buffer = L'\0';
68 return buffer;
71 // @param binPath
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
74 // executable.
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 getPaths(WCHAR * binPath, WCHAR * iniDirectory);
83 #endif
85 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */