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


Java TightSourceRangeComputer類代碼示例

本文整理匯總了Java中org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer的典型用法代碼示例。如果您正苦於以下問題:Java TightSourceRangeComputer類的具體用法?Java TightSourceRangeComputer怎麽用?Java TightSourceRangeComputer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TightSourceRangeComputer類屬於org.eclipse.jdt.internal.corext.refactoring.util包,在下文中一共展示了TightSourceRangeComputer類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: removeTemp

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
private void removeTemp(CompilationUnitRewrite cuRewrite) {
  VariableDeclaration variableDeclaration = getVariableDeclaration();
  TextEditGroup groupDesc =
      cuRewrite.createGroupDescription(
          RefactoringCoreMessages.InlineTempRefactoring_remove_edit_name);
  ASTNode parent = variableDeclaration.getParent();
  ASTRewrite rewrite = cuRewrite.getASTRewrite();
  TightSourceRangeComputer sourceRangeComputer = new TightSourceRangeComputer();
  rewrite.setTargetSourceRangeComputer(sourceRangeComputer);
  if (parent instanceof VariableDeclarationStatement
      && ((VariableDeclarationStatement) parent).fragments().size() == 1) {
    sourceRangeComputer.addTightSourceNode(parent);
    rewrite.remove(parent, groupDesc);
  } else {
    sourceRangeComputer.addTightSourceNode(variableDeclaration);
    rewrite.remove(variableDeclaration, groupDesc);
  }
}
 
開發者ID:eclipse,項目名稱:che,代碼行數:19,代碼來源:InlineTempRefactoring.java

示例2: InlineTargetCompilationUnit

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
private InlineTargetCompilationUnit(
    CompilationUnitRewrite cuRewrite,
    Name[] references,
    InlineConstantRefactoring refactoring,
    HashSet<SimpleName> staticImportsInInitializer) {
  fInitializer = refactoring.getInitializer();
  fInitializerUnit = refactoring.getDeclaringCompilationUnit();

  fCuRewrite = cuRewrite;
  fSourceRangeComputer = new TightSourceRangeComputer();
  fCuRewrite.getASTRewrite().setTargetSourceRangeComputer(fSourceRangeComputer);
  if (refactoring.getRemoveDeclaration()
      && refactoring.getReplaceAllReferences()
      && cuRewrite.getCu().equals(fInitializerUnit))
    fDeclarationToRemove = refactoring.getDeclaration();
  else fDeclarationToRemove = null;

  fOriginalDeclaration = refactoring.getDeclaration();

  fReferences = new Expression[references.length];
  for (int i = 0; i < references.length; i++)
    fReferences[i] = getQualifiedReference(references[i]);

  fIs15 = JavaModelUtil.is50OrHigher(cuRewrite.getCu().getJavaProject());
  fStaticImportsInInitializer = fIs15 ? staticImportsInInitializer : new HashSet<SimpleName>(0);
}
 
開發者ID:eclipse,項目名稱:che,代碼行數:27,代碼來源:InlineConstantRefactoring.java

示例3: InlineTargetCompilationUnit

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
private InlineTargetCompilationUnit(CompilationUnitRewrite cuRewrite, Name[] references, InlineConstantRefactoring refactoring, HashSet<SimpleName> staticImportsInInitializer) {
	fInitializer= refactoring.getInitializer();
	fInitializerUnit= refactoring.getDeclaringCompilationUnit();

	fCuRewrite= cuRewrite;
	fSourceRangeComputer= new TightSourceRangeComputer();
	fCuRewrite.getASTRewrite().setTargetSourceRangeComputer(fSourceRangeComputer);
	if (refactoring.getRemoveDeclaration() && refactoring.getReplaceAllReferences() && cuRewrite.getCu().equals(fInitializerUnit))
		fDeclarationToRemove= refactoring.getDeclaration();
	else
		fDeclarationToRemove= null;

	fOriginalDeclaration= refactoring.getDeclaration();

	fReferences= new Expression[references.length];
	for (int i= 0; i < references.length; i++)
		fReferences[i]= getQualifiedReference(references[i]);

	fIs15= JavaModelUtil.is50OrHigher(cuRewrite.getCu().getJavaProject());
	fStaticImportsInInitializer= fIs15 ? staticImportsInInitializer : new HashSet<SimpleName>(0);
}
 
