import net.sourceforge.phpdt.internal.ui.text.JavaColorManager;
import net.sourceforge.phpdt.internal.ui.text.phpdoc.PHPDocCodeScanner;
import net.sourceforge.phpeclipse.IPreferenceConstants;
-import net.sourceforge.phpeclipse.PHPeclipsePlugin;
import net.sourceforge.phpeclipse.phpeditor.php.HTMLPartitionScanner;
+import net.sourceforge.phpeclipse.phpeditor.php.PHPCodeScanner;
import net.sourceforge.phpeclipse.phpeditor.php.PHPDocumentPartitioner;
import net.sourceforge.phpeclipse.phpeditor.php.PHPPartitionScanner;
-import net.sourceforge.phpeclipse.phpeditor.php.PHPCodeScanner;
import net.sourceforge.phpeclipse.phpeditor.php.SmartyCodeScanner;
import net.sourceforge.phpeclipse.phpeditor.php.SmartyDocCodeScanner;
import net.sourceforge.phpeclipse.xml.ui.XMLPlugin;
-import net.sourceforge.phpeclipse.xml.ui.internal.text.SingleTokenScanner;
import net.sourceforge.phpeclipse.xml.ui.internal.text.XMLPartitionScanner;
import net.sourceforge.phpeclipse.xml.ui.text.XMLTextTools;
import org.eclipse.jface.text.IDocumentExtension3;
import org.eclipse.jface.text.IDocumentPartitioner;
import org.eclipse.jface.text.rules.DefaultPartitioner;
-import org.eclipse.jface.text.rules.IPartitionTokenScanner;
import org.eclipse.jface.text.rules.RuleBasedScanner;
-import org.eclipse.jface.text.rules.Token;
import org.eclipse.jface.util.IPropertyChangeListener;
import org.eclipse.jface.util.PropertyChangeEvent;
PHP_MULTILINE_COMMENT,
PHP_SINGLELINE_COMMENT,
PHP_STRING_DQ,
- PHP_STRING_SQ };
+ PHP_STRING_SQ,
+ PHP_STRING_HEREDOC};
- private static XMLPartitionScanner HTML_PARTITION_SCANNER = null;
+// private static XMLPartitionScanner HTML_PARTITION_SCANNER = null;
- private static FastJavaPartitionScanner PHP_PARTITION_SCANNER = null;
+// private static FastJavaPartitionScanner PHP_PARTITION_SCANNER = null;
private static HTMLPartitionScanner SMARTY_PARTITION_SCANNER = null;
- private static XMLPartitionScanner XML_PARTITION_SCANNER = null;
+// private static XMLPartitionScanner XML_PARTITION_SCANNER = null;
// private final static String[] TYPES= new String[] { PHPPartitionScanner.PHP, PHPPartitionScanner.JAVA_DOC,
// PHPPartitionScanner.JAVA_MULTILINE_COMMENT };
/** The Java singleline comment scanner */
private SingleTokenPHPScanner fSinglelineCommentScanner;
- /** The Java string scanner */
- private SingleTokenPHPScanner fStringScanner;
+ /** The PHP double quoted string scanner */
+// private SingleTokenPHPScanner fStringDQScanner;
+
+ /** The PHP single quoted string scanner */
+// private SingleTokenPHPScanner fStringSQScanner;
/** The PHPDoc scanner */
private PHPDocCodeScanner fPHPDocScanner;
/**
* The core preference store.
- *
+ *
* @since 2.1
*/
private Preferences fCorePreferenceStore;
// private RuleBasedScanner jspBracketScanner;
/**
* Creates a new Java text tools collection.
- *
+ *
* @param store
* the preference store to initialize the text tools. The text tool instance installs a listener on the passed preference
* store to adapt itself to changes in the preference store. In general <code>PreferenceConstants.
/**
* Creates a new Java text tools collection.
- *
+ *
* @param store
* the preference store to initialize the text tools. The text tool instance installs a listener on the passed preference
* store to adapt itself to changes in the preference store. In general <code>PreferenceConstants.
IPreferenceConstants.PHP_MULTILINE_COMMENT);
fSinglelineCommentScanner = new SingleTokenPHPScanner((JavaColorManager) colorManager, store,
IPreferenceConstants.PHP_SINGLELINE_COMMENT);
- fStringScanner = new SingleTokenPHPScanner((JavaColorManager) colorManager, store, IPreferenceConstants.PHP_STRING);
+// fStringDQScanner = new SingleTokenPHPScanner((JavaColorManager) colorManager, store, IPreferenceConstants.PHP_STRING);
+// fStringSQScanner = new SingleTokenPHPScanner((JavaColorManager) colorManager, store, IPreferenceConstants.PHP_STRING);
+
fPHPDocScanner = new PHPDocCodeScanner((JavaColorManager) colorManager, store);
// fHTMLScanner = new HTMLCodeScanner((JavaColorManager)fColorManager, store);
fSmartyScanner = new SmartyCodeScanner((JavaColorManager) colorManager, store);
}
/**
- *
+ *
*/
public XMLTextTools getXMLTextTools() {
return xmlTextTools;
fCodeScanner = null;
fMultilineCommentScanner = null;
fSinglelineCommentScanner = null;
- fStringScanner = null;
+// fStringDQScanner = null;
+// fStringSQScanner = null;
fPHPDocScanner = null;
// fPartitionScanner = null;
/**
* Returns the color manager which is used to manage any Java-specific colors needed for such things like syntax highlighting.
- *
+ *
* @return the color manager to be used for Java text viewers
*/
public JavaColorManager getColorManager() {
/**
* Returns a scanner which is configured to scan Java source code.
- *
+ *
* @return a Java source code scanner
*/
public RuleBasedScanner getCodeScanner() {
/**
* Returns a scanner which is configured to scan Java multiline comments.
- *
+ *
* @return a Java multiline comment scanner
- *
+ *
* @since 2.0
*/
public RuleBasedScanner getMultilineCommentScanner() {
/**
* Returns a scanner which is configured to scan HTML code.
- *
+ *
* @return a HTML scanner
- *
+ *
* @since 2.0
*/
// public RuleBasedScanner getHTMLScanner() {
// }
/**
* Returns a scanner which is configured to scan Smarty code.
- *
+ *
* @return a Smarty scanner
- *
+ *
* @since 2.0
*/
public RuleBasedScanner getSmartyScanner() {
/**
* Returns a scanner which is configured to scan Smarty code.
- *
+ *
* @return a Smarty scanner
- *
+ *
* @since 2.0
*/
public RuleBasedScanner getSmartyDocScanner() {
/**
* Returns a scanner which is configured to scan Java singleline comments.
- *
+ *
* @return a Java singleline comment scanner
- *
+ *
* @since 2.0
*/
public RuleBasedScanner getSinglelineCommentScanner() {
/**
* Returns a scanner which is configured to scan Java strings.
- *
+ *
* @return a Java string scanner
- *
+ *
* @since 2.0
*/
- public RuleBasedScanner getStringScanner() {
- return fStringScanner;
- }
+// public RuleBasedScanner getStringScanner() {
+// return fStringDQScanner;
+// }
/**
* Returns a scanner which is configured to scan JavaDoc compliant comments. Notes that the start sequence "/**" and the
* corresponding end sequence are part of the JavaDoc comment.
- *
+ *
* @return a JavaDoc scanner
*/
public RuleBasedScanner getJavaDocScanner() {
/**
* Returns a scanner which is configured to scan Java-specific partitions, which are multi-line comments, JavaDoc comments, and
* regular Java source code.
- *
+ *
* @return a Java partition scanner
*/
// public IPartitionTokenScanner getPartitionScanner() {
/**
* Factory method for creating a PHP-specific document partitioner using this object's partitions scanner. This method is a
* convenience method.
- *
+ *
* @return a newly created Java document partitioner
*/
public IDocumentPartitioner createDocumentPartitioner() {
/**
* Factory method for creating a PHP-specific document partitioner using this object's partitions scanner. This method is a
* convenience method.
- *
+ *
* @return a newly created Java document partitioner
*/
public IDocumentPartitioner createDocumentPartitioner(String extension) {
/**
* Sets up the Java document partitioner for the given document for the given partitioning.
- *
+ *
* @param document
* the document to be set up
* @param partitioning
* the document partitioning
* @param element
* TODO
- *
+ *
* @since 3.0
*/
// public void setupJavaDocumentPartitioner(IDocument document, String partitioning, Object element) {
/**
* Returns the names of the document position categories used by the document partitioners created by this object to manage their
* partition information. If the partitioners don't use document position categories, the returned result is <code>null</code>.
- *
+ *
* @return the partition managing position categories or <code>null</code> if there is none
*/
public String[] getPartitionManagingPositionCategories() {
/**
* Determines whether the preference change encoded by the given event changes the behavior of one its contained components.
- *
+ *
* @param event
* the event to be investigated
* @return <code>true</code> if event causes a behavioral change
// return fCodeScanner.affectsBehavior(event)
// || fMultilineCommentScanner.affectsBehavior(event)
// || fSinglelineCommentScanner.affectsBehavior(event)
- // || fStringScanner.affectsBehavior(event)
+ // || fStringDQScanner.affectsBehavior(event)
// || fPHPDocScanner.affectsBehavior(event);
// }
/**
* Adapts the behavior of the contained components to the change encoded in the given event.
- *
+ *
* @param event
* the event to which to adapt
* @since 2.0
fMultilineCommentScanner.adaptToPreferenceChange(event);
if (fSinglelineCommentScanner.affectsBehavior(event))
fSinglelineCommentScanner.adaptToPreferenceChange(event);
- // if (fStringScanner.affectsBehavior(event))
- // fStringScanner.adaptToPreferenceChange(event);
+ // if (fStringDQScanner.affectsBehavior(event))
+ // fStringDQScanner.adaptToPreferenceChange(event);
if (fPHPDocScanner.affectsBehavior(event))
fPHPDocScanner.adaptToPreferenceChange(event);
// if (fHTMLScanner.affectsBehavior(event))
}
private IDocumentPartitioner createJSPPartitioner() {
- return new PHPDocumentPartitioner(getJSPPartitionScanner(), getPHPPartitionScanner());
+ return new PHPDocumentPartitioner(getJSPPartitionScanner());
// return new JSPDocumentPartitioner(getJSPPartitionScanner(), jspScriptScanner);
}
/**
- *
+ *
*/
// public IPartitionTokenScanner getJSPScriptScanner() {
// return jspScriptScanner;
/**
* Returns a scanner which is configured to scan plain text in JSP.
- *
+ *
* @return a JSP text scanner
*/
// public RuleBasedScanner getJSPTextScanner() {
// }
/**
* Returns a scanner which is configured to scan plain text in JSP.
- *
+ *
* @return a JSP text scanner
*/
// public RuleBasedScanner getJSPBracketScanner() {
/**
* Return a scanner for creating xml partitions.
*/
- private static XMLPartitionScanner getXMLPartitionScanner() {
- // if (XML_PARTITION_SCANNER == null)
- // XML_PARTITION_SCANNER = new HTMLPartitionScanner(IPHPPartitions.XML_FILE);
- // return XML_PARTITION_SCANNER;
- if (XML_PARTITION_SCANNER == null)
- XML_PARTITION_SCANNER = new XMLPartitionScanner(false);
- return XML_PARTITION_SCANNER;
- }
+// private static XMLPartitionScanner getXMLPartitionScanner() {
+// // if (XML_PARTITION_SCANNER == null)
+// // XML_PARTITION_SCANNER = new HTMLPartitionScanner(IPHPPartitions.XML_FILE);
+// // return XML_PARTITION_SCANNER;
+// if (XML_PARTITION_SCANNER == null)
+// XML_PARTITION_SCANNER = new XMLPartitionScanner(false);
+// return XML_PARTITION_SCANNER;
+// }
private PHPPartitionScanner getJSPPartitionScanner() {
if (jspPartitionScanner == null)
/**
* Sets up the Java document partitioner for the given document for the default partitioning.
- *
+ *
* @param document
* the document to be set up
* @since 3.0
/**
* Sets up the Java document partitioner for the given document for the given partitioning.
- *
+ *
* @param document
* the document to be set up
* @param partitioning
/**
* Returns this text tool's preference store.
- *
+ *
* @return the preference store
* @since 3.0
*/
/**
* Returns this text tool's core preference store.
- *
+ *
* @return the core preference store
* @since 3.0
*/