blob: 2b2afdf4bbf74e221e9a3f63d94f5d46ed8bcca7 (
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
69
70
71
72
73
74
75
76
77
78
79
80
81
|
/*******************************************************************************
* 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.osgi.service.resolver;
/**
* A state wire represents a decision made by a resolver to wire a requirement to a capability.
* There are 4 parts to a state wire.
* <ul>
* <li>The requirement which may have been specified by a host bundle or one of its attached fragments.</li>
* <li>The host bundle which is associated with the requirement. There are cases where the host
* bundle may not be the same as the bundle which declared the requirement. For example, if a fragment
* specifies additional requirements.</li>
* <li>The capability which may have been specified by a host bundle or one of its attached fragments.</li>
* <li>The host bundle which is associated with the capability. There are cases where the host
* bundle may not be the same as the bundle which declared the capability. For example, if a fragment
* specifies additional capabilities.</li>
* </ul>
* @since 3.7
*/
public class StateWire {
private final BundleDescription requirementHost;
private final VersionConstraint declaredRequirement;
private final BundleDescription capabilityHost;
private final BaseDescription declaredCapability;
/**
* Constructs a new state wire.
* @param requirementHost the bundle hosting the requirement.
* @param declaredRequirement the declared requirement. The bundle declaring the requirement may be different from the requirement host.
* @param capabilityHost the bundle hosting the capability.
* @param declaredCapability the declared capability. The bundle declaring the capability may be different from the capability host.
*/
public StateWire(BundleDescription requirementHost, VersionConstraint declaredRequirement, BundleDescription capabilityHost, BaseDescription declaredCapability) {
super();
this.requirementHost = requirementHost;
this.declaredRequirement = declaredRequirement;
this.capabilityHost = capabilityHost;
this.declaredCapability = declaredCapability;
}
/**
* Gets the requirement host.
* @return the requirement host.
*/
public BundleDescription getRequirementHost() {
return requirementHost;
}
/**
* Gets the declared requirement.
* @return the declared requirement.
*/
public VersionConstraint getDeclaredRequirement() {
return declaredRequirement;
}
/**
* gets the capability host.
* @return the capability host.
*/
public BundleDescription getCapabilityHost() {
return capabilityHost;
}
/**
* gets the declared capability.
* @return the declared capability.
*/
public BaseDescription getDeclaredCapability() {
return declaredCapability;
}
}
|