開發者ID:trylimits,項目名稱:Eclipse-Postfix-Code-Completion,代碼行數:22,代碼來源:InlineConstantRefactoring.java

示例4: removeTemp

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
private void removeTemp(CompilationUnitRewrite cuRewrite) {
	VariableDeclaration variableDeclaration= getVariableDeclaration();
	TextEditGroup groupDesc= cuRewrite.createGroupDescription(RefactoringCoreMessages.InlineTempRefactoring_remove_edit_name);
	ASTNode parent= variableDeclaration.getParent();
	ASTRewrite rewrite= cuRewrite.getASTRewrite();
	TightSourceRangeComputer sourceRangeComputer= new TightSourceRangeComputer();
	rewrite.setTargetSourceRangeComputer(sourceRangeComputer);
	if (parent instanceof VariableDeclarationStatement && ((VariableDeclarationStatement) parent).fragments().size() == 1) {
		sourceRangeComputer.addTightSourceNode(parent);
		rewrite.remove(parent, groupDesc);
	} else {
		sourceRangeComputer.addTightSourceNode(variableDeclaration);
		rewrite.remove(variableDeclaration, groupDesc);
	}
}
 
開發者ID:trylimits,項目名稱:Eclipse-Postfix-Code-Completion,代碼行數:16,代碼來源:InlineTempRefactoring.java

示例5: checkFinalConditions

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
@Override
public RefactoringStatus checkFinalConditions(IProgressMonitor pm, CheckConditionsContext context)
    throws CoreException, OperationCanceledException {
  try {
    pm.beginTask(RefactoringCoreMessages.ChangeSignatureRefactoring_checking_preconditions, 8);
    RefactoringStatus result = new RefactoringStatus();
    clearManagers();
    fBaseCuRewrite.clearASTAndImportRewrites();
    fBaseCuRewrite.getASTRewrite().setTargetSourceRangeComputer(new TightSourceRangeComputer());

    if (isSignatureSameAsInitial())
      return RefactoringStatus.createFatalErrorStatus(
          RefactoringCoreMessages.ChangeSignatureRefactoring_unchanged);
    result.merge(checkSignature(true));
    if (result.hasFatalError()) return result;

    if (fDelegateUpdating && isSignatureClashWithInitial())
      result.merge(
          RefactoringStatus.createErrorStatus(
              RefactoringCoreMessages
                  .ChangeSignatureRefactoring_old_and_new_signatures_not_sufficiently_different));

    String binaryRefsDescription =
        Messages.format(
            RefactoringCoreMessages.ReferencesInBinaryContext_ref_in_binaries_description,
            BasicElementLabels.getJavaElementName(getMethodName()));
    ReferencesInBinaryContext binaryRefs = new ReferencesInBinaryContext(binaryRefsDescription);

    fRippleMethods =
        RippleMethodFinder2.getRelatedMethods(
            fMethod, binaryRefs, new SubProgressMonitor(pm, 1), null);
    result.merge(checkVarargs());
    if (result.hasFatalError()) return result;

    fOccurrences = findOccurrences(new SubProgressMonitor(pm, 1), binaryRefs, result);
    binaryRefs.addErrorIfNecessary(result);

    result.merge(checkVisibilityChanges());
    result.merge(checkTypeVariables());

    // TODO:
    // We need a common way of dealing with possible compilation errors for all occurrences,
    // including visibility problems, shadowing and missing throws declarations.

    if (!isOrderSameAsInitial()) result.merge(checkReorderings(new SubProgressMonitor(pm, 1)));
    else pm.worked(1);

    // TODO (bug 58616): check whether changed signature already exists somewhere in the ripple,
    // - error if exists
    // - warn if exists with different parameter types (may cause overloading)

    if (!areNamesSameAsInitial()) result.merge(checkRenamings(new SubProgressMonitor(pm, 1)));
    else pm.worked(1);
    if (result.hasFatalError()) return result;

    //			resolveTypesWithoutBindings(new SubProgressMonitor(pm, 1)); // already done in
    // checkSignature(true)

    createChangeManager(new SubProgressMonitor(pm, 1), result);
    fCachedTypeHierarchy = null;

    if (mustAnalyzeAstOfDeclaringCu())
      result.merge(
          checkCompilationofDeclaringCu()); // TODO: should also check in ripple methods (move
    // into createChangeManager)
    if (result.hasFatalError()) return result;

    Checks.addModifiedFilesToChecker(getAllFilesToModify(), context);
    return result;
  } finally {
    pm.done();
  }
}
 
