blob: 5af144aee0c878d55a14ca7f7759cced3836023b [file] [log] [blame]
/*
* BRLTTY - A background process providing access to the console screen (when in
* text mode) for a blind person using a refreshable braille display.
*
* Copyright (C) 1995-2023 by The BRLTTY Developers.
*
* BRLTTY comes with ABSOLUTELY NO WARRANTY.
*
* This is free software, placed under the terms of the
* GNU Lesser General Public License, as published by the Free Software
* Foundation; either version 2.1 of the License, or (at your option) any
* later version. Please see the file LICENSE-LGPL for details.
*
* Web Page: http://brltty.app/
*
* This software is maintained by Dave Mielke <dave@mielke.cc>.
*/
#ifndef BRLTTY_INCLUDED_PROGRAM
#define BRLTTY_INCLUDED_PROGRAM
#include "pid.h"
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
extern const char standardStreamArgument[];
extern const char standardInputName[];
extern const char standardOutputName[];
extern const char standardErrorName[];
typedef enum {
PROG_EXIT_SUCCESS = 0,
PROG_EXIT_FORCE = 1,
PROG_EXIT_SYNTAX = 2,
PROG_EXIT_SEMANTIC = 3,
PROG_EXIT_FATAL = 4
} ProgramExitStatus;
extern const char *programPath;
extern const char *programName;
extern void beginProgram (int argumentCount, char **argumentVector);
extern void endProgram (void);
typedef void ProgramExitHandler (void *data);
extern void onProgramExit (const char *name, ProgramExitHandler *handler, void *data);
extern void registerProgramMemory (const char *name, void *pointer);
extern const char *getProgramDirectory(void);
extern int fixInstallPath (char **path);
extern char *makeProgramPath(const char *name);
extern char *makeCommandPath(const char *name);
extern int createPidFile (const char *path, ProcessIdentifier pid);
extern int cancelProgram (const char *pidFile);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* BRLTTY_INCLUDED_PROGRAM */