You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ktorrent/libktorrent/torrent/bnode.h

211 lines
5.4 KiB

/***************************************************************************
* Copyright (C) 2005 by Joris Guisson *
* joris.guisson@gmail.com *
* *
* This program 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. *
* *
* This program 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 program; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
#ifndef BTBNODE_H
#define BTBNODE_H
#include <tqptrlist.h>
#include <tqvaluelist.h>
#include <util/constants.h>
#include "value.h"
namespace bt
{
class BListNode;
/**
* @author Joris Guisson
* @brief Base class for a node in a b-encoded piece of data
*
* There are 3 possible pieces of data in b-encoded piece of data.
* This is the base class for all those 3 things.
*/
class BNode
{
public:
enum Type
{
VALUE,DICT,LIST
};
/**
* Constructor, sets the Type, and the offset into
* the data.
* @param type Type of node
* @param off The offset into the data
*/
BNode(Type type,Uint32 off);
virtual ~BNode();
/// Get the type of node
Type getType() const {return type;}
/// Get the offset in the bytearray where this node starts.
Uint32 getOffset() const {return off;}
/// Get the length this node takes up in the bytearray.
Uint32 getLength() const {return len;}
/// Set the length
void setLength(Uint32 l) {len = l;}
/// Print some debugging info
virtual void printDebugInfo() = 0;
private:
Type type;
Uint32 off,len;
};
/**
* @author Joris Guisson
* @brief Represents a value (string,bytearray or int) in bencoded data
*
* @todo Use TQVariant
*/
class BValueNode : public BNode
{
Value v;
public:
BValueNode(const Value & v,Uint32 off);
virtual ~BValueNode();
const Value & data() const {return v;}
void printDebugInfo();
};
/**
* @author Joris Guisson
* @brief Represents a dictionary in bencoded data
*
*/
class BDictNode : public BNode
{
struct DictEntry
{
TQByteArray key;
BNode* node;
};
TQValueList<DictEntry> children;
public:
BDictNode(Uint32 off);
virtual ~BDictNode();
/**
* Insert a BNode in the dictionary.
* @param key The key
* @param node The node
*/
void insert(const TQByteArray & key,BNode* node);
/**
* Get a BNode.
* @param key The key
* @return The node or 0 if there is no node with has key @a key
*/
BNode* getData(const TQString & key);
/**
* Get a BListNode.
* @param key The key
* @return The node or 0 if there is no list node with has key @a key
*/
BListNode* getList(const TQString & key);
/**
* Get a BDictNode.
* @param key The key
* @return The node or 0 if there is no dict node with has key @a key
*/
BDictNode* getDict(const TQString & key);
/**
* Get a BDictNode.
* @param key The key
* @return The node or 0 if there is no dict node with has key @a key
*/
BDictNode* getDict(const TQByteArray & key);
/**
* Get a BValueNode.
* @param key The key
* @return The node or 0 if there is no value node with has key @a key
*/
BValueNode* getValue(const TQString & key);
void printDebugInfo();
};
/**
* @author Joris Guisson
* @brief Represents a list in bencoded data
*
*/
class BListNode : public BNode
{
TQPtrList<BNode> children;
public:
BListNode(Uint32 off);
virtual ~BListNode();
/**
* Append a node to the list.
* @param node The node
*/
void append(BNode* node);
void printDebugInfo();
/// Get the number of nodes in the list.
Uint32 getNumChildren() const {return children.count();}
/**
* Get a node from the list
* @param idx The index
* @return The node or 0 if idx is out of bounds
*/
BNode* getChild(Uint32 idx) {return children.at(idx);}
/**
* Get a BListNode.
* @param idx The index
* @return The node or 0 if the index is out of bounds or the element
* at postion @a idx isn't a BListNode.
*/
BListNode* getList(Uint32 idx);
/**
* Get a BDictNode.
* @param idx The index
* @return The node or 0 if the index is out of bounds or the element
* at postion @a idx isn't a BDictNode.
*/
BDictNode* getDict(Uint32 idx);
/**
* Get a BValueNode.
* @param idx The index
* @return The node or 0 if the index is out of bounds or the element
* at postion @a idx isn't a BValueNode.
*/
BValueNode* getValue(Uint32 idx);
};
}
#endif