Утиліти операційної системи

PyObject *PyOS_FSPath(PyObject *path)
Return value: New reference. Part of the Stable ABI since version 3.6.

Return the file system representation for path. If the object is a str or bytes object, then a new strong reference is returned. If the object implements the os.PathLike interface, then __fspath__() is returned as long as it is a str or bytes object. Otherwise TypeError is raised and NULL is returned.

Added in version 3.6.

int Py_FdIsInteractive(FILE *fp, const char *filename)

Return true (nonzero) if the standard I/O file fp with name filename is deemed interactive. This is the case for files for which isatty(fileno(fp)) is true. If the PyConfig.interactive is non-zero, this function also returns true if the filename pointer is NULL or if the name is equal to one of the strings '<stdin>' or '???'.

This function must not be called before Python is initialized.

void PyOS_BeforeFork()
Part of the Stable ABI on platforms with fork() since version 3.7.

Функція для підготовки деякого внутрішнього стану перед розгалуженням процесу. Це слід викликати перед викликом fork() або будь-якої подібної функції, яка клонує поточний процес. Доступно лише в системах, де визначено fork().

Попередження

Виклик C fork() має здійснюватися лише з «main» потоку«main» інтерпретатора). Те саме стосується PyOS_BeforeFork().

Added in version 3.7.

void PyOS_AfterFork_Parent()
Part of the Stable ABI on platforms with fork() since version 3.7.

Функція для оновлення деякого внутрішнього стану після розгалуження процесу. Це слід викликати з батьківського процесу після виклику fork() або будь-якої подібної функції, яка клонує поточний процес, незалежно від того, чи клонування процесу було успішним. Доступно лише в системах, де визначено fork().

Попередження

Виклик C fork() має здійснюватися лише з «main» потоку«main» інтерпретатора). Те саме стосується PyOS_AfterFork_Parent().

Added in version 3.7.

void PyOS_AfterFork_Child()
Part of the Stable ABI on platforms with fork() since version 3.7.

Функція для оновлення стану внутрішнього інтерпретатора після розгалуження процесу. Це має бути викликано з дочірнього процесу після виклику fork() або будь-якої подібної функції, яка клонує поточний процес, якщо є шанс, що процес знову викличе інтерпретатор Python. Доступно лише в системах, де визначено fork().

Попередження

Виклик C fork() має здійснюватися лише з «main» потоку«main» інтерпретатора). Те саме стосується PyOS_AfterFork_Child().

Added in version 3.7.

Дивись також

os.register_at_fork() дозволяє реєструвати користувацькі функції Python для виклику PyOS_BeforeFork(), PyOS_AfterFork_Parent() і PyOS_AfterFork_Child().

void PyOS_AfterFork()
Part of the Stable ABI on platforms with fork().

Функція для оновлення деякого внутрішнього стану після розгалуження процесу; це слід викликати в новому процесі, якщо інтерпретатор Python продовжуватиме використовуватися. Якщо новий виконуваний файл завантажується в новий процес, цю функцію не потрібно викликати.

Застаріло починаючи з версії 3.7: Цю функцію замінює PyOS_AfterFork_Child().

int PyOS_CheckStack()
Part of the Stable ABI on platforms with USE_STACKCHECK since version 3.7.

Return true when the interpreter runs out of stack space. This is a reliable check, but is only available when USE_STACKCHECK is defined (currently on certain versions of Windows using the Microsoft Visual C++ compiler). USE_STACKCHECK will be defined automatically; you should never change the definition in your own code.

typedef void (*PyOS_sighandler_t)(int)
Part of the Stable ABI.
PyOS_sighandler_t PyOS_getsig(int i)
Part of the Stable ABI.

Return the current signal handler for signal i. This is a thin wrapper around either sigaction() or signal(). Do not call those functions directly!

PyOS_sighandler_t PyOS_setsig(int i, PyOS_sighandler_t h)
Part of the Stable ABI.

Set the signal handler for signal i to be h; return the old signal handler. This is a thin wrapper around either sigaction() or signal(). Do not call those functions directly!

wchar_t *Py_DecodeLocale(const char *arg, size_t *size)
Part of the Stable ABI since version 3.7.

Попередження

Цю функцію не слід викликати безпосередньо: використовуйте PyConfig API з функцією PyConfig_SetBytesString(), яка гарантує, що Python попередньо ініціалізовано.

Цю функцію не можна викликати до Python попередньо ініціалізовано і щоб локаль LC_CTYPE була правильно налаштована: див. функцію Py_PreInitialize().

Декодуйте рядок байтів із filesystem encoding and error handler. Якщо обробником помилок є surrogateescape error handler, недекодовані байти декодуються як символи в діапазоні U+DC80..U+DCFF; і якщо послідовність байтів може бути декодована як сурогатний символ, байти екрануються за допомогою обробника помилок surrogateescape замість їх декодування.

Поверніть вказівник на щойно виділений широкий рядок символів, використовуйте PyMem_RawFree(), щоб звільнити пам’ять. Якщо розмір не дорівнює NULL, запишіть кількість широких символів, за винятком нульового символу, у *size

