1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- /*
- * This program is free software: you can redistribute it and/or modify it under
- * the terms of the GNU General Public License as published by the Free Software
- * Foundation, either version 3 of the License, or (at your option) any later
- * version.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
- * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
- * details.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program. If not, see <http://www.gnu.org/licenses/>.
- */
- package com.l2jserver.gameserver.handler;
- import gnu.trove.map.hash.TIntObjectHashMap;
- import java.util.logging.Logger;
- import com.l2jserver.Config;
- /**
- * This class ...
- *
- * @version $Revision: 1.1.4.5 $ $Date: 2005/03/27 15:30:09 $
- */
- public class VoicedCommandHandler
- {
- private static Logger _log = Logger.getLogger(ItemHandler.class.getName());
-
- private TIntObjectHashMap<IVoicedCommandHandler> _datatable;
-
- public static VoicedCommandHandler getInstance()
- {
- return SingletonHolder._instance;
- }
-
- private VoicedCommandHandler()
- {
- _datatable = new TIntObjectHashMap<IVoicedCommandHandler>();
- }
-
- public void registerVoicedCommandHandler(IVoicedCommandHandler handler)
- {
- String[] ids = handler.getVoicedCommandList();
- for (int i = 0; i < ids.length; i++)
- {
- if (Config.DEBUG)
- _log.fine("Adding handler for command " + ids[i]);
- _datatable.put(ids[i].hashCode(), handler);
- }
- }
-
- public IVoicedCommandHandler getVoicedCommandHandler(String voicedCommand)
- {
- String command = voicedCommand;
- if (voicedCommand.indexOf(" ") != -1)
- {
- command = voicedCommand.substring(0, voicedCommand.indexOf(" "));
- }
- if (Config.DEBUG)
- _log.fine("getting handler for command: " + command + " -> " + (_datatable.get(command.hashCode()) != null));
- return _datatable.get(command.hashCode());
- }
-
- /**
- * @return
- */
- public int size()
- {
- return _datatable.size();
- }
-
- @SuppressWarnings("synthetic-access")
- private static class SingletonHolder
- {
- protected static final VoicedCommandHandler _instance = new VoicedCommandHandler();
- }
- }
|