2012-01-08 17:39:03 +00:00
|
|
|
#ifndef UTILS_H
|
|
|
|
#define UTILS_H
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2012-02-01 18:45:59 +00:00
|
|
|
#include <string>
|
2012-07-29 14:58:56 +01:00
|
|
|
#include <sstream>
|
2012-07-27 20:06:17 +01:00
|
|
|
#include <vector>
|
2012-01-08 17:39:03 +00:00
|
|
|
|
2012-07-29 19:14:14 +03:00
|
|
|
#if defined(WIN) && !defined(__GNUC__)
|
2012-01-08 17:39:03 +00:00
|
|
|
#define x86_cpuid(func,af,bf,cf,df) \
|
|
|
|
do {\
|
|
|
|
__asm mov eax, func\
|
|
|
|
__asm cpuid\
|
|
|
|
__asm mov af, eax\
|
|
|
|
__asm mov bf, ebx\
|
|
|
|
__asm mov cf, ecx\
|
|
|
|
__asm mov df, edx\
|
|
|
|
} while(0)
|
|
|
|
#else
|
|
|
|
#define x86_cpuid(func,af,bf,cf,df) \
|
|
|
|
__asm__ __volatile ("cpuid":\
|
|
|
|
"=a" (af), "=b" (bf), "=c" (cf), "=d" (df) : "a" (func));
|
|
|
|
#endif
|
|
|
|
|
2012-11-18 22:24:56 +00:00
|
|
|
//Linear interpolation
|
|
|
|
template <typename T> inline T LinearInterpolate(T val1, T val2, T lowerCoord, T upperCoord, T coord)
|
|
|
|
{
|
|
|
|
if(lowerCoord == upperCoord) return val1;
|
|
|
|
return (((val2 - val1) / (upperCoord - lowerCoord)) * (coord - lowerCoord)) + val1;
|
|
|
|
}
|
|
|
|
|
2012-01-08 17:39:03 +00:00
|
|
|
//Signum function
|
|
|
|
int isign(float i);
|
|
|
|
|
|
|
|
unsigned clamp_flt(float f, float min, float max);
|
|
|
|
|
|
|
|
float restrict_flt(float f, float min, float max);
|
|
|
|
|
2013-10-26 19:38:50 +04:00
|
|
|
char *mystrdup(const char *s);
|
2012-01-08 17:39:03 +00:00
|
|
|
|
|
|
|
struct strlist
|
|
|
|
{
|
|
|
|
char *str;
|
|
|
|
struct strlist *next;
|
|
|
|
};
|
|
|
|
|
|
|
|
void strlist_add(struct strlist **list, char *str);
|
|
|
|
|
|
|
|
int strlist_find(struct strlist **list, char *str);
|
|
|
|
|
|
|
|
void strlist_free(struct strlist **list);
|
|
|
|
|
|
|
|
void save_presets(int do_update);
|
|
|
|
|
|
|
|
void load_presets(void);
|
|
|
|
|
2013-10-26 19:38:50 +04:00
|
|
|
void strcaturl(char *dst, const char *src);
|
2012-01-08 17:39:03 +00:00
|
|
|
|
2013-10-26 19:38:50 +04:00
|
|
|
void strappend(char *dst, const char *src);
|
2012-01-08 17:39:03 +00:00
|
|
|
|
|
|
|
void *file_load(char *fn, int *size);
|
|
|
|
|
|
|
|
extern char *clipboard_text;
|
|
|
|
|
|
|
|
void HSV_to_RGB(int h,int s,int v,int *r,int *g,int *b);
|
|
|
|
|
|
|
|
void RGB_to_HSV(int r,int g,int b,int *h,int *s,int *v);
|
|
|
|
|
|
|
|
void membwand(void * dest, void * src, size_t destsize, size_t srcsize);
|
2013-08-22 19:50:20 +04:00
|
|
|
|
2012-01-08 17:39:03 +00:00
|
|
|
// a b
|
|
|
|
// c d
|
|
|
|
|
|
|
|
struct matrix2d {
|
|
|
|
float a,b,c,d;
|
|
|
|
};
|
|
|
|
typedef struct matrix2d matrix2d;
|
|
|
|
|
|
|
|
// column vector
|
|
|
|
struct vector2d {
|
|
|
|
float x,y;
|
|
|
|
};
|
|
|
|
typedef struct vector2d vector2d;
|
|
|
|
|
|
|
|
matrix2d m2d_multiply_m2d(matrix2d m1, matrix2d m2);
|
|
|
|
vector2d m2d_multiply_v2d(matrix2d m, vector2d v);
|
|
|
|
matrix2d m2d_multiply_float(matrix2d m, float s);
|
|
|
|
vector2d v2d_multiply_float(vector2d v, float s);
|
|
|
|
|
|
|
|
vector2d v2d_add(vector2d v1, vector2d v2);
|
|
|
|
vector2d v2d_sub(vector2d v1, vector2d v2);
|
|
|
|
|
|
|
|
matrix2d m2d_new(float me0, float me1, float me2, float me3);
|
|
|
|
vector2d v2d_new(float x, float y);
|
|
|
|
|
|
|
|
extern vector2d v2d_zero;
|
|
|
|
extern matrix2d m2d_identity;
|
|
|
|
|
|
|
|
#endif
|