1 /**********************************************************************
2 Copyright (c) 2000, 2002 IBM Corp. and others.
3 All rights reserved. This program and the accompanying materials
4 are made available under the terms of the Common Public License v1.0
5 which accompanies this distribution, and is available at
6 http://www.eclipse.org/legal/cpl-v10.html
9 IBM Corporation - Initial implementation
11 **********************************************************************/
12 package net.sourceforge.phpdt.ui.text;
14 import java.util.Vector;
16 import net.sourceforge.phpdt.core.JavaCore;
17 import net.sourceforge.phpdt.internal.ui.text.AbstractJavaScanner;
18 import net.sourceforge.phpdt.internal.ui.text.ContentAssistPreference;
19 import net.sourceforge.phpdt.internal.ui.text.HTMLTextPresenter;
20 import net.sourceforge.phpdt.internal.ui.text.IPHPPartitions;
21 import net.sourceforge.phpdt.internal.ui.text.JavaAnnotationHover;
22 import net.sourceforge.phpdt.internal.ui.text.JavaCompositeReconcilingStrategy;
23 import net.sourceforge.phpdt.internal.ui.text.JavaElementProvider;
24 import net.sourceforge.phpdt.internal.ui.text.JavaOutlineInformationControl;
25 import net.sourceforge.phpdt.internal.ui.text.JavaPresentationReconciler;
26 import net.sourceforge.phpdt.internal.ui.text.JavaReconciler;
27 import net.sourceforge.phpdt.internal.ui.text.PreferencesAdapter;
28 import net.sourceforge.phpdt.internal.ui.text.java.JavaFormattingStrategy;
29 import net.sourceforge.phpdt.internal.ui.text.java.JavaStringAutoIndentStrategyDQ;
30 import net.sourceforge.phpdt.internal.ui.text.java.JavaStringAutoIndentStrategySQ;
31 import net.sourceforge.phpdt.internal.ui.text.java.hover.JavaEditorTextHoverDescriptor;
32 import net.sourceforge.phpdt.internal.ui.text.java.hover.JavaEditorTextHoverProxy;
33 import net.sourceforge.phpdt.internal.ui.text.java.hover.JavaInformationProvider;
34 import net.sourceforge.phpdt.internal.ui.text.phpdoc.JavaDocAutoIndentStrategy;
35 import net.sourceforge.phpdt.internal.ui.text.phpdoc.PHPDocCodeScanner;
36 import net.sourceforge.phpdt.internal.ui.text.phpdoc.PHPDocCompletionProcessor;
37 import net.sourceforge.phpdt.ui.PreferenceConstants;
38 import net.sourceforge.phpeclipse.IPreferenceConstants;
39 import net.sourceforge.phpeclipse.PHPeclipsePlugin;
40 import net.sourceforge.phpeclipse.phpeditor.html.HTMLFormattingStrategy;
41 import net.sourceforge.phpeclipse.phpeditor.php.HTMLCompletionProcessor;
42 import net.sourceforge.phpeclipse.phpeditor.php.PHPAutoIndentStrategy;
43 import net.sourceforge.phpeclipse.phpeditor.php.PHPCodeScanner;
44 import net.sourceforge.phpeclipse.phpeditor.php.PHPCompletionProcessor;
45 import net.sourceforge.phpeclipse.phpeditor.php.PHPDocumentPartitioner;
46 import net.sourceforge.phpeclipse.phpeditor.php.PHPDoubleClickSelector;
47 import net.sourceforge.phpeclipse.phpeditor.php.PHPPartitionScanner;
48 import net.sourceforge.phpeclipse.xml.ui.XMLPlugin;
49 import net.sourceforge.phpeclipse.xml.ui.internal.text.XMLConfiguration;
50 import net.sourceforge.phpeclipse.xml.ui.internal.text.XMLPartitionScanner;
51 import net.sourceforge.phpeclipse.xml.ui.text.XMLTextTools;
53 import org.eclipse.core.runtime.NullProgressMonitor;
54 import org.eclipse.jface.preference.IPreferenceStore;
55 import org.eclipse.jface.text.DefaultAutoIndentStrategy;
56 import org.eclipse.jface.text.DefaultInformationControl;
57 import org.eclipse.jface.text.IAutoIndentStrategy;
58 import org.eclipse.jface.text.IDocument;
59 import org.eclipse.jface.text.IInformationControl;
60 import org.eclipse.jface.text.IInformationControlCreator;
61 import org.eclipse.jface.text.ITextDoubleClickStrategy;
62 import org.eclipse.jface.text.ITextHover;
63 import org.eclipse.jface.text.ITextViewerExtension2;
64 import org.eclipse.jface.text.TextAttribute;
65 import org.eclipse.jface.text.contentassist.ContentAssistant;
66 import org.eclipse.jface.text.contentassist.IContentAssistProcessor;
67 import org.eclipse.jface.text.contentassist.IContentAssistant;
68 import org.eclipse.jface.text.formatter.ContentFormatter;
69 import org.eclipse.jface.text.formatter.IContentFormatter;
70 import org.eclipse.jface.text.formatter.IFormattingStrategy;
71 import org.eclipse.jface.text.information.IInformationPresenter;
72 import org.eclipse.jface.text.information.IInformationProvider;
73 import org.eclipse.jface.text.information.InformationPresenter;
74 import org.eclipse.jface.text.presentation.IPresentationDamager;
75 import org.eclipse.jface.text.presentation.IPresentationReconciler;
76 import org.eclipse.jface.text.presentation.IPresentationRepairer;
77 import org.eclipse.jface.text.presentation.PresentationReconciler;
78 import org.eclipse.jface.text.reconciler.IReconciler;
79 import org.eclipse.jface.text.rules.BufferedRuleBasedScanner;
80 import org.eclipse.jface.text.rules.DefaultDamagerRepairer;
81 import org.eclipse.jface.text.rules.DefaultPartitioner;
82 import org.eclipse.jface.text.rules.RuleBasedScanner;
83 import org.eclipse.jface.text.rules.Token;
84 import org.eclipse.jface.text.source.IAnnotationHover;
85 import org.eclipse.jface.text.source.ISourceViewer;
86 import org.eclipse.jface.text.source.SourceViewerConfiguration;
87 import org.eclipse.jface.util.Assert;
88 import org.eclipse.jface.util.PropertyChangeEvent;
89 import org.eclipse.swt.SWT;
90 import org.eclipse.swt.widgets.Shell;
91 import org.eclipse.ui.editors.text.EditorsUI;
92 import org.eclipse.ui.texteditor.ChainedPreferenceStore;
93 import org.eclipse.ui.texteditor.ITextEditor;
96 * Configuration for an <code>SourceViewer</code> which shows PHP code.
98 public class PHPSourceViewerConfiguration extends SourceViewerConfiguration {
100 * Preference key used to look up display tab width.
104 public final static String PREFERENCE_TAB_WIDTH = PreferenceConstants.EDITOR_TAB_WIDTH;
107 * Preference key for inserting spaces rather than tabs.
111 public final static String SPACES_FOR_TABS = PreferenceConstants.EDITOR_SPACES_FOR_TABS;
113 // public static final String HTML_DEFAULT =
114 // IPHPPartitionScannerConstants.HTML;
115 //IDocument.DEFAULT_CONTENT_TYPE;
116 private JavaTextTools fJavaTextTools;
118 private ITextEditor fTextEditor;
121 * The document partitioning.
125 private String fDocumentPartitioning;
127 private ContentFormatter fFormatter;
129 private HTMLFormattingStrategy fFormattingStrategy;
132 * Single token scanner.
134 static class SingleTokenScanner extends BufferedRuleBasedScanner {
135 public SingleTokenScanner(TextAttribute attribute) {
136 setDefaultReturnToken(new Token(attribute));
141 * The document partitioning.
145 // private String fDocumentPartitioning;
147 * The Java source code scanner
151 private AbstractJavaScanner fCodeScanner;
154 * The Java multi-line comment scanner
158 private AbstractJavaScanner fMultilineCommentScanner;
161 * The Java single-line comment scanner
165 private AbstractJavaScanner fSinglelineCommentScanner;
168 * The Java string scanner
172 private AbstractJavaScanner fStringScanner;
175 * The Javadoc scanner
179 private AbstractJavaScanner fJavaDocScanner;
182 * The preference store, can be read-only
186 private IPreferenceStore fPreferenceStore;
193 private IColorManager fColorManager;
195 private XMLTextTools fXMLTextTools;
197 private XMLConfiguration xmlConfiguration;
200 * Creates a new Java source viewer configuration for viewers in the given editor using the given preference store, the color
201 * manager and the specified document partitioning.
203 * Creates a Java source viewer configuration in the new setup without text tools. Clients are allowed to call
204 * {@link JavaSourceViewerConfiguration#handlePropertyChangeEvent(PropertyChangeEvent)}and disallowed to call
205 * {@link JavaSourceViewerConfiguration#getPreferenceStore()}on the resulting Java source viewer configuration.
208 * @param colorManager
210 * @param preferenceStore
211 * the preference store, can be read-only
213 * the editor in which the configured viewer(s) will reside
214 * @param partitioning
215 * the document partitioning for this configuration
218 public PHPSourceViewerConfiguration(IColorManager colorManager, IPreferenceStore preferenceStore, ITextEditor editor,
219 String partitioning) {
220 fColorManager = colorManager;
221 fPreferenceStore = preferenceStore;
222 fTextEditor = editor;
223 fDocumentPartitioning = partitioning;
224 // fJavaTextTools = PHPeclipsePlugin.getDefault().getJavaTextTools();
225 fXMLTextTools = XMLPlugin.getDefault().getXMLTextTools();
226 xmlConfiguration = new XMLConfiguration(fXMLTextTools);
227 fColorManager = colorManager;
228 fPreferenceStore = preferenceStore;
229 fTextEditor = editor;
230 fDocumentPartitioning = partitioning;
232 initializeScanners();
236 * Creates a new Java source viewer configuration for viewers in the given editor using the given Java tools.
239 * the Java text tools to be used
241 * the editor in which the configured viewer(s) will reside
243 * @deprecated As of 3.0, replaced by
244 * {@link JavaSourceViewerConfiguration#JavaSourceViewerConfiguration(IColorManager, IPreferenceStore, ITextEditor, String)}
246 // public PHPSourceViewerConfiguration(JavaTextTools tools, PHPEditor editor, String partitioning) {
247 // fJavaTextTools = tools;
248 // fColorManager = tools.getColorManager();
249 // fPreferenceStore = createPreferenceStore();
250 // fDocumentPartitioning = partitioning;
251 // fCodeScanner = (AbstractJavaScanner) fJavaTextTools.getCodeScanner();
252 // fMultilineCommentScanner = (AbstractJavaScanner) fJavaTextTools.getMultilineCommentScanner();
253 // fSinglelineCommentScanner = (AbstractJavaScanner) fJavaTextTools.getSinglelineCommentScanner();
254 // fStringScanner = (AbstractJavaScanner) fJavaTextTools.getStringScanner();
255 // fJavaDocScanner = (AbstractJavaScanner) fJavaTextTools.getJavaDocScanner();
256 // fTextEditor = editor;
257 // fXMLTextTools = XMLPlugin.getDefault().getXMLTextTools();
258 // xmlConfiguration = new XMLConfiguration(fXMLTextTools);
261 * Returns the color manager for this configuration.
263 * @return the color manager
265 protected IColorManager getColorManager() {
266 return fColorManager;
270 * Initializes the scanners.
274 private void initializeScanners() {
275 Assert.isTrue(isNewSetup());
276 fCodeScanner = new PHPCodeScanner(getColorManager(), fPreferenceStore);
277 fMultilineCommentScanner = new SingleTokenPHPScanner(getColorManager(), fPreferenceStore,
278 IPreferenceConstants.PHP_MULTILINE_COMMENT);
279 fSinglelineCommentScanner = new SingleTokenPHPScanner(getColorManager(), fPreferenceStore,
280 IPreferenceConstants.PHP_SINGLELINE_COMMENT);
281 fStringScanner = new SingleTokenPHPScanner(getColorManager(), fPreferenceStore, IPreferenceConstants.PHP_STRING);
282 fJavaDocScanner = new PHPDocCodeScanner(getColorManager(), fPreferenceStore);
286 * Determines whether the preference change encoded by the given event changes the behavior of one of its contained components.
289 * the event to be investigated
290 * @return <code>true</code> if event causes a behavioral change
293 public boolean affectsTextPresentation(PropertyChangeEvent event) {
294 return fCodeScanner.affectsBehavior(event) || fMultilineCommentScanner.affectsBehavior(event)
295 || fSinglelineCommentScanner.affectsBehavior(event) || fStringScanner.affectsBehavior(event)
296 || fJavaDocScanner.affectsBehavior(event);
300 * Adapts the behavior of the contained components to the change encoded in the given event.
302 * Clients are not allowed to call this method if the old setup with text tools is in use.
306 * the event to which to adapt
307 * @see JavaSourceViewerConfiguration#JavaSourceViewerConfiguration(IColorManager, IPreferenceStore, ITextEditor, String)
310 public void handlePropertyChangeEvent(PropertyChangeEvent event) {
311 Assert.isTrue(isNewSetup());
312 if (fCodeScanner.affectsBehavior(event))
313 fCodeScanner.adaptToPreferenceChange(event);
314 if (fMultilineCommentScanner.affectsBehavior(event))
315 fMultilineCommentScanner.adaptToPreferenceChange(event);
316 if (fSinglelineCommentScanner.affectsBehavior(event))
317 fSinglelineCommentScanner.adaptToPreferenceChange(event);
318 if (fStringScanner.affectsBehavior(event))
319 fStringScanner.adaptToPreferenceChange(event);
320 if (fJavaDocScanner.affectsBehavior(event))
321 fJavaDocScanner.adaptToPreferenceChange(event);
325 * @see SourceViewerConfiguration#getContentFormatter(ISourceViewer)
327 public IContentFormatter getContentFormatter(ISourceViewer sourceViewer) {
328 // if (fFormatter == null) {
329 // fFormatter = new ContentFormatter();
330 // fFormattingStrategy = new HTMLFormattingStrategy(this,
332 // fFormatter.setFormattingStrategy(fFormattingStrategy, HTML_DEFAULT);
333 // fFormatter.enablePartitionAwareFormatting(false);
334 // fFormatter.setPartitionManagingPositionCategories(getConfiguredContentTypes(null));
336 // return fFormatter;
337 if (fFormatter == null) {
339 fFormatter = new ContentFormatter();
340 IFormattingStrategy strategy = new JavaFormattingStrategy(sourceViewer);
341 fFormatter.setFormattingStrategy(strategy, IDocument.DEFAULT_CONTENT_TYPE);
342 fFormatter.enablePartitionAwareFormatting(false);
343 fFormatter.setPartitionManagingPositionCategories(getPartitionManagingPositionCategories());
349 * Returns the names of the document position categories used by the document partitioners created by this object to manage their
350 * partition information. If the partitioners don't use document position categories, the returned result is <code>null</code>.
352 * @return the partition managing position categories or <code>null</code> if there is none
354 public String[] getPartitionManagingPositionCategories() {
355 return new String[] { DefaultPartitioner.CONTENT_TYPES_CATEGORY };
359 // * Returns the names of the document position categories used by the
361 // * partitioners created by this object to manage their partition
363 // * If the partitioners don't use document position categories, the
365 // * result is <code>null</code>.
367 // * @return the partition managing position categories or
369 // * if there is none
371 // private String[] getPartitionManagingPositionCategories() {
372 // return new String[] { DefaultPartitioner.CONTENT_TYPES_CATEGORY };
374 public ITextEditor getEditor() {
379 * Returns the preference store used by this configuration to initialize the individual bits and pieces.
381 * @return the preference store used to initialize this configuration
385 protected IPreferenceStore getPreferenceStore() {
386 return PHPeclipsePlugin.getDefault().getPreferenceStore();
390 // * Method declared on SourceViewerConfiguration
392 // public IAnnotationHover getAnnotationHover(ISourceViewer sourceViewer) {
393 // return new PHPAnnotationHover();
396 * @see SourceViewerConfiguration#getAnnotationHover(ISourceViewer)
398 public IAnnotationHover getAnnotationHover(ISourceViewer sourceViewer) {
399 return new JavaAnnotationHover(JavaAnnotationHover.VERTICAL_RULER_HOVER);
403 * @see SourceViewerConfiguration#getOverviewRulerAnnotationHover(ISourceViewer)
406 public IAnnotationHover getOverviewRulerAnnotationHover(ISourceViewer sourceViewer) {
407 return new JavaAnnotationHover(JavaAnnotationHover.OVERVIEW_RULER_HOVER);
411 * (non-Javadoc) Method declared on SourceViewerConfiguration
413 public IAutoIndentStrategy getAutoIndentStrategy(ISourceViewer sourceViewer, String contentType) {
414 if (IPHPPartitions.PHP_PHPDOC_COMMENT.equals(contentType)
415 || IPHPPartitions.PHP_MULTILINE_COMMENT.equals(contentType))
416 return new JavaDocAutoIndentStrategy(getConfiguredDocumentPartitioning(sourceViewer));
417 if (IPHPPartitions.PHP_STRING_DQ.equals(contentType))
418 return new JavaStringAutoIndentStrategyDQ(getConfiguredDocumentPartitioning(sourceViewer));
419 if (IPHPPartitions.PHP_STRING_SQ.equals(contentType))
420 return new JavaStringAutoIndentStrategySQ(getConfiguredDocumentPartitioning(sourceViewer));
422 return (PHPDocumentPartitioner.PHP_TEMPLATE_DATA.equals(contentType)
423 || PHPDocumentPartitioner.PHP_SCRIPT_CODE.equals(contentType) || IDocument.DEFAULT_CONTENT_TYPE.equals(contentType)
424 || IPHPPartitions.PHP_PARTITIONING.equals(contentType) || PHPPartitionScanner.PHP_SCRIPTING_AREA.equals(contentType) ? new PHPAutoIndentStrategy()
425 : new DefaultAutoIndentStrategy());
429 * Returns the PHP source code scanner for this configuration.
431 * @return the PHP source code scanner
433 protected RuleBasedScanner getCodeScanner() {
434 return fCodeScanner; //fJavaTextTools.getCodeScanner();
438 * Returns the Java multi-line comment scanner for this configuration.
440 * @return the Java multi-line comment scanner
443 protected RuleBasedScanner getMultilineCommentScanner() {
444 return fMultilineCommentScanner;
448 * Returns the Java single-line comment scanner for this configuration.
450 * @return the Java single-line comment scanner
453 protected RuleBasedScanner getSinglelineCommentScanner() {
454 return fSinglelineCommentScanner;
458 * Returns the Java string scanner for this configuration.
460 * @return the Java string scanner
463 protected RuleBasedScanner getStringScanner() {
464 return fStringScanner;
468 * Returns the HTML source code scanner for this configuration.
470 * @return the HTML source code scanner
472 // protected RuleBasedScanner getHTMLScanner() {
473 // return fJavaTextTools.getHTMLScanner();
476 * Returns the Smarty source code scanner for this configuration.
478 * @return the Smarty source code scanner
480 // protected RuleBasedScanner getSmartyScanner() {
481 // return fJavaTextTools.getSmartyScanner();
484 * @see SourceViewerConfiguration#getReconciler(ISourceViewer)
487 * @see SourceViewerConfiguration#getReconciler(ISourceViewer)
489 public IReconciler getReconciler(ISourceViewer sourceViewer) {
491 final ITextEditor editor = getEditor();
492 if (editor != null && editor.isEditable()) {
494 JavaCompositeReconcilingStrategy strategy = new JavaCompositeReconcilingStrategy(editor,
495 getConfiguredDocumentPartitioning(sourceViewer));
496 JavaReconciler reconciler = new JavaReconciler(editor, strategy, false);
497 reconciler.setIsIncrementalReconciler(false);
498 reconciler.setProgressMonitor(new NullProgressMonitor());
499 reconciler.setDelay(500);
507 * @see SourceViewerConfiguration#getConfiguredTextHoverStateMasks(ISourceViewer, String)
510 public int[] getConfiguredTextHoverStateMasks(ISourceViewer sourceViewer, String contentType) {
511 JavaEditorTextHoverDescriptor[] hoverDescs = PHPeclipsePlugin.getDefault().getJavaEditorTextHoverDescriptors();
512 int stateMasks[] = new int[hoverDescs.length];
513 int stateMasksLength = 0;
514 for (int i = 0; i < hoverDescs.length; i++) {
515 if (hoverDescs[i].isEnabled()) {
517 int stateMask = hoverDescs[i].getStateMask();
518 while (j < stateMasksLength) {
519 if (stateMasks[j] == stateMask)
523 if (j == stateMasksLength)
524 stateMasks[stateMasksLength++] = stateMask;
527 if (stateMasksLength == hoverDescs.length)
529 int[] shortenedStateMasks = new int[stateMasksLength];
530 System.arraycopy(stateMasks, 0, shortenedStateMasks, 0, stateMasksLength);
531 return shortenedStateMasks;
535 * @see SourceViewerConfiguration#getTextHover(ISourceViewer, String, int)
538 public ITextHover getTextHover(ISourceViewer sourceViewer, String contentType, int stateMask) {
539 JavaEditorTextHoverDescriptor[] hoverDescs = PHPeclipsePlugin.getDefault().getJavaEditorTextHoverDescriptors();
541 while (i < hoverDescs.length) {
542 if (hoverDescs[i].isEnabled() && hoverDescs[i].getStateMask() == stateMask)
543 return new JavaEditorTextHoverProxy(hoverDescs[i], getEditor());
547 // if (fEditor != null) {
548 // IEditorInput editorInput = fEditor.getEditorInput();
549 // if (editorInput instanceof IFileEditorInput) {
551 // IFile f = ((IFileEditorInput) editorInput).getFile();
552 // return new PHPTextHover(f.getProject());
553 // } catch (NullPointerException e) {
554 // // this exception occurs, if getTextHover is called by
555 // // preference pages !
559 // return new PHPTextHover(null);
563 * @see SourceViewerConfiguration#getTextHover(ISourceViewer, String)
565 public ITextHover getTextHover(ISourceViewer sourceViewer, String contentType) {
566 return getTextHover(sourceViewer, contentType, ITextViewerExtension2.DEFAULT_HOVER_STATE_MASK);
570 * Returns the SmartyDoc source code scanner for this configuration.
572 * @return the SmartyDoc source code scanner
574 // protected RuleBasedScanner getSmartyDocScanner() {
575 // return fJavaTextTools.getSmartyDocScanner();
578 * Returns the PHPDoc source code scanner for this configuration.
580 * @return the PHPDoc source code scanner
582 protected RuleBasedScanner getPHPDocScanner() {
583 return fJavaDocScanner; //fJavaTextTools.getJavaDocScanner();
587 * (non-Javadoc) Method declared on SourceViewerConfiguration
589 public String[] getConfiguredContentTypes(ISourceViewer sourceViewer) {
590 return new String[] { IDocument.DEFAULT_CONTENT_TYPE, PHPPartitionScanner.PHP_SCRIPTING_AREA,
592 IPHPPartitions.HTML, IPHPPartitions.HTML_MULTILINE_COMMENT, IPHPPartitions.PHP_PARTITIONING,
593 IPHPPartitions.PHP_SINGLELINE_COMMENT, IPHPPartitions.PHP_MULTILINE_COMMENT, IPHPPartitions.PHP_PHPDOC_COMMENT,
594 IPHPPartitions.PHP_STRING_DQ, IPHPPartitions.PHP_STRING_SQ, IPHPPartitions.CSS, IPHPPartitions.CSS_MULTILINE_COMMENT,
595 IPHPPartitions.JAVASCRIPT, IPHPPartitions.JS_MULTILINE_COMMENT, IPHPPartitions.SMARTY,
596 IPHPPartitions.SMARTY_MULTILINE_COMMENT,
598 XMLPartitionScanner.XML_PI, XMLPartitionScanner.XML_COMMENT, XMLPartitionScanner.XML_DECL, XMLPartitionScanner.XML_TAG,
599 XMLPartitionScanner.XML_ATTRIBUTE, XMLPartitionScanner.XML_CDATA,
601 XMLPartitionScanner.DTD_INTERNAL, XMLPartitionScanner.DTD_INTERNAL_PI, XMLPartitionScanner.DTD_INTERNAL_COMMENT,
602 XMLPartitionScanner.DTD_INTERNAL_DECL,
604 PHPDocumentPartitioner.PHP_TEMPLATE_DATA, PHPDocumentPartitioner.PHP_SCRIPT_CODE };
607 public String[] getConfiguredHTMLContentTypes() {
608 return new String[] { XMLPartitionScanner.XML_PI, XMLPartitionScanner.XML_COMMENT, XMLPartitionScanner.XML_DECL,
609 XMLPartitionScanner.XML_TAG, XMLPartitionScanner.XML_ATTRIBUTE, XMLPartitionScanner.XML_CDATA,
611 XMLPartitionScanner.DTD_INTERNAL, XMLPartitionScanner.DTD_INTERNAL_PI, XMLPartitionScanner.DTD_INTERNAL_COMMENT,
612 XMLPartitionScanner.DTD_INTERNAL_DECL, };
615 public String[] getConfiguredPHPContentTypes() {
616 return new String[] { IDocument.DEFAULT_CONTENT_TYPE, IPHPPartitions.PHP_PARTITIONING, IPHPPartitions.PHP_SINGLELINE_COMMENT,
617 IPHPPartitions.PHP_MULTILINE_COMMENT, IPHPPartitions.PHP_PHPDOC_COMMENT, IPHPPartitions.PHP_STRING_DQ,
618 IPHPPartitions.PHP_STRING_SQ, IPHPPartitions.CSS, IPHPPartitions.CSS_MULTILINE_COMMENT, IPHPPartitions.JAVASCRIPT,
619 IPHPPartitions.JS_MULTILINE_COMMENT, IPHPPartitions.SMARTY, IPHPPartitions.SMARTY_MULTILINE_COMMENT, };
623 * @see org.eclipse.jface.text.source.SourceViewerConfiguration#getConfiguredDocumentPartitioning(org.eclipse.jface.text.source.ISourceViewer)
626 public String getConfiguredDocumentPartitioning(ISourceViewer sourceViewer) {
627 if (fDocumentPartitioning != null)
628 return fDocumentPartitioning;
629 return super.getConfiguredDocumentPartitioning(sourceViewer);
633 * (non-Javadoc) Method declared on SourceViewerConfiguration
635 public IContentAssistant getContentAssistant(ISourceViewer sourceViewer) {
636 ContentAssistant assistant = new ContentAssistant();
637 IContentAssistProcessor processor = new HTMLCompletionProcessor(getEditor());
638 assistant.setDocumentPartitioning(getConfiguredDocumentPartitioning(sourceViewer));
639 assistant.setContentAssistProcessor(processor, IPHPPartitions.HTML);
640 assistant.setContentAssistProcessor(processor, IPHPPartitions.HTML_MULTILINE_COMMENT);
642 assistant.setContentAssistProcessor(processor, IPHPPartitions.CSS);
643 assistant.setContentAssistProcessor(processor, IPHPPartitions.CSS_MULTILINE_COMMENT);
644 assistant.setContentAssistProcessor(processor, IPHPPartitions.JAVASCRIPT);
645 assistant.setContentAssistProcessor(processor, IPHPPartitions.JS_MULTILINE_COMMENT);
646 // TODO define special smarty partition content assist
647 assistant.setContentAssistProcessor(processor, IPHPPartitions.SMARTY);
648 assistant.setContentAssistProcessor(processor, IPHPPartitions.SMARTY_MULTILINE_COMMENT);
650 assistant.setContentAssistProcessor(processor, PHPDocumentPartitioner.PHP_TEMPLATE_DATA);
651 String[] htmlTypes = getConfiguredHTMLContentTypes();
652 for (int i = 0; i < htmlTypes.length; i++) {
653 assistant.setContentAssistProcessor(processor, htmlTypes[i]);
655 processor = new PHPCompletionProcessor(getEditor());
657 assistant.setContentAssistProcessor(processor, PHPDocumentPartitioner.PHP_SCRIPT_CODE);
658 assistant.setContentAssistProcessor(processor, IPHPPartitions.PHP_PARTITIONING);
659 assistant.setContentAssistProcessor(processor, IPHPPartitions.PHP_STRING_DQ);
660 assistant.setContentAssistProcessor(processor, IPHPPartitions.PHP_STRING_SQ);
662 assistant.setContentAssistProcessor(new PHPDocCompletionProcessor(getEditor()), IPHPPartitions.PHP_PHPDOC_COMMENT);
663 // assistant.enableAutoActivation(true);
664 // assistant.setAutoActivationDelay(500);
665 // assistant.setProposalPopupOrientation(ContentAssistant.PROPOSAL_OVERLAY);
666 // ContentAssistPreference.configure(assistant, getPreferenceStore());
667 // assistant.setContextInformationPopupOrientation(
668 // ContentAssistant.CONTEXT_INFO_ABOVE);
669 // assistant.setContextInformationPopupBackground(
670 // PHPEditorEnvironment.getPHPColorProvider().getColor(
671 // new RGB(150, 150, 0)));
672 ContentAssistPreference.configure(assistant, getPreferenceStore());
673 assistant.setContextInformationPopupOrientation(ContentAssistant.CONTEXT_INFO_ABOVE);
674 assistant.setInformationControlCreator(getInformationControlCreator(sourceViewer));
679 * (non-Javadoc) Method declared on SourceViewerConfiguration
681 // public String getDefaultPrefix(ISourceViewer sourceViewer, String
683 // return (PHPPartitionScanner.PHP.equals(contentType) ? "//" : null);
685 // // return (IDocument.DEFAULT_CONTENT_TYPE.equals(contentType) ? "//" :
686 // null); //$NON-NLS-1$
689 * @see SourceViewerConfiguration#getDefaultPrefix(ISourceViewer, String)
692 public String[] getDefaultPrefixes(ISourceViewer sourceViewer, String contentType) {
693 return new String[] { "//", "" }; //$NON-NLS-1$ //$NON-NLS-2$
697 * (non-Javadoc) Method declared on SourceViewerConfiguration
699 public ITextDoubleClickStrategy getDoubleClickStrategy(ISourceViewer sourceViewer, String contentType) {
700 return new PHPDoubleClickSelector();
704 * @see SourceViewerConfiguration#getIndentPrefixes(ISourceViewer, String)
706 public String[] getIndentPrefixes(ISourceViewer sourceViewer, String contentType) {
707 Vector vector = new Vector();
708 // prefix[0] is either '\t' or ' ' x tabWidth, depending on useSpaces
709 final IPreferenceStore preferences = PHPeclipsePlugin.getDefault().getPreferenceStore();
710 int tabWidth = preferences.getInt(JavaCore.FORMATTER_TAB_SIZE);
711 boolean useSpaces = getPreferenceStore().getBoolean(SPACES_FOR_TABS);
712 for (int i = 0; i <= tabWidth; i++) {
713 StringBuffer prefix = new StringBuffer();
715 for (int j = 0; j + i < tabWidth; j++)
720 for (int j = 0; j < i; j++)
725 vector.add(prefix.toString());
727 vector.add(""); //$NON-NLS-1$
728 return (String[]) vector.toArray(new String[vector.size()]);
732 * @return <code>true</code> iff the new setup without text tools is in use.
736 private boolean isNewSetup() {
737 return fJavaTextTools == null;
741 * Creates and returns a preference store which combines the preference stores from the text tools and which is read-only.
743 * @return the read-only preference store
746 private IPreferenceStore createPreferenceStore() {
747 Assert.isTrue(!isNewSetup());
748 IPreferenceStore generalTextStore = EditorsUI.getPreferenceStore();
749 if (fJavaTextTools.getCorePreferenceStore() == null)
750 return new ChainedPreferenceStore(new IPreferenceStore[] { fJavaTextTools.getPreferenceStore(), generalTextStore });
752 return new ChainedPreferenceStore(new IPreferenceStore[] { fJavaTextTools.getPreferenceStore(),
753 new PreferencesAdapter(fJavaTextTools.getCorePreferenceStore()), generalTextStore });
757 * (non-Javadoc) Method declared on SourceViewerConfiguration
759 public IPresentationReconciler getPresentationReconciler(ISourceViewer sourceViewer) {
760 // PHPColorProvider provider =
761 // PHPEditorEnvironment.getPHPColorProvider();
762 // JavaColorManager provider =
763 // PHPEditorEnvironment.getPHPColorProvider();
764 PresentationReconciler phpReconciler = new JavaPresentationReconciler();
765 phpReconciler.setDocumentPartitioning(getConfiguredDocumentPartitioning(sourceViewer));
767 // DefaultDamagerRepairer dr = new DefaultDamagerRepairer(getHTMLScanner());
768 // reconciler.setDamager(dr, IDocument.DEFAULT_CONTENT_TYPE);
769 // reconciler.setRepairer(dr, IDocument.DEFAULT_CONTENT_TYPE);
770 // dr = new DefaultDamagerRepairer(getHTMLScanner());
771 // reconciler.setDamager(dr, IPHPPartitions.HTML);
772 // reconciler.setRepairer(dr, IPHPPartitions.HTML);
773 // dr = new DefaultDamagerRepairer(getHTMLScanner());
774 // reconciler.setDamager(dr, IPHPPartitions.CSS);
775 // reconciler.setRepairer(dr, IPHPPartitions.CSS);
776 // dr = new DefaultDamagerRepairer(getHTMLScanner());
777 // reconciler.setDamager(dr, IPHPPartitions.CSS_MULTILINE_COMMENT);
778 // reconciler.setRepairer(dr, IPHPPartitions.CSS_MULTILINE_COMMENT);
779 // dr = new DefaultDamagerRepairer(getHTMLScanner());
780 // reconciler.setDamager(dr, IPHPPartitions.JAVASCRIPT);
781 // reconciler.setRepairer(dr, IPHPPartitions.JAVASCRIPT);
782 // dr = new DefaultDamagerRepairer(getHTMLScanner());
783 // reconciler.setDamager(dr, IPHPPartitions.JS_MULTILINE_COMMENT);
784 // reconciler.setRepairer(dr, IPHPPartitions.JS_MULTILINE_COMMENT);
785 // DefaultDamagerRepairer phpDR = new DefaultDamagerRepairer(getSmartyScanner());
786 // phpReconciler.setDamager(phpDR, IPHPPartitions.SMARTY);
787 // phpReconciler.setRepairer(phpDR, IPHPPartitions.SMARTY);
788 // phpDR = new DefaultDamagerRepairer(getSmartyDocScanner());
789 // phpReconciler.setDamager(phpDR, IPHPPartitions.SMARTY_MULTILINE_COMMENT);
790 // phpReconciler.setRepairer(phpDR, IPHPPartitions.SMARTY_MULTILINE_COMMENT);
791 // dr = new DefaultDamagerRepairer(new SingleTokenScanner(new TextAttribute(fJavaTextTools.getColorManager().getColor(
792 // PHPColorProvider.MULTI_LINE_COMMENT))));
793 // reconciler.setDamager(dr, IPHPPartitions.HTML_MULTILINE_COMMENT);
794 // reconciler.setRepairer(dr, IPHPPartitions.HTML_MULTILINE_COMMENT);
796 DefaultDamagerRepairer phpDR = new DefaultDamagerRepairer(getCodeScanner());
797 phpReconciler.setDamager(phpDR, IDocument.DEFAULT_CONTENT_TYPE);
798 phpReconciler.setRepairer(phpDR, IDocument.DEFAULT_CONTENT_TYPE);
800 phpDR = new DefaultDamagerRepairer(getCodeScanner());
801 phpReconciler.setDamager(phpDR, IPHPPartitions.PHP_PARTITIONING);
802 phpReconciler.setRepairer(phpDR, IPHPPartitions.PHP_PARTITIONING);
804 phpDR = new DefaultDamagerRepairer(getPHPDocScanner());
805 phpReconciler.setDamager(phpDR, IPHPPartitions.PHP_PHPDOC_COMMENT);
806 phpReconciler.setRepairer(phpDR, IPHPPartitions.PHP_PHPDOC_COMMENT);
808 phpDR = new DefaultDamagerRepairer(getStringScanner());
809 phpReconciler.setDamager(phpDR, IPHPPartitions.PHP_STRING_DQ);
810 phpReconciler.setRepairer(phpDR, IPHPPartitions.PHP_STRING_DQ);
811 phpDR = new DefaultDamagerRepairer(getStringScanner());
812 phpReconciler.setDamager(phpDR, IPHPPartitions.PHP_STRING_SQ);
813 phpReconciler.setRepairer(phpDR, IPHPPartitions.PHP_STRING_SQ);
814 phpDR = new DefaultDamagerRepairer(getSinglelineCommentScanner());
815 phpReconciler.setDamager(phpDR, IPHPPartitions.PHP_SINGLELINE_COMMENT);
816 phpReconciler.setRepairer(phpDR, IPHPPartitions.PHP_SINGLELINE_COMMENT);
817 phpDR = new DefaultDamagerRepairer(getMultilineCommentScanner());
818 phpReconciler.setDamager(phpDR, IPHPPartitions.PHP_MULTILINE_COMMENT);
819 phpReconciler.setRepairer(phpDR, IPHPPartitions.PHP_MULTILINE_COMMENT);
821 PresentationReconciler reconciler = new PresentationReconciler();
822 reconciler.setDocumentPartitioning(getConfiguredDocumentPartitioning(sourceViewer));
824 JavaTextTools jspTextTools = PHPeclipsePlugin.getDefault().getJavaTextTools();
825 DefaultDamagerRepairer dr = new DefaultDamagerRepairer(getPHPDocScanner());//jspTextTools.getJSPTextScanner());
826 reconciler.setDamager(dr, IDocument.DEFAULT_CONTENT_TYPE);
827 reconciler.setRepairer(dr, IDocument.DEFAULT_CONTENT_TYPE);
829 // dr = new DefaultDamagerRepairer(new SingleTokenScanner(new TextAttribute(fJavaTextTools.getColorManager().getColor(
830 // PHPColorProvider.PHPDOC_TAG))));//jspTextTools.getJSPBracketScanner());
831 // reconciler.setDamager(dr, JSPScriptScanner.JSP_BRACKET);
832 // reconciler.setRepairer(dr, JSPScriptScanner.JSP_BRACKET);
835 configureEmbeddedPresentationReconciler(reconciler, xmlConfiguration.getPresentationReconciler(sourceViewer), xmlConfiguration
836 .getConfiguredContentTypes(sourceViewer), PHPDocumentPartitioner.PHP_TEMPLATE_DATA);
839 configureEmbeddedPresentationReconciler(reconciler, phpReconciler, getConfiguredPHPContentTypes(),
840 PHPDocumentPartitioner.PHP_SCRIPT_CODE);
845 private void configureEmbeddedPresentationReconciler(PresentationReconciler reconciler, IPresentationReconciler embedded,
846 String[] types, String defaultType) {
847 for (int i = 0; i < types.length; i++) {
848 String type = types[i];
850 IPresentationDamager damager = embedded.getDamager(type);
851 IPresentationRepairer repairer = embedded.getRepairer(type);
853 if (type == IDocument.DEFAULT_CONTENT_TYPE) {
857 reconciler.setDamager(damager, type);
858 reconciler.setRepairer(repairer, type);
863 * (non-Javadoc) Method declared on SourceViewerConfiguration
865 public int getTabWidth(ISourceViewer sourceViewer) {
866 return getPreferenceStore().getInt(PREFERENCE_TAB_WIDTH);
870 * (non-Javadoc) Method declared on SourceViewerConfiguration
872 // public ITextHover getTextHover(ISourceViewer sourceViewer, String
874 // if (fEditor != null) {
875 // IEditorInput editorInput = fEditor.getEditorInput();
876 // if (editorInput instanceof IFileEditorInput) {
878 // IFile f = ((IFileEditorInput) editorInput).getFile();
879 // return new PHPTextHover(f.getProject());
880 // } catch (NullPointerException e) {
881 // // this exception occurs, if getTextHover is called by preference pages
886 // return new PHPTextHover(null);
889 * @see SourceViewerConfiguration#getInformationControlCreator(ISourceViewer)
892 public IInformationControlCreator getInformationControlCreator(ISourceViewer sourceViewer) {
893 return new IInformationControlCreator() {
894 public IInformationControl createInformationControl(Shell parent) {
895 return new DefaultInformationControl(parent, SWT.NONE, new HTMLTextPresenter(true));
896 // return new HoverBrowserControl(parent);
902 * @see SourceViewerConfiguration#getInformationPresenter(ISourceViewer)
905 public IInformationPresenter getInformationPresenter(ISourceViewer sourceViewer) {
906 InformationPresenter presenter = new InformationPresenter(getInformationPresenterControlCreator(sourceViewer));
907 presenter.setDocumentPartitioning(getConfiguredDocumentPartitioning(sourceViewer));
908 IInformationProvider provider = new JavaInformationProvider(getEditor());
909 presenter.setInformationProvider(provider, IDocument.DEFAULT_CONTENT_TYPE);
910 presenter.setInformationProvider(provider, IPHPPartitions.PHP_PHPDOC_COMMENT);
911 // presenter.setInformationProvider(provider, IPHPPartitions.JAVA_CHARACTER);
912 presenter.setSizeConstraints(60, 10, true, true);
917 * @see SourceViewerConfiguration#getInformationPresenter(ISourceViewer)
920 // public IInformationPresenter getInformationPresenter(ISourceViewer
922 // InformationPresenter presenter= new
923 // InformationPresenter(getInformationPresenterControlCreator(sourceViewer));
924 // IInformationProvider provider= new JavaInformationProvider(getEditor());
925 // presenter.setInformationProvider(provider,
926 // IDocument.DEFAULT_CONTENT_TYPE);
927 // presenter.setInformationProvider(provider, IJavaPartitions.JAVA_DOC);
928 // presenter.setSizeConstraints(60, 10, true, true);
932 * Returns the information presenter control creator. The creator is a factory creating the presenter controls for the given
933 * source viewer. This implementation always returns a creator for <code>DefaultInformationControl</code> instances.
935 * @param sourceViewer
936 * the source viewer to be configured by this configuration
937 * @return an information control creator
940 private IInformationControlCreator getInformationPresenterControlCreator(ISourceViewer sourceViewer) {
941 return new IInformationControlCreator() {
942 public IInformationControl createInformationControl(Shell parent) {
943 int shellStyle = SWT.RESIZE;
944 int style = SWT.V_SCROLL | SWT.H_SCROLL;
945 return new DefaultInformationControl(parent, shellStyle, style, new HTMLTextPresenter(false));
946 // return new HoverBrowserControl(parent);
952 * Returns the outline presenter control creator. The creator is a factory creating outline presenter controls for the given
953 * source viewer. This implementation always returns a creator for <code>JavaOutlineInformationControl</code> instances.
955 * @param sourceViewer
956 * the source viewer to be configured by this configuration
957 * @return an information control creator
960 private IInformationControlCreator getOutlinePresenterControlCreator(ISourceViewer sourceViewer) {
961 return new IInformationControlCreator() {
962 public IInformationControl createInformationControl(Shell parent) {
963 int shellStyle = SWT.RESIZE;
964 int treeStyle = SWT.V_SCROLL | SWT.H_SCROLL;
965 return new JavaOutlineInformationControl(parent, shellStyle, treeStyle);
971 * Returns the outline presenter which will determine and shown information requested for the current cursor position.
973 * @param sourceViewer
974 * the source viewer to be configured by this configuration
975 * @param doCodeResolve
976 * a boolean which specifies whether code resolve should be used to compute the Java element
977 * @return an information presenter
980 public IInformationPresenter getOutlinePresenter(ISourceViewer sourceViewer, boolean doCodeResolve) {
981 InformationPresenter presenter = new InformationPresenter(getOutlinePresenterControlCreator(sourceViewer));
982 presenter.setAnchor(InformationPresenter.ANCHOR_GLOBAL);
983 IInformationProvider provider = new JavaElementProvider(getEditor(), doCodeResolve);
984 presenter.setInformationProvider(provider, IDocument.DEFAULT_CONTENT_TYPE);
985 presenter.setInformationProvider(provider, PHPDocumentPartitioner.PHP_SCRIPT_CODE);
986 presenter.setInformationProvider(provider, IPHPPartitions.PHP_PARTITIONING);
987 presenter.setInformationProvider(provider, IPHPPartitions.PHP_PHPDOC_COMMENT);
988 presenter.setInformationProvider(provider, IPHPPartitions.SMARTY_MULTILINE_COMMENT);
989 presenter.setInformationProvider(provider, IPHPPartitions.HTML);
990 presenter.setInformationProvider(provider, IPHPPartitions.HTML_MULTILINE_COMMENT);
991 presenter.setSizeConstraints(40, 20, true, false);