開發者ID:eclipse,項目名稱:che,代碼行數:74,代碼來源:ChangeSignatureProcessor.java

示例6: createChangeManager

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
private TextChangeManager createChangeManager(IProgressMonitor pm, RefactoringStatus result)
    throws CoreException {
  pm.beginTask(RefactoringCoreMessages.ChangeSignatureRefactoring_preview, 2);
  fChangeManager = new TextChangeManager();
  boolean isNoArgConstructor = isNoArgConstructor();
  Map<ICompilationUnit, Set<IType>> namedSubclassMapping = null;
  if (isNoArgConstructor) {
    // create only when needed;
    namedSubclassMapping = createNamedSubclassMapping(new SubProgressMonitor(pm, 1));
  } else {
    pm.worked(1);
  }
  for (int i = 0; i < fOccurrences.length; i++) {
    if (pm.isCanceled()) throw new OperationCanceledException();
    SearchResultGroup group = fOccurrences[i];
    ICompilationUnit cu = group.getCompilationUnit();
    if (cu == null) continue;
    CompilationUnitRewrite cuRewrite;
    if (cu.equals(getCu())) {
      cuRewrite = fBaseCuRewrite;
    } else {
      cuRewrite = new CompilationUnitRewrite(cu);
      cuRewrite.getASTRewrite().setTargetSourceRangeComputer(new TightSourceRangeComputer());
    }
    ASTNode[] nodes = ASTNodeSearchUtil.findNodes(group.getSearchResults(), cuRewrite.getRoot());

    // IntroduceParameterObjectRefactoring needs to update declarations first:
    List<OccurrenceUpdate<? extends ASTNode>> deferredUpdates =
        new ArrayList<OccurrenceUpdate<? extends ASTNode>>();
    for (int j = 0; j < nodes.length; j++) {
      OccurrenceUpdate<? extends ASTNode> update =
          createOccurrenceUpdate(nodes[j], cuRewrite, result);
      if (update instanceof DeclarationUpdate) {
        update.updateNode();
      } else {
        deferredUpdates.add(update);
      }
    }
    for (Iterator<OccurrenceUpdate<? extends ASTNode>> iter = deferredUpdates.iterator();
        iter.hasNext(); ) {
      iter.next().updateNode();
    }

    if (isNoArgConstructor && namedSubclassMapping.containsKey(cu)) {
      // only non-anonymous subclasses may have noArgConstructors to modify - see bug 43444
      Set<IType> subtypes = namedSubclassMapping.get(cu);
      for (Iterator<IType> iter = subtypes.iterator(); iter.hasNext(); ) {
        IType subtype = iter.next();
        AbstractTypeDeclaration subtypeNode =
            ASTNodeSearchUtil.getAbstractTypeDeclarationNode(subtype, cuRewrite.getRoot());
        if (subtypeNode != null) modifyImplicitCallsToNoArgConstructor(subtypeNode, cuRewrite);
      }
    }
    TextChange change = cuRewrite.createChange(true);
    if (change != null) fChangeManager.manage(cu, change);
  }

  pm.done();
  return fChangeManager;
}
 
