Small space-saving optimisation
git-svn-id: https://svn.code.sf.net/p/nsis/code/NSIS/trunk@687 212acab6-be3b-0410-9dea-997c60f758d6
This commit is contained in:
parent
8b9d432f7e
commit
c05a873977
2 changed files with 25 additions and 30 deletions
|
@ -2,11 +2,12 @@
|
||||||
#ifdef NSIS_CONFIG_CRC_SUPPORT
|
#ifdef NSIS_CONFIG_CRC_SUPPORT
|
||||||
|
|
||||||
// this is based on the (slow,small) CRC32 implementation from zlib.
|
// this is based on the (slow,small) CRC32 implementation from zlib.
|
||||||
|
unsigned long CRC32(unsigned long crc, const unsigned char *buf, unsigned int len)
|
||||||
static unsigned long crc_table[256];
|
|
||||||
|
|
||||||
static void make_crc_table()
|
|
||||||
{
|
{
|
||||||
|
static unsigned long crc_table[256];
|
||||||
|
|
||||||
|
if (!crc_table[1])
|
||||||
|
{
|
||||||
unsigned long c;
|
unsigned long c;
|
||||||
int n, k;
|
int n, k;
|
||||||
|
|
||||||
|
@ -16,14 +17,8 @@ static void make_crc_table()
|
||||||
for (k = 0; k < 8; k++) c = (c >> 1) ^ (c & 1 ? 0xedb88320L : 0);
|
for (k = 0; k < 8; k++) c = (c >> 1) ^ (c & 1 ? 0xedb88320L : 0);
|
||||||
crc_table[n] = c;
|
crc_table[n] = c;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// actually CRC32, but we put it in here so we don't
|
|
||||||
// have to modify the other code.
|
|
||||||
unsigned long CRC32(unsigned long crc, const unsigned char *buf, unsigned int len)
|
|
||||||
{
|
|
||||||
if (!crc_table[1]) make_crc_table();
|
|
||||||
crc = crc ^ 0xffffffffL;
|
crc = crc ^ 0xffffffffL;
|
||||||
while (len-- > 0) {
|
while (len-- > 0) {
|
||||||
crc = crc_table[(crc ^ (*buf++)) & 0xff] ^ (crc >> 8);
|
crc = crc_table[(crc ^ (*buf++)) & 0xff] ^ (crc >> 8);
|
||||||
|
|
|
@ -26,9 +26,9 @@ static LRESULT CALLBACK BG_WndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM l
|
||||||
int rv,gv,bv;
|
int rv,gv,bv;
|
||||||
RECT rect;
|
RECT rect;
|
||||||
HBRUSH brush;
|
HBRUSH brush;
|
||||||
rv = GetRValue(m_color2) * y / r.bottom + GetRValue(m_color1) * (r.bottom - y) / r.bottom;
|
rv = (GetRValue(m_color2) * y + GetRValue(m_color1) * (r.bottom - y)) / r.bottom;
|
||||||
gv = GetGValue(m_color2) * y / r.bottom + GetGValue(m_color1) * (r.bottom - y) / r.bottom;
|
gv = (GetGValue(m_color2) * y + GetGValue(m_color1) * (r.bottom - y)) / r.bottom;
|
||||||
bv = GetBValue(m_color2) * y / r.bottom + GetBValue(m_color1) * (r.bottom - y) / r.bottom;
|
bv = (GetBValue(m_color2) * y + GetBValue(m_color1) * (r.bottom - y)) / r.bottom;
|
||||||
brush = CreateSolidBrush(RGB(rv,gv,bv));
|
brush = CreateSolidBrush(RGB(rv,gv,bv));
|
||||||
SetRect(&rect, r.left, y, r.right, y+4);
|
SetRect(&rect, r.left, y, r.right, y+4);
|
||||||
// note that we don't need to do "SelectObject(hdc, brush)"
|
// note that we don't need to do "SelectObject(hdc, brush)"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue