Graphviz 15.1.1~dev.20260630.1303
Loading...
Searching...
No Matches
gv_math.h
Go to the documentation of this file.
1
4
5#pragma once
6
7#include <assert.h>
8#include <float.h>
9#include <limits.h>
10#include <stdbool.h>
11#include <stddef.h>
12#include <string.h>
13
15static inline int fcmp(double a, double b) {
16 if (a < b) {
17 return -1;
18 }
19 if (a > b) {
20 return 1;
21 }
22 return 0;
23}
24
26static inline int imax(int a, int b) { return a > b ? a : b; }
27
29static inline size_t zmax(size_t a, size_t b) { return a > b ? a : b; }
30
32static inline size_t zmin(size_t a, size_t b) { return a < b ? a : b; }
33
35static inline int imin(int a, int b) { return a < b ? a : b; }
36
51static inline bool is_exactly_equal(double a, double b) {
52 return memcmp(&a, &b, sizeof(a)) == 0;
53}
54
70static inline bool is_exactly_zero(double v) { return is_exactly_equal(v, 0); }
71
79static inline int scale_clamp(int original, double scale) {
80 assert(original >= 0);
81
82 if (scale < 0) {
83 return 0;
84 }
85
86 if (scale > 1 && original > INT_MAX / scale) {
87 return INT_MAX;
88 }
89
90 return (int)(original * scale);
91}
92
94enum { BYTES_PER_PIXEL = 4 };
95
112static inline void argb2rgba(size_t width, size_t height, unsigned char *data) {
113 assert(data != NULL || (width == 0 && height == 0));
114
115 // indices to color bytes in each format
116 enum { Ba = 0, Ga = 1, Ra = 2, Aa = 3 };
117 enum { Rb = 0, Gb = 1, Bb = 2, Ab = 3 };
118
119 for (size_t y = 0; y < height; ++y) {
120 for (size_t x = 0; x < width; ++x) {
121 const unsigned char red = data[Ra];
122 const unsigned char blue = data[Ba];
123 data[Rb] = red;
124 data[Bb] = blue;
125 data += BYTES_PER_PIXEL;
126 }
127 }
128}
129
137#define SWAP(a, b) \
138 do { \
139 /* trigger a -Wcompare-distinct-pointer-types compiler warning if `a` */ \
140 /* and `b` have differing types */ \
141 (void)((a) == (b)); \
142 \
143 /* Swap their targets. Contemporary compilers will optimize the `memcpy`s \
144 * into direct writes for primitive types. \
145 */ \
146 char tmp_[sizeof(*(a))]; \
147 memcpy(tmp_, (a), sizeof(*(a))); \
148 *(a) = *(b); \
149 memcpy((b), tmp_, sizeof(*(b))); \
150 } while (0)
151
159static inline int d2i(double v) {
160 if (v > INT_MAX) {
161 return INT_MAX;
162 }
163 if (v < INT_MIN) {
164 return INT_MIN;
165 }
166 return (int)v;
167}
168
178static inline float d2f(double v) {
179 if (v > FLT_MAX) {
180 return FLT_MAX;
181 }
182 if (v < -FLT_MAX) {
183 return -FLT_MAX;
184 }
185 return (float)v;
186}
static WUR pointf scale(double c, pointf p)
Definition geomprocs.h:148
node NULL
Definition grammar.y:181
static int d2i(double v)
Definition gv_math.h:157
static int scale_clamp(int original, double scale)
scale up or down a non-negative integer, clamping to [0, INT_MAX]
Definition gv_math.h:79
static bool is_exactly_zero(double v)
is a value precisely 0.0?
Definition gv_math.h:70
static size_t zmin(size_t a, size_t b)
minimum of two sizes
Definition gv_math.h:32
static bool is_exactly_equal(double a, double b)
are two values precisely the same?
Definition gv_math.h:51
static int imin(int a, int b)
minimum of two integers
Definition gv_math.h:35
static int fcmp(double a, double b)
comparator for doubles
Definition gv_math.h:15
static size_t zmax(size_t a, size_t b)
maximum of two sizes
Definition gv_math.h:29
@ BYTES_PER_PIXEL
Definition gv_math.h:94
static void argb2rgba(size_t width, size_t height, unsigned char *data)
Definition gv_math.h:112
static int imax(int a, int b)
maximum of two integers
Definition gv_math.h:26
static float d2f(double v)
Definition gv_math.h:176