Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(935)

Side by Side Diff: Source/core/dom/CustomElementRegistrationContext.h

Issue 23009004: Process Custom Elements in post-order. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Less fragile. Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 7 *
8 * 1. Redistributions of source code must retain the above copyright 8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright 10 * 2. Redistributions in binary form must reproduce the above copyright
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
50 class CustomElementRegistrationContext : public RefCounted<CustomElementRegistra tionContext> { 50 class CustomElementRegistrationContext : public RefCounted<CustomElementRegistra tionContext> {
51 public: 51 public:
52 static PassRefPtr<CustomElementRegistrationContext> create(); 52 static PassRefPtr<CustomElementRegistrationContext> create();
53 53
54 ~CustomElementRegistrationContext() { } 54 ~CustomElementRegistrationContext() { }
55 55
56 // Definitions 56 // Definitions
57 void registerElement(Document*, CustomElementConstructorBuilder*, const Atom icString& type, ExceptionState&); 57 void registerElement(Document*, CustomElementConstructorBuilder*, const Atom icString& type, ExceptionState&);
58 58
59 // Instance creation 59 // Instance creation
60 PassRefPtr<Element> createCustomTagElement(Document*, const QualifiedName&); 60 PassRefPtr<Element> createCustomTagElement(Document*, const QualifiedName&, bool byParser = false);
dglazkov 2013/08/14 20:22:34 Can we switch to use enums here?
61 static void setIsAttributeAndTypeExtension(Element*, const AtomicString& typ e); 61 static void setIsAttributeAndTypeExtension(Element*, const AtomicString& typ e);
62 static void setTypeExtension(Element*, const AtomicString& type); 62 static void setTypeExtension(Element*, const AtomicString& type, bool byPars er = false);
63
64 // Instance lifecycle
65 void customElementWasDestroyed(Element*);
66 63
67 protected: 64 protected:
68 CustomElementRegistrationContext() { } 65 CustomElementRegistrationContext() { }
69 66
70 // Instance creation 67 // Instance creation
71 void didGiveTypeExtension(Element*, const AtomicString& type); 68 void didGiveTypeExtension(Element*, const AtomicString& type);
72 69
73 private: 70 private:
74 void resolve(Element*, const AtomicString& typeExtension); 71 void resolve(Element*, const AtomicString& typeExtension);
75 void didResolveElement(CustomElementDefinition*, Element*); 72 void didResolveElement(CustomElementDefinition*, Element*);
76 void didCreateUnresolvedElement(const CustomElementDescriptor&, Element*); 73 void didCreateUnresolvedElement(const CustomElementDescriptor&, Element*);
77 74
78 CustomElementRegistry m_registry; 75 CustomElementRegistry m_registry;
79 76
80 // Element creation 77 // Element creation
81 CustomElementUpgradeCandidateMap m_candidates; 78 CustomElementUpgradeCandidateMap m_candidates;
82 }; 79 };
83 80
84 } 81 }
85 82
86 #endif // CustomElementRegistrationContext_h 83 #endif // CustomElementRegistrationContext_h
87 84
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698