153a5a1b3Sopenharmony_ci#ifndef fooutilhfoo 253a5a1b3Sopenharmony_ci#define fooutilhfoo 353a5a1b3Sopenharmony_ci 453a5a1b3Sopenharmony_ci/*** 553a5a1b3Sopenharmony_ci This file is part of PulseAudio. 653a5a1b3Sopenharmony_ci 753a5a1b3Sopenharmony_ci Copyright 2004-2006 Lennart Poettering 853a5a1b3Sopenharmony_ci Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB 953a5a1b3Sopenharmony_ci 1053a5a1b3Sopenharmony_ci PulseAudio is free software; you can redistribute it and/or modify 1153a5a1b3Sopenharmony_ci it under the terms of the GNU Lesser General Public License as 1253a5a1b3Sopenharmony_ci published by the Free Software Foundation; either version 2.1 of the 1353a5a1b3Sopenharmony_ci License, or (at your option) any later version. 1453a5a1b3Sopenharmony_ci 1553a5a1b3Sopenharmony_ci PulseAudio is distributed in the hope that it will be useful, but 1653a5a1b3Sopenharmony_ci WITHOUT ANY WARRANTY; without even the implied warranty of 1753a5a1b3Sopenharmony_ci MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1853a5a1b3Sopenharmony_ci Lesser General Public License for more details. 1953a5a1b3Sopenharmony_ci 2053a5a1b3Sopenharmony_ci You should have received a copy of the GNU Lesser General Public 2153a5a1b3Sopenharmony_ci License along with PulseAudio; if not, see <http://www.gnu.org/licenses/>. 2253a5a1b3Sopenharmony_ci***/ 2353a5a1b3Sopenharmony_ci 2453a5a1b3Sopenharmony_ci#include <stddef.h> 2553a5a1b3Sopenharmony_ci 2653a5a1b3Sopenharmony_ci#include <pulse/cdecl.h> 2753a5a1b3Sopenharmony_ci#include <pulse/version.h> 2853a5a1b3Sopenharmony_ci 2953a5a1b3Sopenharmony_ci/** \file 3053a5a1b3Sopenharmony_ci * Assorted utility functions */ 3153a5a1b3Sopenharmony_ci 3253a5a1b3Sopenharmony_ciPA_C_DECL_BEGIN 3353a5a1b3Sopenharmony_ci 3453a5a1b3Sopenharmony_ci/** Return the current username in the specified string buffer. */ 3553a5a1b3Sopenharmony_cichar *pa_get_user_name(char *s, size_t l); 3653a5a1b3Sopenharmony_ci 3753a5a1b3Sopenharmony_ci/** Return the current hostname in the specified buffer. */ 3853a5a1b3Sopenharmony_cichar *pa_get_host_name(char *s, size_t l); 3953a5a1b3Sopenharmony_ci 4053a5a1b3Sopenharmony_ci/** Return the fully qualified domain name in s */ 4153a5a1b3Sopenharmony_cichar *pa_get_fqdn(char *s, size_t l); 4253a5a1b3Sopenharmony_ci 4353a5a1b3Sopenharmony_ci/** Return the home directory of the current user */ 4453a5a1b3Sopenharmony_cichar *pa_get_home_dir(char *s, size_t l); 4553a5a1b3Sopenharmony_ci 4653a5a1b3Sopenharmony_ci/** Return the binary file name of the current process. This is not 4753a5a1b3Sopenharmony_ci * supported on all architectures, in which case NULL is returned. */ 4853a5a1b3Sopenharmony_cichar *pa_get_binary_name(char *s, size_t l); 4953a5a1b3Sopenharmony_ci 5053a5a1b3Sopenharmony_ci/** Return a pointer to the filename inside a path (which is the last 5153a5a1b3Sopenharmony_ci * component). If passed NULL will return NULL. */ 5253a5a1b3Sopenharmony_cichar *pa_path_get_filename(const char *p); 5353a5a1b3Sopenharmony_ci 5453a5a1b3Sopenharmony_ci/** Wait t milliseconds */ 5553a5a1b3Sopenharmony_ciint pa_msleep(unsigned long t); 5653a5a1b3Sopenharmony_ci 5753a5a1b3Sopenharmony_ci/** Make the calling thread realtime if we can. On Linux, this uses RealTimeKit 5853a5a1b3Sopenharmony_ci * if available and POSIX APIs otherwise (the latter applies to other UNIX 5953a5a1b3Sopenharmony_ci * variants as well). This is also implemented for macOS and Windows. 6053a5a1b3Sopenharmony_ci * \since 13.0 */ 6153a5a1b3Sopenharmony_ciint pa_thread_make_realtime(int rtprio); 6253a5a1b3Sopenharmony_ci 6353a5a1b3Sopenharmony_ciPA_C_DECL_END 6453a5a1b3Sopenharmony_ci 6553a5a1b3Sopenharmony_ci#endif 66