jaxp/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/classfile/LineNumber.java
author joehw
Mon, 17 Apr 2017 16:24:10 -0700
changeset 44797 8b3b3b911b8a
parent 25868 686eef1e7a79
child 46174 5611d2529b49
permissions -rw-r--r--
8162572: Update License Header for all JAXP sources Reviewed-by: lancea
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6
7f561c08de6b Initial load
duke
parents:
diff changeset
     1
/*
7f561c08de6b Initial load
duke
parents:
diff changeset
     2
 * reserved comment block
7f561c08de6b Initial load
duke
parents:
diff changeset
     3
 * DO NOT REMOVE OR ALTER!
7f561c08de6b Initial load
duke
parents:
diff changeset
     4
 */
44797
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
     5
/*
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
     6
 * Licensed to the Apache Software Foundation (ASF) under one or more
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
     7
 * contributor license agreements.  See the NOTICE file distributed with
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
     8
 * this work for additional information regarding copyright ownership.
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
     9
 * The ASF licenses this file to You under the Apache License, Version 2.0
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    10
 * (the "License"); you may not use this file except in compliance with
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    11
 * the License.  You may obtain a copy of the License at
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    12
 *
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    13
 *      http://www.apache.org/licenses/LICENSE-2.0
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    14
 *
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    15
 * Unless required by applicable law or agreed to in writing, software
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    16
 * distributed under the License is distributed on an "AS IS" BASIS,
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    17
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    18
 * See the License for the specific language governing permissions and
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    19
 * limitations under the License.
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    20
 */
8b3b3b911b8a 8162572: Update License Header for all JAXP sources
joehw
parents: 25868
diff changeset
    21
6
7f561c08de6b Initial load
duke
parents:
diff changeset
    22
package com.sun.org.apache.bcel.internal.classfile;
7f561c08de6b Initial load
duke
parents:
diff changeset
    23
7f561c08de6b Initial load
duke
parents:
diff changeset
    24
7f561c08de6b Initial load
duke
parents:
diff changeset
    25
import  com.sun.org.apache.bcel.internal.Constants;
7f561c08de6b Initial load
duke
parents:
diff changeset
    26
import  java.io.*;
7f561c08de6b Initial load
duke
parents:
diff changeset
    27
7f561c08de6b Initial load
duke
parents:
diff changeset
    28
/**
7f561c08de6b Initial load
duke
parents:
diff changeset
    29
 * This class represents a (PC offset, line number) pair, i.e., a line number in
7f561c08de6b Initial load
duke
parents:
diff changeset
    30
 * the source that corresponds to a relative address in the byte code. This
7f561c08de6b Initial load
duke
parents:
diff changeset
    31
 * is used for debugging purposes.
7f561c08de6b Initial load
duke
parents:
diff changeset
    32
 *
7f561c08de6b Initial load
duke
parents:
diff changeset
    33
 * @author  <A HREF="mailto:markus.dahm@berlin.de">M. Dahm</A>
7f561c08de6b Initial load
duke
parents:
diff changeset
    34
 * @see     LineNumberTable
7f561c08de6b Initial load
duke
parents:
diff changeset
    35
 */
7f561c08de6b Initial load
duke
parents:
diff changeset
    36
