aboutsummaryrefslogtreecommitdiff
path: root/src/org/xbill/DNS/TypeBitmap.java
diff options
context:
space:
mode:
authorShuyi Chen <shuyichen@google.com>2013-05-22 14:51:55 -0700
committerShuyi Chen <shuyichen@google.com>2013-05-22 17:19:30 -0700
commitd7955ce24d294fb2014c59d11fca184471056f44 (patch)
treee260500b0b7639127038495d46a0ad6dcbb6d96c /src/org/xbill/DNS/TypeBitmap.java
parent8f4ce9ea0de51fee918bffe19c434612d6bbb2d7 (diff)
downloadsmack-d7955ce24d294fb2014c59d11fca184471056f44.tar.gz
Add android smack source.HEADandroid-wear-5.0.0_r1android-sdk-4.4.2_r1.0.1android-sdk-4.4.2_r1android-l-preview_r2android-cts-5.1_r9android-cts-5.1_r8android-cts-5.1_r7android-cts-5.1_r6android-cts-5.1_r5android-cts-5.1_r4android-cts-5.1_r3android-cts-5.1_r28android-cts-5.1_r27android-cts-5.1_r26android-cts-5.1_r25android-cts-5.1_r24android-cts-5.1_r23android-cts-5.1_r22android-cts-5.1_r21android-cts-5.1_r20android-cts-5.1_r2android-cts-5.1_r19android-cts-5.1_r18android-cts-5.1_r17android-cts-5.1_r16android-cts-5.1_r15android-cts-5.1_r14android-cts-5.1_r13android-cts-5.1_r10android-cts-5.1_r1android-cts-5.0_r9android-cts-5.0_r8android-cts-5.0_r7android-cts-5.0_r6android-cts-5.0_r5android-cts-5.0_r4android-cts-5.0_r3android-cts-4.4_r4android-cts-4.4_r1android-5.1.1_r9android-5.1.1_r8android-5.1.1_r7android-5.1.1_r6android-5.1.1_r5android-5.1.1_r4android-5.1.1_r38android-5.1.1_r37android-5.1.1_r36android-5.1.1_r35android-5.1.1_r34android-5.1.1_r33android-5.1.1_r30android-5.1.1_r3android-5.1.1_r29android-5.1.1_r28android-5.1.1_r26android-5.1.1_r25android-5.1.1_r24android-5.1.1_r23android-5.1.1_r22android-5.1.1_r20android-5.1.1_r2android-5.1.1_r19android-5.1.1_r18android-5.1.1_r17android-5.1.1_r16android-5.1.1_r15android-5.1.1_r14android-5.1.1_r13android-5.1.1_r12android-5.1.1_r10android-5.1.1_r1android-5.1.0_r5android-5.1.0_r4android-5.1.0_r3android-5.1.0_r1android-5.0.2_r3android-5.0.2_r1android-5.0.1_r1android-5.0.0_r7android-5.0.0_r6android-5.0.0_r5.1android-5.0.0_r5android-5.0.0_r4android-5.0.0_r3android-5.0.0_r2android-5.0.0_r1android-4.4w_r1android-4.4_r1.2.0.1android-4.4_r1.2android-4.4_r1.1.0.1android-4.4_r1.1android-4.4_r1.0.1android-4.4_r1android-4.4_r0.9android-4.4_r0.8android-4.4_r0.7android-4.4.4_r2.0.1android-4.4.4_r2android-4.4.4_r1.0.1android-4.4.4_r1android-4.4.3_r1.1.0.1android-4.4.3_r1.1android-4.4.3_r1.0.1android-4.4.3_r1android-4.4.2_r2.0.1android-4.4.2_r2android-4.4.2_r1.0.1android-4.4.2_r1android-4.4.1_r1.0.1android-4.4.1_r1android-4.3_r3.1android-4.3_r3android-4.3_r2.3android-4.3_r2.2android-4.3_r2.1android-4.3_r2android-4.3_r1.1android-4.3_r1android-4.3_r0.9.1android-4.3_r0.9android-4.3.1_r1tools_r22.2mastermainlollipop-wear-releaselollipop-releaselollipop-mr1-wfc-releaselollipop-mr1-releaselollipop-mr1-fi-releaselollipop-mr1-devlollipop-mr1-cts-releaselollipop-devlollipop-cts-releasel-previewkitkat-wearkitkat-releasekitkat-mr2.2-releasekitkat-mr2.1-releasekitkat-mr2-releasekitkat-mr1.1-releasekitkat-mr1-releasekitkat-devkitkat-cts-releasekitkat-cts-devjb-mr2.0.0-releasejb-mr2.0-releasejb-mr2-releasejb-mr2-devidea133-weekly-releaseidea133
Change-Id: I49ce97136c17173c4ae3965c694af6e7bc49897d
Diffstat (limited to 'src/org/xbill/DNS/TypeBitmap.java')
-rw-r--r--src/org/xbill/DNS/TypeBitmap.java147
1 files changed, 147 insertions, 0 deletions
diff --git a/src/org/xbill/DNS/TypeBitmap.java b/src/org/xbill/DNS/TypeBitmap.java
new file mode 100644
index 0000000..628cc35
--- /dev/null
+++ b/src/org/xbill/DNS/TypeBitmap.java
@@ -0,0 +1,147 @@
+// Copyright (c) 2004-2009 Brian Wellington (bwelling@xbill.org)
+
+package org.xbill.DNS;
+
+/**
+ * Routines for deal with the lists of types found in NSEC/NSEC3 records.
+ *
+ * @author Brian Wellington
+ */
+
+import java.io.*;
+import java.util.*;
+
+final class TypeBitmap implements Serializable {
+
+private static final long serialVersionUID = -125354057735389003L;
+
+private TreeSet types;
+
+private
+TypeBitmap() {
+ types = new TreeSet();
+}
+
+public
+TypeBitmap(int [] array) {
+ this();
+ for (int i = 0; i < array.length; i++) {
+ Type.check(array[i]);
+ types.add(new Integer(array[i]));
+ }
+}
+
+public
+TypeBitmap(DNSInput in) throws WireParseException {
+ this();
+ int lastbase = -1;
+ while (in.remaining() > 0) {
+ if (in.remaining() < 2)
+ throw new WireParseException
+ ("invalid bitmap descriptor");
+ int mapbase = in.readU8();
+ if (mapbase < lastbase)
+ throw new WireParseException("invalid ordering");
+ int maplength = in.readU8();
+ if (maplength > in.remaining())
+ throw new WireParseException("invalid bitmap");
+ for (int i = 0; i < maplength; i++) {
+ int current = in.readU8();
+ if (current == 0)
+ continue;
+ for (int j = 0; j < 8; j++) {
+ if ((current & (1 << (7 - j))) == 0)
+ continue;
+ int typecode = mapbase * 256 + + i * 8 + j;
+ types.add(Mnemonic.toInteger(typecode));
+ }
+ }
+ }
+}
+
+public
+TypeBitmap(Tokenizer st) throws IOException {
+ this();
+ while (true) {
+ Tokenizer.Token t = st.get();
+ if (!t.isString())
+ break;
+ int typecode = Type.value(t.value);
+ if (typecode < 0) {
+ throw st.exception("Invalid type: " + t.value);
+ }
+ types.add(Mnemonic.toInteger(typecode));
+ }
+ st.unget();
+}
+
+public int []
+toArray() {
+ int [] array = new int[types.size()];
+ int n = 0;
+ for (Iterator it = types.iterator(); it.hasNext(); )
+ array[n++] = ((Integer)it.next()).intValue();
+ return array;
+}
+
+public String
+toString() {
+ StringBuffer sb = new StringBuffer();
+ for (Iterator it = types.iterator(); it.hasNext(); ) {
+ int t = ((Integer)it.next()).intValue();
+ sb.append(Type.string(t));
+ if (it.hasNext())
+ sb.append(' ');
+ }
+ return sb.toString();
+}
+
+private static void
+mapToWire(DNSOutput out, TreeSet map, int mapbase) {
+ int arraymax = (((Integer)map.last()).intValue()) & 0xFF;
+ int arraylength = (arraymax / 8) + 1;
+ int [] array = new int[arraylength];
+ out.writeU8(mapbase);
+ out.writeU8(arraylength);
+ for (Iterator it = map.iterator(); it.hasNext(); ) {
+ int typecode = ((Integer)it.next()).intValue();
+ array[(typecode & 0xFF) / 8] |= (1 << ( 7 - typecode % 8));
+ }
+ for (int j = 0; j < arraylength; j++)
+ out.writeU8(array[j]);
+}
+
+public void
+toWire(DNSOutput out) {
+ if (types.size() == 0)
+ return;
+
+ int mapbase = -1;
+ TreeSet map = new TreeSet();
+
+ for (Iterator it = types.iterator(); it.hasNext(); ) {
+ int t = ((Integer)it.next()).intValue();
+ int base = t >> 8;
+ if (base != mapbase) {
+ if (map.size() > 0) {
+ mapToWire(out, map, mapbase);
+ map.clear();
+ }
+ mapbase = base;
+ }
+ map.add(new Integer(t));
+ }
+ mapToWire(out, map, mapbase);
+}
+
+public boolean
+empty() {
+ return types.isEmpty();
+}
+
+public boolean
+contains(int typecode) {
+ return types.contains(Mnemonic.toInteger(typecode));
+}
+
+}