X-Git-Url: http://git.phpeclipse.com diff --git a/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/phpeditor/PHPTextHover.java b/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/phpeditor/PHPTextHover.java index 071cb9f..032adf0 100644 --- a/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/phpeditor/PHPTextHover.java +++ b/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/phpeditor/PHPTextHover.java @@ -11,8 +11,19 @@ Contributors: **********************************************************************/ package net.sourceforge.phpeclipse.phpeditor; +import java.io.FileReader; +import java.util.HashMap; +import java.util.List; +import java.util.Vector; + +import net.sourceforge.phpdt.internal.corext.phpdoc.PHPDocCharArrayCommentReader; +import net.sourceforge.phpeclipse.PHPeclipsePlugin; +import net.sourceforge.phpeclipse.builder.IdentifierIndexManager; +import net.sourceforge.phpeclipse.builder.PHPIdentifierLocation; +import net.sourceforge.phpeclipse.phpeditor.php.PHPElement; import net.sourceforge.phpeclipse.phpeditor.php.PHPWordExtractor; -import org.eclipse.jface.text.BadLocationException; + +import org.eclipse.core.resources.IProject; import org.eclipse.jface.text.IRegion; import org.eclipse.jface.text.ITextHover; import org.eclipse.jface.text.ITextViewer; @@ -20,11 +31,21 @@ import org.eclipse.jface.text.Region; import org.eclipse.swt.graphics.Point; /** - * Example implementation for an ITextHover + * Implementation for an ITextHover * which hovers over PHP code. */ public class PHPTextHover implements ITextHover { + public static HashMap functionDescriptions = null; + private static PHPWordExtractor phpWordDetector = new PHPWordExtractor(); + /** + * The current project; maybe null for preference pages + */ + private IProject fProject; + + public PHPTextHover(IProject project) { + fProject = project; + } /* (non-Javadoc) * Method declared on ITextHover */ @@ -32,9 +53,69 @@ public class PHPTextHover implements ITextHover { if (hoverRegion != null) { try { if (hoverRegion.getLength() > -1) { - return textViewer.getDocument().get(hoverRegion.getOffset(), hoverRegion.getLength()); + String word = textViewer.getDocument().get(hoverRegion.getOffset(), hoverRegion.getLength()); + if (functionDescriptions == null) { + functionDescriptions = new HashMap(); + // PHPSyntaxRdr syntaxRdr = new PHPSyntaxRdr(); + // syntaxRdr.readInSyntax(); + + // Vector syntaxbuffer = syntaxRdr.getsyntaxdata(); + Vector syntaxbuffer = PHPSyntaxRdr.getsyntaxdata(); + String strbuffer = null; + PHPElement elbuffer = null; + while ((syntaxbuffer != null) + && (!syntaxbuffer.isEmpty() && ((elbuffer = (PHPElement) syntaxbuffer.remove(0)) != null))) { + functionDescriptions.put(elbuffer.getName(), elbuffer.getHoverText()); + } + + // functionDescriptions = new HashMap(997); + // for (int i=0; i 0) { + try { + PHPIdentifierLocation location; + String filename; + FileReader phpdocFileReader; + PHPDocCharArrayCommentReader phpdocConverter; + StringBuffer hoverInfoBuffer = new StringBuffer(); + String workspaceLocation = PHPeclipsePlugin.getWorkspace().getRoot().getLocation().toString(); + // boolean foundPHPdoc = false; + for (int i = 0; i < list.size(); i++) { + location = (PHPIdentifierLocation) list.get(i); + filename = workspaceLocation + location.getFilename(); + hoverInfoBuffer.append(location.toString()); + hoverInfoBuffer.append('\n'); + if (location.getPHPDocOffset() >= 0) { + // foundPHPdoc = true; + phpdocFileReader = new FileReader(filename); + char[] charArray = new char[location.getPHPDocLength()]; + phpdocFileReader.skip(location.getPHPDocOffset()); + phpdocFileReader.read(charArray, 0, location.getPHPDocLength()); + phpdocConverter = new PHPDocCharArrayCommentReader(charArray); + hoverInfoBuffer.append(phpdocConverter.getString()); + hoverInfoBuffer.append('\n'); + } + } + // if (foundPHPdoc) { + hoverInfo = hoverInfoBuffer.toString(); + // } + } catch (Throwable e) { + // ignore exceptions + // e.printStackTrace(); + } + } + } + return hoverInfo; } - } catch (BadLocationException x) { + // } catch (BadLocationException x) { + } catch (Exception x) { } } return "empty selection"; @@ -45,8 +126,8 @@ public class PHPTextHover implements ITextHover { */ public IRegion getHoverRegion(ITextViewer textViewer, int offset) { Point selection = PHPWordExtractor.findWord(textViewer.getDocument(), offset); -// show the extracted word as a tooltip - if (selection!=null && selection.x <= offset && offset < selection.x + selection.y) + // show the extracted word as a tooltip + if (selection != null && selection.x <= offset && offset < selection.x + selection.y) return new Region(selection.x, selection.y); return new Region(offset, 0); }