blob: 590a80a6e2d03017ee87fc52d11ced3290a34ba1 [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#ifndef ADC_CMD_SINCEDATA_HXX
#define ADC_CMD_SINCEDATA_HXX
// USED SERVICES
// BASE CLASSES
#include "adc_cmd.hxx"
// COMPONENTS
// PARAMETERS
namespace autodoc
{
namespace command
{
/** Provides replacements for the contents of the @@since documentation tag.
Because the @@since tag is part of the source code, it allows only one kind
of version information there. If this is to be mapped for different products
(example: from OpenOffice.org versions in the @@since tag to StarOffice or
StarSuite products), the value of @@since needs a replacement, which is provided
by this class.
*/
class SinceTagTransformationData : public Context
{
public:
/** The key of this map are the version numbers within @since.
The value is the string to display for each version number.
*/
typedef std::map<String,String> Map_Version2Display;
// LIFECYCLE
SinceTagTransformationData();
virtual ~SinceTagTransformationData();
// INQUIRY
/// False, if no transformation table exists.
bool DoesTransform() const;
/** Gets the string to display for a version number.
@param i_sVersionNumber
Usually should be the result of ->StripSinceTagValue().
*/
const String & DisplayOf(
const String & i_sVersionNumber ) const;
private:
// Interface Context:
virtual void do_Init(
opt_iter & i_nCurArgsBegin,
opt_iter i_nEndOfAllArgs );
// DATA
Map_Version2Display aTransformationTable;
};
} // namespace command
} // namespace autodoc
#endif