/*=============================================================================# # Copyright (c) 2011-2016 Stephan Wahlbrink (WalWare.de) and others. # All rights reserved. This program and the accompanying materials # are made available under the terms of either (per the licensee's choosing) # - the Eclipse Public License v1.0 # which accompanies this distribution, and is available at # http://www.eclipse.org/legal/epl-v10.html, or # - the GNU Lesser General Public License v2.1 or newer # which accompanies this distribution, and is available at # http://www.gnu.org/licenses/lgpl.html # # Contributors: # Stephan Wahlbrink - initial API and implementation #=============================================================================*/ package de.walware.rj.server.dbg; public class Srcref { public static final int BEGIN_LINE= 0; public static final int BEGIN_COLUMN= 4; public static final int BEGIN_BYTE= 1; public static final int END_LINE= 2; public static final int END_COLUMN= 5; public static final int END_BYTE= 3; public static final int NA= Integer.MIN_VALUE; public static int[] diff(final int[] base, final int[] rel) { final int[] diff= new int[6]; if (base[BEGIN_LINE] > 0 && rel[BEGIN_LINE] > 0) { diff[BEGIN_LINE]= 1 + rel[BEGIN_LINE] - base[BEGIN_LINE]; if (diff[BEGIN_LINE] <= 0) { return null; } } else { diff[BEGIN_LINE]= NA; } if (diff[BEGIN_LINE] == 1) { if (base[BEGIN_COLUMN] > 0 && rel[BEGIN_COLUMN] > 0) { diff[BEGIN_COLUMN]= 1 + rel[BEGIN_COLUMN] - base[BEGIN_COLUMN]; if (diff[BEGIN_COLUMN] <= 0) { return null; } } else { diff[BEGIN_COLUMN]= NA; } if (base[BEGIN_BYTE] > 0 && rel[BEGIN_BYTE] > 0) { diff[BEGIN_BYTE]= 1 + rel[BEGIN_BYTE] - base[BEGIN_BYTE]; if (diff[BEGIN_BYTE] <= 0) { diff[BEGIN_BYTE]= NA; } } else { diff[BEGIN_BYTE]= NA; } } if (base[BEGIN_LINE] > 0 && rel[END_LINE] > 0) { diff[END_LINE]= 1 + rel[END_LINE] - base[BEGIN_LINE]; if (diff[END_LINE] <= 0) { return null; } } else { diff[END_LINE]= NA; } if (diff[END_LINE] == 1) { if (base[BEGIN_COLUMN] > 0 && rel[END_COLUMN] > 0) { diff[END_COLUMN]= 1 + rel[END_COLUMN] - base[BEGIN_COLUMN]; if (diff[END_COLUMN] <= 0) { return null; } } else { diff[END_COLUMN]= NA; } if (base[BEGIN_BYTE] > 0 && rel[END_BYTE] > 0) { diff[END_BYTE]= 1 + rel[END_BYTE] - base[BEGIN_BYTE]; if (diff[END_BYTE] <= 0) { diff[END_BYTE]= NA; } } else { diff[END_BYTE]= NA; } } return diff; } public static int addLine(final int base, final int diff) { if (base > 0 && diff > 0) { return base + diff - 1; } else { return NA; } } public static int[] add(final int[] base, final int[] diff) { final int[] sum= new int[6]; sum[BEGIN_LINE]= addLine(base[BEGIN_LINE], diff[BEGIN_LINE]); if (diff[BEGIN_LINE] == 1) { if (base[BEGIN_COLUMN] > 0 && diff[BEGIN_COLUMN] > 0) { sum[BEGIN_COLUMN]= base[BEGIN_COLUMN] + diff[BEGIN_COLUMN] - 1; } else { sum[BEGIN_COLUMN]= NA; } if (base[BEGIN_BYTE] > 0 && diff[BEGIN_BYTE] > 0) { sum[BEGIN_BYTE]= base[BEGIN_BYTE] + diff[BEGIN_BYTE] - 1; } else { sum[BEGIN_BYTE]= NA; } } else { sum[BEGIN_COLUMN]= base[BEGIN_COLUMN]; sum[BEGIN_BYTE]= base[BEGIN_BYTE]; } sum[END_LINE]= addLine(base[BEGIN_LINE], diff[END_LINE]); if (diff[END_LINE] == 1) { if (base[BEGIN_COLUMN] > 0 && diff[END_COLUMN] > 0) { sum[END_COLUMN]= base[BEGIN_COLUMN] + diff[END_COLUMN] - 1; } else { sum[END_COLUMN]= NA; } if (base[BEGIN_BYTE] > 0 && diff[END_BYTE] > 0) { sum[END_BYTE]= base[BEGIN_BYTE] + diff[END_BYTE] - 1; } else { sum[END_BYTE]= NA; } } else { sum[END_COLUMN]= base[END_COLUMN]; sum[END_BYTE]= base[END_BYTE]; } return sum; } }