summaryrefslogtreecommitdiffstats
path: root/src/svnqt/url.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/svnqt/url.cpp')
-rw-r--r--src/svnqt/url.cpp209
1 files changed, 209 insertions, 0 deletions
diff --git a/src/svnqt/url.cpp b/src/svnqt/url.cpp
new file mode 100644
index 0000000..185f582
--- /dev/null
+++ b/src/svnqt/url.cpp
@@ -0,0 +1,209 @@
+/*
+ * 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/.
+ * ====================================================================
+ */
+#if defined( _MSC_VER) && _MSC_VER <= 1200
+#pragma warning( disable: 4786 )// debug symbol truncated
+#endif
+
+
+// svncpp
+#include "pool.hpp"
+#include "url.hpp"
+
+#include <qglobal.h>
+#if QT_VERSION < 0x040000
+#include <qvaluelist.h>
+#else
+#include <QtCore>
+#endif
+
+// subversion api
+#include "svn_ra.h"
+
+namespace svn
+{
+ static const char *
+ VALID_SCHEMAS [] =
+ {
+ "http","https","file",
+ "svn","svn+ssh","svn+http","svn+https","svn+file",
+ "ksvn","ksvn+ssh","ksvn+http","ksvn+https","ksvn+file","ksvn",
+ 0
+ };
+
+ static bool mSchemasInitialized = false;
+#if QT_VERSION < 0x040000
+ QValueList<QString> mSchemas;
+#else
+ QList<QString> mSchemas;
+#endif
+
+ Url::Url () {}
+
+ Url::~Url () {}
+
+ bool Url::isLocal(const QString& url)
+ {
+#if QT_VERSION < 0x040000
+ bool cs = false;
+#else
+ Qt::CaseSensitivity cs=Qt::CaseInsensitive;
+#endif
+ if (
+ url.startsWith("file://",cs) ||
+ url.startsWith("/") ||
+ url.startsWith("svn+file://",cs) ||
+ url.startsWith("ksvn+file://",cs) )
+ {
+ return true;
+ }
+ return false;
+ }
+
+ bool Url::isValid (const QString& url)
+ {
+ QString urlTest(url);
+ unsigned int index = 0;
+ while (VALID_SCHEMAS[index]!=0)
+ {
+ QString schema = QString::FROMUTF8(VALID_SCHEMAS[index]);
+ QString urlComp = urlTest.mid(0, schema.length());
+
+ if (schema == urlComp)
+ {
+ return true;
+ }
+ ++index;
+ }
+
+ return false;
+ }
+
+ QString
+ Url::transformProtokoll(const QString&prot)
+ {
+#if QT_VERSION < 0x040000
+ QString _prot = prot.lower();
+#else
+ QString _prot = prot.toLower();
+#endif
+ if (QString::compare(_prot,"svn+http")==0||
+ QString::compare(_prot,"ksvn+http")==0) {
+ return QString("http");
+ } else if (QString::compare(_prot,"svn+https")==0||
+ QString::compare(_prot,"ksvn+https")==0) {
+ return QString("https");
+ }else if (QString::compare(_prot,"svn+file")==0||
+ QString::compare(_prot,"ksvn+file")==0) {
+ return QString("file");
+ } else if (QString::compare(_prot,"ksvn+ssh")==0) {
+ return QString("svn+ssh");
+ } else if (QString::compare(_prot,"ksvn")==0) {
+ return QString("svn");
+ }
+ return _prot;
+ }
+
+
+ /**
+ * the implementation of the function that pull the supported
+ * url schemas out of the ra layer it rather dirty now since
+ * we are lacking a higher level of abstraction
+ */
+#if QT_VERSION < 0x040000
+ QValueList<QString>
+#else
+ QList<QString>
+#endif
+ Url::supportedSchemas ()
+ {
+ if (mSchemasInitialized)
+ return mSchemas;
+
+ mSchemasInitialized = true;
+ Pool pool;
+ void * ra_baton;
+
+ svn_error_t * error =
+ svn_ra_init_ra_libs (&ra_baton, pool);
+ if (error)
+ return mSchemas;
+
+ svn_stringbuf_t *descr;
+ error =
+ svn_ra_print_ra_libraries (&descr, ra_baton, pool);
+ if (error)
+ return mSchemas;
+
+ // schemas are in the following form:
+ // <schema>:<whitespace><description>\n...
+ // find the f�st :
+ QString descriptions (descr->data);
+ int pos=0;
+ const int not_found = -1;
+ do
+ {
+ const QString tokenStart ("handles '");
+ const QString tokenEnd ("' schem");
+#if QT_VERSION < 0x040000
+ pos = descriptions.find (tokenStart, pos);
+#else
+ pos = descriptions.indexOf( tokenStart, pos );
+#endif
+ if (pos == not_found)
+ break;
+
+ pos += tokenStart.length ();
+
+#if QT_VERSION < 0x040000
+ int posEnd = descriptions.find (tokenEnd, pos);
+#else
+ int posEnd = descriptions.indexOf( tokenEnd, pos );
+#endif
+ if (posEnd == not_found)
+ break;
+
+ // found
+ QString schema (descriptions.mid(pos, posEnd-pos) + ":");
+ mSchemas.push_back (schema);
+
+ // forward to the next newline
+ pos = posEnd + tokenEnd.length ();
+ }
+ while (pos != not_found);
+
+ return mSchemas;
+ }
+}
+
+/* -----------------------------------------------------------------
+ * local variables:
+ * eval: (load-file "../../rapidsvn-dev.el")
+ * end:
+ */