LibreOffice
LibreOffice 24.2 SDK C/C++ API Reference
Loading...
Searching...
No Matches
process.h
Go to the documentation of this file.
1/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2/*
3 * This file is part of the LibreOffice project.
4 *
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/.
8 *
9 * This file incorporates work covered by the following license notice:
10 *
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 .
18 */
19
20/*
21 * This file is part of LibreOffice published API.
22 */
23
24#ifndef INCLUDED_OSL_PROCESS_H
25#define INCLUDED_OSL_PROCESS_H
26
27#include "sal/config.h"
28
29#include "osl/file.h"
30#include "osl/security.h"
31#include "osl/time.h"
32#include "rtl/locale.h"
33#include "rtl/ustring.h"
34#include "sal/saldllapi.h"
35
36#ifdef __cplusplus
37extern "C" {
38#endif
39
40
41typedef sal_Int32 oslProcessOption;
42#define osl_Process_WAIT 0x0001 /* wait for completion */
43#define osl_Process_SEARCHPATH 0x0002 /* search path for executable */
44#define osl_Process_DETACHED 0x0004 /* run detached */
45#define osl_Process_NORMAL 0x0000 /* run in normal window */
46#define osl_Process_HIDDEN 0x0010 /* run hidden */
47#define osl_Process_MINIMIZED 0x0020 /* run in minimized window */
48#define osl_Process_MAXIMIZED 0x0040 /* run in maximized window */
49#define osl_Process_FULLSCREEN 0x0080 /* run in fullscreen window */
50
51typedef sal_Int32 oslProcessData;
52
53/* defines for osl_getProcessInfo , can be OR'ed */
54#define osl_Process_IDENTIFIER 0x0001 /* retrieves the process identifier */
55#define osl_Process_EXITCODE 0x0002 /* retrieves exit code of the process */
56#define osl_Process_CPUTIMES 0x0004 /* retrieves used cpu time */
57#define osl_Process_HEAPUSAGE 0x0008 /* retrieves the used size of heap */
58
59typedef sal_uInt32 oslProcessIdentifier;
60typedef sal_uInt32 oslProcessExitCode;
61
62typedef enum {
63 osl_Process_E_None, /* no error */
64 osl_Process_E_NotFound, /* image not found */
65 osl_Process_E_TimedOut, /* timeout occurred */
66 osl_Process_E_NoPermission, /* permission denied */
67 osl_Process_E_Unknown, /* unknown error */
68 osl_Process_E_InvalidError, /* unmapped error */
71
72#ifdef _WIN32
73# pragma pack(push, 8)
74#endif
75
76typedef struct {
77 sal_uInt32 Size;
83 sal_uInt32 HeapUsage;
85
86#if defined( _WIN32)
87# pragma pack(pop)
88#endif
89
98typedef void* oslProcess;
99
154 rtl_uString* ustrImageName,
155 rtl_uString* ustrArguments[],
156 sal_uInt32 nArguments,
157 oslProcessOption Options,
158 oslSecurity Security,
159 rtl_uString* ustrDirectory,
160 rtl_uString* ustrEnvironments[],
161 sal_uInt32 nEnvironmentVars,
162 oslProcess* pProcess);
163
164
233 rtl_uString* strImageName,
234 rtl_uString* ustrArguments[],
235 sal_uInt32 nArguments,
236 oslProcessOption Options,
237 oslSecurity Security,
238 rtl_uString* ustrDirectory,
239 rtl_uString* ustrEnvironments[],
240 sal_uInt32 nEnvironmentVars,
241 oslProcess* pProcess,
242 oslFileHandle* pChildInputWrite,
243 oslFileHandle* pChildOutputRead,
244 oslFileHandle* pChildErrorRead);
245
255 oslProcess Process);
256
257
267 oslProcessIdentifier Ident) SAL_COLD;
268
269
275 oslProcess Process);
276
277
286 oslProcess Process);
287
302 oslProcess Process, const TimeValue* pTimeout);
303
321 oslProcess Process, oslProcessData Fields, oslProcessInfo* pInfo);
322
335 rtl_uString **strFile);
336
341SAL_DLLPUBLIC sal_uInt32 SAL_CALL osl_getCommandArgCount(void);
342
350 sal_uInt32 nArg, rtl_uString **strCommandArg);
351
365SAL_DLLPUBLIC void SAL_CALL osl_setCommandArgs (int argc, char **argv);
366
372 rtl_uString *strVar, rtl_uString **strValue);
373
381 rtl_uString *strVar, rtl_uString *strValue);
382
389 rtl_uString *strVar);
390
398 rtl_uString **pustrWorkingDir );
399
406 rtl_Locale ** ppLocale );
407
417 rtl_Locale * pLocale );
418
419#ifdef __cplusplus
420}
421#endif
422
423#endif // INCLUDED_OSL_PROCESS_H
424
425/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
#define SAL_DLLPUBLIC
Definition saldllapi.h:34
#define SAL_MAX_ENUM
Definition types.h:205
void * oslSecurity
Process handle.
Definition security.h:49
Main goals and usage hints.
void * oslFileHandle
Definition file.h:630
The implementation structure of a locale.
Definition locale.h:47
Definition process.h:76
sal_uInt32 Size
Definition process.h:77
TimeValue SystemTime
Definition process.h:82
oslProcessIdentifier Ident
Definition process.h:79
oslProcessData Fields
Definition process.h:78
oslProcessExitCode Code
Definition process.h:80
TimeValue UserTime
Definition process.h:81
sal_uInt32 HeapUsage
Definition process.h:83
Time since Jan-01-1970.
Definition time.h:76
SAL_DLLPUBLIC oslProcessError osl_joinProcessWithTimeout(oslProcess Process, const TimeValue *pTimeout)
Wait with a timeout for the completion of the specified child process.
SAL_DLLPUBLIC oslProcessError osl_joinProcess(oslProcess Process)
Wait for completion of the specified childprocess.
SAL_DLLPUBLIC oslProcess osl_getProcess(oslProcessIdentifier Ident) SAL_COLD
SAL_DLLPUBLIC oslProcessError osl_terminateProcess(oslProcess Process)
Terminate a process.
oslProcessError
Definition process.h:62
@ osl_Process_E_None
Definition process.h:63
@ osl_Process_E_InvalidError
Definition process.h:68
@ osl_Process_E_TimedOut
Definition process.h:65
@ osl_Process_E_Unknown
Definition process.h:67
@ osl_Process_E_NoPermission
Definition process.h:66
@ osl_Process_E_FORCE_EQUAL_SIZE
Definition process.h:69
@ osl_Process_E_NotFound
Definition process.h:64
SAL_DLLPUBLIC sal_uInt32 osl_getCommandArgCount(void)
SAL_DLLPUBLIC oslProcessError osl_getProcessInfo(oslProcess Process, oslProcessData Fields, oslProcessInfo *pInfo)
Retrieves information about a Process.
SAL_DLLPUBLIC oslProcessError osl_getCommandArg(sal_uInt32 nArg, rtl_uString **strCommandArg)
Get the nArg-th command-line argument passed to the main-function of this process.
SAL_DLLPUBLIC oslProcessError osl_getProcessWorkingDir(rtl_uString **pustrWorkingDir)
Get the working directory of the current process as a file URL.
sal_uInt32 oslProcessExitCode
Definition process.h:60
SAL_DLLPUBLIC oslProcessError osl_setEnvironment(rtl_uString *strVar, rtl_uString *strValue)
Set the value of one environment variable.
SAL_DLLPUBLIC oslProcessError osl_executeProcess(rtl_uString *ustrImageName, rtl_uString *ustrArguments[], sal_uInt32 nArguments, oslProcessOption Options, oslSecurity Security, rtl_uString *ustrDirectory, rtl_uString *ustrEnvironments[], sal_uInt32 nEnvironmentVars, oslProcess *pProcess)
Execute a process.
sal_Int32 oslProcessOption
Definition process.h:41
SAL_DLLPUBLIC void osl_setCommandArgs(int argc, char **argv)
Set the command-line arguments as passed to the main-function of this process.
sal_uInt32 oslProcessIdentifier
Definition process.h:59
SAL_DLLPUBLIC oslProcessError osl_executeProcess_WithRedirectedIO(rtl_uString *strImageName, rtl_uString *ustrArguments[], sal_uInt32 nArguments, oslProcessOption Options, oslSecurity Security, rtl_uString *ustrDirectory, rtl_uString *ustrEnvironments[], sal_uInt32 nEnvironmentVars, oslProcess *pProcess, oslFileHandle *pChildInputWrite, oslFileHandle *pChildOutputRead, oslFileHandle *pChildErrorRead)
Execute a process and redirect child process standard IO.
sal_Int32 oslProcessData
Definition process.h:51
SAL_DLLPUBLIC oslProcessError osl_getProcessLocale(rtl_Locale **ppLocale)
Get the locale the process is currently running in.
SAL_DLLPUBLIC oslProcessError osl_getExecutableFile(rtl_uString **strFile)
Get the filename of the executable.
SAL_DLLPUBLIC oslProcessError osl_setProcessLocale(rtl_Locale *pLocale)
Change the locale of the process.
void * oslProcess
Process handle.
Definition process.h:98
SAL_DLLPUBLIC oslProcessError osl_clearEnvironment(rtl_uString *strVar)
Unsets the value of one environment variable.
SAL_DLLPUBLIC void osl_freeProcessHandle(oslProcess Process)
Free the specified process-handle.
SAL_DLLPUBLIC oslProcessError osl_getEnvironment(rtl_uString *strVar, rtl_uString **strValue)
Get the value of one environment variable.