Повертає NULL у разі помилки декодування або помилки виділення пам’яті. Якщо size не дорівнює NULL, *size встановлюється на (size_t)-1 у разі помилки пам’яті або встановлюється на (size_t)-2 у разі помилки декодування.

filesystem encoding and error handler вибираються PyConfig_Read(): див. члени filesystem_encoding і filesystem_errors PyConfig.

Помилки декодування ніколи не повинні траплятися, якщо немає помилки в бібліотеці C.

Використовуйте функцію Py_EncodeLocale(), щоб закодувати рядок символів назад у рядок байтів.

Дивись також

Функції PyUnicode_DecodeFSDefaultAndSize() і PyUnicode_DecodeLocaleAndSize().

Added in version 3.5.

Змінено в версії 3.7: Тепер функція використовує кодування UTF-8 у режимі Python UTF-8 Mode.

Змінено в версії 3.8: The function now uses the UTF-8 encoding on Windows if PyPreConfig.legacy_windows_fs_encoding is zero;

char *Py_EncodeLocale(const wchar_t *text, size_t *error_pos)
Part of the Stable ABI since version 3.7.

Закодуйте широкий рядок символів у filesystem encoding and error handler. Якщо обробником помилок є surrogateescape error handler, сурогатні символи в діапазоні U+DC80..U+DCFF перетворюються на байти 0x80..0xFF.

Поверніть вказівник на щойно виділений рядок байтів, використовуйте PyMem_Free(), щоб звільнити пам’ять. Повертає NULL у разі помилки кодування або помилки виділення пам’яті.

Якщо error_pos не дорівнює NULL, *error_pos встановлюється на (size_t)-1 у разі успіху або встановлюється на індекс недійсного символу в разі помилки кодування.

filesystem encoding and error handler вибираються PyConfig_Read(): див. члени filesystem_encoding і filesystem_errors PyConfig.

Використовуйте функцію Py_DecodeLocale(), щоб декодувати рядок байтів назад до широкого рядка символів.

Попередження

Цю функцію не можна викликати до Python попередньо ініціалізовано і щоб локаль LC_CTYPE була правильно налаштована: див. функцію Py_PreInitialize().

Дивись також

Функції PyUnicode_EncodeFSDefault() і PyUnicode_EncodeLocale().

Added in version 3.5.

Змінено в версії 3.7: Тепер функція використовує кодування UTF-8 у режимі Python UTF-8 Mode.

Змінено в версії 3.8: The function now uses the UTF-8 encoding on Windows if PyPreConfig.legacy_windows_fs_encoding is zero.

Системні функції

Це службові функції, які роблять функціональні можливості модуля sys доступними для коду C. Усі вони працюють із dict модуля sys поточного потоку інтерпретатора, який міститься у внутрішній структурі стану потоку.

PyObject *PySys_GetObject(const char *name)
Return value: Borrowed reference. Part of the Stable ABI.

Повертає ім’я об’єкта з модуля sys або NULL, якщо він не існує, без встановлення винятку.

int PySys_SetObject(const char *name, PyObject *v)
Part of the Stable ABI.

Встановіть name у модулі sys на v, якщо v не має значення NULL, у цьому випадку name буде видалено з модуля sys. Повертає 0 у разі успіху, -1 у разі помилки.

void PySys_ResetWarnOptions()
Part of the Stable ABI.

Скинути sys.warnoptions до порожнього списку. Цю функцію можна викликати перед Py_Initialize().

Deprecated since version 3.13, will be removed in version 3.15: Clear sys.warnoptions and warnings.filters instead.

void PySys_WriteStdout(const char *format, ...)
Part of the Stable ABI.

Запишіть вихідний рядок, описаний format, у sys.stdout. Ніяких винятків не викликається, навіть якщо відбувається скорочення (див. нижче).

format має обмежувати загальний розмір відформатованого вихідного рядка до 1000 байтів або менше – після 1000 байтів вихідний рядок скорочується. Зокрема, це означає, що необмежені формати «%s» не повинні відбуватися; їх слід обмежити за допомогою «%. <N> s», де <N> — це десяткове число, обчислене таким чином, що <N> плюс максимальний розмір іншого відформатованого тексту не перевищує 1000 байт. Також слідкуйте за «%f», який може друкувати сотні цифр для дуже великих чисел.

Якщо виникає проблема або sys.stdout не налаштовано, форматоване повідомлення записується в реальний (рівень C) stdout.

void PySys_WriteStderr(const char *format, ...)
Part of the Stable ABI.

Як PySys_WriteStdout(), але натомість записуйте в sys.stderr або stderr.

void PySys_FormatStdout(const char *format, ...)
Part of the Stable ABI.

Функція схожа на PySys_WriteStdout(), але форматує повідомлення за допомогою PyUnicode_FromFormatV() і не скорочує повідомлення до довільної довжини.

Added in version 3.2.

