/* * 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/. * ==================================================================== */ // subversion api #include "svn_types.h" // apr api #include "apr_pools.h" #include "apr_strings.h" // svncpp #include "svnqt/targets.h" #include "svnqt/path.h" #include "svnqt/pool.h" #include "svnqt/svnqt_defines.h" #include namespace svn { Targets::Targets (const Pathes & targets) { m_targets = targets; } Targets::Targets(const TQStringList&targets) { m_targets.clear(); for (unsigned int i = 0; i < targets.size();++i) { if (targets[i].isEmpty()) { m_targets.push_back(""); } else { m_targets.push_back(targets[i]); } } } Targets::Targets (const apr_array_header_t * apr_targets) { int i; m_targets.clear (); //m_targets.reserve (apr_targets->nelts); for (i = 0; i < apr_targets->nelts; i++) { const char ** target = &APR_ARRAY_IDX (apr_targets, i, const char *); m_targets.push_back (Path (*target)); } } Targets::Targets (const Targets & targets) { m_targets = targets.targets (); } Targets::Targets (const TQString& target) { if (!target.isEmpty()) { m_targets.push_back(target); } } Targets::Targets (const Path& target) { if (!target.cstr().isEmpty()) { m_targets.push_back(target); } } Targets::Targets (const char* target) { if (target) { m_targets.push_back(TQString::FROMUTF8(target)); } } Targets::~Targets () { } apr_array_header_t * Targets::array (const Pool & pool) const { Pathes::const_iterator it; apr_pool_t *apr_pool = pool.pool (); apr_array_header_t *apr_targets = apr_array_make (apr_pool, m_targets.size(), sizeof (const char *)); for (it = m_targets.begin (); it != m_targets.end (); it++) { TQByteArray s = (*it).path().TOUTF8(); char * t2 = apr_pstrndup (apr_pool,s,s.size()); (*((const char **) apr_array_push (apr_targets))) = t2; } return apr_targets; } const Pathes & Targets::targets () const { return m_targets; } size_t Targets::size () const { return m_targets.size (); } const Path& Targets::operator [](size_t which)const { return m_targets[which]; } const Path Targets::target (unsigned int which) const { if (m_targets.size () > which) { return m_targets[which]; } else { return Path(); } } }