public static void test(int level, ByteBufferN b, bool direct) { show(level, b); //TODO if (direct != b.isDirect()) //TODO fail("Wrong direction", b); // Gets and puts relPut(b); relGet(b); absGet(b); bulkGet(b); absPut(b); relGet(b); absGet(b); bulkGet(b); bulkPutArray(b); relGet(b); bulkPutBuffer(b); relGet(b); // Compact relPut(b); b.position(13); b.compact(); b.flip(); relGet(b, 13); // Exceptions relPut(b); b.limit(b.capacity() / 2); b.position(b.limit()); tryCatch(b, typeof(BufferUnderflowException), () => { b.get(); }); tryCatch(b, typeof(BufferOverflowException), () => { b.put(42); }); // The index must be non-negative and lesss than the buffer's limit. tryCatch(b, typeof(IndexOutOfBoundsException), () => { b.get(b.limit()); }); tryCatch(b, typeof(IndexOutOfBoundsException), () => { b.get(-1); }); tryCatch(b, typeof(IndexOutOfBoundsException), () => { b.put(b.limit(), 42); }); tryCatch(b, typeof(InvalidMarkException), () => { b.position(0); b.mark(); b.compact(); b.reset(); }); // Values b.clear(); b.put(0); b.put(0xff); b.put(1); b.put(Byte.MAX_VALUE); b.put(Byte.MIN_VALUE); b.flip(); ck(b, b.get(), 0); ck(b, b.get(), 0xff); ck(b, b.get(), 1); ck(b, b.get(), Byte.MAX_VALUE); ck(b, b.get(), Byte.MIN_VALUE); // Comparison b.rewind(); ByteBufferN b2 = ByteBufferN.allocate(b.capacity()); b2.put(b); b2.flip(); b.position(2); b2.position(2); if (!b.equals(b2)) { for (int i = 2; i < b.limit(); i++) { byte x = b.get(i); byte y = b2.get(i); if (x != y ) outt.println("[" + i + "] " + x + " != " + y); } fail("Identical buffers not equal", b, b2); } if (b.compareTo(b2) != 0) fail("Comparison to identical buffer != 0", b, b2); b.limit(b.limit() + 1); b.position(b.limit() - 1); b.put(99); b.rewind(); b2.rewind(); if (b.equals(b2)) fail("Non-identical buffers equal", b, b2); if (b.compareTo(b2) <= 0) fail("Comparison to shorter buffer <= 0", b, b2); b.limit(b.limit() - 1); b.put(2, 42); if (b.equals(b2)) fail("Non-identical buffers equal", b, b2); if (b.compareTo(b2) <= 0) fail("Comparison to lesser buffer <= 0", b, b2); // Sub, dup relPut(b); relGet(b.duplicate()); b.position(13); relGet(b.duplicate(), 13); relGet(b.duplicate().slice(), 13); relGet(b.slice(), 13); relGet(b.slice().duplicate(), 13); // Slice b.position(5); ByteBufferN sb = b.slice(); checkSlice(b, sb); b.position(0); ByteBufferN sb2 = sb.slice(); checkSlice(sb, sb2); if (!sb.equals(sb2)) fail("Sliced slices do not match", sb, sb2); if ((sb.hasArray()) && (sb.arrayOffset() != sb2.arrayOffset())) fail("Array offsets do not match: " + sb.arrayOffset() + " != " + sb2.arrayOffset(), sb, sb2); // Views b.clear(); b.order(ByteOrder.BIG_ENDIAN); testViews(level + 1, b, direct); for (int i = 1; i <= 9; i++) { b.position(i); show(level + 1, b); testViews(level + 2, b, direct); } b.position(0); b.order(ByteOrder.LITTLE_ENDIAN); testViews(level + 1, b, direct); // Heterogeneous accessors b.order(ByteOrder.BIG_ENDIAN); for (int i = 0; i <= 9; i++) { b.position(i); testHet(level + 1, b); } b.order(ByteOrder.LITTLE_ENDIAN); b.position(3); testHet(level + 1, b); // Read-only views /* TODO b.rewind(); ByteBuffer rb = b.asReadOnlyBuffer(); if (!b.equals(rb)) fail("BufferN not equal to read-only view", b, rb); show(level + 1, rb); tryCatch(b, typeof(ReadOnlyBufferException), () => { relPut(rb); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { absPut(rb); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { bulkPutArray(rb); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { bulkPutBuffer(rb); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.compact(); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putChar((char)1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putChar(0, (char)1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putShort(1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putShort(0, 1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putInt(1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putInt(0, 1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putLong(1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putLong(0, 1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putFloat(1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putFloat(0, 1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putDouble(1); }); tryCatch(b, typeof(ReadOnlyBufferException), () => { rb.putDouble(0, 1); }); // Bulk puts from read-only buffers b.clear(); rb.rewind(); b.put(rb); // For byte buffers, test both the direct and non-direct cases ByteBuffer ob = (b.isDirect() ? ByteBuffer.allocate(rb.capacity()) : ByteBuffer.allocateDirect(rb.capacity())); rb.rewind(); ob.put(rb); */ relPut(b); // Required by testViews }