You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LoggingCommand.java 4.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * Copyright (c) 2006-2017 DMDirc Developers
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
  5. * documentation files (the "Software"), to deal in the Software without restriction, including without limitation the
  6. * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
  7. * permit persons to whom the Software is furnished to do so, subject to the following conditions:
  8. *
  9. * The above copyright notice and this permission notice shall be included in all copies or substantial portions of the
  10. * Software.
  11. *
  12. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  13. * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
  14. * OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
  15. * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  16. */
  17. package com.dmdirc.addons.logging;
  18. import com.dmdirc.commandparser.BaseCommandInfo;
  19. import com.dmdirc.commandparser.CommandArguments;
  20. import com.dmdirc.commandparser.CommandType;
  21. import com.dmdirc.commandparser.commands.BaseCommand;
  22. import com.dmdirc.commandparser.commands.IntelligentCommand;
  23. import com.dmdirc.commandparser.commands.context.CommandContext;
  24. import com.dmdirc.interfaces.CommandController;
  25. import com.dmdirc.interfaces.WindowModel;
  26. import com.dmdirc.ui.input.AdditionalTabTargets;
  27. import javax.annotation.Nonnull;
  28. import javax.inject.Inject;
  29. /**
  30. * The logging command retrieves information from a dcop application.
  31. */
  32. public class LoggingCommand extends BaseCommand implements IntelligentCommand {
  33. /** Command name. */
  34. private static final String LOGGING = "logging";
  35. /** A command info object for this command. */
  36. public static final BaseCommandInfo INFO = new BaseCommandInfo(LOGGING,
  37. "logging <history|help> - view logging related information",
  38. CommandType.TYPE_SERVER);
  39. /** Logging manager. */
  40. private final LoggingManager manager;
  41. /**
  42. * Creates a new instance of this command.
  43. *
  44. * @param controller The controller to use for command information.
  45. * @param manager The manager providing logging services.
  46. */
  47. @Inject
  48. public LoggingCommand(final CommandController controller, final LoggingManager manager) {
  49. super(controller);
  50. this.manager = manager;
  51. }
  52. @Override
  53. public void execute(@Nonnull final WindowModel origin,
  54. final CommandArguments args, final CommandContext context) {
  55. if (args.getArguments().length > 0) {
  56. if ("history".equalsIgnoreCase(args.getArguments()[0])) {
  57. if (!manager.showHistory(origin)) {
  58. showError(origin, args.isSilent(), "Unable to open history for this window.");
  59. }
  60. } else if ("help".equalsIgnoreCase(args.getArguments()[0])) {
  61. showOutput(origin, args.isSilent(), LOGGING
  62. + " history - Open the history of this window, if available.");
  63. showOutput(origin, args.isSilent(), LOGGING
  64. + " help - Show this help.");
  65. } else {
  66. showError(origin, args.isSilent(), "Unknown command '"
  67. + args.getArguments()[0] + "'. Use " + LOGGING
  68. + " help for a list of commands.");
  69. }
  70. } else {
  71. showError(origin, args.isSilent(), "Use " + LOGGING + " help for a list of commands.");
  72. }
  73. }
  74. @Override
  75. public AdditionalTabTargets getSuggestions(final int arg,
  76. final IntelligentCommandContext context) {
  77. final AdditionalTabTargets res = new AdditionalTabTargets();
  78. if (arg == 0) {
  79. res.add("history");
  80. res.add("help");
  81. res.excludeAll();
  82. }
  83. return res;
  84. }
  85. }