office-gobmx/xml2cmp/source/x2cclass/xml_cdim.cxx
Jens-Heiner Rechtien b525a3115f initial import
2000-09-18 14:29:57 +00:00

217 lines
7 KiB
C++

/*************************************************************************
*
* $RCSfile: xml_cdim.cxx,v $
*
* $Revision: 1.1.1.1 $
*
* last change: $Author: hr $ $Date: 2000-09-18 15:29:00 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#include "xml_cdim.hxx"
const char ComponentDescriptionImpl::C_sTagDescription[]
= "COMPONENTDESCRIPTION";
const char ComponentDescriptionImpl::C_sStatus[]
= "Status";
const char * ComponentDescriptionImpl::C_sSubTags[ComponentDescription::tag_MAX]
= { "None",
"Name",
"Description",
"ModuleName",
"LoaderName",
"SupportedService",
"ProjectBuildDependency",
"RuntimeModuleDependency",
"ServiceDependency",
"Language",
C_sStatus,
"Type"
};
ComponentDescriptionImpl::ComponentDescriptionImpl()
// : aTags
{
const int i_max = tag_MAX;
aTags.reserve(i_max);
for (int i = 0; i < i_max; ++i)
{
aTags.push_back( new ValueList(E_Tag(i)) );
} // end for
}
ComponentDescriptionImpl::~ComponentDescriptionImpl()
{
for ( std::vector< ValueList* >::iterator aIter = aTags.begin();
aIter != aTags.end();
++aIter )
{
delete *aIter;
}
}
inline void
GetStatusValue( ByteString & o_sValue, const ByteString & i_sStatusTag )
{
// o_sValue is always == "" at the beginning.
const char * pStatusValue = strchr(i_sStatusTag.GetBuffer(), '"');
if (pStatusValue == 0)
return;
pStatusValue++;
const char * pStatusValueEnd = strrchr(pStatusValue,'"');
if (pStatusValueEnd == 0 || pStatusValueEnd - pStatusValue < 1)
return ;
ByteString sValue(pStatusValue, pStatusValueEnd - pStatusValue);
o_sValue = sValue;
}
ComponentDescriptionImpl::ValueList *
ComponentDescriptionImpl::GetBeginTag( ByteString & o_sValue,
const char *& io_pStartOfTag ) const
{
o_sValue = "";
const char * pCurTextEnd = strchr(io_pStartOfTag,'>');
if ( 0 == pCurTextEnd )
return 0;
if ( ComponentDescriptionImpl::CheckEndOfDescription(io_pStartOfTag) )
return 0;
ByteString sTag(io_pStartOfTag + 1, pCurTextEnd - io_pStartOfTag - 1);
io_pStartOfTag += sTag.Len() + 2;
// Special case <Status ... >
if ( strnicmp(C_sStatus, sTag.GetBuffer(), (sizeof C_sStatus) - 1 ) == 0 )
{
GetStatusValue(o_sValue,sTag);
return aTags[tag_Status];
}
// Regular seeking for matching data list:
for ( INT32 i = 0; i < tag_MAX; i++ )
{
if ( 0 == stricmp(sTag.GetBuffer(), C_sSubTags[i]) )
return aTags[i];
} // end for
return 0;
}
const std::vector< ByteString > &
ComponentDescriptionImpl::DataOf( ComponentDescriptionImpl::E_Tag i_eTag ) const
{
if (0 < i_eTag && i_eTag < tag_MAX)
return *aTags[i_eTag];
else
return ValueList::Null_();
}
ByteString
ComponentDescriptionImpl::DatumOf( ComponentDescriptionImpl::E_Tag i_eTag ) const
{
if (0 < i_eTag && i_eTag < tag_MAX)
{
ValueList & rValues = *aTags[i_eTag];
if (rValues.size() > 0)
return rValues[0];
}
return "";
}
void
ComponentDescriptionImpl::ParseUntilStartOfDescription( const char * & io_pBufferPosition )
{
for ( const char * pSearch = strchr(io_pBufferPosition,'<');
pSearch != 0;
pSearch = strchr(pSearch+1,'<') )
{
if ( pSearch != io_pBufferPosition
&& 0 == strnicmp(pSearch+1,C_sTagDescription, strlen(C_sTagDescription))
&& *(pSearch + strlen(C_sTagDescription) + 1) == '>' )
{
io_pBufferPosition = pSearch + strlen(C_sTagDescription) + 2;
return;
}
} // end for
io_pBufferPosition = 0;
}
BOOL
ComponentDescriptionImpl::ValueList::MatchesEndTag( const char * i_pTextPosition ) const
{
return strnicmp( i_pTextPosition+2, C_sSubTags[eTag], strlen(C_sSubTags[eTag]) ) == 0
&& strncmp(i_pTextPosition,"</",2) == 0
&& *(i_pTextPosition + 2 + strlen(C_sSubTags[eTag]) ) == '>';
}
INT32
ComponentDescriptionImpl::ValueList::EndTagLength() const
{
return strlen(C_sSubTags[eTag]) + 3;
}
const ComponentDescriptionImpl::ValueList &
ComponentDescriptionImpl::ValueList::Null_()
{
static const ValueList aNull_(ComponentDescription::tag_None);
return aNull_;
}