|
|
@ -36,6 +36,8 @@ import java.awt.Color; |
|
|
|
import java.awt.Font; |
|
|
|
import java.awt.Font; |
|
|
|
import java.awt.Graphics; |
|
|
|
import java.awt.Graphics; |
|
|
|
import java.awt.event.KeyEvent; |
|
|
|
import java.awt.event.KeyEvent; |
|
|
|
|
|
|
|
import java.io.IOException; |
|
|
|
|
|
|
|
import java.io.StringReader; |
|
|
|
import java.util.logging.Level; |
|
|
|
import java.util.logging.Level; |
|
|
|
import java.util.logging.Logger; |
|
|
|
import java.util.logging.Logger; |
|
|
|
import javax.swing.ImageIcon; |
|
|
|
import javax.swing.ImageIcon; |
|
|
@ -68,7 +70,6 @@ import org.openide.util.ImageUtilities; |
|
|
|
public class AssetCompletionProvider implements CompletionProvider { |
|
|
|
public class AssetCompletionProvider implements CompletionProvider { |
|
|
|
|
|
|
|
|
|
|
|
private static final Logger logger = Logger.getLogger(AssetCompletionProvider.class.getName()); |
|
|
|
private static final Logger logger = Logger.getLogger(AssetCompletionProvider.class.getName()); |
|
|
|
|
|
|
|
|
|
|
|
private static ImageIcon assetIcon = |
|
|
|
private static ImageIcon assetIcon = |
|
|
|
new ImageIcon(ImageUtilities.loadImage("com/jme3/gde/core/assets/nodes/icons/assets.gif")); |
|
|
|
new ImageIcon(ImageUtilities.loadImage("com/jme3/gde/core/assets/nodes/icons/assets.gif")); |
|
|
|
private static ImageIcon modelIcon = |
|
|
|
private static ImageIcon modelIcon = |
|
|
@ -233,14 +234,40 @@ public class AssetCompletionProvider implements CompletionProvider { |
|
|
|
|
|
|
|
|
|
|
|
private boolean hasLastCommand(String line, String command) { |
|
|
|
private boolean hasLastCommand(String line, String command) { |
|
|
|
int idx = line.lastIndexOf(command); |
|
|
|
int idx = line.lastIndexOf(command); |
|
|
|
|
|
|
|
int brackState = 0; |
|
|
|
if (idx != -1) { |
|
|
|
if (idx != -1) { |
|
|
|
int bIdx = line.indexOf(")", idx); |
|
|
|
StringReader reader = null; |
|
|
|
if (bIdx == -1) { |
|
|
|
try { |
|
|
|
return true; |
|
|
|
line = line.substring(idx + command.length()); |
|
|
|
|
|
|
|
// logger.log(Level.INFO, "Search in command: {0}", line);
|
|
|
|
|
|
|
|
reader = new StringReader(line); |
|
|
|
|
|
|
|
int in = reader.read(); |
|
|
|
|
|
|
|
while (in != -1) { |
|
|
|
|
|
|
|
if (in == '(') { |
|
|
|
|
|
|
|
// logger.log(Level.INFO, "Found open bracket in command: {0}", line);
|
|
|
|
|
|
|
|
brackState++; |
|
|
|
|
|
|
|
} else if (in == ')') { |
|
|
|
|
|
|
|
// logger.log(Level.INFO, "Found close bracket in command: {0}", line);
|
|
|
|
|
|
|
|
brackState--; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
in = reader.read(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} catch (IOException ex) { |
|
|
|
|
|
|
|
Exceptions.printStackTrace(ex); |
|
|
|
|
|
|
|
} finally { |
|
|
|
|
|
|
|
if (reader != null) { |
|
|
|
|
|
|
|
reader.close(); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
brackState = -1; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (brackState == 0) { |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private ProjectAssetManager getProjectAssetManager(Document doc) { |
|
|
|
private ProjectAssetManager getProjectAssetManager(Document doc) { |
|
|
|
Object sdp = doc.getProperty(Document.StreamDescriptionProperty); |
|
|
|
Object sdp = doc.getProperty(Document.StreamDescriptionProperty); |
|
|
|