summaryrefslogtreecommitdiffstats
path: root/src/svnqt/targets.hpp
diff options
context:
space:
mode:
authortpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2010-03-15 17:32:48 +0000
committertpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2010-03-15 17:32:48 +0000
commite2f541c98dfa4081fa3ab3d28f08ea2309281884 (patch)
treecb721a55bc88753ddeb9754dc98ef45e2850ce30 /src/svnqt/targets.hpp
downloadtdesvn-e2f541c98dfa4081fa3ab3d28f08ea2309281884.tar.gz
tdesvn-e2f541c98dfa4081fa3ab3d28f08ea2309281884.zip
Added KDE3 version of kdesvn
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/kdesvn@1103685 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'src/svnqt/targets.hpp')
-rw-r--r--src/svnqt/targets.hpp168
1 files changed, 168 insertions, 0 deletions
diff --git a/src/svnqt/targets.hpp b/src/svnqt/targets.hpp
new file mode 100644
index 0000000..06cef77
--- /dev/null
+++ b/src/svnqt/targets.hpp
@@ -0,0 +1,168 @@
+/*
+ * Port for usage with qt-framework and development for kdesvn
+ * (C) 2005-2007 by Rajko Albrecht
+ * http://kdesvn.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 <qglobal.h>
+#if QT_VERSION < 0x040000
+#include <qvaluelist.h>
+#else
+#include <QtCore>
+#endif
+
+// apr api
+#include "apr_tables.h"
+
+class QStringList;
+
+namespace svn
+{
+ // forward declarations
+ class Pool;
+
+ /**
+ * Encapsulation for Subversion target arrays handling
+ */
+ class SVNQT_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 QString& target = QString::null);
+ /**
+ * Constructor. Initializes list with just
+ * one entry
+ *
+ * @param target
+ */
+ Targets (const char * target);
+ /**
+ * Constructor. Convert stringlist into target list.
+ * @param targets
+ */
+ Targets(const QStringList&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
+/* -----------------------------------------------------------------
+ * local variables:
+ * eval: (load-file "../../rapidsvn-dev.el")
+ * end:
+ */