-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Embed the required StateFactory implementations
Currently P2 has the BundleDescription in its API where the only implementation is in the discouraged osgi.compatibility fragment, but actually P2 does not really need a full implementation, it is just using that to parse manifest headers and generate metadata from it. This embeds a stripped down version of the actual implementation in the p2.publisher.eclipse that allows to create implementation objects without rely on the compatibility fragment anymore.
- Loading branch information
Showing
16 changed files
with
3,734 additions
and
6 deletions.
There are no files selected for viewing
75 changes: 75 additions & 0 deletions
75
bundles/org.eclipse.equinox.p2.publisher.eclipse/.settings/.api_filters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
<?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||
<component id="org.eclipse.equinox.p2.publisher.eclipse" version="2"> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/BaseDescriptionImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.BaseDescriptionImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="BaseDescription"/> | ||
<message_argument value="BaseDescriptionImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/BundleDescriptionImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.BundleDescriptionImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="BundleDescription"/> | ||
<message_argument value="BundleDescriptionImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/BundleSpecificationImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.BundleSpecificationImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="BundleSpecification"/> | ||
<message_argument value="BundleSpecificationImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/ExportPackageDescriptionImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.ExportPackageDescriptionImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="ExportPackageDescription"/> | ||
<message_argument value="ExportPackageDescriptionImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/GenericDescriptionImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.GenericDescriptionImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="GenericDescription"/> | ||
<message_argument value="GenericDescriptionImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/GenericSpecificationImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.GenericSpecificationImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="GenericSpecification"/> | ||
<message_argument value="GenericSpecificationImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/HostSpecificationImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.HostSpecificationImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="HostSpecification"/> | ||
<message_argument value="HostSpecificationImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/ImportPackageSpecificationImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.ImportPackageSpecificationImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="ImportPackageSpecification"/> | ||
<message_argument value="ImportPackageSpecificationImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
<resource path="src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/VersionConstraintImpl.java" type="org.eclipse.equinox.p2.publisher.eclipse.statefactory.VersionConstraintImpl"> | ||
<filter id="574619656"> | ||
<message_arguments> | ||
<message_argument value="VersionConstraint"/> | ||
<message_argument value="VersionConstraintImpl"/> | ||
</message_arguments> | ||
</filter> | ||
</resource> | ||
</component> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
190 changes: 190 additions & 0 deletions
190
...clipse/src/org/eclipse/equinox/p2/publisher/eclipse/statefactory/BaseDescriptionImpl.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,190 @@ | ||
/******************************************************************************* | ||
* Copyright (c) 2004, 2016 IBM Corporation and others. | ||
* | ||
* This program and the accompanying materials | ||
* are made available under the terms of the Eclipse Public License 2.0 | ||
* which accompanies this distribution, and is available at | ||
* https://www.eclipse.org/legal/epl-2.0/ | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 | ||
* | ||
* Contributors: | ||
* IBM Corporation - initial API and implementation | ||
* Rob Harrop - SpringSource Inc. (bug 247522) | ||
*******************************************************************************/ | ||
package org.eclipse.equinox.p2.publisher.eclipse.statefactory; | ||
|
||
import java.util.*; | ||
import java.util.Map.Entry; | ||
import org.eclipse.osgi.service.resolver.BaseDescription; | ||
import org.osgi.framework.Version; | ||
import org.osgi.framework.wiring.BundleCapability; | ||
import org.osgi.framework.wiring.BundleRevision; | ||
|
||
abstract class BaseDescriptionImpl implements BaseDescription { | ||
|
||
protected final Object monitor = new Object(); | ||
|
||
private volatile String name; | ||
|
||
private volatile Version version; | ||
|
||
private volatile Object userObject; | ||
|
||
@Override | ||
public String getName() { | ||
return name; | ||
} | ||
|
||
@Override | ||
public Version getVersion() { | ||
synchronized (this.monitor) { | ||
if (version == null) | ||
return Version.emptyVersion; | ||
return version; | ||
} | ||
} | ||
|
||
protected void setName(String name) { | ||
this.name = name; | ||
} | ||
|
||
protected void setVersion(Version version) { | ||
this.version = version; | ||
} | ||
|
||
static <V> String toString(Map<String, V> map, boolean directives) { | ||
if (map.size() == 0) | ||
return ""; //$NON-NLS-1$ | ||
String assignment = directives ? ":=" : "="; //$NON-NLS-1$//$NON-NLS-2$ | ||
Set<Entry<String, V>> set = map.entrySet(); | ||
StringBuilder sb = new StringBuilder(); | ||
for (Entry<String, V> entry : set) { | ||
sb.append("; "); //$NON-NLS-1$ | ||
String key = entry.getKey(); | ||
Object value = entry.getValue(); | ||
if (value instanceof List) { | ||
@SuppressWarnings("unchecked") | ||
List<Object> list = (List<Object>) value; | ||
if (list.size() == 0) | ||
continue; | ||
Object component = list.get(0); | ||
String className = component.getClass().getName(); | ||
String type = className.substring(className.lastIndexOf('.') + 1); | ||
sb.append(key).append(':').append("List<").append(type).append(">").append(assignment).append('"'); //$NON-NLS-1$ //$NON-NLS-2$ | ||
for (Object object : list) | ||
sb.append(object).append(','); | ||
sb.setLength(sb.length() - 1); | ||
sb.append('"'); | ||
} else { | ||
String type = ""; //$NON-NLS-1$ | ||
if (!(value instanceof String)) { | ||
String className = value.getClass().getName(); | ||
type = ":" + className.substring(className.lastIndexOf('.') + 1); //$NON-NLS-1$ | ||
} | ||
sb.append(key).append(type).append(assignment).append('"').append(value).append('"'); | ||
} | ||
} | ||
return sb.toString(); | ||
} | ||
|
||
String getInternalNameSpace() { | ||
return null; | ||
} | ||
|
||
public BaseDescription getFragmentDeclaration() { | ||
return null; | ||
} | ||
|
||
@Override | ||
public BundleCapability getCapability() { | ||
return getCapability(null); | ||
} | ||
|
||
BundleCapability getCapability(String namespace) { | ||
BaseDescriptionImpl fragmentDeclaration = (BaseDescriptionImpl) getFragmentDeclaration(); | ||
if (fragmentDeclaration != null) | ||
return fragmentDeclaration.getCapability(namespace); | ||
if (namespace == null) | ||
namespace = getInternalNameSpace(); | ||
if (namespace == null) | ||
return null; | ||
return new BaseCapability(namespace); | ||
} | ||
|
||
@Override | ||
public Object getUserObject() { | ||
return userObject; | ||
} | ||
|
||
@Override | ||
public void setUserObject(Object userObject) { | ||
this.userObject = userObject; | ||
} | ||
|
||
public class BaseCapability implements BundleCapability { | ||
private final String namespace; | ||
|
||
public BaseCapability(String namespace) { | ||
super(); | ||
this.namespace = namespace; | ||
} | ||
|
||
@Override | ||
public BundleRevision getRevision() { | ||
return getSupplier(); | ||
} | ||
|
||
@Override | ||
public String getNamespace() { | ||
return namespace; | ||
} | ||
|
||
@Override | ||
public Map<String, String> getDirectives() { | ||
return getDeclaredDirectives(); | ||
} | ||
|
||
@Override | ||
public Map<String, Object> getAttributes() { | ||
Map<String, Object> attrs = getDeclaredAttributes(); | ||
String internalName = BaseDescriptionImpl.this.getInternalNameSpace(); | ||
if (namespace.equals(internalName)) | ||
return attrs; | ||
// we are doing an alias, must remove internal Name and add alias | ||
attrs = new HashMap<>(attrs); | ||
Object nameValue = attrs.remove(internalName); | ||
if (nameValue != null) | ||
attrs.put(namespace, nameValue); | ||
return Collections.unmodifiableMap(attrs); | ||
} | ||
|
||
@Override | ||
public int hashCode() { | ||
return System.identityHashCode(BaseDescriptionImpl.this); | ||
} | ||
|
||
public BaseDescriptionImpl getBaseDescription() { | ||
return BaseDescriptionImpl.this; | ||
} | ||
|
||
@Override | ||
public boolean equals(Object obj) { | ||
if (this == obj) | ||
return true; | ||
if (!(obj instanceof BaseCapability)) | ||
return false; | ||
return (((BaseCapability) obj).getBaseDescription() == BaseDescriptionImpl.this) && namespace.equals(((BaseCapability) obj).getNamespace()); | ||
} | ||
|
||
@Override | ||
public String toString() { | ||
return getNamespace() + BaseDescriptionImpl.toString(getAttributes(), false) + BaseDescriptionImpl.toString(getDirectives(), true); | ||
} | ||
|
||
@Override | ||
public BundleRevision getResource() { | ||
return getRevision(); | ||
} | ||
} | ||
} |
Oops, something went wrong.