/
codebase/src/net/sourceforge/pain/admin/console/command/
codebase/src/net/sourceforge/pain/data/role/
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/util/
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/
mudlibs/tinylib/
mudlibs/tinylib/area/
mudlibs/tinylib/etc/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/data/affect/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/data/prototype/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/data/trigger/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/affect/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/deploy/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/guitool/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/guitool/event/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/fn/util/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/trigger/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/trigger/impl/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/command/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/reset/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/shutdown/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/social/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/util/
tests/
tests/src/
tests/src/net/sourceforge/pain/db/data/
package net.sourceforge.pain.tinylib.logic.fn;

import net.sourceforge.pain.tinylib.data.type.*;
import net.sourceforge.pain.tinylib.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;
    }

}