mirror of
https://github.com/swaywm/sway.git
synced 2024-12-30 17:06:40 +01:00
Merge pull request #562 from fluxchief/border-endian
improve endianess handeling
This commit is contained in:
commit
ef45bac131
1 changed files with 9 additions and 14 deletions
|
@ -8,21 +8,16 @@
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "client/pango.h"
|
#include "client/pango.h"
|
||||||
|
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
|
||||||
void cairo_set_source_u32(cairo_t *cairo, uint32_t color) {
|
void cairo_set_source_u32(cairo_t *cairo, uint32_t color) {
|
||||||
int endian = 1;
|
color = htonl(color);
|
||||||
if (*(char *)&endian == 1) { // little endian
|
|
||||||
cairo_set_source_rgba(cairo,
|
cairo_set_source_rgba(cairo,
|
||||||
|
(color >> (2*8) & 0xFF) / 255.0,
|
||||||
(color >> (1*8) & 0xFF) / 255.0,
|
(color >> (1*8) & 0xFF) / 255.0,
|
||||||
(color >> (2*8) & 0xFF) / 255.0,
|
|
||||||
(color >> (3*8) & 0xFF) / 255.0,
|
|
||||||
(color >> (0*8) & 0xFF) / 255.0);
|
|
||||||
} else { // big endian
|
|
||||||
cairo_set_source_rgba(cairo,
|
|
||||||
(color >> (0*8) & 0xFF) / 255.0,
|
(color >> (0*8) & 0xFF) / 255.0,
|
||||||
(color >> (3*8) & 0xFF) / 255.0,
|
(color >> (3*8) & 0xFF) / 255.0);
|
||||||
(color >> (2*8) & 0xFF) / 255.0,
|
|
||||||
(color >> (1*8) & 0xFF) / 255.0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static cairo_t *create_border_buffer(swayc_t *view, struct wlc_geometry geo, cairo_surface_t **surface) {
|
static cairo_t *create_border_buffer(swayc_t *view, struct wlc_geometry geo, cairo_surface_t **surface) {
|
||||||
|
|
Loading…
Reference in a new issue