當前位置: 首頁>>代碼示例>>Java>>正文


Java JavaRuntime.getJavaProject方法代碼示例

本文整理匯總了Java中org.eclipse.jdt.launching.JavaRuntime.getJavaProject方法的典型用法代碼示例。如果您正苦於以下問題:Java JavaRuntime.getJavaProject方法的具體用法?Java JavaRuntime.getJavaProject怎麽用?Java JavaRuntime.getJavaProject使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.eclipse.jdt.launching.JavaRuntime的用法示例。


在下文中一共展示了JavaRuntime.getJavaProject方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: computeUnresolvedClasspath

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public IRuntimeClasspathEntry[] computeUnresolvedClasspath(final ILaunchConfiguration configuration)
      throws CoreException {
    boolean useDefault = configuration.getAttribute(IJavaLaunchConfigurationConstants.ATTR_DEFAULT_CLASSPATH, true);
    if(useDefault) {
      IJavaProject javaProject = JavaRuntime.getJavaProject(configuration);
      IRuntimeClasspathEntry jreEntry = JavaRuntime.computeJREEntry(configuration);
      IRuntimeClasspathEntry projectEntry = JavaRuntime.newProjectRuntimeClasspathEntry(javaProject);
      IRuntimeClasspathEntry mavenEntry = JavaRuntime.newRuntimeContainerClasspathEntry(new Path(
          IClasspathManager.CONTAINER_ID), IRuntimeClasspathEntry.USER_CLASSES);

      if(jreEntry == null) {
        return new IRuntimeClasspathEntry[] {projectEntry, mavenEntry};
      }

      return new IRuntimeClasspathEntry[] {jreEntry, projectEntry, mavenEntry};
    }

    return recoverRuntimePath(configuration, IJavaLaunchConfigurationConstants.ATTR_CLASSPATH);
  }
 
開發者ID:fbricon,項目名稱:wildfly-hive,代碼行數:21,代碼來源:MavenRuntimeClasspathProvider.java

示例2: resolveClasspath0

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
IRuntimeClasspathEntry[] resolveClasspath0(IRuntimeClasspathEntry[] entries, ILaunchConfiguration configuration,
    IProgressMonitor monitor) throws CoreException {
  int scope = getArtifactScope(configuration);
  Set<IRuntimeClasspathEntry> all = new LinkedHashSet<>(entries.length);
  for(IRuntimeClasspathEntry entry : entries) {
    if(entry.getType() == IRuntimeClasspathEntry.CONTAINER
        && MavenClasspathHelpers.isMaven2ClasspathContainer(entry.getPath())) {
      addMavenClasspathEntries(all, entry, configuration, scope, monitor);
    } else if(entry.getType() == IRuntimeClasspathEntry.PROJECT) {
      IJavaProject javaProject = JavaRuntime.getJavaProject(configuration);
      if(javaProject.getPath().equals(entry.getPath())) {
        addProjectEntries(all, entry.getPath(), scope, THIS_PROJECT_CLASSIFIER, configuration, monitor);
      } else {
        addStandardClasspathEntries(all, entry, configuration);
      }
    } else {
      addStandardClasspathEntries(all, entry, configuration);
    }
  }
  return all.toArray(new IRuntimeClasspathEntry[all.size()]);
}
 
開發者ID:fbricon,項目名稱:wildfly-hive,代碼行數:22,代碼來源:MavenRuntimeClasspathProvider.java

示例3: addMavenClasspathEntries

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
private void addMavenClasspathEntries(Set<IRuntimeClasspathEntry> resolved,
      IRuntimeClasspathEntry runtimeClasspathEntry, ILaunchConfiguration configuration, int scope,
      IProgressMonitor monitor) throws CoreException {
    IJavaProject javaProject = JavaRuntime.getJavaProject(configuration);
    MavenJdtPlugin plugin = MavenJdtPlugin.getDefault();
    IClasspathManager buildpathManager = plugin.getBuildpathManager();
    IClasspathEntry[] cp = buildpathManager.getClasspath(javaProject.getProject(), scope, false, monitor);
    for(IClasspathEntry entry : cp) {
      switch(entry.getEntryKind()) {
        case IClasspathEntry.CPE_PROJECT:
          addProjectEntries(resolved, entry.getPath(), scope, getArtifactClassifier(entry), configuration, monitor);
          break;
        case IClasspathEntry.CPE_LIBRARY:
          resolved.add(JavaRuntime.newArchiveRuntimeClasspathEntry(entry.getPath()));
          break;
//        case IClasspathEntry.CPE_SOURCE:
//          resolved.add(newSourceClasspathEntry(javaProject, cp[i]));
//          break;
      }
    }
  }
 
