mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-12 14:29:28 +00:00
vtfontcvt: simplify rshift_row
We don't need to specify the buffer size in both bytes and bits. MFC after: 1 week Sponsored by: The FreeBSD Foundation
This commit is contained in:
parent
ec7ea489e0
commit
40adef9e59
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=351425
@ -224,38 +224,19 @@ add_char(unsigned curchar, unsigned map_idx, uint8_t *bytes, uint8_t *bytes_r)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Right-shift glyph row by _shift_ bits. Row _len_ bits wide, _size_ bytes.
|
* Right-shift glyph row.
|
||||||
*/
|
*/
|
||||||
static int
|
static void
|
||||||
rshift_row(uint8_t *line, size_t size, size_t len, size_t shift)
|
rshift_row(uint8_t *buf, size_t len, size_t shift)
|
||||||
{
|
{
|
||||||
size_t d, s, i;
|
ssize_t i, off_byte = shift / 8;
|
||||||
uint16_t t;
|
size_t off_bit = shift % 8;
|
||||||
|
|
||||||
assert(size > 0 && len > 0);
|
|
||||||
assert(size * 8 >= len);
|
|
||||||
|
|
||||||
if (shift == 0)
|
if (shift == 0)
|
||||||
return (0);
|
return;
|
||||||
|
for (i = len - 1; i >= 0; i--)
|
||||||
d = shift / 8;
|
buf[i] = (i >= off_byte ? buf[i - off_byte] >> off_bit : 0) |
|
||||||
s = 8 - shift % 8;
|
(i > off_byte ? buf[i - off_byte - 1] << (8 - off_bit) : 0);
|
||||||
i = howmany(len, 8);
|
|
||||||
|
|
||||||
while (i > 0) {
|
|
||||||
i--;
|
|
||||||
|
|
||||||
t = *(line + i);
|
|
||||||
*(line + i) = 0;
|
|
||||||
|
|
||||||
t <<= s;
|
|
||||||
|
|
||||||
if (i + d + 1 < size)
|
|
||||||
*(line + i + d + 1) |= (uint8_t)t;
|
|
||||||
if (i + d < size)
|
|
||||||
*(line + i + d) = t >> 8;
|
|
||||||
}
|
|
||||||
return (0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -426,11 +407,7 @@ parse_bdf(FILE *fp, unsigned int map_idx)
|
|||||||
*(line + j) = (uint8_t)val;
|
*(line + j) = (uint8_t)val;
|
||||||
}
|
}
|
||||||
|
|
||||||
rv = rshift_row(line, wbytes * 2, bbw,
|
rshift_row(line, wbytes * 2, bbox - fbbox);
|
||||||
bbox - fbbox);
|
|
||||||
if (rv != 0)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
rv = split_row(bytes + i * wbytes,
|
rv = split_row(bytes + i * wbytes,
|
||||||
bytes_r + i * wbytes, line, dwidth);
|
bytes_r + i * wbytes, line, dwidth);
|
||||||
if (rv != 0)
|
if (rv != 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user