gnu.inet.ldap

Class BERDecoder


public class BERDecoder
extends Object

Utility class for decoding BER values. For each value to be read, the application must call parseType to return the type of the value, then the specific parseXXX method for the type to return the actual value, or skip to skip the value.

Constructor Summary

BERDecoder(byte[] data, boolean utf8)

Method Summary

boolean
available()
static void
main(String[] args)
boolean
parseBoolean()
int
parseInt()
byte[]
parseOctetString()
BERDecoder
parseSequence()
BERDecoder
parseSequence(int code)
BERDecoder
parseSet()
BERDecoder
parseSet(int code)
String
parseString()
int
parseType()
Returns the type of the current value record.
void
skip()

Constructor Details

BERDecoder

public BERDecoder(byte[] data,
                  boolean utf8)

Method Details

available

public boolean available()


main

public static void main(String[] args)


parseBoolean

public boolean parseBoolean()
            throws BERException


parseInt

public int parseInt()
            throws BERException


parseOctetString

public byte[] parseOctetString()
            throws BERException


parseSequence

public BERDecoder parseSequence()
            throws BERException


parseSequence

public BERDecoder parseSequence(int code)
            throws BERException


parseSet

public BERDecoder parseSet()
            throws BERException


parseSet

public BERDecoder parseSet(int code)
            throws BERException


parseString

public String parseString()
            throws BERException


parseType

public int parseType()
            throws BERException
Returns the type of the current value record. If there are no more records to read, this method returns -1.


skip

public void skip()


* BERDecoder.java * Copyright (C) 2004 The Free Software Foundation * * This file is part of GNU inetlib, a library. * * GNU inetlib is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * GNU inetlib is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * Linking this library statically or dynamically with other modules is * making a combined work based on this library. Thus, the terms and * conditions of the GNU General Public License cover the whole * combination. * * As a special exception, the copyright holders of this library give you * permission to link this library with independent modules to produce an * executable, regardless of the license terms of these independent * modules, and to copy and distribute the resulting executable under * terms of your choice, provided that you also meet, for each linked * independent module, the terms and conditions of the license of that * module. An independent module is a module which is not derived from * or based on this library. If you modify this library, you may extend * this exception to your version of the library, but you are not * obliged to do so. If you do not wish to do so, delete this * exception statement from your version.