diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 13:18:03 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 13:18:03 +0000 |
commit | afce081b90c1e2c50c3507758c7558a0dfa1f33e (patch) | |
tree | 3fb840f0bd9de41b463443ddf17131a0ad77f226 /src/xpm_w32.c | |
parent | Initial commit. (diff) | |
download | vim-afce081b90c1e2c50c3507758c7558a0dfa1f33e.tar.xz vim-afce081b90c1e2c50c3507758c7558a0dfa1f33e.zip |
Adding upstream version 2:8.2.2434.upstream/2%8.2.2434upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/xpm_w32.c')
-rw-r--r-- | src/xpm_w32.c | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/src/xpm_w32.c b/src/xpm_w32.c new file mode 100644 index 0000000..111988a --- /dev/null +++ b/src/xpm_w32.c @@ -0,0 +1,56 @@ +/* vi:set ts=8 sts=4 sw=4 noet: + * + * Load XPM image. + * + * This function is placed in separate file because Xpm headers conflict with + * Vim ones :( + * + * Written by Sergey Khorev. + * http://iamphet.nm.ru/vim/index.html + */ + +#ifndef WIN32_LEAN_AND_MEAN +# define WIN32_LEAN_AND_MEAN +#endif +#include <windows.h> + +#include "xpm_w32.h" + +// Engage Windows support in libXpm +#define FOR_MSW + +#include "xpm.h" + +/* + * Tries to load an Xpm image from the file "filename". + * Returns -1 on failure. + * Returns 0 on success and stores image and mask BITMAPS in "hImage" and + * "hShape". + */ + int +LoadXpmImage( + char *filename, + HBITMAP *hImage, + HBITMAP *hShape) +{ + XImage *img; // loaded image + XImage *shp; // shapeimage + XpmAttributes attr; + int res; + HDC hdc = CreateCompatibleDC(NULL); + + attr.valuemask = 0; + res = XpmReadFileToImage(&hdc, filename, &img, &shp, &attr); + DeleteDC(hdc); + if (res < 0) + return -1; + if (shp == NULL) + { + if (img) + XDestroyImage(img); + return -1; + } + *hImage = img->bitmap; + *hShape = shp->bitmap; + return 0; +} |