blob: 0442c38fd9c50445e8e551263f8add28c326948a (
plain) (
blame)
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
|
/*******************************************************************************
* Copyright (c) 2011 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.equinox.coordinator;
import java.lang.ref.ReferenceQueue;
import java.lang.ref.WeakReference;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;
import org.eclipse.osgi.util.NLS;
import org.osgi.service.coordinator.Coordination;
import org.osgi.service.coordinator.CoordinationException;
import org.osgi.service.log.LogService;
public class CoordinationWeakReference extends WeakReference<CoordinationReferent> {
private static final ReferenceQueue<CoordinationReferent> referenceQueue = new ReferenceQueue<CoordinationReferent>();
private static final Set<CoordinationWeakReference> references = Collections.synchronizedSet(new HashSet<CoordinationWeakReference>());
public static CoordinationWeakReference newInstance(CoordinationReferent referent) {
CoordinationWeakReference reference = new CoordinationWeakReference(referent);
references.add(reference);
return reference;
}
public static void processOrphanedCoordinations() {
CoordinationWeakReference r;
while ((r = (CoordinationWeakReference)referenceQueue.poll()) != null) {
references.remove(r);
CoordinationImpl c = r.getCoordination();
try {
c.fail(Coordination.ORPHANED);
}
catch (Throwable t) {
c.getLogService().log(LogService.LOG_ERROR, NLS.bind(Messages.CoordinatorImpl_5, c.getName(), c.getId()), t);
}
finally {
try {
c.end();
}
catch (CoordinationException e) {
// This is expected since we already failed the coordination.
}
}
}
}
private final CoordinationImpl coordination;
private CoordinationWeakReference(CoordinationReferent referent) {
super(referent, referenceQueue);
coordination = referent.getDelegate();
if (coordination == null)
throw new NullPointerException();
}
public CoordinationImpl getCoordination() {
return coordination;
}
}
|