#region MigraDoc - Creating Documents on the Fly
//
// Authors:
// Stefan Lange
// Klaus Potzesny
// David Stephensen
//
// Copyright (c) 2001-2017 empira Software GmbH, Cologne Area (Germany)
//
// http://www.pdfsharp.com
// http://www.migradoc.com
// http://sourceforge.net/projects/pdfsharp
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
#endregion
using System;
using MigraDoc.DocumentObjectModel.publics;
namespace MigraDoc.DocumentObjectModel.Fields
{
///
/// NumericFieldBase serves as a base for Numeric fields, which are:
/// NumPagesField, PageField, PageRefField, SectionField, SectionPagesField
///
public abstract class NumericFieldBase : DocumentObject
{
///
/// The valid format strings for the supported numeric types.
///
protected static string[] ValidFormatStrings =
{
"",
"ROMAN",
"roman",
"ALPHABETIC",
"alphabetic"
};
///
/// Initializes a new instance of the NumericFieldBase class.
///
public NumericFieldBase()
{ }
///
/// Initializes a new instance of the NumericFieldBase class with the specified parent.
///
public NumericFieldBase(DocumentObject parent) : base(parent) { }
#region Methods
///
/// Creates a deep copy of this object.
///
public new NumericFieldBase Clone()
{
return (NumericFieldBase)DeepCopy();
}
///
/// Implements the deep copy of the object.
///
protected override object DeepCopy()
{
NumericFieldBase numericFieldBase = (NumericFieldBase)base.DeepCopy();
return numericFieldBase;
}
#endregion
#region Properties
///
/// Gets or sets the format of the number.
///
public string Format
{
get { return _format.Value; }
set
{
if (IsValidFormat(value))
_format.Value = value;
else
throw new ArgumentException(DomSR.InvalidFieldFormat(value));
}
}
[DV]
public NString _format = NString.NullValue;
#endregion
///
/// Determines whether the format is valid for numeric fields.
///
protected bool IsValidFormat(string format)
{
foreach (string name in ValidFormatStrings)
{
if (name == Format)
return true;
}
return false;
}
///
/// Determines whether this instance is null (not set).
///
public override bool IsNull()
{
return false;
}
}
}