2015-08-26 03:53:59 +10:00
|
|
|
#ifndef _SWAY_UTIL_H
|
|
|
|
#define _SWAY_UTIL_H
|
|
|
|
|
2016-01-06 04:07:43 +11:00
|
|
|
#include <stdint.h>
|
2016-06-10 21:08:59 +10:00
|
|
|
#include <unistd.h>
|
2016-01-06 04:07:43 +11:00
|
|
|
#include <xkbcommon/xkbcommon.h>
|
|
|
|
|
2015-08-25 23:17:18 +10:00
|
|
|
/**
|
|
|
|
* Wrap i into the range [0, max[
|
|
|
|
*/
|
|
|
|
int wrap(int i, int max);
|
2015-08-26 03:53:59 +10:00
|
|
|
|
2016-01-24 08:35:32 +11:00
|
|
|
/**
|
|
|
|
* Count number of digits in int
|
|
|
|
*/
|
|
|
|
int numlen(int n);
|
|
|
|
|
2016-01-06 04:07:43 +11:00
|
|
|
/**
|
|
|
|
* Get modifier mask from modifier name.
|
|
|
|
*
|
|
|
|
* Returns the modifer mask or 0 if the name isn't found.
|
|
|
|
*/
|
|
|
|
uint32_t get_modifier_mask_by_name(const char *name);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get modifier name from modifier mask.
|
|
|
|
*
|
|
|
|
* Returns the modifier name or NULL if it isn't found.
|
|
|
|
*/
|
|
|
|
const char *get_modifier_name_by_mask(uint32_t modifier);
|
|
|
|
|
2016-01-07 02:59:54 +11:00
|
|
|
/**
|
|
|
|
* Get an array of modifier names from modifier_masks
|
|
|
|
*
|
|
|
|
* Populates the names array and return the number of names added.
|
|
|
|
*/
|
|
|
|
int get_modifier_names(const char **names, uint32_t modifier_masks);
|
|
|
|
|
2016-06-10 21:08:59 +10:00
|
|
|
/**
|
|
|
|
* Get the pid of a parent process given the pid of a child process.
|
|
|
|
*
|
|
|
|
* Returns the parent pid or NULL if the parent pid cannot be determined.
|
|
|
|
*/
|
|
|
|
pid_t get_parent_pid(pid_t pid);
|
|
|
|
|
2016-07-31 09:50:13 +10:00
|
|
|
/**
|
|
|
|
* Given a string that represents an RGB(A) color, return a uint32_t
|
|
|
|
* version of the color.
|
|
|
|
*/
|
|
|
|
uint32_t parse_color(const char *color);
|
|
|
|
|
2017-04-15 06:37:43 +10:00
|
|
|
/**
|
|
|
|
* Given a path string, recurseively resolves any symlinks to their targets
|
|
|
|
* (which may be a file, directory) and returns the result.
|
|
|
|
* argument is returned. Caller must free the returned buffer.
|
|
|
|
* If an error occures, if the path does not exist or if the path corresponds
|
|
|
|
* to a dangling symlink, NULL is returned.
|
|
|
|
*/
|
|
|
|
char* resolve_path(const char* path);
|
2015-08-26 03:53:59 +10:00
|
|
|
#endif
|