public final class LineNumber implements Cloneable, Node, Serializable {
7f561c08de6b Initial load
duke
parents:
diff changeset
    37
  private int start_pc;    // Program Counter (PC) corresponds to line
7f561c08de6b Initial load
duke
parents:
diff changeset
    38
  private int line_number; // number in source file
7f561c08de6b Initial load
duke
parents:
diff changeset
    39
7f561c08de6b Initial load
duke
parents:
diff changeset
    40
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    41
   * Initialize from another object.
7f561c08de6b Initial load
duke
parents:
diff changeset
    42
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    43
  public LineNumber(LineNumber c) {
7f561c08de6b Initial load
duke
parents:
diff changeset
    44
    this(c.getStartPC(), c.getLineNumber());
7f561c08de6b Initial load
duke
parents:
diff changeset
    45
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
    46
7f561c08de6b Initial load
duke
parents:
diff changeset
    47
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    48
   * Construct object from file stream.
7f561c08de6b Initial load
duke
parents:
diff changeset
    49
   * @param file Input stream
7f561c08de6b Initial load
duke
parents:
diff changeset
    50
   * @throws IOException
7f561c08de6b Initial load
duke
parents:
diff changeset
    51
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    52
  LineNumber(DataInputStream file) throws IOException
7f561c08de6b Initial load
duke
parents:
diff changeset
    53
  {
7f561c08de6b Initial load
duke
parents:
diff changeset
    54
    this(file.readUnsignedShort(), file.readUnsignedShort());
7f561c08de6b Initial load
duke
parents:
diff changeset
    55
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
    56
7f561c08de6b Initial load
duke
parents:
diff changeset
    57
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    58
   * @param start_pc Program Counter (PC) corresponds to
7f561c08de6b Initial load
duke
parents:
diff changeset
    59
   * @param line_number line number in source file
7f561c08de6b Initial load
duke
parents:
diff changeset
    60
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    61
  public LineNumber(int start_pc, int line_number)
7f561c08de6b Initial load
duke
parents:
diff changeset
    62
  {
7f561c08de6b Initial load
duke
parents:
diff changeset
    63
    this.start_pc    = start_pc;
7f561c08de6b Initial load
duke
parents:
diff changeset
    64
    this.line_number = line_number;
7f561c08de6b Initial load
duke
parents:
diff changeset
    65
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
    66
7f561c08de6b Initial load
duke
parents:
diff changeset
    67
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    68
   * Called by objects that are traversing the nodes of the tree implicitely
7f561c08de6b Initial load
duke
parents:
diff changeset
    69
   * defined by the contents of a Java class. I.e., the hierarchy of methods,
7f561c08de6b Initial load
duke
parents:
diff changeset
    70
   * fields, attributes, etc. spawns a tree of objects.
7f561c08de6b Initial load
duke
parents:
diff changeset
    71
   *
7f561c08de6b Initial load
duke
parents:
diff changeset
    72
   * @param v Visitor object
7f561c08de6b Initial load
duke
parents:
diff changeset
    73
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    74
  public void accept(Visitor v) {
7f561c08de6b Initial load
duke
parents:
diff changeset
    75
    v.visitLineNumber(this);
7f561c08de6b Initial load
duke
parents:
diff changeset
    76
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
    77
7f561c08de6b Initial load
duke
parents:
diff changeset
    78
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    79
   * Dump line number/pc pair to file stream in binary format.
7f561c08de6b Initial load
duke
parents:
diff changeset
    80
   *
7f561c08de6b Initial load
duke
parents:
diff changeset
    81
   * @param file Output file stream
7f561c08de6b Initial load
duke
parents:
diff changeset
    82
   * @throws IOException
7f561c08de6b Initial load
duke
parents:
diff changeset
    83
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    84
  public final void dump(DataOutputStream file) throws IOException
7f561c08de6b Initial load
duke
parents:
diff changeset
    85
  {
7f561c08de6b Initial load
duke
parents:
diff changeset
    86
    file.writeShort(start_pc);
7f561c08de6b Initial load
duke
parents:
diff changeset
    87
    file.writeShort(line_number);
7f561c08de6b Initial load
duke
parents:
diff changeset
    88
7f561c08de6b Initial load
duke
parents:
diff changeset
    89
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
    90
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    91
   * @return Corresponding source line
7f561c08de6b Initial load
duke
parents:
diff changeset
    92
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    93
  public final int getLineNumber() { return line_number; }
7f561c08de6b Initial load
duke
parents:
diff changeset
    94
7f561c08de6b Initial load
duke
parents:
diff changeset
    95
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
    96
   * @return PC in code
7f561c08de6b Initial load
duke
parents:
diff changeset
    97
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
    98
  public final int getStartPC() { return start_pc; }
7f561c08de6b Initial load
duke
parents:
diff changeset
    99
7f561c08de6b Initial load
duke
parents:
diff changeset
   100
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   101
   * @param line_number.
7f561c08de6b Initial load
duke
parents:
diff changeset
   102
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
   103
  public final void setLineNumber(int line_number) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   104
    this.line_number = line_number;
7f561c08de6b Initial load
duke
parents:
diff changeset
   105
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
   106
7f561c08de6b Initial load
duke
parents:
diff changeset
   107
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   108
   * @param start_pc.
7f561c08de6b Initial load
duke
parents:
diff changeset
   109
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
   110
  public final void setStartPC(int start_pc) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   111
    this.start_pc = start_pc;
7f561c08de6b Initial load
duke
parents:
diff changeset
   112
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
   113
7f561c08de6b Initial load
duke
parents:
diff changeset
   114
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   115
   * @return String representation
7f561c08de6b Initial load
duke
parents:
diff changeset
   116
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
   117
  public final String toString() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   118
    return "LineNumber(" + start_pc + ", " + line_number + ")";
7f561c08de6b Initial load
duke
parents:
diff changeset
   119
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
   120
7f561c08de6b Initial load
duke
parents:
diff changeset
   121
  /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   122
   * @return deep copy of this object
7f561c08de6b Initial load
duke
parents:
diff changeset
   123
   */
7f561c08de6b Initial load
duke
parents:
diff changeset
   124
  public LineNumber copy() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   125
    try {
7f561c08de6b Initial load
duke
parents:
diff changeset
   126
      return (LineNumber)clone();
7f561c08de6b Initial load
duke
parents:
diff changeset
   127
    } catch(CloneNotSupportedException e) {}
7f561c08de6b Initial load
duke
parents:
diff changeset
   128
7f561c08de6b Initial load
duke
parents:
diff changeset
   129
    return null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   130
  }
7f561c08de6b Initial load
duke
parents:
diff changeset
   131
}