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.
tdesvn/src/svnqt/targets.hpp

160 lines
3.7 KiB

/*
* Port for usage with qt-framework and development for tdesvn
* (C) 2005-2007 by Rajko Albrecht
* http://tdesvn.alwins-world.de
*/
/*
* ====================================================================
* Copyright (c) 2002-2005 The RapidSvn Group. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library (in the file LGPL.txt); if not,
* write to the Free Software Foundation, Inc., 51 Franklin St,
* Fifth Floor, Boston, MA 02110-1301 USA
*
* This software consists of voluntary contributions made by many
* individuals. For exact contribution history, see the revision
* history and logs, available at http://rapidsvn.tigris.org/.
* ====================================================================
*/
#ifndef _SVNCPP_TARGETS_HPP_
#define _SVNCPP_TARGETS_HPP_
#include "svnqt/svnqt_defines.hpp"
#include "svnqt/svnqttypes.hpp"
#include <tqglobal.h>
#include <tqvaluelist.h>
// apr api
#include "apr_tables.h"
class TQStringList;
namespace svn
{
// forward declarations
class Pool;
/**
* Encapsulation for Subversion target arrays handling
*/
class SVNTQT_EXPORT Targets
{
public:
/**
* Constructor
*
* @param targets vector of paths
*/
Targets (const Pathes & targets);
/**
* Constructor
* @param path a single paths
*/
Targets (const Path & targets);
/**
* Constructor from an APR array containing
* char *.
*
* @param targets APR array header
*/
Targets (const apr_array_header_t * targets);
/**
* Constructor. Initializes list with just
* one entry
*
* @param target
*/
Targets (const TQString& target = TQString());
/**
* Constructor. Initializes list with just
* one entry
*
* @param target
*/
Targets (const char * target);
/**
* Constructor. Convert stringlist into target list.
* @param targets
*/
Targets(const TQStringList&targets);
/**
* Copy Constructor
*
* @param targets Source
*/
Targets (const Targets & targets);
/**
* Destructor
*/
virtual ~Targets ();
/**
* Returns an apr array containing
* char *.
*
* @param pool Pool used for conversion
*/
apr_array_header_t *
array (const Pool & pool) const;
/**
* Returns a vector of paths
*
* @return vector of paths
*/
const Pathes &
targets() const;
/**
* @return the number of targets
*/
size_t size () const;
/**
* operator to return the vector
*
* @return vector with targets
*/
operator const Pathes & () const
{
return m_targets;
}
const Path& operator [](size_t which)const;
/**
* returns one single target.
* the first in the vector, if no parameter given if there are more
* than one. if there is no target or parameter > then stored pathes returns
* an empty path
* \param which which item we want
* @return single path
*/
const Path
target(unsigned int which = 0) const;
private:
Pathes m_targets;
};
}
#endif