void PySys_FormatStderr(const char *format, ...)
Part of the Stable ABI.

Як PySys_FormatStdout(), але замість цього записуйте в sys.stderr або stderr.

Added in version 3.2.

PyObject *PySys_GetXOptions()
Return value: Borrowed reference. Part of the Stable ABI since version 3.7.

Повертає поточний словник параметрів -X, подібно до sys._xoptions. У разі помилки повертається NULL і встановлюється виняток.

Added in version 3.2.

int PySys_Audit(const char *event, const char *format, ...)
Part of the Stable ABI since version 3.13.

Викликати подію аудиту з будь-якими активними хуками. Повертає нуль у разі успіху та відмінний від нуля з винятком, встановленим у випадку невдачі.

The event string argument must not be NULL.

If any hooks have been added, format and other arguments will be used to construct a tuple to pass. Apart from N, the same format characters as used in Py_BuildValue() are available. If the built value is not a tuple, it will be added into a single-element tuple.

The N format option must not be used. It consumes a reference, but since there is no way to know whether arguments to this function will be consumed, using it may cause reference leaks.

Зауважте, що символи формату # завжди слід розглядати як Py_ssize_t, незалежно від того, чи було визначено PY_SSIZE_T_CLEAN.

sys.audit() виконує ту саму функцію з коду Python.

See also PySys_AuditTuple().

Added in version 3.8.

Змінено в версії 3.8.2: Вимагати Py_ssize_t для символів формату #. Раніше виникало неминуче попередження про застарілу версію.

int PySys_AuditTuple(const char *event, PyObject *args)
Part of the Stable ABI since version 3.13.

Similar to PySys_Audit(), but pass arguments as a Python object. args must be a tuple. To pass no arguments, args can be NULL.

Added in version 3.13.

int PySys_AddAuditHook(Py_AuditHookFunction hook, void *userData)

Додайте хук, який можна викликати, до списку активних хуків аудиту. Повертає нуль у разі успіху та ненуль у разі невдачі. Якщо середовище виконання було ініціалізовано, також установіть помилку в разі помилки. Хуки, додані через цей API, викликаються для всіх інтерпретаторів, створених середовищем виконання.

Покажчик userData передається в функцію-перехоплювач. Оскільки функції підключення можуть викликатися з різних середовищ виконання, цей вказівник не повинен посилатися безпосередньо на стан Python.

Цю функцію безпечно викликати перед Py_Initialize(). Під час виклику після ініціалізації середовища виконання наявні перехоплювачі аудиту отримують сповіщення та можуть мовчки перервати операцію, викликавши помилку підкласу з Exception (інші помилки не будуть заглушені).

The hook function is always called with the GIL held by the Python interpreter that raised the event.

Дивіться PEP 578 для детального опису аудиту. Функції середовища виконання та стандартної бібліотеки, які викликають події, перераховані в таблиці подій аудиту. Подробиці наведено в документації кожної функції.

If the interpreter is initialized, this function raises an auditing event sys.addaudithook with no arguments. If any existing hooks raise an exception derived from Exception, the new hook will not be added and the exception is cleared. As a result, callers cannot assume that their hook has been added unless they control all existing hooks.

typedef int (*Py_AuditHookFunction)(const char *event, PyObject *args, void *userData)

The type of the hook function. event is the C string event argument passed to PySys_Audit() or PySys_AuditTuple(). args is guaranteed to be a PyTupleObject. userData is the argument passed to PySys_AddAuditHook().

Added in version 3.8.

Контроль процесів

void Py_FatalError(const char *message)
Part of the Stable ABI.

Print a fatal error message and kill the process. No cleanup is performed. This function should only be invoked when a condition is detected that would make it dangerous to continue using the Python interpreter; e.g., when the object administration appears to be corrupted. On Unix, the standard C library function abort() is called which will attempt to produce a core file.

Функцію Py_FatalError() замінено макросом, який автоматично реєструє назву поточної функції, якщо не визначено макрос Py_LIMITED_API.

Змінено в версії 3.9: Автоматично реєструйте назву функції.

void Py_Exit(int status)
Part of the Stable ABI.

Вийти з поточного процесу. Це викликає Py_FinalizeEx(), а потім викликає стандартну функцію бібліотеки C exit(status). Якщо Py_FinalizeEx() вказує на помилку, статус виходу встановлюється на 120.

Змінено в версії 3.6: Помилки під час фіналізації більше не ігноруються.

int Py_AtExit(void (*func)())
Part of the Stable ABI.

Зареєструйте функцію очищення, яку буде викликати Py_FinalizeEx(). Функція очищення буде викликана без аргументів і не повинна повертати значення. Можна зареєструвати щонайбільше 32 функції очищення. Після успішної реєстрації Py_AtExit() повертає 0; у разі помилки повертає -1. Першою викликається функція очищення, зареєстрована останньою. Кожна функція очищення буде викликана щонайбільше один раз. Оскільки внутрішня фіналізація Python буде завершена до виконання функції очищення, жодні API Python не повинні викликатися за допомогою func.