Welcome to mirror list, hosted at ThFree Co, Russian Federation.

v_util.c « dist « verse « extern - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: a36f4c77791ee8c6dc6f38f3e83b2923122a373f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
 * Utility functions.
*/

#include <stdio.h>

#include "verse_header.h"
#include "v_network.h"
#include "v_util.h"

/* Safe string copy. Copies from <src> to <dst>, not using more than <size>
 * bytes of destination space. Always 0-terminates the destination. Returns
 * the beginning of the destination string.
*/
char * v_strlcpy(char *dst, const char *src, size_t size)
{
	char	*base = dst;

	if(size == 0)
		return NULL;
	for(size--; size > 0 && *src != '\0'; size--)
		*dst++ = *src++;
	*dst = '\0';

	return base;
}

void v_timer_start(VUtilTimer *timer)
{
	v_n_get_current_time(&timer->seconds, &timer->fractions);
}

void v_timer_advance(VUtilTimer *timer, double seconds)
{
	if(timer == NULL)
		return;
	timer->seconds   += (uint32) seconds;
	timer->fractions += (uint32) ((seconds - (int) seconds) * (double) 0xffffffff);
}

double v_timer_elapsed(const VUtilTimer *timer)
{
	uint32 cur_seconds, cur_fractions;

	v_n_get_current_time(&cur_seconds, &cur_fractions);
	return (double)(cur_seconds - timer->seconds) + ((double)cur_fractions - (double)timer->fractions) / (double) 0xffffffff;
}

void v_timer_print(const VUtilTimer *timer)
{
	uint32 cur_seconds, cur_fractions;

	v_n_get_current_time(&cur_seconds, &cur_fractions);
	printf("%f", (double)(cur_seconds - timer->seconds) + ((double)cur_fractions - (double)timer->fractions) / (double) 0xffffffff);
}

/* Compare |x| against built-in semi-magical constant, and return 1 if it's larger, 0 if not. */
static int quat_valid(real64 x)
{
	const real64	EPSILON = 0.0000001;
	return x > 0.0 ? x > EPSILON : x < -EPSILON;
}

int v_quat32_valid(const VNQuat32 *q)
{
	if(q == NULL)
		return 0;
	return quat_valid(q->x) && quat_valid(q->y) && quat_valid(q->z) && quat_valid(q->w);
}

int v_quat64_valid(const VNQuat64 *q)
{
	if(q == NULL)
		return 0;
	return quat_valid(q->x) && quat_valid(q->y) && quat_valid(q->z) && quat_valid(q->w);
}

VNQuat32 * v_quat32_from_quat64(VNQuat32 *dst, const VNQuat64 *src)
{
	if(dst == NULL || src == NULL)
		return NULL;
	dst->x = (real32) src->x;
	dst->y = (real32) src->y;
	dst->z = (real32) src->z;	
	dst->w = (real32) src->w;
	return dst;
}

VNQuat64 * v_quat64_from_quat32(VNQuat64 *dst, const VNQuat32 *src)
{
	if(dst == NULL || src == NULL)
		return NULL;
	dst->x = src->x;	
	dst->y = src->y;
	dst->z = src->z;	
	dst->w = src->w;
	return dst;
}