開發者ID:fbricon,項目名稱:wildfly-hive,代碼行數:22,代碼來源:MavenRuntimeClasspathProvider.java

示例4: resolveClasspath

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public IRuntimeClasspathEntry[] resolveClasspath(IRuntimeClasspathEntry[] entries,
    ILaunchConfiguration configuration) throws CoreException {

  IRuntimeClasspathEntry[] resolvedEntries = super.resolveClasspath(entries, configuration);

  IJavaProject proj = JavaRuntime.getJavaProject(configuration);
  if (proj == null) {
    return resolvedEntries;
  }

  List<IRuntimeClasspathEntry> resolvedEntriesList =
      new ArrayList<IRuntimeClasspathEntry>(Arrays.asList(resolvedEntries));

  return resolvedEntriesList.toArray(new IRuntimeClasspathEntry[resolvedEntriesList.size()]);
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:17,代碼來源:MavenClasspathProvider.java

示例5: isValid

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public boolean isValid(ILaunchConfiguration config) {
  try {
    IJavaProject javaProject = JavaRuntime.getJavaProject(getCurrentLaunchConfiguration());

    if (javaProject != null
        && !GWTNature.isGWTProject(javaProject.getProject())) {
      setErrorMessage("Selected project does not have GWT enabled.");
      return false;
    }
  } catch (CoreException e) {
    GWTPluginLog.logError(e);
  }

  return super.isValid(config);
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:17,代碼來源:JUnitLaunchConfigurationTabDecorator.java

示例6: isValid

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public boolean isValid(ILaunchConfiguration launchConfig) {
  setErrorMessage(null);
  setMessage(null);

  if (!super.isValid(launchConfig)) {
    return false;
  }

  IProject project;
  try {
    IJavaProject javaProject = JavaRuntime.getJavaProject(launchConfig);
    if (javaProject == null) {
      return false;
    }

    project = javaProject.getProject();
  } catch (CoreException ce) {
    // Thrown if the Java project does not exist, which is not of concern in
    // this tab (the Main tab handles those error messages)
    return false;
  }

  return true;
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:26,代碼來源:WebAppServerTab.java

示例7: computeUnresolvedClasspath

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public IRuntimeClasspathEntry[] computeUnresolvedClasspath(ILaunchConfiguration configuration) throws CoreException
{
	boolean useDefault = configuration.getAttribute(IJavaLaunchConfigurationConstants.ATTR_DEFAULT_CLASSPATH, true);
	if (!useDefault)
	{
		// recover persisted classpath
		return recoverRuntimePath(configuration, IJavaLaunchConfigurationConstants.ATTR_CLASSPATH);
	}

	Path lcp = new Path(LeJOSEV3LibContainer.ID+"/"+LeJOSEV3Util.LIBSUBDIR_EV3);
	
	IJavaProject proj = JavaRuntime.getJavaProject(configuration);
	if (proj == null)
	{
		IRuntimeClasspathEntry rte = JavaRuntime.newRuntimeContainerClasspathEntry(lcp, IRuntimeClasspathEntry.STANDARD_CLASSES);
		return new IRuntimeClasspathEntry[] { rte };
	}
	
	return JavaRuntime.computeUnresolvedRuntimeClasspath(proj);		
}
 
開發者ID:JanKoehnlein,項目名稱:XRobot,代碼行數:22,代碼來源:LaunchEV3ClasspathProvider.java

示例8: sameProjectOnly

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
private void sameProjectOnly(Collection<IPackageFragmentRoot> filtered,
    final ILaunchConfiguration configuration) throws CoreException {
  final IJavaProject javaProject = JavaRuntime.getJavaProject(configuration);
  if (javaProject != null) {
    for (final Iterator<IPackageFragmentRoot> i = filtered.iterator(); i
        .hasNext();) {
      if (!javaProject.equals(i.next().getJavaProject())) {
        i.remove();
      }
    }
  }
}
 
開發者ID:eclipse,項目名稱:eclemma,代碼行數:13,代碼來源:DefaultScopeFilter.java

示例9: getOverallScope

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
public Set<IPackageFragmentRoot> getOverallScope(
    ILaunchConfiguration configuration) throws CoreException {
  final IJavaProject project = JavaRuntime.getJavaProject(configuration);
  if (project == null) {
    return Collections.emptySet();
  } else {
    return ScopeUtils.filterJREEntries(Arrays.asList(project
        .getAllPackageFragmentRoots()));
  }
}
 
開發者ID:eclipse,項目名稱:eclemma,代碼行數:11,代碼來源:JavaApplicationLauncher.java

示例10: getArtifactScope

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
protected int getArtifactScope(ILaunchConfiguration configuration) throws CoreException {
  String typeid = configuration.getType().getAttribute("id"); //$NON-NLS-1$
  if(JDT_JAVA_APPLICATION.equals(typeid) || "org.jboss.tools.servers.wildfly.swarm.core.serverLaunchConfig".equals(typeid)) {
    IResource[] resources = configuration.getMappedResources();

    // MNGECLIPSE-530: NPE starting openarchitecture workflow 
    if(resources == null || resources.length == 0) {
      return IClasspathManager.CLASSPATH_RUNTIME;
    }

    // ECLIPSE-33: applications from test sources should use test scope 
    final Set<IPath> testSources = new HashSet<>();
    IJavaProject javaProject = JavaRuntime.getJavaProject(configuration);
    IMavenProjectFacade facade = projectManager.create(javaProject.getProject(), new NullProgressMonitor());
    if(facade == null) {
      return IClasspathManager.CLASSPATH_RUNTIME;
    }

    testSources.addAll(Arrays.asList(facade.getTestCompileSourceLocations()));

    for(int i = 0; i < resources.length; i++ ) {
      for(IPath testPath : testSources) {
        if(testPath.isPrefixOf(resources[i].getProjectRelativePath())) {
          return IClasspathManager.CLASSPATH_TEST;
        }
      }
    }
    return IClasspathManager.CLASSPATH_RUNTIME;
  } else if(JDT_JUNIT_TEST.equals(typeid) || JDT_TESTNG_TEST.equals(typeid)) {
    return IClasspathManager.CLASSPATH_TEST;
  } else {
    throw new CoreException(new Status(IStatus.ERROR, IMavenConstants.PLUGIN_ID, 0, NLS.bind(
        Messages.MavenRuntimeClasspathProvider_error_unsupported, typeid), null));
  }
}
 
開發者ID:fbricon,項目名稱:wildfly-hive,代碼行數:36,代碼來源:MavenRuntimeClasspathProvider.java

示例11: getJavaProject

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
/**
 * @return the Java project, or null
 */
public static IJavaProject getJavaProject(
    ILaunchConfiguration launchConfiguration) {
  try {
    return JavaRuntime.getJavaProject(launchConfiguration);
  } catch (CoreException e) {
    // When the attribute holding the Java project had an issue, assume no
    // Java project
    return null;
  }
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:14,代碼來源:LaunchConfigurationUtilities.java

示例12: getProject

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
private IProject getProject(LaunchConfiguration launchConfig) {
  if (launchConfig == null) {
    return null;
  }

  ILaunch launch = launchConfig.getLaunch();
  if (launch == null) {
    return null;
  }

  ILaunchConfiguration lc = launch.getLaunchConfiguration();
  if (lc == null) {
    return null;
  }

  IJavaProject project;
  try {
    project = JavaRuntime.getJavaProject(lc);
  } catch (CoreException e) {
    return null;
  }
  if (project == null) {
    return null;
  }

  return project.getProject();
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:28,代碼來源:LaunchConfigurationContent.java

示例13: setupLaunchConfiguration

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public void setupLaunchConfiguration(ILaunchConfigurationWorkingCopy workingCopy, IProgressMonitor monitor)
		throws CoreException {
	IServer server = ServerUtil.getServer(workingCopy);
	if (server == null) {
		return;
	}
	
	String projectName = workingCopy.getAttribute(IJavaLaunchConfigurationConstants.ATTR_PROJECT_NAME, (String)null);
	if (projectName == null) {
		projectName = server.getAttribute(IJavaLaunchConfigurationConstants.ATTR_PROJECT_NAME, (String)null);
		workingCopy.setAttribute(IJavaLaunchConfigurationConstants.ATTR_PROJECT_NAME, projectName);
	}
	IJavaProject proj = JavaRuntime.getJavaProject(workingCopy);
	Collection<String> mainClasses = MainClassDetector.findMainClasses(proj, monitor);
	if (mainClasses.isEmpty()) {
		return;
	}
	if ( mainClasses.size() > 1) {
		//TODO handle multiple Main classes 
	}
	String mainClass =  mainClasses.iterator().next();
	workingCopy.setAttribute(IJavaLaunchConfigurationConstants.ATTR_MAIN_TYPE_NAME, mainClass);
	
       StringBuilder vmArgs = new StringBuilder(DEVAULT_VM_ARGS);
       int targetPort = 8080;
	int portOffset = SocketUtil.detectPortOffset(targetPort);
	if (portOffset > 0) {
    	   targetPort += portOffset;
          vmArgs.append(" -Dswarm.port.offset=").append(portOffset);
	}
	workingCopy.setAttribute(IJavaLaunchConfigurationConstants.ATTR_VM_ARGUMENTS, vmArgs.toString());

	final ControllableServerBehavior behavior = (ControllableServerBehavior)JBossServerBehaviorUtils.getControllableBehavior(server);
	//TODO parse Main class AST to detect default context root?
	if (behavior != null) {
		//XXX seems weird/wrong
		behavior.putSharedData("welcomePage", "http://localhost:"+targetPort+"/");
	}
	//if m2e project only
	workingCopy.setAttribute(IJavaLaunchConfigurationConstants.ATTR_CLASSPATH_PROVIDER, "org.jboss.tools.servers.wildfly.swarm.launchconfig.classpathProvider");
}
 
開發者ID:fbricon,項目名稱:wildfly-hive,代碼行數:43,代碼來源:WildFlySwarmServerBehavior.java

示例14: computeUnresolvedClasspath

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public IRuntimeClasspathEntry[] computeUnresolvedClasspath(ILaunchConfiguration config)
    throws CoreException {
  IRuntimeClasspathEntry[] unresolvedClasspathEntries = super.computeUnresolvedClasspath(config);
  IJavaProject proj = JavaRuntime.getJavaProject(config);
  if (proj == null) {
    return unresolvedClasspathEntries;
  }

  /*
   * Figure out if we are supposed to be relying on the default classpath or not. The default
   * classpath is the one that is generated for a launch configuration based on the launch
   * configuration's project's build classpath.
   *
   * To determine whether or not to rely on the default classpath, we look at the
   * ATTR_DEFAULT_CLASSPATH attribute of the launch configuration. This attribute is set whenever
   * the user makes a change to the launch configuration classpath using the add/remove buttons.
   * From this point on, Eclipse will respect the user's changes and will not replace their
   * entries with the classpath that it computes.
   *
   * However, users can specify that they want to restore the behavior of having Eclipse compute
   * the classpath by clicking on the "Restore Default Entries" button. This causes the
   * ATTR_DEFAULT_ATTRIBUTE to be unset for a launch configuration.
   */
  boolean useDefault =
      config.getAttribute(IJavaLaunchConfigurationConstants.ATTR_DEFAULT_CLASSPATH, true);

  if (!useDefault) {
    return unresolvedClasspathEntries;
  }

  if (!MavenUtils.hasMavenNature(proj.getProject())) {
    return unresolvedClasspathEntries;
  }

  // Use a LinkedHashSet to prevent dupes
  Set<IRuntimeClasspathEntry> classpath =
      new LinkedHashSet<IRuntimeClasspathEntry>(unresolvedClasspathEntries.length);
  classpath.addAll(Arrays.asList(unresolvedClasspathEntries));

  // Add GWT dev jar
  if (GWTNature.isGWTProject(proj.getProject())) {
    addGwtDevjarIfPossible(proj, classpath);
  }

  IRuntimeClasspathEntry[] resolvedEntries =
      classpath.toArray(new IRuntimeClasspathEntry[classpath.size()]);

  return resolvedEntries;
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:51,代碼來源:MavenClasspathProvider.java

示例15: computeUnresolvedClasspath

import org.eclipse.jdt.launching.JavaRuntime; //導入方法依賴的package包/類
@Override
public IRuntimeClasspathEntry[] computeUnresolvedClasspath(ILaunchConfiguration config) throws CoreException {
  IRuntimeClasspathEntry[] unresolvedClasspathEntries = super.computeUnresolvedClasspath(config);
  IJavaProject proj = JavaRuntime.getJavaProject(config);
  if (proj == null || !GWTNature.isGWTProject(proj.getProject())) {
    // Only GWT projects require source folders to be computed
    return unresolvedClasspathEntries;
  }

  /*
   * Figure out if we are supposed to be relying on the default classpath or not. The default
   * classpath is the one that is generated for a launch configuration based on the launch
   * configuration's project's build classpath.
   *
   * To determine whether or not to rely on the default classpath, we look at the
   * ATTR_DEFAULT_CLASSPATH attribute of the launch configuration. This attribute is set whenever
   * the user makes a change to the launch configuration classpath using the add/remove buttons.
   * From this point on, Eclipse will respect the user's changes and will not replace their
   * entries with the classpath that it computes.
   *
   * However, users can specify that they want to restore the behavior of having Eclipse compute
   * the classpath by clicking on the "Restore Default Entries" button. This causes the
   * ATTR_DEFAULT_ATTRIBUTE to be unset for a launch configuration.
   */
  boolean useDefault = config.getAttribute(IJavaLaunchConfigurationConstants.ATTR_DEFAULT_CLASSPATH, true);

  if (!useDefault) {
    return unresolvedClasspathEntries;
  }

  /*
   * Compute the default classpath for the launch configuration. Note that all of the entries for
   * the default classpath DO NOT appear under the 'default entries' section. This is because we
   * are going to be adding the GWT-related source paths to the classpath, and we want to give
   * users the opportunity to tweak them. If we add them to the 'default entries' section, they
   * will be unable to tweak them.
   *
   * You might think that adding the source paths to the non-default section would cause Eclipse
   * to think that the user actually modified the classpath, thereby causing the
   * ATTR_DEFAULT_CLASSPATH attribute to be changed. This is not the case; this attribute is only
   * changed based on UI interaction, so it is safe for us to add entries to the non-default
   * section programmatically.
   */
  ArrayList<IRuntimeClasspathEntry> defaultRuntimeClasspathEntries = new ArrayList<IRuntimeClasspathEntry>();
  defaultRuntimeClasspathEntries.addAll(Arrays.asList(unresolvedClasspathEntries));

  /*
   * Now, record the source folder(s) of each of the transitively required projects.
   *
   * Make sure that the source paths come before the default classpath entries so users can
   * override GWT functionality. They also must appear after any existing bootstrap entries (e.g.
   * the JRE), since that's the order the JavaClasspathTab will expect them to be in when it goes
   * to calculate whether or not the configured classpath = default.
   */
  int srcPathsInsertionIndex = findIndexOfFirstUserEntry(defaultRuntimeClasspathEntries);

  try {
    defaultRuntimeClasspathEntries.addAll(
        srcPathsInsertionIndex,
        GWTProjectUtilities.getGWTSourceFolderPathsFromProjectAndDependencies(proj,
            GWTJUnitLaunchDelegate.isJUnitLaunchConfig(config.getType())));
  } catch (SdkException e) {
    GWTPluginLog.logError(e);
  }

  return defaultRuntimeClasspathEntries.toArray(new IRuntimeClasspathEntry[defaultRuntimeClasspathEntries.size()]);
}
 
開發者ID:gwt-plugins,項目名稱:gwt-eclipse-plugin,代碼行數:68,代碼來源:ModuleClasspathProvider.java


注:本文中的org.eclipse.jdt.launching.JavaRuntime.getJavaProject方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。