package net.sourceforge.phpdt.internal.launching;

import net.sourceforge.phpdt.core.JavaModelException;
import net.sourceforge.phpeclipse.phpeditor.EditorUtility;

import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.ResourcesPlugin;
import org.eclipse.core.runtime.IPath;
import org.eclipse.core.runtime.Path;
import org.eclipse.debug.ui.console.IConsole;
import org.eclipse.debug.ui.console.IConsoleLineTracker;
import org.eclipse.jface.text.BadLocationException;
import org.eclipse.jface.text.IDocument;
import org.eclipse.jface.text.IRegion;
import org.eclipse.ui.IEditorPart;
import org.eclipse.ui.PartInitException;
import org.eclipse.ui.texteditor.ITextEditor;

public class ConsoleLineTracker implements IConsoleLineTracker {

	private static class JavadocConsoleHyperLink /*
													 * TODO XXX Disabled for 3.1
													 * implements
													 * IConsoleHyperlink
													 */{

		private IPath fExternalPath;

		private int fLineNumber;

		public JavadocConsoleHyperLink(IPath externalPath, int lineNumber) {
			fExternalPath = externalPath;
			fLineNumber = lineNumber;
		}

		/*
		 * (non-Javadoc)
		 * 
		 * @see org.eclipse.debug.ui.console.IConsoleHyperlink#linkEntered()
		 */
		public void linkEntered() {
		}

		/*
		 * (non-Javadoc)
		 * 
		 * @see org.eclipse.debug.ui.console.IConsoleHyperlink#linkExited()
		 */
		public void linkExited() {
		}

		/*
		 * (non-Javadoc)
		 * 
		 * @see org.eclipse.debug.ui.console.IConsoleHyperlink#linkActivated()
		 */
		public void linkActivated() {
			try {
				IFile[] files = ResourcesPlugin.getWorkspace().getRoot()
						.findFilesForLocation(fExternalPath);
				if (files.length > 0) {
					for (int i = 0; i < files.length; i++) {
						IFile curr = files[0];
						IEditorPart part = EditorUtility.openInEditor(curr,
								true);
						if (part != null) {
							if (part instanceof ITextEditor) {
								revealLine((ITextEditor) part, fLineNumber);
							}
							return;
						}
					}
				}
			} catch (BadLocationException e) {
				PHPLaunchingPlugin.log(e);
			} catch (PartInitException e) {
				PHPLaunchingPlugin.log(e);
			} catch (JavaModelException e) {
				PHPLaunchingPlugin.log(e);
			}
		}

		private void revealLine(ITextEditor editor, int lineNumber)
				throws BadLocationException {
			IDocument document = editor.getDocumentProvider().getDocument(
					editor.getEditorInput());
			IRegion region = document.getLineInformation(lineNumber - 1);
			editor.selectAndReveal(region.getOffset(), 0);
		}

	}

	private IConsole fConsole;

	public ConsoleLineTracker() {
		super();
	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see org.eclipse.debug.ui.console.IConsoleLineTracker#init(org.eclipse.debug.ui.console.IConsole)
	 */
	public void init(IConsole console) {
		fConsole = console;
	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see org.eclipse.debug.ui.console.IConsoleLineTracker#lineAppended(org.eclipse.jface.text.IRegion)
	 */
	public void lineAppended(IRegion line) {
		try {
			int offset = line.getOffset();
			int length = line.getLength();
			String text = fConsole.getDocument().get(offset, length);

			int index1 = text.indexOf(':');
			if (index1 == -1) {
				return;
			}

			int lineNumber = -1;
			IPath path = null;
			int index2 = text.indexOf(':', index1 + 1);
			while ((index2 != -1) && (path == null)) {
				if (index1 < index2) {
					try {
						String substr = text.substring(index1 + 1, index2);
						lineNumber = Integer.parseInt(substr);
						path = new Path(text.substring(0, index1));
					} catch (NumberFormatException e) {
						// ignore
					}
				}
				index1 = index2;
				index2 = text.indexOf(':', index1 + 1);
			}

			if (lineNumber != -1) {
				JavadocConsoleHyperLink link = new JavadocConsoleHyperLink(
						path, lineNumber);
				// TODO XXX Disabled for 3.1 fConsole.addLink(link,
				// line.getOffset(), index1);

			}
		} catch (BadLocationException e) {
			// ignore
		}
	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see org.eclipse.debug.ui.console.IConsoleLineTracker#dispose()
	 */
	public void dispose() {
		fConsole = null;
	}

}