Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

CompositeErrorMessage.java 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. /*
  2. * Copyright 2000-2014 Vaadin Ltd.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License"); you may not
  5. * use this file except in compliance with the License. You may obtain a copy of
  6. * the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  12. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  13. * License for the specific language governing permissions and limitations under
  14. * the License.
  15. */
  16. package com.vaadin.server;
  17. import java.util.Collection;
  18. import java.util.Iterator;
  19. /**
  20. * Class for combining multiple error messages together.
  21. *
  22. * @author Vaadin Ltd
  23. * @since 3.0
  24. */
  25. @SuppressWarnings("serial")
  26. public class CompositeErrorMessage extends AbstractErrorMessage {
  27. /**
  28. * Constructor for CompositeErrorMessage.
  29. *
  30. * @param errorMessages
  31. * the array of error messages that are listed together. Nulls
  32. * are ignored, but at least one message is required.
  33. */
  34. public CompositeErrorMessage(ErrorMessage... errorMessages) {
  35. super(null);
  36. setErrorLevel(ErrorLevel.INFORMATION);
  37. for (int i = 0; i < errorMessages.length; i++) {
  38. addErrorMessage(errorMessages[i]);
  39. }
  40. if (getCauses().size() == 0) {
  41. throw new IllegalArgumentException(
  42. "Composite error message must have at least one error");
  43. }
  44. }
  45. /**
  46. * Constructor for CompositeErrorMessage.
  47. *
  48. * @param errorMessages
  49. * the Collection of error messages that are listed together. At
  50. * least one message is required.
  51. */
  52. public CompositeErrorMessage(
  53. Collection<? extends ErrorMessage> errorMessages) {
  54. super(null);
  55. setErrorLevel(ErrorLevel.INFORMATION);
  56. for (final Iterator<? extends ErrorMessage> i = errorMessages
  57. .iterator(); i.hasNext();) {
  58. addErrorMessage(i.next());
  59. }
  60. if (getCauses().size() == 0) {
  61. throw new IllegalArgumentException(
  62. "Composite error message must have at least one error");
  63. }
  64. }
  65. /**
  66. * Adds a error message into this composite message. Updates the level
  67. * field.
  68. *
  69. * @param error
  70. * the error message to be added. Duplicate errors are ignored.
  71. */
  72. private void addErrorMessage(ErrorMessage error) {
  73. if (error != null && !getCauses().contains(error)) {
  74. addCause(error);
  75. if (error.getErrorLevel().intValue() > getErrorLevel().intValue()) {
  76. setErrorLevel(error.getErrorLevel());
  77. }
  78. }
  79. }
  80. /**
  81. * Gets Error Iterator.
  82. *
  83. * @return the error iterator.
  84. */
  85. public Iterator<ErrorMessage> iterator() {
  86. return getCauses().iterator();
  87. }
  88. /**
  89. * Returns a comma separated list of the error messages.
  90. *
  91. * @return String, comma separated list of error messages.
  92. */
  93. @Override
  94. public String toString() {
  95. String retval = "[";
  96. int pos = 0;
  97. for (final Iterator<ErrorMessage> i = getCauses().iterator(); i
  98. .hasNext();) {
  99. if (pos > 0) {
  100. retval += ",";
  101. }
  102. pos++;
  103. retval += i.next().toString();
  104. }
  105. retval += "]";
  106. return retval;
  107. }
  108. }