Source: ./classparser/ParsedScopeContainer.h


Annotated List
Files
Globals
Hierarchy
Index
/***************************************************************************
                          ParsedScopeContainer.cpp  -  description
                             -------------------
    begin                : Thu Nov 18 1999
    copyright            : (C) 1999 by Jonas Nordin
    email                : jonas.nordin@syncom.se
   
 ***************************************************************************/

/***************************************************************************
 *                                                                         *
 *   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.                                   * 
 *                                                                         *
 ***************************************************************************/

#ifndef _PARSEDSCOPECONTAINER_H_INCLUDED_
#define _PARSEDSCOPECONTAINER_H_INCLUDED_

#include "ParsedClassContainer.h"

/** This is a container for scopes, like namespaces in C++
 * or Modules in IDL-files.
 *
 * @author Jonas Nordin
 */
class CParsedScopeContainer : public CParsedClassContainer
{
public: // Constructor and Destructor

  /**
   * Constructor
   *
   */
  CParsedScopeContainer();

  /**
   * Destructor
   *
   */
  ~CParsedScopeContainer();

private: // Private attributes

  /** All scopes defined in this scope. */
  QDict scopes;

public: // Public attributes

  /** Iterator for all scopes. */
  QDictIterator scopeIterator;

public: // Public queries

  /**
   * Tells if a scope exists in this scope.
   *
   * @param aName Name of the scope to check for.
   */
  bool hasScope( const char *aName );

  /**
   * Fetch a scope by using it's name.
   *
   * @param aName Name of the scope to fetch.
   *
   * @return Pointer to the scope or NULL if not found.
   */
  CParsedScopeContainer *getScopeByName( const char *aName );

  /**
   * Get all scopes in sorted order.
   *
   * @return A list of all scopes in alphabetical order.
   */
  QList *getSortedScopeList();

  /**
   * Get all scopenames in sorted order.
   *
   * @return A list of all scopenames in alphabetical order.
   */
  QStrList *getSortedScopeNameList();

public: // Public methods

  /** Add a scope to this scope. 
   *
   * @param aScope The scope to add.
   */
  void addScope( CParsedScopeContainer *aScope );

  /**
   * Remove a scope from this scope.
   *
   * @param aName Name of the scope to remove.
   */
  void removeScope( const char *aName );

  /** 
   * Clear the internal state. 
   *
   */
  void clear();

  /**
   * Output this object to stdout.
   *
   */
  void out();

};

#endif

Generated by: jr on radge on Wed Sep 25 00:11:47 2002, using kdoc 2.0a54.