開發者ID:eclipse,項目名稱:che,代碼行數:61,代碼來源:ChangeSignatureProcessor.java

示例7: getTightSourceRangeComputer

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
protected final TightSourceRangeComputer getTightSourceRangeComputer() {
  return (TightSourceRangeComputer) fCuRewrite.getASTRewrite().getExtendedSourceRangeComputer();
}
 
開發者ID:eclipse,項目名稱:che,代碼行數:4,代碼來源:ChangeSignatureProcessor.java

示例8: checkFinalConditions

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
@Override
	public RefactoringStatus checkFinalConditions(IProgressMonitor pm, CheckConditionsContext context) throws CoreException, OperationCanceledException {
		try {
			pm.beginTask(RefactoringCoreMessages.ChangeSignatureRefactoring_checking_preconditions, 8);
			RefactoringStatus result= new RefactoringStatus();
			clearManagers();
			fBaseCuRewrite.clearASTAndImportRewrites();
			fBaseCuRewrite.getASTRewrite().setTargetSourceRangeComputer(new TightSourceRangeComputer());

			if (isSignatureSameAsInitial())
				return RefactoringStatus.createFatalErrorStatus(RefactoringCoreMessages.ChangeSignatureRefactoring_unchanged);
			result.merge(checkSignature(true));
			if (result.hasFatalError())
				return result;

			if (fDelegateUpdating && isSignatureClashWithInitial())
				result.merge(RefactoringStatus.createErrorStatus(RefactoringCoreMessages.ChangeSignatureRefactoring_old_and_new_signatures_not_sufficiently_different ));

			String binaryRefsDescription= Messages.format(RefactoringCoreMessages.ReferencesInBinaryContext_ref_in_binaries_description , BasicElementLabels.getJavaElementName(getMethodName()));
			ReferencesInBinaryContext binaryRefs= new ReferencesInBinaryContext(binaryRefsDescription);

			fRippleMethods= RippleMethodFinder2.getRelatedMethods(fMethod, binaryRefs, new SubProgressMonitor(pm, 1), null);
			result.merge(checkVarargs());
			if (result.hasFatalError())
				return result;

			fOccurrences= findOccurrences(new SubProgressMonitor(pm, 1), binaryRefs, result);
			binaryRefs.addErrorIfNecessary(result);

			result.merge(checkVisibilityChanges());
			result.merge(checkTypeVariables());

			//TODO:
			// We need a common way of dealing with possible compilation errors for all occurrences,
			// including visibility problems, shadowing and missing throws declarations.

			if (! isOrderSameAsInitial())
				result.merge(checkReorderings(new SubProgressMonitor(pm, 1)));
			else
				pm.worked(1);

			//TODO (bug 58616): check whether changed signature already exists somewhere in the ripple,
			// - error if exists
			// - warn if exists with different parameter types (may cause overloading)

			if (! areNamesSameAsInitial())
				result.merge(checkRenamings(new SubProgressMonitor(pm, 1)));
			else
				pm.worked(1);
			if (result.hasFatalError())
				return result;

//			resolveTypesWithoutBindings(new SubProgressMonitor(pm, 1)); // already done in checkSignature(true)

			createChangeManager(new SubProgressMonitor(pm, 1), result);
			fCachedTypeHierarchy= null;

			if (mustAnalyzeAstOfDeclaringCu())
				result.merge(checkCompilationofDeclaringCu()); //TODO: should also check in ripple methods (move into createChangeManager)
			if (result.hasFatalError())
				return result;

			Checks.addModifiedFilesToChecker(getAllFilesToModify(), context);
			return result;
		} finally {
			pm.done();
		}
	}
 
