kabc Library API Documentation

AdrParam.cpp

00001 /*
00002     libvcard - vCard parsing library for vCard version 3.0
00003 
00004     Copyright (C) 1998 Rik Hemsley rik@kde.org
00005     
00006   Permission is hereby granted, free of charge, to any person obtaining a copy
00007   of this software and associated documentation files (the "Software"), to
00008   deal in the Software without restriction, including without limitation the
00009   rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
00010   sell copies of the Software, and to permit persons to whom the Software is
00011   furnished to do so, subject to the following conditions:
00012 
00013   The above copyright notice and this permission notice shall be included in
00014   all copies or substantial portions of the Software.
00015 
00016   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
00017   IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
00018   FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
00019   AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
00020   ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
00021   WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
00022 */
00023 
00024 #include <VCardRToken.h>
00025 #include <VCardAdrParam.h>
00026 #include <VCardParam.h>
00027 
00028 using namespace VCARD;
00029 
00030 AdrParam::AdrParam()
00031     :   Param()
00032 {
00033 }
00034 
00035 AdrParam::AdrParam(const AdrParam & x)
00036     :   Param(x),
00037         adrTypeList_    (x.adrTypeList_)
00038 {
00039 }
00040 
00041 AdrParam::AdrParam(const QCString & s)
00042     :   Param(s)
00043 {
00044 }
00045 
00046     AdrParam &
00047 AdrParam::operator = (AdrParam & x)
00048 {
00049     if (*this == x) return *this;
00050     
00051     adrTypeList_    = x.adrTypeList();
00052     textParam_      = x.textParam();
00053 
00054     Param::operator = (x);
00055     return *this;
00056 }
00057 
00058     AdrParam &
00059 AdrParam::operator = (const QCString & s)
00060 {
00061     Param::operator = (s);
00062     
00063     adrTypeList_.clear();
00064     textParam_.truncate(0);
00065     
00066     return *this;
00067 }
00068 
00069     bool
00070 AdrParam::operator == (AdrParam & x)
00071 {
00072     parse();
00073 
00074     if (!x.textParam().isEmpty())
00075         return (x.textParam_ == textParam_);
00076 
00077     if (x.adrTypeList().count() != adrTypeList_.count())
00078         return false;
00079     
00080     QStrListIterator it(x.adrTypeList_);
00081     
00082     for (; it.current(); ++it)
00083         if (!adrTypeList_.find(it.current()))
00084             return false;
00085     
00086     return true;
00087 }
00088 
00089 AdrParam::~AdrParam()
00090 {
00091 }
00092 
00093     void
00094 AdrParam::_parse()
00095 {
00096     adrTypeList_.clear();
00097 
00098     if (strRep_.left(4) != "TYPE") {
00099         textParam_ = strRep_;
00100         return;
00101     }
00102     
00103     if (!strRep_.contains('='))
00104         return;
00105     
00106     RTokenise(strRep_, ",", adrTypeList_);
00107 }
00108 
00109     void
00110 AdrParam::_assemble()
00111 {
00112     if (!textParam_.isEmpty()) {
00113         strRep_ = textParam_;
00114         return;
00115     }
00116     
00117     QStrListIterator it(adrTypeList_);
00118     
00119     for (; it.current(); ++it) {
00120         
00121         strRep_ += it.current();
00122         
00123         if (it.current() != adrTypeList_.last())
00124             strRep_ += ',';
00125     }
00126 }
KDE Logo
This file is part of the documentation for kdelibs Version 3.1.4.
Documentation copyright © 1996-2002 the KDE developers.
Generated on Sun Feb 27 22:16:07 2005 by doxygen 1.3.4 written by Dimitri van Heesch, © 1997-2001