ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvtutil.C
(Generate patch)

Comparing rxvt-unicode/src/rxvtutil.C (file contents):
Revision 1.1 by root, Sun Aug 15 00:37:04 2004 UTC vs.
Revision 1.11 by root, Mon Jan 3 03:05:47 2011 UTC

1/*----------------------------------------------------------------------*
2 * File: rxvtutil.C
3 *----------------------------------------------------------------------*
4 *
5 * All portions of code are copyright by their respective author/s.
6 * Copyright (c) 2004-2006 Marc Lehmann <pcg@goof.com>
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 *----------------------------------------------------------------------*/
22
1#include <cstdlib> 23#include <cstdlib>
2#include <cstring> 24#include <cstring>
3#include <inttypes.h> 25#include <inttypes.h>
4 26
5#include "rxvtutil.h" 27#include "rxvtutil.h"
6 28
7class byteorder byteorder; 29#if !HAVE_GCC_BUILTINS
30int rxvt_ctz (unsigned int x) CONST
31{
32 int r = 0;
8 33
9byteorder::byteorder () 34 x &= -x; // this isolates the lowest bit
35
36 if (x & 0xaaaaaaaa) r += 1;
37 if (x & 0xcccccccc) r += 2;
38 if (x & 0xf0f0f0f0) r += 4;
39 if (x & 0xff00ff00) r += 8;
40 if (x & 0xffff0000) r += 16;
41
42 return r;
43}
44
45int rxvt_popcount (unsigned int x) CONST
10{ 46{
11 union { 47 x -= (x >> 1) & 0x55555555;
12 uint32_t u; 48 x = ((x >> 2) & 0x33333333) + (x & 0x33333333);
13 uint8_t b[4]; 49 x = ((x >> 4) + x) & 0x0f0f0f0f;
14 } w; 50 x *= 0x01010101;
15 51
16 w.b[0] = 0x11; 52 return x >> 24;
17 w.b[1] = 0x22; 53}
18 w.b[2] = 0x33; 54#endif
19 w.b[3] = 0x44;
20 55
21 e = w.u; 56void *
57zero_initialized::operator new (size_t s)
58{
59 void *p = malloc (s);
60
61 memset (p, 0, s);
62 return p;
63}
64
65void
66zero_initialized::operator delete (void *p, size_t s)
67{
68 free (p);
69}
70
71static void *temp_buf;
72static uint32_t temp_len;
73
74void *
75rxvt_temp_buf (int len)
76{
77 if (len > temp_len)
78 {
79 temp_buf = realloc (temp_buf, len);
80 temp_len = len;
81 }
82
83 return temp_buf;
22} 84}
23 85
24 86
25

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines