-
Notifications
You must be signed in to change notification settings - Fork 38k
/
EmptyTargetSource.java
149 lines (122 loc) · 4.25 KB
/
EmptyTargetSource.java
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
/*
* Copyright 2002-2010 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.aop.target;
import java.io.Serializable;
import org.springframework.aop.TargetSource;
import org.springframework.util.ObjectUtils;
/**
* Canonical <code>TargetSource</code> when there is no target
* (or just the target class known), and behavior is supplied
* by interfaces and advisors only.
*
* @author Rod Johnson
* @author Juergen Hoeller
*/
public class EmptyTargetSource implements TargetSource, Serializable {
/** use serialVersionUID from Spring 1.2 for interoperability */
private static final long serialVersionUID = 3680494563553489691L;
//---------------------------------------------------------------------
// Static factory methods
//---------------------------------------------------------------------
/**
* The canonical (Singleton) instance of this {@link EmptyTargetSource}.
*/
public static final EmptyTargetSource INSTANCE = new EmptyTargetSource(null, true);
/**
* Return an EmptyTargetSource for the given target Class.
* @param targetClass the target Class (may be <code>null</code>)
* @see #getTargetClass()
*/
public static EmptyTargetSource forClass(Class targetClass) {
return forClass(targetClass, true);
}
/**
* Return an EmptyTargetSource for the given target Class.
* @param targetClass the target Class (may be <code>null</code>)
* @param isStatic whether the TargetSource should be marked as static
* @see #getTargetClass()
*/
public static EmptyTargetSource forClass(Class targetClass, boolean isStatic) {
return (targetClass == null && isStatic ? INSTANCE : new EmptyTargetSource(targetClass, isStatic));
}
//---------------------------------------------------------------------
// Instance implementation
//---------------------------------------------------------------------
private final Class targetClass;
private final boolean isStatic;
/**
* Create a new instance of the {@link EmptyTargetSource} class.
* <p>This constructor is <code>private</code> to enforce the
* Singleton pattern / factory method pattern.
* @param targetClass the target class to expose (may be <code>null</code>)
* @param isStatic whether the TargetSource is marked as static
*/
private EmptyTargetSource(Class targetClass, boolean isStatic) {
this.targetClass = targetClass;
this.isStatic = isStatic;
}
/**
* Always returns the specified target Class, or <code>null</code> if none.
*/
public Class<?> getTargetClass() {
return this.targetClass;
}
/**
* Always returns <code>true</code>.
*/
public boolean isStatic() {
return this.isStatic;
}
/**
* Always returns <code>null</code>.
*/
public Object getTarget() {
return null;
}
/**
* Nothing to release.
*/
public void releaseTarget(Object target) {
}
/**
* Returns the canonical instance on deserialization in case
* of no target class, thus protecting the Singleton pattern.
*/
private Object readResolve() {
return (this.targetClass == null && this.isStatic ? INSTANCE : this);
}
@Override
public boolean equals(Object other) {
if (this == other) {
return true;
}
if (!(other instanceof EmptyTargetSource)) {
return false;
}
EmptyTargetSource otherTs = (EmptyTargetSource) other;
return (ObjectUtils.nullSafeEquals(this.targetClass, otherTs.targetClass) && this.isStatic == otherTs.isStatic);
}
@Override
public int hashCode() {
return EmptyTargetSource.class.hashCode() * 13 + ObjectUtils.nullSafeHashCode(this.targetClass);
}
@Override
public String toString() {
return "EmptyTargetSource: " +
(this.targetClass != null ? "target class [" + this.targetClass.getName() + "]" : "no target class") +
", " + (this.isStatic ? "static" : "dynamic");
}
}