~ubuntu-branches/ubuntu/precise/kompozer/precise

« back to all changes in this revision

Viewing changes to mozilla/content/xul/templates/src/nsContentTestNode.h

  • Committer: Bazaar Package Importer
  • Author(s): Anthony Yarusso
  • Date: 2007-08-27 01:11:03 UTC
  • Revision ID: james.westby@ubuntu.com-20070827011103-2jgf4s6532gqu2ka
Tags: upstream-0.7.10
ImportĀ upstreamĀ versionĀ 0.7.10

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
 
2
/* ***** BEGIN LICENSE BLOCK *****
 
3
 * Version: NPL 1.1/GPL 2.0/LGPL 2.1
 
4
 *
 
5
 * The contents of this file are subject to the Netscape Public License
 
6
 * Version 1.1 (the "License"); you may not use this file except in
 
7
 * compliance with the License. You may obtain a copy of the License at
 
8
 * http://www.mozilla.org/NPL/
 
9
 *
 
10
 * Software distributed under the License is distributed on an "AS IS" basis,
 
11
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 
12
 * for the specific language governing rights and limitations under the
 
13
 * License.
 
14
 *
 
15
 * The Original Code is Mozilla Communicator client code.
 
16
 *
 
17
 * The Initial Developer of the Original Code is 
 
18
 * Netscape Communications Corporation.
 
19
 * Portions created by the Initial Developer are Copyright (C) 1998
 
20
 * the Initial Developer. All Rights Reserved.
 
21
 *
 
22
 * Contributor(s):
 
23
 *   Chris Waterson <waterson@netscape.com>
 
24
 *
 
25
 *
 
26
 * Alternatively, the contents of this file may be used under the terms of
 
27
 * either the GNU General Public License Version 2 or later (the "GPL"), or
 
28
 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 
29
 * in which case the provisions of the GPL or the LGPL are applicable instead
 
30
 * of those above. If you wish to allow use of your version of this file only
 
31
 * under the terms of either the GPL or the LGPL, and not to allow others to
 
32
 * use your version of this file under the terms of the NPL, indicate your
 
33
 * decision by deleting the provisions above and replace them with the notice
 
34
 * and other provisions required by the GPL or the LGPL. If you do not delete
 
35
 * the provisions above, a recipient may use your version of this file under
 
36
 * the terms of any one of the NPL, the GPL or the LGPL.
 
37
 *
 
38
 * ***** END LICENSE BLOCK ***** */
 
39
 
 
40
#ifndef nsContentTestNode_h__
 
41
#define nsContentTestNode_h__
 
42
 
 
43
#include "nscore.h"
 
44
#include "nsRuleNetwork.h"
 
45
#include "nsFixedSizeAllocator.h"
 
46
#include "nsIAtom.h"
 
47
 
 
48
class nsIXULTemplateBuilder;
 
49
class nsIXULDocument;
 
50
class nsConflictSet;
 
51
 
 
52
class nsContentTestNode : public TestNode
 
53
{
 
54
public:
 
55
    nsContentTestNode(InnerNode* aParent,
 
56
                      nsConflictSet& aConflictSet,
 
57
                      nsIXULDocument* aDocument,
 
58
                      nsIXULTemplateBuilder* aBuilder,
 
59
                      PRInt32 aContentVariable,
 
60
                      PRInt32 aIdVariable,
 
61
                      nsIAtom* aTag);
 
62
 
 
63
    virtual nsresult
 
64
    FilterInstantiations(InstantiationSet& aInstantiations, void* aClosure) const;
 
65
 
 
66
    virtual nsresult
 
67
    GetAncestorVariables(VariableSet& aVariables) const;
 
68
 
 
69
    class Element : public MemoryElement {
 
70
    private:
 
71
        // Hide so that only Create() and Destroy() can be used to
 
72
        // allocate and deallocate from the heap
 
73
        static void* operator new(size_t) CPP_THROW_NEW { return 0; }
 
74
        static void operator delete(void*, size_t) {}
 
75
 
 
76
    public:
 
77
        Element(nsIContent* aContent)
 
78
            : mContent(aContent) {
 
79
            MOZ_COUNT_CTOR(nsContentTestNode::Element); }
 
80
 
 
81
        virtual ~Element() { MOZ_COUNT_DTOR(nsContentTestNode::Element); }
 
82
 
 
83
        static Element*
 
84
        Create(nsFixedSizeAllocator& aPool, nsIContent* aContent) {
 
85
            void* place = aPool.Alloc(sizeof(Element));
 
86
            return place ? ::new (place) Element(aContent) : nsnull; }
 
87
 
 
88
        static void
 
89
        Destroy(nsFixedSizeAllocator& aPool, Element* aElement) {
 
90
            aElement->~Element();
 
91
            aPool.Free(aElement, sizeof(*aElement)); }
 
92
 
 
93
        virtual const char* Type() const {
 
94
            return "nsContentTestNode::Element"; }
 
95
 
 
96
        virtual PLHashNumber Hash() const {
 
97
            return PLHashNumber(NS_PTR_TO_INT32(mContent.get())) >> 2; }
 
98
 
 
99
        virtual PRBool Equals(const MemoryElement& aElement) const {
 
100
            if (aElement.Type() == Type()) {
 
101
                const Element& element = NS_STATIC_CAST(const Element&, aElement);
 
102
                return mContent == element.mContent;
 
103
            }
 
104
            return PR_FALSE; }
 
105
 
 
106
        virtual MemoryElement* Clone(void* aPool) const {
 
107
            return Create(*NS_STATIC_CAST(nsFixedSizeAllocator*, aPool), mContent); }
 
108
 
 
109
    protected:
 
110
        nsCOMPtr<nsIContent> mContent;
 
111
    };
 
112
 
 
113
protected:
 
114
    nsConflictSet& mConflictSet;
 
115
    nsIXULDocument* mDocument; // [WEAK] because we know the document will outlive us
 
116
    nsIXULTemplateBuilder *mBuilder;
 
117
    PRInt32 mContentVariable;
 
118
    PRInt32 mIdVariable;
 
119
    nsCOMPtr<nsIAtom> mTag;
 
120
};
 
121
 
 
122
#endif // nsContentTestNode_h__
 
123