View Javadoc
1   ///////////////////////////////////////////////////////////////////////////////////////////////
2   // checkstyle: Checks Java source code and other text files for adherence to a set of rules.
3   // Copyright (C) 2001-2024 the original author or authors.
4   //
5   // This library is free software; you can redistribute it and/or
6   // modify it under the terms of the GNU Lesser General Public
7   // License as published by the Free Software Foundation; either
8   // version 2.1 of the License, or (at your option) any later version.
9   //
10  // This library is distributed in the hope that it will be useful,
11  // but WITHOUT ANY WARRANTY; without even the implied warranty of
12  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  // Lesser General Public License for more details.
14  //
15  // You should have received a copy of the GNU Lesser General Public
16  // License along with this library; if not, write to the Free Software
17  // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18  ///////////////////////////////////////////////////////////////////////////////////////////////
19  
20  package com.puppycrawl.tools.checkstyle.api;
21  
22  import java.util.Objects;
23  
24  /**
25   * Immutable line and column numbers.
26   *
27   */
28  public class LineColumn implements Comparable<LineColumn> {
29  
30      /** The one-based line number. */
31      private final int line;
32  
33      /** The zero-based column number. */
34      private final int column;
35  
36      /**
37       * Constructs a new pair of line and column numbers.
38       *
39       * @param line the one-based line number
40       * @param column the zero-based column number
41       */
42      public LineColumn(int line, int column) {
43          this.line = line;
44          this.column = column;
45      }
46  
47      /**
48       * Gets the one-based line number.
49       *
50       * @return the one-based line number
51       */
52      public int getLine() {
53          return line;
54      }
55  
56      /**
57       * Gets the zero-based column number.
58       *
59       * @return the zero-based column number
60       */
61      public int getColumn() {
62          return column;
63      }
64  
65      @Override
66      public int compareTo(LineColumn lineColumn) {
67          final int result;
68          if (line == lineColumn.line) {
69              result = Integer.compare(column, lineColumn.column);
70          }
71          else {
72              result = Integer.compare(line, lineColumn.line);
73          }
74          return result;
75      }
76  
77      @Override
78      public boolean equals(Object other) {
79          if (this == other) {
80              return true;
81          }
82          if (other == null || getClass() != other.getClass()) {
83              return false;
84          }
85          final LineColumn lineColumn = (LineColumn) other;
86          return Objects.equals(line, lineColumn.line)
87                  && Objects.equals(column, lineColumn.column);
88      }
89  
90      @Override
91      public int hashCode() {
92          return Objects.hash(line, column);
93      }
94  
95  }