view src/core/sys.h @ 61:8d34a12484db

core: game should present the window at the very end
author David Demelier <markand@malikania.fr>
date Wed, 22 Jan 2020 12:12:25 +0100
parents 52792b863ff7
children 6203e1ac9b18
line wrap: on
line source

/*
 * sys.h -- system routines
 *
 * Copyright (c) 2020 David Demelier <markand@malikania.fr>
 *
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

#ifndef MOLKO_SYS_H
#define MOLKO_SYS_H

/**
 * \file sys.h
 * \brief System routines.
 */

#include <stdarg.h>
#include <stdbool.h>

/**
 * Initialize the system, should be called in the beginning of the main.
 */
bool
sys_init(void);

/**
 * Get the base system directory path.
 *
 * \return the path where the executable lives
 */
const char *
sys_datadir(void);

/**
 * Construct path to assets directory using printf-like format.
 *
 * \param fmt the format string
 * \return the path to the file
 * \note This function returns pointer to static string.
 */
const char *
sys_datapath(const char *fmt, ...);

/**
 * Similar to \a sys_datapath.
 *
 * \param fmt the format string
 * \param ap the variadic arguments pointer
 * \return the path to the file
 * \note This function returns pointer to static string.
 */
const char *
sys_datapathv(const char *fmt, va_list ap);

/**
 * Close the system.
 */
void
sys_close(void);

#endif /* !MOLKO_SYS_H */