applying code changes to fix ticket issue #637. You can now work with files and get...
[phpeclipse.git] / net.sourceforge.phpeclipse / src / net / sourceforge / phpeclipse / phpeditor / PHPTextHover.java
index 4d0aa94..bc388b1 100644 (file)
@@ -54,7 +54,8 @@ public class PHPTextHover implements ITextHover {
                if (hoverRegion != null) {
                        try {
                                if (hoverRegion.getLength() > -1) {
-                                       String word = textViewer.getDocument().get(hoverRegion.getOffset(), hoverRegion.getLength());
+                                       String word = textViewer.getDocument().get(
+                                                       hoverRegion.getOffset(), hoverRegion.getLength());
                                        if (functionDescriptions == null) {
                                                functionDescriptions = new HashMap();
                                                identDescriptions = new HashMap();
@@ -64,15 +65,19 @@ public class PHPTextHover implements ITextHover {
                                                        for (int i = 0; i < syntaxbuffer.size(); i++) {
                                                                elbuffer = (PHPElement) syntaxbuffer.get(i);
                                                                if (elbuffer instanceof PHPFunction) {
-                                                                       functionDescriptions.put(elbuffer.getName(), elbuffer.getHoverText());
+                                                                       functionDescriptions.put(
+                                                                                       elbuffer.getName(), elbuffer
+                                                                                                       .getHoverText());
                                                                } else {
-                                                                       identDescriptions.put(elbuffer.getName(), elbuffer.getHoverText());
+                                                                       identDescriptions.put(elbuffer.getName(),
+                                                                                       elbuffer.getHoverText());
                                                                }
                                                        }
                                                }
                                                //
                                                // while ((syntaxbuffer != null)
-                                               // && (!syntaxbuffer.isEmpty() && ((elbuffer = (PHPElement)
+                                               // && (!syntaxbuffer.isEmpty() && ((elbuffer =
+                                               // (PHPElement)
                                                // syntaxbuffer.remove(0)) != null))) {
                                                // functionDescriptions.put(elbuffer.getName(),
                                                // elbuffer.getHoverText());
@@ -80,11 +85,14 @@ public class PHPTextHover implements ITextHover {
                                        }
                                        String hoverInfo = (String) identDescriptions.get(word);
                                        if (hoverInfo == null & word.length() > 0) {
-                                               hoverInfo = (String) functionDescriptions.get(word.toLowerCase());
+                                               hoverInfo = (String) functionDescriptions.get(word
+                                                               .toLowerCase());
                                        }
                                        if (hoverInfo == null && fProject != null) {
-                                               // get the possible PHPDoc information from the index file
-                                               IdentifierIndexManager indexManager = PHPeclipsePlugin.getDefault().getIndexManager(fProject);
+                                               // get the possible PHPDoc information from the index
+                                               // file
+                                               IdentifierIndexManager indexManager = PHPeclipsePlugin
+                                                               .getDefault().getIndexManager(fProject);
                                                List list = indexManager.getLocations(word);
                                                if (list.size() > 0) {
                                                        try {
@@ -93,16 +101,22 @@ public class PHPTextHover implements ITextHover {
                                                                StringBuffer hoverInfoBuffer = new StringBuffer();
                                                                String workspaceLocation;
                                                                if (fProject != null) {
-                                                                       workspaceLocation = fProject.getLocation().toString() + '/';
+                                                                       workspaceLocation = fProject.getFullPath()
+                                                                                       .toString() + '/';
                                                                } else {
                                                                        // should never happen?
-                                                                       workspaceLocation = PHPeclipsePlugin.getWorkspace().getRoot().getLocation().toString();
+                                                                       workspaceLocation = PHPeclipsePlugin
+                                                                                       .getWorkspace().getRoot()
+                                                                                       .getFullPath().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);
+                                                                       location = (PHPIdentifierLocation) list
+                                                                                       .get(i);
+                                                                       filename = workspaceLocation
+                                                                                       + location.getFilename();
+                                                                       PHPDocUtil.appendPHPDoc(hoverInfoBuffer,
+                                                                                       filename, location);
                                                                }
                                                                hoverInfo = hoverInfoBuffer.toString();
                                                        } catch (Throwable e) {
@@ -126,9 +140,11 @@ public class PHPTextHover implements ITextHover {
         * (non-Javadoc) Method declared on ITextHover
         */
        public IRegion getHoverRegion(ITextViewer textViewer, int offset) {
-               Point selection = PHPWordExtractor.findWord(textViewer.getDocument(), 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)
+               if (selection != null && selection.x <= offset
+                               && offset < selection.x + selection.y)
                        return new Region(selection.x, selection.y);
                return new Region(offset, 0);
        }