blob: 57506b8f757a877488eadec5401087a99d2c0a0a (
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
|
// 1. Search backwards for whitespace
// - found?
// y) wrap
// n) break at limit
// - end?
// y) terminate
// n) goto 1. with offset += limit
void
wrap(u8* Text, u32 Len, u32 XLimit, u32 YLimit)
{
u32 SearchingOffset = XLimit;
u32 X = SearchingOffset;
u32 Y = 0;
u8 t;
u32 PrevX = 0;
while (X < Len)
{
// Search for whitespace to break on
while (1)
{
if (is_whitespace(Text[X])) break;
X--;
// if we got back to the previous position break on Text[SearchingOffset]
if (X == PrevX)
{
X = XLimit;
break;
}
}
// break
t = Text[X];
*(Text + X) = '\0';
tb_printf(0, Y, 0, 0, "%s", Text + PrevX);
Text[X] = t;
Y++;
if (Y >= YLimit) break;
// consume leading whitespace
while (is_whitespace(Text[X])) X++;
PrevX = X;
X += XLimit;
}
tb_printf(0, Y, 0, 0, "%s", Text + PrevX);
return;
}
|