~ubuntu-branches/ubuntu/oneiric/monodevelop/oneiric-updates

« back to all changes in this revision

Viewing changes to src/addins/MonoDevelop.XmlEditor/MonoDevelop.Xml.StateEngine/State.cs

  • Committer: Bazaar Package Importer
  • Author(s): Jo Shields
  • Date: 2009-02-18 08:40:51 UTC
  • mfrom: (1.2.1 upstream)
  • Revision ID: james.westby@ubuntu.com-20090218084051-gh8m6ukvokbwj7cf
Tags: 1.9.2+dfsg-1ubuntu1
* Merge from Debian Experimental (LP: #330519), remaining Ubuntu changes:
  + debian/control:
    - Update for Gnome# 2.24
    - Add libmono-cairo1.0-cil to build-deps to fool pkg-config check

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
// 
 
2
// State.cs
 
3
// 
 
4
// Author:
 
5
//   Michael Hutchinson <mhutchinson@novell.com>
 
6
// 
 
7
// Copyright (C) 2008 Novell, Inc (http://www.novell.com)
 
8
// 
 
9
// Permission is hereby granted, free of charge, to any person obtaining
 
10
// a copy of this software and associated documentation files (the
 
11
// "Software"), to deal in the Software without restriction, including
 
12
// without limitation the rights to use, copy, modify, merge, publish,
 
13
// distribute, sublicense, and/or sell copies of the Software, and to
 
14
// permit persons to whom the Software is furnished to do so, subject to
 
15
// the following conditions:
 
16
// 
 
17
// The above copyright notice and this permission notice shall be
 
18
// included in all copies or substantial portions of the Software.
 
19
// 
 
20
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 
21
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 
22
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 
23
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 
24
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 
25
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 
26
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
27
//
 
28
 
 
29
using System;
 
30
using System.Diagnostics;
 
31
using System.Collections.Generic;
 
32
using System.Text;
 
33
 
 
34
namespace MonoDevelop.Xml.StateEngine
 
35
{
 
36
        public abstract class State
 
37
        {
 
38
                State parent;
 
39
 
 
40
                /// <summary>
 
41
                /// When the <see cref="Parser"/> advances by one character, it calls this method 
 
42
                /// on the currently active <see cref="State"/> to determine the next state.
 
43
                /// </summary>
 
44
                /// <param name="c">The current character.</param>
 
45
                /// <param name="rollback"> If set non-null, the parser will be rolled back that number 
 
46
                /// of characters (empty string means replay current char to the next state.
 
47
                /// Note that this will not change the DOM state.</param>
 
48
                /// <returns>
 
49
                /// The next state. A new or parent <see cref="State"/> will change the parser state; 
 
50
                /// the current state or <see cref="null"/> will not.
 
51
                /// </returns>
 
52
                public abstract State PushChar (char c, IParseContext context, ref string rollback);
 
53
 
 
54
                public State Parent { get { return parent; } }
 
55
                
 
56
                protected void Adopt (State child)
 
57
                {
 
58
                        Debug.Assert (child.parent == null);
 
59
                        child.parent = this;
 
60
                }
 
61
                
 
62
                public RootState RootState {
 
63
                        get {
 
64
                                return (this as RootState) ?? parent.RootState;
 
65
                        }
 
66
                }
 
67
        }
 
68
        
 
69
        public abstract class RootState : State
 
70
        {
 
71
                public abstract XDocument CreateDocument ();
 
72
        }
 
73
}