/interpreter/tags/at2dist110511/src/edu/vub/at/exceptions/XParseError.java

http://ambienttalk.googlecode.com/ · Java · 130 lines · 51 code · 15 blank · 64 comment · 3 complexity · e0c4d81d63440c3766a84207720ed60a MD5 · raw file

  1. /**
  2. * AmbientTalk/2 Project
  3. * XParseError.java created on 29-jul-2006 at 14:36:07
  4. * (c) Programming Technology Lab, 2006 - 2007
  5. * Authors: Tom Van Cutsem & Stijn Mostinckx
  6. *
  7. * Permission is hereby granted, free of charge, to any person
  8. * obtaining a copy of this software and associated documentation
  9. * files (the "Software"), to deal in the Software without
  10. * restriction, including without limitation the rights to use,
  11. * copy, modify, merge, publish, distribute, sublicense, and/or
  12. * sell copies of the Software, and to permit persons to whom the
  13. * Software is furnished to do so, subject to the following
  14. * conditions:
  15. *
  16. * The above copyright notice and this permission notice shall be
  17. * included in all copies or substantial portions of the Software.
  18. *
  19. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  20. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
  21. * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  22. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
  23. * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
  24. * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  25. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
  26. * OTHER DEALINGS IN THE SOFTWARE.
  27. */
  28. package edu.vub.at.exceptions;
  29. import edu.vub.at.objects.ATTypeTag;
  30. import edu.vub.at.objects.coercion.NativeTypeTags;
  31. import java.io.InputStream;
  32. /**
  33. * XParseError is thrown when illegal input is parsed by the AmbientTalk parser.
  34. *
  35. * @author tvc
  36. */
  37. public final class XParseError extends InterpreterException {
  38. private static final long serialVersionUID = 3910243526236096495L;
  39. private InputStream erroneousCode_;
  40. // indicates the position of the parse error
  41. private final String fileName_;
  42. private final int line_;
  43. private final int column_;
  44. /**
  45. * Convenience constructor which takes only a message and an underlying exception.
  46. * @param message a message detailing the suspected reason for the parser to fail
  47. * @param cause an underlying exception detailing the actual cause of this exception
  48. */
  49. public XParseError(String message, Throwable cause) {
  50. super(message, cause);
  51. fileName_ = null;
  52. line_ = 0;
  53. column_ = 0;
  54. }
  55. /**
  56. * Complete constructor taking information on both the error and the precise position in which
  57. * the erroneous code was detected by the parser.
  58. * @param erroneousCode the code snippet which could not be parsed
  59. * @param message a message detailing the suspected reason for the parser to fail
  60. * @param filename the file from which the parser was reading
  61. * @param line the line at which the erroneous code is situated
  62. * @param column the column at which the token that could not be parsed starts.
  63. * @param cause an underlying exception detailing the actual cause of this exception
  64. */
  65. public XParseError(InputStream erroneousCode,
  66. String message,
  67. String filename,
  68. int line,
  69. int column,
  70. Throwable cause) {
  71. super(message, cause);
  72. erroneousCode_ = erroneousCode;
  73. fileName_ = filename;
  74. line_ = line;
  75. column_ = column;
  76. }
  77. /**
  78. * @return Returns the column.
  79. */
  80. public int getColumn() {
  81. return column_;
  82. }
  83. /**
  84. * @return Returns the fileName.
  85. */
  86. public String getFileName() {
  87. return fileName_;
  88. }
  89. /**
  90. * @return Returns the line.
  91. */
  92. public int getLine() {
  93. return line_;
  94. }
  95. /**
  96. * @return Returns the erroneous code.
  97. */
  98. public InputStream getErroneousCode() {
  99. return erroneousCode_;
  100. }
  101. /**
  102. * Method overridden to provide a more elaborate message when information on the source file,
  103. * the line number and column position were provided.
  104. */
  105. public String getMessage() {
  106. if (fileName_ != null) {
  107. return fileName_ + ":" + line_ + ":" + column_ + ":" + super.getMessage();
  108. } else {
  109. return super.getMessage();
  110. }
  111. }
  112. public ATTypeTag getType() {
  113. return NativeTypeTags._PARSEERROR_;
  114. }
  115. }