File: bitmap.sml

package info (click to toggle)
mlton 20210117%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 58,464 kB
  • sloc: ansic: 27,682; sh: 4,455; asm: 3,569; lisp: 2,879; makefile: 2,347; perl: 1,169; python: 191; pascal: 68; javascript: 7
file content (18 lines) | stat: -rw-r--r-- 699 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
   structure BM =
   struct
      structure W8A = Word8Array
      structure W8  = Word8
      structure W   = Word
      fun create N = W8A.array(W.toIntX(W.>>(W.fromInt(N + 7), 0w3)), 0w0) 
      fun markAndTest(bitmap,i) = 
      let val byte = W.toIntX(W.>>(W.fromInt i,0w3))
          val mask = W8.<<(0w1, W.andb(W.fromInt i,0w7))
          val n    = W8A.sub(bitmap, byte)
      in  W8.andb(n, mask) <> 0w0 orelse
          (W8A.update(bitmap, byte, W8.orb(n, mask)); false)
      end
      fun contains(bitmap,i) = 
      let val byte = W.toIntX(W.>>(W.fromInt i,0w3))
          val mask = W8.<<(0w1, W.andb(W.fromInt i,0w7))
      in  W8.andb(W8A.sub(bitmap, byte), mask) <> 0w0 end
   end