[go: up one dir, main page]

Menu

[897c37]: / modules / bit.c  Maximize  Restore  History

Download this file

90 lines (82 with data), 2.0 kB

 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
#ifdef BIT_STRINGS
void SET_BIT()
{
Val arg, arg1, arg2, *ret;
char *str;
int len, old_len, ind;
int x, nonblank;
Pop(&arg2);
Pop(&arg1);
Pop(&arg);
type_check(&arg, T_STRING, "set_bit", 1);
type_check(&arg1, T_NUMBER, "set_bit", 2);
type_check(&arg2, T_NUMBER, "set_bit", 3);
if (arg1.u.number > MAX_BITS)
{
efun_error("set_bit: too big bit number: %d\n", arg1.u.number);
return;
}
if (arg1.u.number < 0)
{
efun_error("set_bit: negative bit number: %d\n", arg1.u.number);
return;
}
old_len = len = strlen(arg.u.string);
ind = arg1.u.number / 6;
if (ind >= len)
len = ind + 1;
str = xalloc(len + 1);
str[len] = '\0';
nonblank = 0;
for (x = len - 1; x >= 0; x--)
{
char c;
if (x < old_len)
c = arg.u.string[x];
else
c = ' ';
if (x == ind)
{
if (arg2.u.number)
c = (c - ' ' | (1 << arg1.u.number % 6)) + ' ';
else
c = (c - ' ' & ~(1 << arg1.u.number % 6)) + ' ';
if (c > 0x3f + ' ' || c < ' ')
{
efun_error("Illegal bit pattern in set_bit character %d\n", ind);
return;
}
}
if (c == ' ' && !nonblank)
c = '\0'; /* truncate strings where possible */
else
nonblank = 1;
str[x] = c;
}
ret = share_string(str);
free(str);
Push(ret);
}
void TEST_BIT()
{
Val arg, arg1, *ret;
int len;
Pop(&arg1);
Pop(&arg);
type_check(&arg, T_STRING, "test_bit", 1);
type_check(&arg1, T_NUMBER, "test_bit", 2);
len = strlen(arg.u.string);
if (arg1.u.number / 6 >= len)
{
Push(Const(0));
return;
}
if (arg.u.string[arg1.u.number / 6] - ' ' & 1
<< arg1.u.number % 6)
{
Push(Const(1));
return;
}
Push(Const(0));
}
#endif