-
Notifications
You must be signed in to change notification settings - Fork 45
/
airscan-array.c
97 lines (81 loc) · 1.89 KB
/
airscan-array.c
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
/* AirScan (a.k.a. eSCL) backend for SANE
*
* Copyright (C) 2019 and up by Alexander Pevzner ([email protected])
* See LICENSE for license terms and conditions
*
* SANE_Word/SANE_String/SANE_Device* arrays
*/
#include "airscan.h"
#include <stdlib.h>
#include <string.h>
/* Compare function for sane_word_array_sort
*/
static int
sane_word_array_sort_cmp(const void *p1, const void *p2)
{
return *(SANE_Word*) p1 - *(SANE_Word*) p2;
}
/* Drop array elements that outside of specified boundary
*/
void
sane_word_array_bound (SANE_Word *a, SANE_Word min, SANE_Word max)
{
SANE_Word len = a[0];
SANE_Word i, o;
for (i = o = 1; i < len + 1; i ++) {
if (min <= a[i] && a[i] <= max) {
a[o ++] = a[i];
}
}
a[0] = o - 1;
mem_shrink(a, o);
}
/* Sort array of SANE_Word in increasing order
*/
void
sane_word_array_sort(SANE_Word *a)
{
SANE_Word len = a[0];
if (len) {
qsort(a + 1, len, sizeof(SANE_Word), sane_word_array_sort_cmp);
}
}
/* Intersect two sorted arrays.
*/
SANE_Word*
sane_word_array_intersect_sorted (const SANE_Word *a1, const SANE_Word *a2)
{
const SANE_Word *end1 = a1 + sane_word_array_len(a1) + 1;
const SANE_Word *end2 = a2 + sane_word_array_len(a2) + 1;
SANE_Word *out = sane_word_array_new();
a1 ++;
a2 ++;
while (a1 < end1 && a2 < end2) {
if (*a1 < *a2) {
a1 ++;
} else if (*a1 > *a2) {
a2 ++;
} else {
out = sane_word_array_append(out, *a1);
a1 ++;
a2 ++;
}
}
return out;
}
/* Compute max string length in array of strings
*/
size_t
sane_string_array_max_strlen(const SANE_String *a)
{
size_t max_len = 0;
for (; *a != NULL; a ++) {
size_t len = strlen(*a);
if (len > max_len) {
max_len = len;
}
}
return max_len;
}
/* vim:ts=8:sw=4:et
*/