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..5271e47 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.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+
+import net.sourceforge.phpdt.internal.corext.phpdoc.PHPDocUtil;
+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,71 @@ 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();
+
+ ArrayList syntaxbuffer = PHPSyntaxRdr.getSyntaxData();
+ String strbuffer = null;
+ PHPElement elbuffer = null;
+ if (syntaxbuffer!=null) {
+ 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();
+ PHPDocUtil.appendPHPDoc(hoverInfoBuffer, filename, location);
+//
+// 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 +128,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);
}