author | skyhusker <skyhusker> | 2005-04-24 17:50:42 (UTC) |
---|---|---|
committer | skyhusker <skyhusker> | 2005-04-24 17:50:42 (UTC) |
commit | 883d2f517fe0aaab83d820e1413edffc1471bb4e (patch) (unidiff) | |
tree | dc7255faf24d909bf0ca8f0afc05202459615414 | |
parent | ceaea9869115287b48781fabc938bd51cb67625c (diff) | |
download | opie-883d2f517fe0aaab83d820e1413edffc1471bb4e.zip opie-883d2f517fe0aaab83d820e1413edffc1471bb4e.tar.gz opie-883d2f517fe0aaab83d820e1413edffc1471bb4e.tar.bz2 |
Sort applications alphabetically. Fixes bug #1476.
-rw-r--r-- | core/launcher/startmenu.cpp | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/core/launcher/startmenu.cpp b/core/launcher/startmenu.cpp index 66f665f..ce7840e 100644 --- a/core/launcher/startmenu.cpp +++ b/core/launcher/startmenu.cpp | |||
@@ -62,16 +62,17 @@ StartMenu::StartMenu(QWidget *parent) : QLabel( parent ) | |||
62 | int sz = AppLnk::smallIconSize()+3; | 62 | int sz = AppLnk::smallIconSize()+3; |
63 | QPixmap pm; | 63 | QPixmap pm; |
64 | pm.convertFromImage(Resource::loadImage( startButtonPixmap).smoothScale( sz,sz) ); | 64 | pm.convertFromImage(Resource::loadImage( startButtonPixmap).smoothScale( sz,sz) ); |
65 | setPixmap(pm); | 65 | setPixmap(pm); |
66 | setFocusPolicy( NoFocus ); | 66 | setFocusPolicy( NoFocus ); |
67 | 67 | ||
68 | useWidePopupMenu = true; | 68 | useWidePopupMenu = true; |
69 | launchMenu = 0; | 69 | launchMenu = 0; |
70 | currentItem = 0; | ||
70 | refreshMenu(); | 71 | refreshMenu(); |
71 | } | 72 | } |
72 | 73 | ||
73 | 74 | ||
74 | void StartMenu::mousePressEvent( QMouseEvent * ) | 75 | void StartMenu::mousePressEvent( QMouseEvent * ) |
75 | { | 76 | { |
76 | launch(); | 77 | launch(); |
77 | } | 78 | } |
@@ -145,21 +146,31 @@ void StartMenu::createAppEntry( QPopupMenu *menu, QDir dir, QString file ) | |||
145 | delete applnk; | 146 | delete applnk; |
146 | } else { | 147 | } else { |
147 | QPixmap test; | 148 | QPixmap test; |
148 | QImage img = Resource::loadImage( applnk->icon() ); | 149 | QImage img = Resource::loadImage( applnk->icon() ); |
149 | if(!img.isNull() ) | 150 | if(!img.isNull() ) |
150 | test.convertFromImage( | 151 | test.convertFromImage( |
151 | img.smoothScale( | 152 | img.smoothScale( |
152 | AppLnk::smallIconSize(), AppLnk::smallIconSize() ), 0 ); | 153 | AppLnk::smallIconSize(), AppLnk::smallIconSize() ), 0 ); |
153 | 154 | ||
155 | // Insert items ordered lexically | ||
156 | int current, left = 0, right = currentItem; | ||
157 | while( left != right ) { | ||
158 | current = ( left + right ) / 2; | ||
159 | if ( menu->text(menu->idAt( ( current ) ) ) < applnk->name() ) | ||
160 | left = ++current; | ||
161 | else | ||
162 | right = current; | ||
163 | } | ||
164 | |||
154 | menu->insertItem( test, applnk->name(), | 165 | menu->insertItem( test, applnk->name(), |
155 | currentItem + APPLNK_ID_OFFSET ); | 166 | currentItem + APPLNK_ID_OFFSET, current ); |
156 | appLnks.insert( currentItem + APPLNK_ID_OFFSET, applnk ); | 167 | appLnks.insert( currentItem + APPLNK_ID_OFFSET, applnk ); |
157 | currentItem++; | 168 | currentItem++; |
158 | } | 169 | } |
159 | } | 170 | } |
160 | 171 | ||
161 | } | 172 | } |
162 | 173 | ||
163 | void StartMenu::createDirEntry( QPopupMenu *menu, QDir dir, QString file, bool lot ) | 174 | void StartMenu::createDirEntry( QPopupMenu *menu, QDir dir, QString file, bool lot ) |
164 | { | 175 | { |
165 | // do some sanity checks and collect information | 176 | // do some sanity checks and collect information |