1 | // <developer>niklas@protocol7.com</developer>
|
---|
2 | // <completed>80</completed>
|
---|
3 |
|
---|
4 | using System;
|
---|
5 | using System.Collections.Generic;
|
---|
6 | using System.Text.RegularExpressions;
|
---|
7 |
|
---|
8 | namespace SharpVectors.Dom.Css
|
---|
9 | {
|
---|
10 | /// <summary>
|
---|
11 | /// The CSSCharsetRule interface represents a @charset rule in a CSS style sheet. The value of the encoding attribute does not affect the encoding of text data in the DOM objects; this encoding is always UTF-16. After a stylesheet is loaded, the value of the encoding attribute is the value found in the @charset rule. If there was no @charset in the original document, then no CSSCharsetRule is created. The value of the encoding attribute may also be used as a hint for the encoding used on serialization of the style sheet.
|
---|
12 | /// The value of the @charset rule (and therefore of the CSSCharsetRule) may not correspond to the encoding the document actually came in; character encoding information e.g. in an HTTP header, has priority (see CSS document representation) but this is not reflected in the CSSCharsetRule.
|
---|
13 | /// </summary>
|
---|
14 | public class CssCharsetRule : CssRule, ICssCharsetRule
|
---|
15 | {
|
---|
16 | #region Static members
|
---|
17 | private static Regex regex = new Regex(@"^@charset\s""(?<charsetencoding>[^""]+)"";");
|
---|
18 |
|
---|
19 | internal static CssRule Parse(ref string css, object parent, bool readOnly, IList<string> replacedStrings, CssStyleSheetType origin)
|
---|
20 | {
|
---|
21 | Match match = regex.Match(css);
|
---|
22 | if(match.Success)
|
---|
23 | {
|
---|
24 | CssCharsetRule rule = new CssCharsetRule(match, parent, readOnly, replacedStrings, origin);
|
---|
25 | css = css.Substring(match.Length);
|
---|
26 | return rule;
|
---|
27 | }
|
---|
28 | else
|
---|
29 | {
|
---|
30 | // didn't match => do nothing
|
---|
31 | return null;
|
---|
32 | }
|
---|
33 | }
|
---|
34 | #endregion
|
---|
35 |
|
---|
36 | #region Constructors
|
---|
37 |
|
---|
38 | /// <summary>
|
---|
39 | /// The constructor for CssCharSetRule
|
---|
40 | /// </summary>
|
---|
41 | /// <param name="match">The Regex match that found the charset rule</param>
|
---|
42 | /// <param name="parent">The parent rule or parent stylesheet</param>
|
---|
43 | /// <param name="readOnly">True if this instance is readonly</param>
|
---|
44 | /// <param name="replacedStrings">An array of strings that have been replaced in the string used for matching. These needs to be put back use the DereplaceStrings method</param>
|
---|
45 | /// <param name="origin">The type of CssStyleSheet</param>
|
---|
46 | internal CssCharsetRule(Match match, object parent, bool readOnly,
|
---|
47 | IList<string> replacedStrings, CssStyleSheetType origin)
|
---|
48 | : base(parent, readOnly, replacedStrings, origin)
|
---|
49 | {
|
---|
50 | _Encoding = DeReplaceStrings(match.Groups["charsetencoding"].Value);
|
---|
51 | }
|
---|
52 |
|
---|
53 | #endregion
|
---|
54 |
|
---|
55 | #region Implementation of ICssCharsetRule
|
---|
56 | private string _Encoding;
|
---|
57 | /// <summary>
|
---|
58 | /// The encoding information used in this @charset rule
|
---|
59 | /// </summary>
|
---|
60 | public string Encoding
|
---|
61 | {
|
---|
62 | get
|
---|
63 | {
|
---|
64 | return _Encoding;
|
---|
65 | }
|
---|
66 | set
|
---|
67 | {
|
---|
68 | /*
|
---|
69 | * TODO: SYNTAX_ERR: Raised if the specified encoding value has a syntax error and is unparsable.
|
---|
70 | * */
|
---|
71 |
|
---|
72 | if (readOnly)
|
---|
73 | throw new DomException(DomExceptionType.NoModificationAllowedErr);
|
---|
74 |
|
---|
75 | _Encoding = value;
|
---|
76 | }
|
---|
77 | }
|
---|
78 | #endregion
|
---|
79 |
|
---|
80 | #region Implementation of ICssRule
|
---|
81 | /// <summary>
|
---|
82 | /// The type of the rule. The expectation is that binding-specific casting methods can be used to cast down from an instance of the CSSRule interface to the specific derived interface implied by the type.
|
---|
83 | /// </summary>
|
---|
84 | public override CssRuleType Type
|
---|
85 | {
|
---|
86 | get
|
---|
87 | {
|
---|
88 | return CssRuleType.CharsetRule;
|
---|
89 | }
|
---|
90 | }
|
---|
91 | #endregion
|
---|
92 | }
|
---|
93 | }
|
---|