0213661a7c
Xcursor loading code has hardcoded search paths, in order to take into account distros installing app data in a different location, libwayland-cursor sets the ICONDIR to the icon directory computed based on the install prefix. However, that won't work with gitlab CI because it relocates binaries. A more robust way to find cursors would be to use QStandardPaths to find all the icon directories on the system. Another advantage of using own cursor loading code is that it allows us to reuse cursor images that are symlinks. For example, with breeze_cursors, almost half of the files in the cursors directory are symlinks. The main disadvantage of this approach is that we would have to keep the search paths up to date. However, on the hand, there are not that many of them, e.g. ~/.icons, ~/.local/share/icons, /usr/share/icons, /usr/local/share/icons. The last three are implicitly handled by the QStandardPaths.
70 lines
2.2 KiB
C
70 lines
2.2 KiB
C
/*
|
|
* Copyright © 2002 Keith Packard
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining
|
|
* a copy of this software and associated documentation files (the
|
|
* "Software"), to deal in the Software without restriction, including
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
* the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice (including the
|
|
* next paragraph) shall be included in all copies or substantial
|
|
* portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*/
|
|
|
|
#ifndef XCURSOR_H
|
|
#define XCURSOR_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h>
|
|
|
|
typedef int XcursorBool;
|
|
typedef uint32_t XcursorUInt;
|
|
|
|
typedef XcursorUInt XcursorDim;
|
|
typedef XcursorUInt XcursorPixel;
|
|
|
|
typedef struct _XcursorImage {
|
|
XcursorUInt version; /* version of the image data */
|
|
XcursorDim size; /* nominal size for matching */
|
|
XcursorDim width; /* actual width */
|
|
XcursorDim height; /* actual height */
|
|
XcursorDim xhot; /* hot spot x (must be inside image) */
|
|
XcursorDim yhot; /* hot spot y (must be inside image) */
|
|
XcursorUInt delay; /* animation delay to next frame (ms) */
|
|
XcursorPixel *pixels; /* pointer to pixels */
|
|
} XcursorImage;
|
|
|
|
/*
|
|
* Other data structures exposed by the library API
|
|
*/
|
|
typedef struct _XcursorImages {
|
|
int nimage; /* number of images */
|
|
XcursorImage **images; /* array of XcursorImage pointers */
|
|
} XcursorImages;
|
|
|
|
XcursorImages *
|
|
XcursorFileLoadImages (const char *file, int size);
|
|
|
|
void
|
|
XcursorImagesDestroy (XcursorImages *images);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|