/
com/planet_ink/coffee_mud/Abilities/Common/
com/planet_ink/coffee_mud/Abilities/Diseases/
com/planet_ink/coffee_mud/Abilities/Druid/
com/planet_ink/coffee_mud/Abilities/Fighter/
com/planet_ink/coffee_mud/Abilities/Languages/
com/planet_ink/coffee_mud/Abilities/Misc/
com/planet_ink/coffee_mud/Abilities/Prayers/
com/planet_ink/coffee_mud/Abilities/Properties/
com/planet_ink/coffee_mud/Abilities/Skills/
com/planet_ink/coffee_mud/Abilities/Songs/
com/planet_ink/coffee_mud/Abilities/Specializations/
com/planet_ink/coffee_mud/Abilities/Spells/
com/planet_ink/coffee_mud/Abilities/Thief/
com/planet_ink/coffee_mud/Abilities/Traps/
com/planet_ink/coffee_mud/Behaviors/
com/planet_ink/coffee_mud/CharClasses/
com/planet_ink/coffee_mud/CharClasses/interfaces/
com/planet_ink/coffee_mud/Commands/
com/planet_ink/coffee_mud/Commands/interfaces/
com/planet_ink/coffee_mud/Common/
com/planet_ink/coffee_mud/Common/interfaces/
com/planet_ink/coffee_mud/Exits/interfaces/
com/planet_ink/coffee_mud/Items/Armor/
com/planet_ink/coffee_mud/Items/Basic/
com/planet_ink/coffee_mud/Items/BasicTech/
com/planet_ink/coffee_mud/Items/CompTech/
com/planet_ink/coffee_mud/Items/MiscMagic/
com/planet_ink/coffee_mud/Items/Weapons/
com/planet_ink/coffee_mud/Items/interfaces/
com/planet_ink/coffee_mud/Libraries/
com/planet_ink/coffee_mud/Libraries/interfaces/
com/planet_ink/coffee_mud/Locales/
com/planet_ink/coffee_mud/MOBS/
com/planet_ink/coffee_mud/Races/
com/planet_ink/coffee_mud/Races/interfaces/
com/planet_ink/coffee_mud/WebMacros/
com/planet_ink/coffee_mud/WebMacros/interfaces/
com/planet_ink/coffee_mud/core/
com/planet_ink/coffee_mud/core/collections/
com/planet_ink/coffee_mud/core/interfaces/
com/planet_ink/coffee_mud/core/intermud/
com/planet_ink/coffee_mud/core/intermud/i3/
com/planet_ink/coffee_web/server/
com/planet_ink/siplet/applet/
lib/
resources/factions/
resources/fakedb/
resources/progs/autoplayer/
resources/quests/holidays/
web/
web/admin.templates/
web/admin/grinder/
web/admin/images/
web/clan.templates/
web/pub.templates/
web/pub/images/mxp/
web/pub/sounds/
web/pub/textedit/
package com.planet_ink.coffee_mud.Items.interfaces;
import com.planet_ink.coffee_mud.core.interfaces.*;
import com.planet_ink.coffee_mud.core.*;
import com.planet_ink.coffee_mud.core.collections.*;
import com.planet_ink.coffee_mud.Abilities.interfaces.*;
import com.planet_ink.coffee_mud.Areas.interfaces.*;
import com.planet_ink.coffee_mud.Behaviors.interfaces.*;
import com.planet_ink.coffee_mud.CharClasses.interfaces.*;
import com.planet_ink.coffee_mud.Commands.interfaces.*;
import com.planet_ink.coffee_mud.Common.interfaces.*;
import com.planet_ink.coffee_mud.Exits.interfaces.*;
import com.planet_ink.coffee_mud.Items.interfaces.*;
import com.planet_ink.coffee_mud.Libraries.interfaces.*;
import com.planet_ink.coffee_mud.Locales.interfaces.*;
import com.planet_ink.coffee_mud.MOBS.interfaces.*;
import com.planet_ink.coffee_mud.Races.interfaces.*;

/*
   Copyright 2003-2019 Bo Zimmerman

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

	   http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
*/
/**
 * Musical instruments are typically used by Bard types
 * to make their magic.  Having hard coded types allows
 * skills and such to do thing based on these types.
 * @author Bo Zimmerman
 */
public interface MusicalInstrument extends Item
{
	/**
	 * The enum of instrument types.  These are general
	 * categories of instruments, so hopefully nothing is
	 * missing.  They are used by skills to identify an
	 * instrument category.
	 * @author Bo Zimmerman
	 *
	 */
	public enum InstrumentType
	{
		CLARINETS,
		CYMBALS,
		DRUMS,
		FLUTES,
		GUITARS,
		HARMONICAS,
		HARPS,
		HORNS,
		OBOES,
		ORGANS,
		PIANOS,
		TROMBONES,
		TRUMPETS,
		TUBAS,
		VIOLINS,
		WOODS,
		XYLOPHONES,
		OTHER_INSTRUMENT_TYPE
		;
		private static String[] valueNames = null;
		public static String[] valueNames()
		{
			if(valueNames != null)
			{
				return valueNames;
			}
			valueNames = new String[InstrumentType.values().length];
			int i=0;
			for(final InstrumentType type : InstrumentType.values())
				valueNames[i++] = type.name();
			return valueNames;
		}
	}

	/**
	 * Returns the instrument type of this instrument
	 * @see InstrumentType
	 * @see MusicalInstrument#setInstrumentType(InstrumentType)
	 * @see MusicalInstrument#setInstrumentType(String)
	 * @see MusicalInstrument#setInstrumentType(int)
	 * @return the instrument type enum object of this instrument
	 */
	public InstrumentType getInstrumentType();

	/**
	 * Returns the instrument type name of this instrument
	 * @see InstrumentType
	 * @see MusicalInstrument#setInstrumentType(InstrumentType)
	 * @see MusicalInstrument#setInstrumentType(String)
	 * @see MusicalInstrument#setInstrumentType(int)
	 * @return the instrument type name of this instrument
	 */
	public String getInstrumentTypeName();

	/**
	 * Sets the instrument type of this instrument
	 * @see InstrumentType
	 * @see MusicalInstrument#setInstrumentType(InstrumentType)
	 * @see MusicalInstrument#setInstrumentType(String)
	 * @see MusicalInstrument#setInstrumentType(int)
	 * @param type the instrument type enum object of this instrument
	 */
	public void setInstrumentType(InstrumentType type);

	/**
	 * Sets the instrument type of this instrument
	 * @see InstrumentType
	 * @see MusicalInstrument#setInstrumentType(InstrumentType)
	 * @see MusicalInstrument#setInstrumentType(String)
	 * @see MusicalInstrument#setInstrumentType(int)
	 * @param typeName the instrument type name for this instrument
	 */
	public void setInstrumentType(String typeName);

	/**
	 * Sets the instrument type of this instrument
	 * @see InstrumentType
	 * @see MusicalInstrument#setInstrumentType(InstrumentType)
	 * @see MusicalInstrument#setInstrumentType(String)
	 * @see MusicalInstrument#setInstrumentType(int)
	 * @param typeOrdinal the instrument ordinal of this instrument
	 */
	public void setInstrumentType(int typeOrdinal);
}