blob: 14a2ee3152429cf8b996ccda3c8e0d6bda697674 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef DOM_SMIL_SMILTARGETIDENTIFIER_H_
#define DOM_SMIL_SMILTARGETIDENTIFIER_H_
// XXX Avoid including this here by moving function bodies to the cpp file
#include "nsAtom.h"
#include "nsIContent.h"
#include "mozilla/dom/Element.h"
class nsIContent;
namespace mozilla {
namespace dom {
class Element;
}
/**
* Struct: SMILTargetIdentifier
*
* Tuple of: { Animated Element, Attribute Name }
*
* Used in SMILAnimationController as hash key for mapping an animation
* target to the SMILCompositor for that target.
*
* NOTE: Need a nsRefPtr for the element & attribute name, because
* SMILAnimationController retain its hash table for one sample into the
* future, and we need to make sure their target isn't deleted in that time.
*/
struct SMILTargetIdentifier {
SMILTargetIdentifier()
: mElement(nullptr),
mAttributeName(nullptr),
mAttributeNamespaceID(kNameSpaceID_Unknown) {}
inline bool Equals(const SMILTargetIdentifier& aOther) const {
return (aOther.mElement == mElement &&
aOther.mAttributeName == mAttributeName &&
aOther.mAttributeNamespaceID == mAttributeNamespaceID);
}
RefPtr<mozilla::dom::Element> mElement;
RefPtr<nsAtom> mAttributeName;
int32_t mAttributeNamespaceID;
};
/**
* Class: SMILWeakTargetIdentifier
*
* Version of the above struct that uses non-owning pointers. These are kept
* private, to ensure that they aren't ever dereferenced (or used at all,
* outside of Equals()).
*
* This is solely for comparisons to determine if a target has changed
* from one sample to the next.
*/
class SMILWeakTargetIdentifier {
public:
// Trivial constructor
SMILWeakTargetIdentifier() : mElement(nullptr), mAttributeName(nullptr) {}
// Allow us to update a weak identifier to match a given non-weak identifier
SMILWeakTargetIdentifier& operator=(const SMILTargetIdentifier& aOther) {
mElement = aOther.mElement;
mAttributeName = aOther.mAttributeName;
return *this;
}
// Allow for comparison vs. non-weak identifier
inline bool Equals(const SMILTargetIdentifier& aOther) const {
return (aOther.mElement == mElement &&
aOther.mAttributeName == mAttributeName);
}
private:
const nsIContent* mElement;
const nsAtom* mAttributeName;
};
} // namespace mozilla
#endif // DOM_SMIL_SMILTARGETIDENTIFIER_H_
|