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