2 * Copyright (C) 2007 EDIT
3 * European Distributed Institute of Taxonomy
4 * http://www.e-taxonomy.eu
6 * The contents of this file are subject to the Mozilla Public License Version 1.1
7 * See LICENSE.TXT at the top of this package for the full license terms.
10 package eu
.etaxonomy
.taxeditor
.editor
.name
.container
;
12 import java
.util
.ArrayList
;
13 import java
.util
.Collection
;
14 import java
.util
.Scanner
;
16 import org
.eclipse
.swt
.custom
.StyledText
;
17 import org
.eclipse
.swt
.events
.KeyEvent
;
18 import org
.eclipse
.swt
.events
.KeyListener
;
19 import org
.eclipse
.swt
.events
.VerifyEvent
;
20 import org
.eclipse
.swt
.events
.VerifyListener
;
23 * Checks text entered into a StyledText widget for line breaks, sends
24 * split text to abstract method handleSplitText().
26 * VerifyListener interface methods break up the text into lines. Each line is sent individually
27 * to the handleSplitText() method when the KeyListener interface method keyReleased() is called.
28 * This is because if the StyledText widget is disposed before the key is released, an SWT
31 * The listener should be set on the StyledText widget as follows:
33 * StyledText styledText = new SourceViewer().getTextWidget();
34 * LineBreakListener lineBreakListener = new LineBreakListener() {
35 * public void handleSplitText(String text) {
36 * ... some operation ...
40 * styledText.addVerifyListener(lineBreakListener);
41 * styledText.addKeyListener(lineBreakListener);
48 public abstract class LineBreakListener
implements VerifyListener
, KeyListener
{
50 Collection
<String
> splitTexts
;
55 * Checks for 3 conditions of name viewer text:
56 * 1) no line breaks in text
57 * 2) line break at the end of the text
58 * 3) line break in the middle of the text
59 * @see org.eclipse.swt.events.VerifyListener#verifyText(org.eclipse.swt.events.VerifyEvent)
61 public void verifyText(VerifyEvent e
) {
63 String verifyText
= e
.text
;
65 StyledText styledText
= (StyledText
) e
.widget
;
66 String widgetText
= styledText
.getText();
67 int cursorPosition
= styledText
.getCaretOffset();
69 // If no line break in verifyText, Parse text normally
70 if (!verifyText
.contains(System
.getProperty("line.separator"))) {
74 // Don't add verifyText without further processing
77 // Initialize split text collection
78 splitTexts
= new ArrayList
<String
>();
80 // If user has entered return at the end of the line,
81 // make a new, empty synonym
82 if (widgetText
.length() == cursorPosition
&&
83 verifyText
.equals(System
.getProperty("line.separator"))) {
88 // Concatenate old and new texts
89 String textForSplitting
= widgetText
.substring(0, cursorPosition
)
91 + widgetText
.substring(cursorPosition
);
93 // Split on line breaks
94 Scanner scanner
= new Scanner( textForSplitting
);
95 scanner
.useDelimiter (System
.getProperty("line.separator"));
97 // Put first string into name viewer
98 styledText
.setText(scanner
.next());
100 // Start new synonyms with the rest
101 while (scanner
.hasNext()) {
102 splitTexts
.add(scanner
.next());
108 public void keyPressed(KeyEvent e
) {}
112 public void keyReleased(KeyEvent e
) {
113 if (splitTexts
!= null) {
114 for (String text
: splitTexts
) {
115 handleSplitText(text
);
122 * <p>handleSplitText</p>
124 * @param text a {@link java.lang.String} object.
126 abstract public void handleSplitText(String text
);