diff options
Diffstat (limited to 'kdeprint/util.cpp')
-rw-r--r-- | kdeprint/util.cpp | 139 |
1 files changed, 139 insertions, 0 deletions
diff --git a/kdeprint/util.cpp b/kdeprint/util.cpp new file mode 100644 index 000000000..7e8be8cf8 --- /dev/null +++ b/kdeprint/util.cpp @@ -0,0 +1,139 @@ +/* + * This file is part of the KDE libraries + * Copyright (c) 2001 Michael Goffioul <kdeprint@swing.be> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License version 2 as published by the Free Software Foundation. + * + * 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 + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public License + * along with this library; see the file COPYING.LIB. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + **/ + +#include "util.h" +#include <qstringlist.h> + +void urlToSmb(const KURL& url, QString& work, QString& server, QString& printer) +{ + if (url.protocol() != "smb") + return; + QString h = url.host(); + QStringList l = QStringList::split('/', url.path(), false); + if (l.count() > 1) + { + work = h; + server = l[0]; + printer = l[1]; + } + else + { + work = QString::null; + server = h; + printer = l[0]; + } +} + +KURL smbToUrl(const QString& s) +{ + // allow to handle non-encoded chars in login/password + KURL url; + int p = s.find('@'); + if (p == -1) + { + // assumes url starts with "smb://". Use encoding in + // case the printer name contains chars like '#'. + url = KURL("smb://" + KURL::encode_string(s.mid(6))); + } + else + { + // assumes URL starts with "smb://" + QString username = s.mid(6, p-6); + url = KURL("smb://" + KURL::encode_string(s.mid(p+1))); + int q = username.find(':'); + if (q == -1) + url.setUser(username); + else + { + url.setUser(username.left(q)); + url.setPass(username.mid(q+1)); + } + } + return url; +} + +int findIndex(int ID) +{ + for (int i=0; i<KPrinter::NPageSize-1; i++) + if (page_sizes[i].ID == ID) + return i; + return 4; +} + +QString buildSmbURI( const QString& work, const QString& server, const QString& printer, const QString& user, const QString& passwd ) +{ + QString uri = server + "/" + printer; + if ( !work.isEmpty() ) + uri.prepend( work + "/" ); + if ( !user.isEmpty() ) + { + uri.prepend( "@" ); + if ( !passwd.isEmpty() ) + uri.prepend( ":" + passwd ); + uri.prepend( user ); + } + uri.prepend( "smb://" ); + return uri; +} + +bool splitSmbURI( const QString& uri, QString& work, QString& server, QString& printer, QString& user, QString& passwd ) +{ + int p( 0 ); + if ( !uri.startsWith( "smb://" ) ) + return false; + p = 6; + + int p1 = uri.find( '/', p ); + if ( p1 != -1 ) + { + int p2 = uri.find( '@', p ); + if ( p2 != -1 && p2 < p1 ) + { + // Got a user + int p3 = uri.find( ':', p ); + if ( p3 != -1 && p3 < p2 ) + { + // Got a password + user = uri.mid( p, p3-p ); + passwd = uri.mid( p3+1, p2-p3-1 ); + } + else + user = uri.mid( p, p2-p ); + } + else + p2 = p-1; + QStringList l = QStringList::split( '/', uri.mid( p2+1 ), false ); + switch ( l.count() ) + { + case 3: + work = l[ 0 ]; + server = l[ 1 ]; + printer = l[ 2 ]; + break; + case 2: + server = l[ 0 ]; + printer = l[ 1 ]; + break; + default: + return false; + } + return true; + } + return false; +} |