blob: 266dccf2a6032e60357db005efdfddfe7bf76e16 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2007, 2008 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
* yyyymmdd bug Email and other contact information
* -------- -------- -----------------------------------------------------------
* 20070327 172339 kathy@ca.ibm.com - Kathy Chan
* 20070716 191357 kathy@ca.ibm.com - Kathy Chan
* 20080220 219537 makandre@ca.ibm.com - Andrew Mak
* 20080421 227824 makandre@ca.ibm.com - Andrew Mak, AdapterUtils adapt to IFile before String
*******************************************************************************/
package org.eclipse.wst.ws.internal.ui.utils;
import java.net.URI;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.runtime.Platform;
/**
* The AdapterUtils class provides utility methods to get objects from the Platform's adapter extension.
*
*/
public class AdapterUtils {
/**
* Determine if the given object has an IFile or String adapter.
*
* @param object The object.
* @return True the object is adaptable to IFile or String, false otherwise.
*/
public static boolean hasAdapter(Object object) {
if (object == null)
return false;
boolean hasAdapter = Platform.getAdapterManager().hasAdapter(object, "org.eclipse.core.resource.IFile");
if (!hasAdapter)
hasAdapter = Platform.getAdapterManager().hasAdapter(object, "java.lang.String");
return hasAdapter;
}
/**
* @param object Object to adapt
* @return The adapted object representing the file or String if an adapter is found.
* Returns null if an adapter is not found.
*/
public static Object getAdaptedObject (Object object) {
if (object == null)
return null;
Object adaptedObject = Platform.getAdapterManager().loadAdapter(object, "java.lang.String");
if (adaptedObject == null) {
adaptedObject = Platform.getAdapterManager().loadAdapter(object, "org.eclipse.core.resources.IFile");
}
return adaptedObject;
}
/**
* @param object Look up an adapter mapping the object to IFile or String.
* @return The WSDL uri returned by the adapter or null if no adapter is found.
*/
public static String getAdaptedWSDL (Object object) {
String wsdlURI = null;
Object adaptedObject = AdapterUtils.getAdaptedObject(object);
if ( adaptedObject != null) {
if (adaptedObject instanceof IFile)
{
URI uri = ((IFile)adaptedObject).getLocationURI();
if (uri != null) {
wsdlURI = uri.toString();
}
} else if (adaptedObject instanceof String) {
wsdlURI = (String) adaptedObject;
}
}
return wsdlURI;
}
}