Package org.eclipse.jdt.internal.core.search.matching

Source Code of org.eclipse.jdt.internal.core.search.matching.PossibleMatchSet

/*******************************************************************************
* Copyright (c) 2000, 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
*******************************************************************************/
package org.eclipse.jdt.internal.core.search.matching;

import org.eclipse.core.runtime.IPath;
import org.eclipse.jdt.core.IPackageFragmentRoot;
import org.eclipse.jdt.internal.compiler.util.ObjectVector;
import org.eclipse.jdt.internal.compiler.util.SimpleLookupTable;

/**
* A set of PossibleMatches that is sorted by package fragment roots.
*/
public class PossibleMatchSet {

private SimpleLookupTable rootsToPossibleMatches = new SimpleLookupTable(5);
private int elementCount = 0;

public void add(PossibleMatch possibleMatch) {
  IPath path = possibleMatch.openable.getPackageFragmentRoot().getPath();
  ObjectVector possibleMatches = (ObjectVector) this.rootsToPossibleMatches.get(path);
  if (possibleMatches != null) {
    PossibleMatch storedMatch = (PossibleMatch) possibleMatches.find(possibleMatch);
    if (storedMatch != null) {
      while (storedMatch.getSimilarMatch() != null) {
        storedMatch = storedMatch.getSimilarMatch();
      }
      storedMatch.setSimilarMatch(possibleMatch);
      return;
    }
  } else{
    this.rootsToPossibleMatches.put(path, possibleMatches = new ObjectVector());
  }

  possibleMatches.add(possibleMatch);
  this.elementCount++;
}
public PossibleMatch[] getPossibleMatches(IPackageFragmentRoot[] roots) {
  PossibleMatch[] result = new PossibleMatch[this.elementCount];
  int index = 0;
  for (int i = 0, length = roots.length; i < length; i++) {
    ObjectVector possibleMatches = (ObjectVector) this.rootsToPossibleMatches.get(roots[i].getPath());
    if (possibleMatches != null) {
      possibleMatches.copyInto(result, index);
      index += possibleMatches.size();
    }
  }
  if (index < this.elementCount)
    System.arraycopy(result, 0, result = new PossibleMatch[index], 0, index);
  return result;
}
public void reset() {
  this.rootsToPossibleMatches = new SimpleLookupTable(5);
  this.elementCount = 0;
}
}
TOP

Related Classes of org.eclipse.jdt.internal.core.search.matching.PossibleMatchSet

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.