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.2 by root, Sat Aug 21 05:32:00 2004 UTC vs.
Revision 1.13 by root, Mon Feb 21 07:41:03 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 <schmorp@schmorp.de>
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
9unsigned int byteorder::e; 34 x &= -x; // this isolates the lowest bit
10 35
11byteorder::byteorder () 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
12{ 46{
13 union { 47 x -= (x >> 1) & 0x55555555;
14 uint32_t u; 48 x = ((x >> 2) & 0x33333333) + (x & 0x33333333);
15 uint8_t b[4]; 49 x = ((x >> 4) + x) & 0x0f0f0f0f;
16 } w; 50 x *= 0x01010101;
17 51
18 w.b[0] = 0x11; 52 return x >> 24;
19 w.b[1] = 0x22;
20 w.b[2] = 0x33;
21 w.b[3] = 0x44;
22
23 e = w.u;
24} 53}
54#endif
25 55
26void * 56void *
27zero_initialized::operator new (size_t s) 57zero_initialized::operator new (size_t s)
28{ 58{
29 void *p = malloc (s); 59 void *p = malloc (s);
36zero_initialized::operator delete (void *p, size_t s) 66zero_initialized::operator delete (void *p, size_t s)
37{ 67{
38 free (p); 68 free (p);
39} 69}
40 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 free (temp_buf);
80 temp_buf = malloc (len);
81 temp_len = len;
82 }
83
84 return temp_buf;
85}
41 86
42 87

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines