3 -- Copyright (C) 2010 Toni Gundogdu <legatvs@gmail.com>
5 -- This file is part of quvi <http://quvi.sourceforge.net/>.
7 -- This library is free software; you can redistribute it and/or
8 -- modify it under the terms of the GNU Lesser General Public
9 -- License as published by the Free Software Foundation; either
10 -- version 2.1 of the License, or (at your option) any later version.
12 -- This library is distributed in the hope that it will be useful,
13 -- but WITHOUT ANY WARRANTY; without even the implied warranty of
14 -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 -- Lesser General Public License for more details.
17 -- You should have received a copy of the GNU Lesser General Public
18 -- License along with this library; if not, write to the Free Software
19 -- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
25 function M
.bit_or (x
, y
) -- http://is.gd/iVg4x
27 while p
< x
do p
= p
+ p
end
28 while p
< y
do p
= p
+ p
end
31 if p
<= x
or p
<= y
then
33 if p
<= x
then x
= x
- p
end
34 if p
<= y
then y
= y
- p
end
42 function M
.bit (p
) return 2 ^
(p
- 1) end
44 -- e.g. "if has_bit (foo, bit (n)) then ..."
45 function M
.has_bit(x
, p
) return x
% (p
+ p
) >= p
end
49 -- vim: set ts=4 sw=4 tw=72 expandtab: