Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

ActionComponentChain.java 5.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. /*
  2. * Copyright (c) 2006-2011 Chris Smith, Shane Mc Cormack, Gregory Holmes
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy
  5. * of this software and associated documentation files (the "Software"), to deal
  6. * in the Software without restriction, including without limitation the rights
  7. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. * copies of the Software, and to permit persons to whom the Software is
  9. * furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  20. * SOFTWARE.
  21. */
  22. package com.dmdirc.actions;
  23. import com.dmdirc.Precondition;
  24. import com.dmdirc.actions.interfaces.ActionComponent;
  25. import com.dmdirc.logger.Logger;
  26. import java.util.ArrayList;
  27. import java.util.List;
  28. /**
  29. * An action component chain supports chaining of multiple action components
  30. * together.
  31. *
  32. * @author chris
  33. */
  34. public class ActionComponentChain implements ActionComponent {
  35. /**
  36. * A list of components in this chain.
  37. */
  38. private final List<ActionComponent> components = new ArrayList<ActionComponent>();
  39. /**
  40. * Creates a new component chain from the specified text representation.
  41. * Chains are separated with full stops (.).
  42. *
  43. * @param source The class that this chain needs to start with
  44. * @param chain The textual representation of the chain
  45. */
  46. public ActionComponentChain(final Class<?> source, final String chain) {
  47. Class<?> current = source;
  48. for (String componentName : chain.split("\\.")) {
  49. final ActionComponent component = ActionManager.getActionComponent(componentName);
  50. if (component == null) {
  51. throw new IllegalArgumentException("Component " + componentName
  52. + " not found");
  53. } else if (component.appliesTo() == current) {
  54. components.add(component);
  55. current = component.getType();
  56. } else {
  57. throw new IllegalArgumentException("Component " + componentName
  58. + " cannot be applied to " + current.getName());
  59. }
  60. }
  61. }
  62. /** {@inheritDoc} */
  63. @Override
  64. public Object get(final Object argument) {
  65. Object res = argument;
  66. for (ActionComponent component : components) {
  67. if (res == null) {
  68. return null;
  69. }
  70. res = component.get(res);
  71. }
  72. return res;
  73. }
  74. /** {@inheritDoc} */
  75. @Precondition("This component chain has one or more components")
  76. @Override
  77. public Class<?> appliesTo() {
  78. Logger.assertTrue(!components.isEmpty());
  79. return components.get(0).appliesTo();
  80. }
  81. /** {@inheritDoc} */
  82. @Precondition("This component chain has one or more components")
  83. @Override
  84. public Class<?> getType() {
  85. Logger.assertTrue(!components.isEmpty());
  86. return components.get(components.size() - 1).getType();
  87. }
  88. /** {@inheritDoc} */
  89. @Precondition("This component chain has one or more components")
  90. @Override
  91. public String getName() {
  92. Logger.assertTrue(!components.isEmpty());
  93. final StringBuilder name = new StringBuilder();
  94. for (ActionComponent component : components) {
  95. name.append("'s ");
  96. name.append(component.getName());
  97. }
  98. return name.substring(3);
  99. }
  100. /** {@inheritDoc} */
  101. @Override
  102. @Precondition("This component chain has one or more components")
  103. public String toString() {
  104. Logger.assertTrue(!components.isEmpty());
  105. final StringBuilder name = new StringBuilder();
  106. for (ActionComponent component : components) {
  107. name.append('.');
  108. name.append(component.toString());
  109. }
  110. return name.substring(1);
  111. }
  112. /** {@inheritDoc} */
  113. @Override
  114. public String name() {
  115. return toString();
  116. }
  117. /**
  118. * Determines if any components in this chain require a server to have
  119. * an established connection in order to function.
  120. *
  121. * @since 0.6.4
  122. * @return True iff at least one component requires a connection
  123. */
  124. public boolean requiresConnection() {
  125. boolean res = false;
  126. for (ActionComponent component : components) {
  127. try {
  128. final ComponentOptions options = component.getClass()
  129. .getMethod("get", Object.class).getAnnotation(ComponentOptions.class);
  130. if (options != null) {
  131. res |= options.requireConnected();
  132. }
  133. } catch (NoSuchMethodException ex) {
  134. // Do nothing
  135. }
  136. }
  137. return res;
  138. }
  139. }