開發者ID:trylimits,項目名稱:Eclipse-Postfix-Code-Completion,代碼行數:69,代碼來源:ChangeSignatureProcessor.java

示例9: createChangeManager

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
private TextChangeManager createChangeManager(IProgressMonitor pm, RefactoringStatus result) throws CoreException {
	pm.beginTask(RefactoringCoreMessages.ChangeSignatureRefactoring_preview, 2);
	fChangeManager= new TextChangeManager();
	boolean isNoArgConstructor= isNoArgConstructor();
	Map<ICompilationUnit, Set<IType>> namedSubclassMapping= null;
	if (isNoArgConstructor){
		//create only when needed;
		namedSubclassMapping= createNamedSubclassMapping(new SubProgressMonitor(pm, 1));
	}else{
		pm.worked(1);
	}
	for (int i= 0; i < fOccurrences.length; i++) {
		if (pm.isCanceled())
			throw new OperationCanceledException();
		SearchResultGroup group= fOccurrences[i];
		ICompilationUnit cu= group.getCompilationUnit();
		if (cu == null)
			continue;
		CompilationUnitRewrite cuRewrite;
		if (cu.equals(getCu())) {
			cuRewrite= fBaseCuRewrite;
		} else {
			cuRewrite= new CompilationUnitRewrite(cu);
			cuRewrite.getASTRewrite().setTargetSourceRangeComputer(new TightSourceRangeComputer());
		}
		ASTNode[] nodes= ASTNodeSearchUtil.findNodes(group.getSearchResults(), cuRewrite.getRoot());

		//IntroduceParameterObjectRefactoring needs to update declarations first:
		List<OccurrenceUpdate<? extends ASTNode>> deferredUpdates= new ArrayList<OccurrenceUpdate<? extends ASTNode>>();
		for (int j= 0; j < nodes.length; j++) {
			OccurrenceUpdate<? extends ASTNode> update= createOccurrenceUpdate(nodes[j], cuRewrite, result);
			if (update instanceof DeclarationUpdate) {
				update.updateNode();
			} else {
				deferredUpdates.add(update);
			}
		}
		for (Iterator<OccurrenceUpdate<? extends ASTNode>> iter= deferredUpdates.iterator(); iter.hasNext();) {
			iter.next().updateNode();
		}

		if (isNoArgConstructor && namedSubclassMapping.containsKey(cu)){
			//only non-anonymous subclasses may have noArgConstructors to modify - see bug 43444
			Set<IType> subtypes= namedSubclassMapping.get(cu);
			for (Iterator<IType> iter= subtypes.iterator(); iter.hasNext();) {
				IType subtype= iter.next();
				AbstractTypeDeclaration subtypeNode= ASTNodeSearchUtil.getAbstractTypeDeclarationNode(subtype, cuRewrite.getRoot());
				if (subtypeNode != null)
					modifyImplicitCallsToNoArgConstructor(subtypeNode, cuRewrite);
			}
		}
		TextChange change= cuRewrite.createChange(true);
		if (change != null)
			fChangeManager.manage(cu, change);
	}

	pm.done();
	return fChangeManager;
}
 
開發者ID:trylimits,項目名稱:Eclipse-Postfix-Code-Completion,代碼行數:60,代碼來源:ChangeSignatureProcessor.java

示例10: getTightSourceRangeComputer

import org.eclipse.jdt.internal.corext.refactoring.util.TightSourceRangeComputer; //導入依賴的package包/類
protected final TightSourceRangeComputer getTightSourceRangeComputer() {
	return (TightSourceRangeComputer) fCuRewrite.getASTRewrite().getExtendedSourceRangeComputer();
}
 
開發者ID:trylimits,項目名稱:Eclipse-Postfix-Code-Completion,代碼行數:4,代碼來源:ChangeSignatureProcessor.java


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