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.
160 lines
3.7 KiB
160 lines
3.7 KiB
14 years ago
|
/*
|
||
13 years ago
|
* Port for usage with qt-framework and development for tdesvn
|
||
14 years ago
|
* (C) 2005-2007 by Rajko Albrecht
|
||
13 years ago
|
* http://tdesvn.alwins-world.de
|
||
14 years ago
|
*/
|
||
|
/*
|
||
|
* ====================================================================
|
||
|
* 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_
|
||
|
|
||
3 years ago
|
#include "svnqt/svnqt_defines.h"
|
||
|
#include "svnqt/svnqttypes.h"
|
||
14 years ago
|
|
||
13 years ago
|
#include <tqglobal.h>
|
||
|
#include <tqvaluelist.h>
|
||
14 years ago
|
|
||
|
// apr api
|
||
|
#include "apr_tables.h"
|
||
|
|
||
13 years ago
|
class TQStringList;
|
||
14 years ago
|
|
||
|
namespace svn
|
||
|
{
|
||
|
// forward declarations
|
||
|
class Pool;
|
||
|
|
||
|
/**
|
||
|
* Encapsulation for Subversion target arrays handling
|
||
|
*/
|
||
13 years ago
|
class SVNTQT_EXPORT Targets
|
||
14 years ago
|
{
|
||
|
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
|
||
|
*/
|
||
13 years ago
|
Targets (const TQString& target = TQString());
|
||
14 years ago
|
/**
|
||
|
* Constructor. Initializes list with just
|
||
|
* one entry
|
||
|
*
|
||
|
* @param target
|
||
|
*/
|
||
|
Targets (const char * target);
|
||
|
/**
|
||
|
* Constructor. Convert stringlist into target list.
|
||
|
* @param targets
|
||
|
*/
|
||
13 years ago
|
Targets(const TQStringList&targets);
|
||
14 years ago
|
|
||
|
/**
|
||
|
* 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
|