//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//------------------------------------------------------------------------------
using System;
using System.Collections;
using System.Collections.Specialized;
using System.Diagnostics;
using System.Web.UI;
namespace System.Web.UI.MobileControls
{
/*
* CompileLiteralTextParser class.
*
* This is a specialized version of the LiteralTextParser class.
* It creates a set of control builders from the parsed literal text.
*
* Copyright (c) 2000 Microsoft Corporation
*/
[Obsolete("The System.Web.Mobile.dll assembly has been deprecated and should no longer be used. For information about how to develop ASP.NET mobile applications, see http://go.microsoft.com/fwlink/?LinkId=157231.")]
internal class CompileLiteralTextParser : LiteralTextParser
{
TemplateParser _parser;
ControlBuilder _parentBuilder;
String _fileName;
int _lineNumber;
IList _tagInnerTextElements = null;
internal CompileLiteralTextParser(TemplateParser parser,
ControlBuilder parentBuilder,
String fileName,
int lineNumber)
{
_parser = parser;
_parentBuilder = parentBuilder;
_fileName = fileName;
_lineNumber = lineNumber;
}
protected override void ProcessElement(LiteralElement element)
{
ControlBuilder subBuilder;
switch (element.Type)
{
case LiteralElementType.Text:
Debug.Assert(_tagInnerTextElements == null);
subBuilder = ControlBuilder.CreateBuilderFromType(
_parser, _parentBuilder,
typeof(LiteralText), typeof(LiteralText).Name,
null,
GetPropertyDictionary(element.Format, element.BreakAfter, null),
_lineNumber, _fileName);
break;
case LiteralElementType.Anchor:
{
String linkUrl = (String)element.GetAttribute("href");
subBuilder = ControlBuilder.CreateBuilderFromType(
_parser, _parentBuilder,
typeof(LiteralLink), typeof(LiteralLink).Name,
null,
GetPropertyDictionary(element.Format, element.BreakAfter, linkUrl),
_lineNumber, _fileName);
AddTagInnerTextElements(subBuilder);
break;
}
default:
return;
}
_parentBuilder.AppendSubBuilder(subBuilder);
if (element.Text == null || element.Text.Length != 0)
{
subBuilder.AppendLiteralString(element.Text);
}
}
private IList TagInnerTextElements
{
get
{
if (_tagInnerTextElements == null)
{
_tagInnerTextElements = new ArrayList();
}
return _tagInnerTextElements;
}
}
private void AddTagInnerTextElements(ControlBuilder builder)
{
if (_tagInnerTextElements != null)
{
foreach(Object o in _tagInnerTextElements)
{
if (o is String)
{
builder.AppendLiteralString((String)o);
}
else
{
builder.AppendSubBuilder((ControlBuilder)o);
}
}
_tagInnerTextElements = null;
}
}
protected override void ProcessTagInnerText(String text)
{
// Called to add an inner text segment of a multi-segment tag, e.g.
// some text <%# a databinding %> some more text
TagInnerTextElements.Add(text);
}
internal /*public*/ void AddDataBinding(ControlBuilder builder)
{
if (IsInTag)
{
TagInnerTextElements.Add(builder);
}
else
{
ControlBuilder newBuilder = ControlBuilder.CreateBuilderFromType(
_parser, _parentBuilder,
typeof(LiteralText), typeof(LiteralText).Name,
null,
GetPropertyDictionary(CurrentFormat, false, null),
_lineNumber, _fileName);
_parentBuilder.AppendSubBuilder(newBuilder);
newBuilder.AppendSubBuilder(builder);
OnAfterDataBoundLiteral();
}
}
// Convert formatting and other options into a set of properties, just as if they had been
// specified in persistence format.
private ListDictionary GetPropertyDictionary(LiteralFormat format, bool breakAfter, String linkUrl)
{
ListDictionary dictionary = null;
if (format != LiteralFormat.None || !breakAfter || linkUrl != null)
{
dictionary = new ListDictionary();
if ((format & LiteralFormat.Bold) == LiteralFormat.Bold)
{
dictionary.Add("Font-Bold", "True");
}
if ((format & LiteralFormat.Italic) == LiteralFormat.Italic)
{
dictionary.Add("Font-Italic", "True");
}
if(!breakAfter)
{
dictionary.Add("BreakAfter", "False");
}
if (linkUrl != null)
{
dictionary.Add("NavigateUrl", linkUrl);
}
}
return dictionary;
}
}
}