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.

MissingModeAliasException.java 2.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  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;
  18. import com.dmdirc.parser.interfaces.Parser;
  19. /**
  20. * An exception detailing the missing modes aliases and supporting information.
  21. */
  22. public class MissingModeAliasException extends Exception {
  23. /** A version number for this class. */
  24. private static final long serialVersionUID = 1;
  25. /**
  26. * Creates a new exception detailing the missing modes aliases and supporting information.
  27. *
  28. * @param network Network
  29. * @param parser Associated parser
  30. * @param modeAliasesVersion Current mode aliases version
  31. * @param missingModes Missing modes
  32. */
  33. public MissingModeAliasException(final String network, final Parser parser,
  34. final String modeAliasesVersion, final String missingModes) {
  35. super(missingModes + '\n'
  36. + "Network: " + network + '\n'
  37. + "IRCd: " + parser.getServerSoftware() + '\n'
  38. + " (" + parser.getServerSoftwareType() + " )\n"
  39. + "Mode alias version: "
  40. + modeAliasesVersion + '\n'
  41. + "Extra info: \n"
  42. + arrayListToString(parser.getServerInformationLines()) + "\n\n");
  43. }
  44. private static String arrayListToString(final Iterable<String> lines) {
  45. final StringBuilder sb = new StringBuilder();
  46. for (String line : lines) {
  47. sb.append(line).append('\n');
  48. }
  49. return sb.toString();
  50. }
  51. }