Files
java-design-patterns/extension-objects/src/main/java/App.java

63 lines
1.9 KiB
Java
Raw Normal View History

2017-04-27 13:58:58 +02:00
import abstractextensions.CommanderExtension;
import abstractextensions.SergeantExtension;
import abstractextensions.SoldierExtension;
import units.CommanderUnit;
import units.SergeantUnit;
import units.SoldierUnit;
import units.Unit;
2017-06-04 20:49:15 +02:00
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
2017-04-27 13:58:58 +02:00
/**
* Anticipate that an objects interface needs to be extended in the future.
* Additional interfaces are defined by extension objects.
2017-04-27 13:58:58 +02:00
*/
public class App {
/**
* Program entry point
*
* @param args command line args
*/
public static void main(String[] args) {
//Create 3 different units
2017-06-04 20:49:15 +02:00
Unit soldierUnit = new SoldierUnit("SoldierUnit1");
Unit sergeantUnit = new SergeantUnit("SergeantUnit1");
Unit commanderUnit = new CommanderUnit("CommanderUnit1");
2017-04-27 13:58:58 +02:00
//check for each unit to have an extension
2017-06-04 20:49:15 +02:00
checkExtensionsForUnit(soldierUnit);
checkExtensionsForUnit(sergeantUnit);
checkExtensionsForUnit(commanderUnit);
2017-04-27 13:58:58 +02:00
}
private static void checkExtensionsForUnit(Unit unit) {
2017-06-04 20:49:15 +02:00
final Logger logger = LoggerFactory.getLogger(App.class);
2017-04-27 13:58:58 +02:00
SoldierExtension soldierExtension = (SoldierExtension) unit.getUnitExtension("SoldierExtension");
SergeantExtension sergeantExtension = (SergeantExtension) unit.getUnitExtension("SergeantExtension");
CommanderExtension commanderExtension = (CommanderExtension) unit.getUnitExtension("CommanderExtension");
2017-05-03 13:21:13 +02:00
//if unit have extension call the method
2017-04-27 13:58:58 +02:00
if (soldierExtension != null) {
soldierExtension.soldierReady();
} else {
2017-06-04 20:49:15 +02:00
logger.info(unit.getName() + " without SoldierExtension");
2017-04-27 13:58:58 +02:00
}
if (sergeantExtension != null) {
sergeantExtension.sergeantReady();
} else {
2017-06-04 20:49:15 +02:00
logger.info(unit.getName() + " without SergeantExtension");
2017-04-27 13:58:58 +02:00
}
if (commanderExtension != null) {
2017-05-03 13:21:13 +02:00
commanderExtension.commanderReady();
2017-04-27 13:58:58 +02:00
} else {
2017-06-04 20:49:15 +02:00
logger.info(unit.getName() + " without CommanderExtension");
2017-04-27 13:58:58 +02:00
}
}
}