/
codebase/
codebase/area/
codebase/doc/
codebase/etc/
codebase/src/net/sourceforge/pain/data/trigger/
codebase/src/net/sourceforge/pain/logic/
codebase/src/net/sourceforge/pain/logic/affect/
codebase/src/net/sourceforge/pain/logic/event/
codebase/src/net/sourceforge/pain/logic/event/deploy/
codebase/src/net/sourceforge/pain/logic/event/guitool/
codebase/src/net/sourceforge/pain/logic/event/guitool/event/
codebase/src/net/sourceforge/pain/logic/fn/util/
codebase/src/net/sourceforge/pain/logic/trigger/
codebase/src/net/sourceforge/pain/logic/trigger/impl/
codebase/src/net/sourceforge/pain/network/console/
codebase/src/net/sourceforge/pain/network/console/telnet/
codebase/src/net/sourceforge/pain/network/guitool/
codebase/src/net/sourceforge/pain/plugin/
codebase/src/net/sourceforge/pain/plugin/command/
codebase/src/net/sourceforge/pain/plugin/reset/
codebase/src/net/sourceforge/pain/plugin/shutdown/
codebase/src/net/sourceforge/pain/plugin/social/
codebase/src/net/sourceforge/pain/util/
db/doc/javadoc/resources/
db/src/net/sourceforge/pain/util/
gui/
gui/lib/
gui/src/net/sourceforge/pain/tools/guitool/dbbrowse/
gui/src/net/sourceforge/pain/tools/guitool/dialog/
gui/src/net/sourceforge/pain/tools/guitool/menu/
gui/src/net/sourceforge/pain/tools/guitool/resources/
gui/src/net/sourceforge/pain/tools/guitool/resources/images/
gui/src/net/sourceforge/pain/tools/guitool/resources/images/explorer/
tests/
tests/src/
tests/src/net/sourceforge/pain/db/data/
package net.sourceforge.pain.logic.fn;

import net.sourceforge.pain.data.type.*;
import net.sourceforge.pain.logic.fn.util.*;

public final class SpaceFindFn {

	private SpaceFindFn() {
	}

	public static Interactive findByPrefix(Located actor, String namePrefix) {
		return findByPrefix(actor, actor.getLocation(), namePrefix);
	}

	public static Interactive findByPrefix(Located actor, Space location, String namePrefix) {
		if (namePrefix == null || namePrefix.length() == 0) {
			return null;
		}

		String prefix = namePrefix.toLowerCase();
		if (namePrefix.equals("self")) {
			Interactive interactive = (Interactive) actor.getRole(Interactive.class);
			if (interactive != null) {
				return interactive;
			}
			// else we will look for this obj;
		}

		String mostSimilarName = null;
		Interactive result = null;
		for (Located obj = location.getFirstInSpace(); obj != null; obj = obj.getNextInSpace()) { // backstep lists are chained
			Interactive interactive = (Interactive) obj.getRole(Interactive.class);
			if (interactive == null) {
				continue;
			}
			String[] inames = interactive.getTargetList();
			for (int i = 0; i < inames.length; i++) {
				String iname = inames[i];
				if (iname.startsWith(prefix)) {
					if (iname.length() == prefix.length()) {
						return interactive; // found exact
					}
					if (mostSimilarName == null) {
						mostSimilarName = iname;
						result = interactive;
						continue;
					} else {
						if (Utils.isCloserTo(prefix, iname, mostSimilarName)) {
							mostSimilarName = iname;
							result = interactive;
						}
					}
				}
			}
		}
		return result;
	}

}