diff options
| author | nyamatongwe <devnull@localhost> | 2005-03-25 05:08:19 +0000 | 
|---|---|---|
| committer | nyamatongwe <devnull@localhost> | 2005-03-25 05:08:19 +0000 | 
| commit | da2b8dbcba956ae7c37f47e9e6017ae8ef4a00b8 (patch) | |
| tree | 3aa540e36a7ccf7eb74c51ecfb7b78e91531648b | |
| parent | b222e2ae0ba2aa4f859920081b55b44f8baf533e (diff) | |
| download | scintilla-mirror-da2b8dbcba956ae7c37f47e9e6017ae8ef4a00b8.tar.gz | |
Patch from Blair McGlashan for autocompletion on Windows to
* Set maximum width of list
* set maximum height of list
* better calculate width
* use ellipsis when text is truncated to fit window
* use popup window so it can extend past parent window
* disallow resizing too small
* draw to bottom edge when resized so last item not full line high
* improve time to display by by 90%
Minor tweaks by me to fix warnings, layout etc.
| -rw-r--r-- | doc/ScintillaDoc.html | 59 | ||||
| -rw-r--r-- | gtk/PlatGTK.cxx | 40 | 
2 files changed, 78 insertions, 21 deletions
| diff --git a/doc/ScintillaDoc.html b/doc/ScintillaDoc.html index 879cccc36..3c23df0da 100644 --- a/doc/ScintillaDoc.html +++ b/doc/ScintillaDoc.html @@ -787,7 +787,7 @@ struct TextToFind {      unless the document is read-only.</p>      <p>On X, the clipboard is asynchronous and may require several messages between -    the destination and source applications. Data from SCI_PASTE will not arrive in the +    the destination and source applications. Data from SCI_PASTE will not arrive in the       document immediately.</p>       <b id="SCI_COPYRANGE">SCI_COPYRANGE(int start, int end)</b><br /> @@ -2323,8 +2323,8 @@ struct TextToFind {      horizontal space, such as Thai, will mostly work but there are some issues where the characters      are drawn separately leading to visual glitches. Bi-directional text is not supported.</p> -    <p>On Windows, code page can be set to 932 (Japanese Shift-JIS), 936 (Simplified Chinese GBK), -    949 (Korean), and 950 (Traditional Chinese Big5) although these may require installation of language +    <p>On Windows, code page can be set to 932 (Japanese Shift-JIS), 936 (Simplified Chinese GBK),  +    949 (Korean), and 950 (Traditional Chinese Big5) although these may require installation of language       specific support.</p>      <p>On GTK+, code page <code>SC_CP_DBCS</code> (1) sets Scintilla into @@ -2888,10 +2888,10 @@ struct TextToFind {      <p>When the user makes a selection from the list the container is sent a <code><a class="message"      href="#SCN_AUTOCSELECTION">SCN_AUTOCSELECTION</a></code> <a class="jump" -    href="#Notifications">notification message</a>. On return from the notification Scintilla will insert +    href="#Notifications">notification message</a>. On return from the notification Scintilla will insert        the selected text unless the autocompletion list has been cancelled, for example by the container sending       <code><a class="message" href="#SCI_AUTOCCANCEL">SCI_AUTOCCANCEL</a></code>.</p> - +          <p>To make use of autocompletion you must monitor each character added to the document. See      <code>SciTEBase::CharAdded()</code> in SciTEBase.cxx for an example of autocompletion.</p>      <code><a class="message" href="#SCI_AUTOCSHOW">SCI_AUTOCSHOW(int lenEntered, const char @@ -2928,6 +2928,10 @@ struct TextToFind {       <a class="message" href="#SCI_CLEARREGISTEREDIMAGES">SCI_CLEARREGISTEREDIMAGES</a><br />       <a class="message" href="#SCI_AUTOCSETTYPESEPARATOR">SCI_AUTOCSETTYPESEPARATOR(char separatorCharacter)</a><br />       <a class="message" href="#SCI_AUTOCGETTYPESEPARATOR">SCI_AUTOCGETTYPESEPARATOR</a><br /> +     <a class="message" href="#SCI_AUTOCSETMAXHEIGHT">SCI_AUTOCSETMAXHEIGHT(int rowCount)</a><br /> +     <a class="message" href="#SCI_AUTOCGETMAXHEIGHT">SCI_AUTOCGETMAXHEIGHT</a><br /> +     <a class="message" href="#SCI_AUTOCSETMAXWIDTH">SCI_AUTOCSETMAXWIDTH(int characterCount)</a><br /> +     <a class="message" href="#SCI_AUTOCGETMAXWIDTH">SCI_AUTOCGETMAXWIDTH</a><br />      </code>      <p><b id="SCI_AUTOCSHOW">SCI_AUTOCSHOW(int lenEntered, const char *list)</b><br /> @@ -3037,6 +3041,23 @@ struct TextToFind {        with <code>SCI_AUTOCSETTYPESEPARATOR</code>.      </p> +    <p> +      <b id="SCI_AUTOCSETMAXHEIGHT">SCI_AUTOCSETMAXHEIGHT(int rowCount)</b><br /> +      <b id="SCI_AUTOCGETMAXHEIGHT">SCI_AUTOCGETMAXHEIGHT</b><br /> + +      Get or set the maximum number of rows that will be visible in an autocompletion list. If there are more rows in the list, then a vertical +      scrollbar is shown. The default is 5. +     </p> + +    <p> +      <b id="SCI_AUTOCSETMAXWIDTH">SCI_AUTOCSETMAX(int characterCount)</b><br /> +      <b id="SCI_AUTOCGETMAXWIDTH">SCI_AUTOCGETMAX</b><br /> + +      Get or set the maximum width of an autocompletion list expressed as the number of characters in the longest item that will be totally visible. +      If zero (the default) then the list's width is calculated to fit the item with the most characters. Any items that cannot be fully displayed within  +      the available width are indicated by the presence of ellipsis. +     </p> +      <h2 id="UserLists">User lists</h2>      <p>User lists use the same internal mechanisms as autocompletion lists, and all the calls @@ -3599,10 +3620,10 @@ struct RangeToFormat {       into the print rectangle. If you set <code>SC_WRAP_NONE</code>, each line of text       generates one line of output and the line is truncated if it is too long to fit       into the print area.<br /> -     <code>SC_WRAP_WORD</code> tries to wrap only between words as indicated by -     white space or style changes although if a word is longer than a line, it will be wrapped before -     the line end. <code>SC_WRAP_CHAR</code> is preferred to -     <code>SC_WRAP_WORD</code> for Asian languages where there is no white space +     <code>SC_WRAP_WORD</code> tries to wrap only between words as indicated by  +     white space or style changes although if a word is longer than a line, it will be wrapped before  +     the line end. <code>SC_WRAP_CHAR</code> is preferred to  +     <code>SC_WRAP_WORD</code> for Asian languages where there is no white space        between words.</p>      <h2 id="DirectAccess">Direct access</h2> @@ -3730,7 +3751,7 @@ sptr_t CallScintilla(unsigned int iMessage, uptr_t wParam, sptr_t lParam){      The best way to see how this is done is to search the SciTE source code for the messages used      in this section of the documentation and see how they are used. You will also need to use      markers and a folding margin to complete your folding implementation. -    The <code>"fold"</code> property should be set to <code>"1"</code> with +    The <code>"fold"</code> property should be set to <code>"1"</code> with       <code>SCI_SETPROPERTY("fold", "1")</code> to enable folding. </p>      <code><a class="message" href="#SCI_VISIBLEFROMDOCLINE">SCI_VISIBLEFROMDOCLINE(int      docLine)</a><br /> @@ -3945,13 +3966,13 @@ sptr_t CallScintilla(unsigned int iMessage, uptr_t wParam, sptr_t lParam){      <p><b id="SCI_SETWRAPMODE">SCI_SETWRAPMODE(int wrapMode)</b><br />       <b id="SCI_GETWRAPMODE">SCI_GETWRAPMODE</b><br /> -     Set wrapMode to <code>SC_WRAP_WORD</code> (1) to enable wrapping -     on word boundaries, <code>SC_WRAP_CHAR</code> (2) to enable wrapping -     between any characters, and to <code>SC_WRAP_NONE</code> (0) to disable line -     wrapping. <code>SC_WRAP_CHAR</code> is preferred to -     <code>SC_WRAP_WORD</code> for Asian languages where there is no white space +     Set wrapMode to <code>SC_WRAP_WORD</code> (1) to enable wrapping  +     on word boundaries, <code>SC_WRAP_CHAR</code> (2) to enable wrapping  +     between any characters, and to <code>SC_WRAP_NONE</code> (0) to disable line  +     wrapping. <code>SC_WRAP_CHAR</code> is preferred to  +     <code>SC_WRAP_WORD</code> for Asian languages where there is no white space        between words.</p> - +          <p><b id="SCI_SETWRAPVISUALFLAGS">SCI_SETWRAPVISUALFLAGS(int wrapVisualFlags)</b><br />       <b id="SCI_GETWRAPVISUALFLAGS">SCI_GETWRAPVISUALFLAGS</b><br /> @@ -4421,7 +4442,7 @@ href="#SCI_POSITIONFROMLINE">SCI_POSITIONFROMLINE</a>(lineNumber);      href="#SCI_SETREADONLY">SCI_SETREADONLY</a></code>.</p>      <p><b id="SCN_KEY">SCN_KEY</b><br /> -     Reports all keys pressed but not consumed by Scintilla. Used on GTK+ because of +     Reports all keys pressed but not consumed by Scintilla. Used on GTK+ because of        some problems with keyboard focus and is not sent by the Windows version. <code>SCNotification.ch</code> holds the key code and      <code>SCNotification.modifiers</code> holds the modifiers. This notification is sent if the      modifiers include <code>SCMOD_ALT</code> or <code>SCMOD_CTRL</code> and the key code is less @@ -4490,7 +4511,7 @@ href="#SCI_POSITIONFROMLINE">SCI_POSITIONFROMLINE</a>(lineNumber);            <td align="left">Valid for text changes, not for style changes. If we are collecting undo            information this holds a pointer to the text that is handed to the Undo system, otherwise -          it is zero. For user performed SC_MOD_BEFOREDELETE the text field is 0 and +          it is zero. For user performed SC_MOD_BEFOREDELETE the text field is 0 and   		  for user performed SC_MOD_BEFOREINSERT the text field points to an array of cells,  	 	  not bytes.</td>          </tr> @@ -4905,7 +4926,7 @@ for line = lineStart to lineEnd do SCI_ENSUREVISIBLE(line) next      <p><b id="SCN_AUTOCSELECTION">SCN_AUTOCSELECTION</b><br />       The user has selected an item in an <a class="jump" href="#Autocompletion">autocompletion list</a>. The -     notification is sent before the selection is inserted. Automatic insertion can be cancelled by sending a +     notification is sent before the selection is inserted. Automatic insertion can be cancelled by sending a        <code><a class="message" href="#SCI_AUTOCCANCEL">SCI_AUTOCCANCEL</a></code> message       before returning from the notification. The <code>SCNotification</code> fields used are:</p> diff --git a/gtk/PlatGTK.cxx b/gtk/PlatGTK.cxx index 00dc3d2a8..9ba18a8ce 100644 --- a/gtk/PlatGTK.cxx +++ b/gtk/PlatGTK.cxx @@ -1794,9 +1794,10 @@ public:  		}  	}  	virtual void SetFont(Font &font); -	virtual void Create(Window &parent, int ctrlID, int lineHeight_, bool unicodeMode_); +	virtual void Create(Window &parent, int ctrlID, Point location_, int lineHeight_, bool unicodeMode_);  	virtual void SetAverageCharWidth(int width);  	virtual void SetVisibleRows(int rows); +	virtual int GetVisibleRows() const;  	virtual PRectangle GetDesiredRect();  	virtual int CaretFromEdge();  	virtual void Clear(); @@ -1812,6 +1813,7 @@ public:  		doubleClickAction = action;  		doubleClickActionData = data;  	} +	virtual void SetList(const char* list, char separator, char typesep);  };  ListBox *ListBox::Allocate() { @@ -1842,7 +1844,7 @@ static gboolean ButtonPress(GtkWidget *, GdkEventButton* ev, gpointer p) {  	return FALSE;  } -void ListBoxX::Create(Window &, int, int, bool) { +void ListBoxX::Create(Window &, int, Point, int, bool) {  	id = gtk_window_new(GTK_WINDOW_POPUP);  	GtkWidget *frame = gtk_frame_new(NULL); @@ -1936,6 +1938,10 @@ void ListBoxX::SetVisibleRows(int rows) {  	desiredVisibleRows = rows;  } +int ListBoxX::GetVisibleRows() const { +	return desiredVisibleRows; +} +  PRectangle ListBoxX::GetDesiredRect() {  	// Before any size allocated pretend its 100 wide so not scrolled  	PRectangle rc(0, 0, 100, 100); @@ -2280,6 +2286,36 @@ void ListBoxX::ClearRegisteredImages() {  	xset.Clear();  } +void ListBoxX::SetList(const char* list, char separator, char typesep) { +	Clear(); +	int count = strlen(list) + 1; +	char *words = new char[count]; +	if (words) { +		memcpy(words, list, count); +		char *startword = words; +		char *numword = NULL; +		int i = 0; +		for (; words[i]; i++) { +			if (words[i] == separator) { +				words[i] = '\0'; +				if (numword) +					*numword = '\0'; +				Append(startword, numword?atoi(numword + 1):-1); +				startword = words + i + 1; +				numword = NULL; +			} else if (words[i] == typesep) { +				numword = words + i; +			} +		} +		if (startword) { +			if (numword) +				*numword = '\0'; +			Append(startword, numword?atoi(numword + 1):-1); +		} +		delete []words; +	} +} +  Menu::Menu() : id(0) {}  void Menu::CreatePopUp() { | 
