-rw-r--r-- | ChangeLog | 1 | ||||
-rw-r--r-- | noncore/settings/networksettings/mainwindow/mainwindowimp.cpp | 8 |
2 files changed, 6 insertions, 3 deletions
@@ -1,285 +1,286 @@ | |||
1 | 2005-??-??Opie 1.2.1 | 1 | 2005-??-??Opie 1.2.1 |
2 | 2 | ||
3 | 3 | ||
4 | New Features | 4 | New Features |
5 | ------------ | 5 | ------------ |
6 | * OpieStumbler: Scans WiFi networks using the wireless extension scanning (skyhusker) | 6 | * OpieStumbler: Scans WiFi networks using the wireless extension scanning (skyhusker) |
7 | * Opie-Reader: Support for document formats ArriereGo and Reb, add flite output (tim,pohly) | 7 | * Opie-Reader: Support for document formats ArriereGo and Reb, add flite output (tim,pohly) |
8 | * Opie-Networksettings: Add support for wlan-ng devices and improve WEP handling (Dirk Opfer) | 8 | * Opie-Networksettings: Add support for wlan-ng devices and improve WEP handling (Dirk Opfer) |
9 | 9 | ||
10 | Fixed Bugs | 10 | Fixed Bugs |
11 | ---------- | 11 | ---------- |
12 | * #1476 - Wrong order of application entries in the O-menu (skyhusker) | 12 | * #1476 - Wrong order of application entries in the O-menu (skyhusker) |
13 | * #1535- Missing line break and unnecessary location shown with Today-Calendar plugin (deller) | 13 | * #1535- Missing line break and unnecessary location shown with Today-Calendar plugin (deller) |
14 | * #1565 - crash-fix in odevice.cpp while scanning the distribution table (deller) | 14 | * #1565 - crash-fix in odevice.cpp while scanning the distribution table (deller) |
15 | * #1614 - Make Opie-console start in $HOME instead of / (skyhusker) | 15 | * #1614 - Make Opie-console start in $HOME instead of / (skyhusker) |
16 | * n.a.- always show volume and wireless applet popups inside visible screen (deller) | 16 | * n.a.- always show volume and wireless applet popups inside visible screen (deller) |
17 | * n.a. - scale O-Menu-Applets appropriately (mickeyl) | 17 | * n.a. - scale O-Menu-Applets appropriately (mickeyl) |
18 | * n.a.- libopienet: fix bugs in wireless scanning and setting SSID (skyhusker) | 18 | * n.a.- libopienet: fix bugs in wireless scanning and setting SSID (skyhusker) |
19 | * n.a.- Wellenreiter: relax WE version matching test a bit (mickeyl) | 19 | * n.a.- Wellenreiter: relax WE version matching test a bit (mickeyl) |
20 | * n.a.- scale BluezApplet appropriately and use larger icons (mickeyl) | 20 | * n.a.- scale BluezApplet appropriately and use larger icons (mickeyl) |
21 | * n.a.- memoryapplet: fix crash in memoryapplet on kernels without swap support (seneca cunningham) | 21 | * n.a.- memoryapplet: fix crash in memoryapplet on kernels without swap support (seneca cunningham) |
22 | * n.a. - networksettings: ignore hostap control interfaces wifi* (mickeyl) | ||
22 | 23 | ||
23 | Internal | 24 | Internal |
24 | -------- | 25 | -------- |
25 | * Make BluezApplet use OTaskbarApplet (mickeyl) | 26 | * Make BluezApplet use OTaskbarApplet (mickeyl) |
26 | * Rewrite OFileNotification to use the upcoming inotify interface instead of the deprecated dnotify (mickeyl) | 27 | * Rewrite OFileNotification to use the upcoming inotify interface instead of the deprecated dnotify (mickeyl) |
27 | * libopienet: Skip hostap control interfaces 'wifi' and improve robustness in ONetworkInterface (mickeyl) | 28 | * libopienet: Skip hostap control interfaces 'wifi' and improve robustness in ONetworkInterface (mickeyl) |
28 | 29 | ||
29 | 2005-03-25Opie 1.2.0 | 30 | 2005-03-25Opie 1.2.0 |
30 | 31 | ||
31 | Fixed Bugs | 32 | Fixed Bugs |
32 | ---------- | 33 | ---------- |
33 | * #1613 - AdvancedFM - scale toolbar icons appropriately (drw) | 34 | * #1613 - AdvancedFM - scale toolbar icons appropriately (drw) |
34 | * #1620 - OFileSelector - show the button on press and not on press on hold (alwin) | 35 | * #1620 - OFileSelector - show the button on press and not on press on hold (alwin) |
35 | * #1473 - Opie-Eye - Same as #1620 but we lack a common FileSystem Button class (zecke) | 36 | * #1473 - Opie-Eye - Same as #1620 but we lack a common FileSystem Button class (zecke) |
36 | * n.a. - PackageManager - fix bug where messages show up multiple times in install dialog (drw) | 37 | * n.a. - PackageManager - fix bug where messages show up multiple times in install dialog (drw) |
37 | * n.a.- make qpeglobal.h include qglobal.h (zecke) | 38 | * n.a.- make qpeglobal.h include qglobal.h (zecke) |
38 | 39 | ||
39 | 2005-03-20Opie 1.2.0-rc1 | 40 | 2005-03-20Opie 1.2.0-rc1 |
40 | 41 | ||
41 | 42 | ||
42 | New Features | 43 | New Features |
43 | ------------ | 44 | ------------ |
44 | * Launcher: Support a static background pixmap (mickeyl) | 45 | * Launcher: Support a static background pixmap (mickeyl) |
45 | * LauncherSettings: Choose whether to have a static background pixmap (mickeyl) | 46 | * LauncherSettings: Choose whether to have a static background pixmap (mickeyl) |
46 | * PackageManager supports the 'lists_dir' ipkg configuration option (drw) | 47 | * PackageManager supports the 'lists_dir' ipkg configuration option (drw) |
47 | * Added hi-res inline images for large resolution devices (drw) | 48 | * Added hi-res inline images for large resolution devices (drw) |
48 | * Improved launcher icons for consistency (ar) | 49 | * Improved launcher icons for consistency (ar) |
49 | * Datebook: Added plugin system to datebook so holidays and birthdays from contacts may displayed in datebook (alwin) | 50 | * Datebook: Added plugin system to datebook so holidays and birthdays from contacts may displayed in datebook (alwin) |
50 | 51 | ||
51 | Fixed Bugs | 52 | Fixed Bugs |
52 | ---------- | 53 | ---------- |
53 | * #1236 - VCards contained empty home and work address entries causing Palms to crash (eilers) | 54 | * #1236 - VCards contained empty home and work address entries causing Palms to crash (eilers) |
54 | * #1412 - Launcher Settings - fixed default settings for background in Edit tab dialog (drw) | 55 | * #1412 - Launcher Settings - fixed default settings for background in Edit tab dialog (drw) |
55 | * #1472 - Opie textedit now check for unsaved changes on ESC key (ljp) | 56 | * #1472 - Opie textedit now check for unsaved changes on ESC key (ljp) |
56 | * #1474 - Implement GUI for Scrollbars on the Left in Appearance (zecke) | 57 | * #1474 - Implement GUI for Scrollbars on the Left in Appearance (zecke) |
57 | * #1482 - Fix double '/' in paths (zecke) | 58 | * #1482 - Fix double '/' in paths (zecke) |
58 | * #1536 - Autosave of custom locations in opie backup (ar) | 59 | * #1536 - Autosave of custom locations in opie backup (ar) |
59 | * #1539 - Fixed displaying too long path in the delete dialog in opie-eye (zecke) | 60 | * #1539 - Fixed displaying too long path in the delete dialog in opie-eye (zecke) |
60 | * #1540 - Implemented deletion of DocLnks in opie-eye (zecke) | 61 | * #1540 - Implemented deletion of DocLnks in opie-eye (zecke) |
61 | * #1542 - Fixed Todo crash when priority < 1 or > 5 (drw) | 62 | * #1542 - Fixed Todo crash when priority < 1 or > 5 (drw) |
62 | * #1550 - Browse for alarm sound start in QPEDIR/sounds/ (zecke) | 63 | * #1550 - Browse for alarm sound start in QPEDIR/sounds/ (zecke) |
63 | * #1554 - Fixed Opie-Console name in .desktop file (mickeyl) | 64 | * #1554 - Fixed Opie-Console name in .desktop file (mickeyl) |
64 | * #1556 - Start to look for sound files in /opt/QtPalmtop/sounds (zecke) | 65 | * #1556 - Start to look for sound files in /opt/QtPalmtop/sounds (zecke) |
65 | * #1558 - Fixed opie-login breaking opie startup (mickeyl) | 66 | * #1558 - Fixed opie-login breaking opie startup (mickeyl) |
66 | * #1560 - Fixed Opie-Console picking up the wrong shell (bluelightning) | 67 | * #1560 - Fixed Opie-Console picking up the wrong shell (bluelightning) |
67 | * #1570 - Confirmation needed befor Restore a backup and overwrite local data (ar) | 68 | * #1570 - Confirmation needed befor Restore a backup and overwrite local data (ar) |
68 | * #1591 - Addressbook sortorder changed by clicking on column 0 (eilers) | 69 | * #1591 - Addressbook sortorder changed by clicking on column 0 (eilers) |
69 | * #1599 - Security - change recommendation for opie-multiauth to opie-securityplugin (gints) | 70 | * #1599 - Security - change recommendation for opie-multiauth to opie-securityplugin (gints) |
70 | * #1604 - Checkbook crashed on startup (drw) | 71 | * #1604 - Checkbook crashed on startup (drw) |
71 | * #1608 - Addressbook crashed after search, which may caused by not initialzed member variable (eilers) | 72 | * #1608 - Addressbook crashed after search, which may caused by not initialzed member variable (eilers) |
72 | * #1608 - QueryByExampe-Datediff on SQL database did not worked properly (eilers) | 73 | * #1608 - QueryByExampe-Datediff on SQL database did not worked properly (eilers) |
73 | * n.a. - Netsystemtime - fixed UI to prevent error dialog from displaying when it shouldn't, get rid of some compiler warnings (drw) | 74 | * n.a. - Netsystemtime - fixed UI to prevent error dialog from displaying when it shouldn't, get rid of some compiler warnings (drw) |
74 | * n.a. - PackageManager - fixed where last package in status file was not shown as installed when it should be (drw) | 75 | * n.a. - PackageManager - fixed where last package in status file was not shown as installed when it should be (drw) |
75 | * n.a. - PackageManager - fixed bug where lists_dir was not being honored at startup (drw) | 76 | * n.a. - PackageManager - fixed bug where lists_dir was not being honored at startup (drw) |
76 | * n.a. - PackageManager - provided default value for lists_dir when none is entered in configuration dialog (drw) | 77 | * n.a. - PackageManager - provided default value for lists_dir when none is entered in configuration dialog (drw) |
77 | * n.a. - OTabWidget - fixed scroll buttons, fix display position of tabs (drw) | 78 | * n.a. - OTabWidget - fixed scroll buttons, fix display position of tabs (drw) |
78 | * n.a. - AddressBook - fixed sorting by 'File As' name (drw) | 79 | * n.a. - AddressBook - fixed sorting by 'File As' name (drw) |
79 | * n.a. - AddressBook - fixed category handling for 'All' and 'Unfiled' (eilers) | 80 | * n.a. - AddressBook - fixed category handling for 'All' and 'Unfiled' (eilers) |
80 | * n.a. - AddressBook - fixed letter picker record selection and sort records afterwards (drw) | 81 | * n.a. - AddressBook - fixed letter picker record selection and sort records afterwards (drw) |
81 | 82 | ||
82 | Internal | 83 | Internal |
83 | -------- | 84 | -------- |
84 | * Worked around bug in Qt/Embedded 2.3.10: qt_version() returns 231 (mickeyl) | 85 | * Worked around bug in Qt/Embedded 2.3.10: qt_version() returns 231 (mickeyl) |
85 | * Killed the need for weak symbols in QtE (zecke) | 86 | * Killed the need for weak symbols in QtE (zecke) |
86 | * Added optional building libqpe without inline images (mickeyl) | 87 | * Added optional building libqpe without inline images (mickeyl) |
87 | * OColorButton - fixed so does not emit a colorSelected signal inside of resizeEvent (drw) | 88 | * OColorButton - fixed so does not emit a colorSelected signal inside of resizeEvent (drw) |
88 | 89 | ||
89 | 2005-02-03Opie 1.1.9 | 90 | 2005-02-03Opie 1.1.9 |
90 | 91 | ||
91 | New Features | 92 | New Features |
92 | ------------ | 93 | ------------ |
93 | * Number of icon columns in Launcher is customizable through Launcher.conf (hrw,zecke,mickeyl) | 94 | * Number of icon columns in Launcher is customizable through Launcher.conf (hrw,zecke,mickeyl) |
94 | * Number of icon columns in Launcher is customizable through LauncherSettings (mickeyl) | 95 | * Number of icon columns in Launcher is customizable through LauncherSettings (mickeyl) |
95 | * Usability enhancements in OpieIRC (skyhusker) | 96 | * Usability enhancements in OpieIRC (skyhusker) |
96 | 97 | ||
97 | Fixed Bugs | 98 | Fixed Bugs |
98 | ---------- | 99 | ---------- |
99 | * #1501 - Fixed bug in todo sql backend (eilers) | 100 | * #1501 - Fixed bug in todo sql backend (eilers) |
100 | * #1505 - Added more Swap sizes in memoryapplet (mickeyl) | 101 | * #1505 - Added more Swap sizes in memoryapplet (mickeyl) |
101 | * #1525 - Hopefully fixed double alarms and not removing alarms set with the Clock application (zecke) | 102 | * #1525 - Hopefully fixed double alarms and not removing alarms set with the Clock application (zecke) |
102 | * #1533 - Security Owner Dialog (shown in case of unsuccessfull authentiacation) wasn't able to display information in non latin1 encoding (zecke) | 103 | * #1533 - Security Owner Dialog (shown in case of unsuccessfull authentiacation) wasn't able to display information in non latin1 encoding (zecke) |
103 | * n.a. - Removed hard coded font sizes in a couple of inputmethods (mickeyl) | 104 | * n.a. - Removed hard coded font sizes in a couple of inputmethods (mickeyl) |
104 | * n.a. - Removed MediumDlg appearing prior to FirstUsage wizard (i.e. calibration) (mickeyl) | 105 | * n.a. - Removed MediumDlg appearing prior to FirstUsage wizard (i.e. calibration) (mickeyl) |
105 | * n.a. - Fixed numerous buglets in OpieIRC (skyhusker) | 106 | * n.a. - Fixed numerous buglets in OpieIRC (skyhusker) |
106 | 107 | ||
107 | Internal | 108 | Internal |
108 | -------- | 109 | -------- |
109 | * Added the Qtopia 1.7 SDK macros for quick-apps to easa compilation of 3rd party apps against our headers (mickeyl) | 110 | * Added the Qtopia 1.7 SDK macros for quick-apps to easa compilation of 3rd party apps against our headers (mickeyl) |
110 | * You can now use the Opie build system in combination with a OpenEmbedded staging area which makes a nice cross development environment (mickeyl) | 111 | * You can now use the Opie build system in combination with a OpenEmbedded staging area which makes a nice cross development environment (mickeyl) |
111 | * Made Opie compilable with Qt/Embedded 2.3.10 (ar) | 112 | * Made Opie compilable with Qt/Embedded 2.3.10 (ar) |
112 | * Changed Launcher to get default orientation from ODevice w/ QWS_DISPLAY overriding (mickeyl) | 113 | * Changed Launcher to get default orientation from ODevice w/ QWS_DISPLAY overriding (mickeyl) |
113 | * Build tree cleanups (mickeyl) | 114 | * Build tree cleanups (mickeyl) |
114 | 115 | ||
115 | 2004-11-26Opie 1.1.8 | 116 | 2004-11-26Opie 1.1.8 |
116 | 117 | ||
117 | New Features | 118 | New Features |
118 | ------------ | 119 | ------------ |
119 | * PackageManager supports installation of local ipkg files (drw) | 120 | * PackageManager supports installation of local ipkg files (drw) |
120 | * PackageManager supports linking of applications to root (drw) | 121 | * PackageManager supports linking of applications to root (drw) |
121 | * PackageManager supports src/gz feeds (drw,wimpie) | 122 | * PackageManager supports src/gz feeds (drw,wimpie) |
122 | * Added a syslog information tab to sysinfo (mickeyl) | 123 | * Added a syslog information tab to sysinfo (mickeyl) |
123 | * Added new, more consistent, PIM icons + a GIMP teplate (ar) | 124 | * Added new, more consistent, PIM icons + a GIMP teplate (ar) |
124 | 125 | ||
125 | Fixed Bugs | 126 | Fixed Bugs |
126 | ---------- | 127 | ---------- |
127 | * #1017 - Tetrix doesn't display correctly for high resolution screens (drw) | 128 | * #1017 - Tetrix doesn't display correctly for high resolution screens (drw) |
128 | * #1269 - VCards were imported into personal area if it was activated (eilers) | 129 | * #1269 - VCards were imported into personal area if it was activated (eilers) |
129 | * #1464 - Packagemanager dont set active filter after install a package (drw) | 130 | * #1464 - Packagemanager dont set active filter after install a package (drw) |
130 | * #1479 - Improved VCard-Parser to import VCards created by Evolution 2 and Apple Addressbook (eilers) | 131 | * #1479 - Improved VCard-Parser to import VCards created by Evolution 2 and Apple Addressbook (eilers) |
131 | * #1493 - Fixed one column layout bug of the launcher (hrw) | 132 | * #1493 - Fixed one column layout bug of the launcher (hrw) |
132 | * n.a. - PackageManager - (Minor UI tweak) in filter dialog, when option is enabled, set focus to widget that corresponds to that option (drw) | 133 | * n.a. - PackageManager - (Minor UI tweak) in filter dialog, when option is enabled, set focus to widget that corresponds to that option (drw) |
133 | * n.a. - PackageManager - (Minor UI tweak) fix double entry in source feed configuration when adding a new feed (drw) | 134 | * n.a. - PackageManager - (Minor UI tweak) fix double entry in source feed configuration when adding a new feed (drw) |
134 | * n.a. - Battery Applet - fix sizing of battery info popup (drw,mickeyl) | 135 | * n.a. - Battery Applet - fix sizing of battery info popup (drw,mickeyl) |
135 | 136 | ||
136 | Internal | 137 | Internal |
137 | -------- | 138 | -------- |
138 | * Moved libopie1 to unsupported (mickeyl) | 139 | * Moved libopie1 to unsupported (mickeyl) |
139 | * Implemented generic queryByExample() with incremental searching. A lot of internal changes of the Pim2-library (eilers) | 140 | * Implemented generic queryByExample() with incremental searching. A lot of internal changes of the Pim2-library (eilers) |
140 | * Added fast and full featured and incremental sorted() for SQL addressbook backend (eilers) | 141 | * Added fast and full featured and incremental sorted() for SQL addressbook backend (eilers) |
141 | 142 | ||
142 | 2004-11-14Opie 1.1.7 | 143 | 2004-11-14Opie 1.1.7 |
143 | 144 | ||
144 | New Features | 145 | New Features |
145 | ------------ | 146 | ------------ |
146 | * libOpieDB now uses SQLite V3 instead V2. Remember to upgrade your database files! (eilers) | 147 | * libOpieDB now uses SQLite V3 instead V2. Remember to upgrade your database files! (eilers) |
147 | * Backup now uses the busy indicator when backing up and restore (ar) | 148 | * Backup now uses the busy indicator when backing up and restore (ar) |
148 | * OpiePlayer2 gained adding of Directories to the playlist (zecke) | 149 | * OpiePlayer2 gained adding of Directories to the playlist (zecke) |
149 | * OpiePlayer2 better error handling (zecke) | 150 | * OpiePlayer2 better error handling (zecke) |
150 | * OpiePlayer2 progress indication while streaming (zecke) | 151 | * OpiePlayer2 progress indication while streaming (zecke) |
151 | * OpiePlayer2 ported to use libxine 1.0.0-rc6a (brad,zecke) | 152 | * OpiePlayer2 ported to use libxine 1.0.0-rc6a (brad,zecke) |
152 | * Ported brightnessapplet from Qtopia 1.7 (mickeyl) | 153 | * Ported brightnessapplet from Qtopia 1.7 (mickeyl) |
153 | * Opie-Eye got a Digital Camera File Backend (alwin,zecke) | 154 | * Opie-Eye got a Digital Camera File Backend (alwin,zecke) |
154 | * Support for Tuxpad1 of Tradesquare.NL (mickeyl,zecke) | 155 | * Support for Tuxpad1 of Tradesquare.NL (mickeyl,zecke) |
155 | * Opie-Console use Custom Font and Size in a Profile (harlekin) | 156 | * Opie-Console use Custom Font and Size in a Profile (harlekin) |
156 | * Opie-Console transparently log the Output and Input to a file (harlekin) | 157 | * Opie-Console transparently log the Output and Input to a file (harlekin) |
157 | * Added new O-menu icon to lock the PDA immediately: opie-lockapplet (clem) | 158 | * Added new O-menu icon to lock the PDA immediately: opie-lockapplet (clem) |
158 | * Opie-Security now hides the plugin-based authentication tabs if no auth. plugin package is installed (clem) | 159 | * Opie-Security now hides the plugin-based authentication tabs if no auth. plugin package is installed (clem) |
159 | * Opie-Security gained a 'test authentication' button (clem) | 160 | * Opie-Security gained a 'test authentication' button (clem) |
160 | * Opie-Eye got a more unique layout (menubar), a slideshow, user can setup some defaults | 161 | * Opie-Eye got a more unique layout (menubar), a slideshow, user can setup some defaults |
161 | * Opie-Mail improve the handling of POP mail boxes (alwin) | 162 | * Opie-Mail improve the handling of POP mail boxes (alwin) |
162 | * Both Opie-Eye and Opie-Mail were greatly improved due the hard work of Rajko Albrecht(alwin) | 163 | * Both Opie-Eye and Opie-Mail were greatly improved due the hard work of Rajko Albrecht(alwin) |
163 | * Opie IRC - backports of the 'NeIRC fork' (zecke) | 164 | * Opie IRC - backports of the 'NeIRC fork' (zecke) |
164 | 165 | ||
165 | Fixed Bugs | 166 | Fixed Bugs |
166 | ---------- | 167 | ---------- |
167 | * #501 - Pickboard is able to show 'Umlaute' (TT,zecke) | 168 | * #501 - Pickboard is able to show 'Umlaute' (TT,zecke) |
168 | * #608 - Make Opie usable for left handed users (zecke) | 169 | * #608 - Make Opie usable for left handed users (zecke) |
169 | * #957 - Import of VCards/VTodos/VEvents with BASE64 encoding (ljp,zecke) | 170 | * #957 - Import of VCards/VTodos/VEvents with BASE64 encoding (ljp,zecke) |
170 | * #1245 - Opie-Go 'paused' (zecke) | 171 | * #1245 - Opie-Go 'paused' (zecke) |
171 | * #1358 - DocTab didn't show any MimeTypes (was fixed earlier) (zecke) | 172 | * #1358 - DocTab didn't show any MimeTypes (was fixed earlier) (zecke) |
172 | * #1380 - QDateBookAccess::remove() doesn't remove entries (eilers, zecke) | 173 | * #1380 - QDateBookAccess::remove() doesn't remove entries (eilers, zecke) |
173 | * #1395 - Build VNC Backend with gcc3.4 | 174 | * #1395 - Build VNC Backend with gcc3.4 |
174 | * #1440 - The icon of opie-mobilemsg is missing (CoreDump) | 175 | * #1440 - The icon of opie-mobilemsg is missing (CoreDump) |
175 | * #1426 - Add missing opie-bartender Icon (CoreDump) | 176 | * #1426 - Add missing opie-bartender Icon (CoreDump) |
176 | * #1445 - Opie-Sheet Has No Icon (CoreDump) | 177 | * #1445 - Opie-Sheet Has No Icon (CoreDump) |
177 | * #1448 - Brightness Applet added (mickeyl) | 178 | * #1448 - Brightness Applet added (mickeyl) |
178 | * #1450 - ZSame didn't clear the bonus item after winning a game (zecke) | 179 | * #1450 - ZSame didn't clear the bonus item after winning a game (zecke) |
179 | * #1482 - Fix OFileSelector to be able to sort by size (zecke) | 180 | * #1482 - Fix OFileSelector to be able to sort by size (zecke) |
180 | * n.a. - Opie-mail: fixed some crasher, some layout-problems | 181 | * n.a. - Opie-mail: fixed some crasher, some layout-problems |
181 | * n.a. - Converted applications to not hardcode /opt/QtPalmtop but to use QPEApplication::qpeDir (zecke) | 182 | * n.a. - Converted applications to not hardcode /opt/QtPalmtop but to use QPEApplication::qpeDir (zecke) |
182 | * n.a. - Converted usage of qpeDir() not to include a '/' as first charachter of the string (zecke) | 183 | * n.a. - Converted usage of qpeDir() not to include a '/' as first charachter of the string (zecke) |
183 | * n.a. - Build system: Enable distcc and ccache when crosscompiling too, and use them everywhere we can (clem) | 184 | * n.a. - Build system: Enable distcc and ccache when crosscompiling too, and use them everywhere we can (clem) |
184 | * n.a. - Build system: Fix deps in several config.in (and fix scripts/deps.pl too) to stop breaking builds, especially with make -j highNumber (clem) | 185 | * n.a. - Build system: Fix deps in several config.in (and fix scripts/deps.pl too) to stop breaking builds, especially with make -j highNumber (clem) |
185 | * n.a. - Removed hardcoded icon size in a couple of applets (mickeyl) | 186 | * n.a. - Removed hardcoded icon size in a couple of applets (mickeyl) |
186 | 187 | ||
187 | Internal | 188 | Internal |
188 | -------- | 189 | -------- |
189 | * Opie-Qashmoney has been moved to unsupported (mickeyl) | 190 | * Opie-Qashmoney has been moved to unsupported (mickeyl) |
190 | * Opie-Ubrowser has been moved to unsupported (mickeyl) | 191 | * Opie-Ubrowser has been moved to unsupported (mickeyl) |
191 | 192 | ||
192 | 2004-09-17Opie 1.1.6 | 193 | 2004-09-17Opie 1.1.6 |
193 | 194 | ||
194 | New Features | 195 | New Features |
195 | ------------ | 196 | ------------ |
196 | * Fifteen gained configurable number of items (zecke) | 197 | * Fifteen gained configurable number of items (zecke) |
197 | * Fifteen can have custom background images (zecke) | 198 | * Fifteen can have custom background images (zecke) |
198 | * Added daemonizing capabilities to QWS Server [via Qt/Embedded] (mickeyl) | 199 | * Added daemonizing capabilities to QWS Server [via Qt/Embedded] (mickeyl) |
199 | * Integrated the new security framework into libopie2 (zecke,clem) | 200 | * Integrated the new security framework into libopie2 (zecke,clem) |
200 | * Converted the launcher to use the new security framework (zecke) | 201 | * Converted the launcher to use the new security framework (zecke) |
201 | * Backup can now handle custom locations for backup and restore (ar) | 202 | * Backup can now handle custom locations for backup and restore (ar) |
202 | * Implemented right-on-hold feedback (wimpie,zecke) | 203 | * Implemented right-on-hold feedback (wimpie,zecke) |
203 | * Lots of new features in opie-reader (tim,pohly) | 204 | * Lots of new features in opie-reader (tim,pohly) |
204 | * Build system cleanups (schurig) | 205 | * Build system cleanups (schurig) |
205 | 206 | ||
206 | Fixed Bugs | 207 | Fixed Bugs |
207 | -------- | 208 | -------- |
208 | * #1005 - Fixed backup to CompactFlash (ar) | 209 | * #1005 - Fixed backup to CompactFlash (ar) |
209 | * #1167 - Fixed Opie write crashing on more text than one page (ar) | 210 | * #1167 - Fixed Opie write crashing on more text than one page (ar) |
210 | * #1225 - Fixed repeated light flashing on Zaurus with keyz (mickeyl) | 211 | * #1225 - Fixed repeated light flashing on Zaurus with keyz (mickeyl) |
211 | * #1359 - Fixed bookmarks in Gutenbrowser (ljp) | 212 | * #1359 - Fixed bookmarks in Gutenbrowser (ljp) |
212 | * #1361 - Fixed auto upercase in Opie-Addressbook (eilers) | 213 | * #1361 - Fixed auto upercase in Opie-Addressbook (eilers) |
213 | * #1370 - Pimconverter now reacts on cancel key (eilers) | 214 | * #1370 - Pimconverter now reacts on cancel key (eilers) |
214 | * #1376 - Bring back the capslock/numlock display (zecke) | 215 | * #1376 - Bring back the capslock/numlock display (zecke) |
215 | * #1383 - Language settings now warns about losing open apps (Markus Litz) | 216 | * #1383 - Language settings now warns about losing open apps (Markus Litz) |
216 | * #1393 - Fixed line wrap issues in opie-console for the default profile (mickeyl) | 217 | * #1393 - Fixed line wrap issues in opie-console for the default profile (mickeyl) |
217 | * #1394 - Fixed oversized headline in opie-login (coredump) | 218 | * #1394 - Fixed oversized headline in opie-login (coredump) |
218 | * #1396 - Opie-console captures the escape key and vim is working (zecke) | 219 | * #1396 - Opie-console captures the escape key and vim is working (zecke) |
219 | * #1401 - Scrollbar is now only visible if necessary in DocTab (mickeyl) | 220 | * #1401 - Scrollbar is now only visible if necessary in DocTab (mickeyl) |
220 | 221 | ||
221 | 2004-07-06Opie 1.1.4 | 222 | 2004-07-06Opie 1.1.4 |
222 | 223 | ||
223 | New Features | 224 | New Features |
224 | ------------ | 225 | ------------ |
225 | * Added four themes courtesy Robert Griebl (http://www.softforge.de/zstyle) | 226 | * Added four themes courtesy Robert Griebl (http://www.softforge.de/zstyle) |
226 | * Added Conversion tool for pim-data (eilers) | 227 | * Added Conversion tool for pim-data (eilers) |
227 | * Introduced new OPimAccessFactory and OBackendFactory which simplyfies database access (eilers) | 228 | * Introduced new OPimAccessFactory and OBackendFactory which simplyfies database access (eilers) |
228 | * Modified the PIM API for providing generic use of OPimRecords (eilers) | 229 | * Modified the PIM API for providing generic use of OPimRecords (eilers) |
229 | * Clicking on the application symbol now iterates over the application's top level widgets if already raised (zecke) | 230 | * Clicking on the application symbol now iterates over the application's top level widgets if already raised (zecke) |
230 | 231 | ||
231 | Fixed Bugs | 232 | Fixed Bugs |
232 | -------- | 233 | -------- |
233 | * #1068 - Country Drop Down Box Off Screen | 234 | * #1068 - Country Drop Down Box Off Screen |
234 | * #1291 - Opie tinykate does not open .desktop files (ar) | 235 | * #1291 - Opie tinykate does not open .desktop files (ar) |
235 | * #1291 - Opie sheet not saving correctly (ar) | 236 | * #1291 - Opie sheet not saving correctly (ar) |
236 | * #1294 - Opie does not know about British Summer Time | 237 | * #1294 - Opie does not know about British Summer Time |
237 | * #1314 - Drawpad initialization (mickeyl) | 238 | * #1314 - Drawpad initialization (mickeyl) |
238 | * #1317 - Packagemanager crashes on hold-down or install (chicken) | 239 | * #1317 - Packagemanager crashes on hold-down or install (chicken) |
239 | * #1321 - Batteryapplet graphic glitch (harlekin) | 240 | * #1321 - Batteryapplet graphic glitch (harlekin) |
240 | * #1324 - ZSafe not starting up (mickeyl) | 241 | * #1324 - ZSafe not starting up (mickeyl) |
241 | * #1328 - Personal Home Address fields is trimmed to 1char (eilers) | 242 | * #1328 - Personal Home Address fields is trimmed to 1char (eilers) |
242 | * #1327 - Opie-mail ipk does not depend on libopiedb2 (chicken) | 243 | * #1327 - Opie-mail ipk does not depend on libopiedb2 (chicken) |
243 | * #1345 - Networksettingsplugin wlan plugin dependency on libpcap0 (mickeyl) | 244 | * #1345 - Networksettingsplugin wlan plugin dependency on libpcap0 (mickeyl) |
244 | * #1348 - Datebook dependency on libopiedb2 (chicken) | 245 | * #1348 - Datebook dependency on libopiedb2 (chicken) |
245 | * #1328 - Switched SQLDatabase and VCards char encoding from latin1 to unicode (eilers) | 246 | * #1328 - Switched SQLDatabase and VCards char encoding from latin1 to unicode (eilers) |
246 | 247 | ||
247 | 2004-04-25Opie 1.1.3 | 248 | 2004-04-25Opie 1.1.3 |
248 | 249 | ||
249 | * Introduced first implementation of SQL-Support using SQLite (eilers) | 250 | * Introduced first implementation of SQL-Support using SQLite (eilers) |
250 | * Added a new Gutenberg Project reader app - opie-gutenbrowser (ljp) | 251 | * Added a new Gutenberg Project reader app - opie-gutenbrowser (ljp) |
251 | * Added a real system graffiti character set (brad) | 252 | * Added a real system graffiti character set (brad) |
252 | * Added Generic Keyconfig Widget (zecke) | 253 | * Added Generic Keyconfig Widget (zecke) |
253 | * Improved Screenshotapplet and Drawpad integration. You can now open a screenshot in drawpad and take notes (zecke) | 254 | * Improved Screenshotapplet and Drawpad integration. You can now open a screenshot in drawpad and take notes (zecke) |
254 | * Added new Bible reader app - opie-dagger (drw) | 255 | * Added new Bible reader app - opie-dagger (drw) |
255 | * Added a new Image Viewer. Work is ongoing (zecke,alwin) | 256 | * Added a new Image Viewer. Work is ongoing (zecke,alwin) |
256 | * Added namespace usage in libopie2 and everywhere (zecke,alwin) | 257 | * Added namespace usage in libopie2 and everywhere (zecke,alwin) |
257 | * Enabled the possibility to pass command line arguments to applications (mickeyl) | 258 | * Enabled the possibility to pass command line arguments to applications (mickeyl) |
258 | * Added an about applet showing some credits and information about Opie (mickeyl) | 259 | * Added an about applet showing some credits and information about Opie (mickeyl) |
259 | * Added benchmarking functionality to sysinfo (mickeyl) | 260 | * Added benchmarking functionality to sysinfo (mickeyl) |
260 | * Added applet and configuration application for switching hardware keyboard layouts (alwin) | 261 | * Added applet and configuration application for switching hardware keyboard layouts (alwin) |
261 | * Ported applications from libopie1 to libopie2* (drw,ar,alwin) | 262 | * Ported applications from libopie1 to libopie2* (drw,ar,alwin) |
262 | * Imported fullscreen and font improvements from the Qkonsole fork to embeddedkonsole (waspe) | 263 | * Imported fullscreen and font improvements from the Qkonsole fork to embeddedkonsole (waspe) |
263 | * Clean-up of package information in control files (drw) | 264 | * Clean-up of package information in control files (drw) |
264 | * Repaired mediummount which was broken since integrating the quicklauncher (alwin) | 265 | * Repaired mediummount which was broken since integrating the quicklauncher (alwin) |
265 | * Improved big-screen support (zecke,ar) | 266 | * Improved big-screen support (zecke,ar) |
266 | * Improved multikeyboard support, added keyboard layout switching applet (mouse) | 267 | * Improved multikeyboard support, added keyboard layout switching applet (mouse) |
267 | * Added a new mail client based on libetpan (harlekin,alwin,jgf) | 268 | * Added a new mail client based on libetpan (harlekin,alwin,jgf) |
268 | * Added new package manager - opie-packagemanager (drw) | 269 | * Added new package manager - opie-packagemanager (drw) |
269 | * Improved light-n-power for C7x0 (mickeyl) | 270 | * Improved light-n-power for C7x0 (mickeyl) |
270 | * Added automatic rotation support for C7x0 (treke) | 271 | * Added automatic rotation support for C7x0 (treke) |
271 | * Split libopie1 up into a set of smaller - functionally grouped - libraries (mickeyl) | 272 | * Split libopie1 up into a set of smaller - functionally grouped - libraries (mickeyl) |
272 | * Added scanning the wireless network neighbourhood to networksettings (mickeyl) | 273 | * Added scanning the wireless network neighbourhood to networksettings (mickeyl) |
273 | 274 | ||
274 | 2003-11-29Opie 1.0.3 | 275 | 2003-11-29Opie 1.0.3 |
275 | 276 | ||
276 | * Released as Version 1.0.3 | 277 | * Released as Version 1.0.3 |
277 | * Improved i18n (various contributors) | 278 | * Improved i18n (various contributors) |
278 | * Reduced application startup time by integrating the TT quicklauncher (zecke,harlekin) | 279 | * Reduced application startup time by integrating the TT quicklauncher (zecke,harlekin) |
279 | * Made the Documents Tab optional (mickeyl) | 280 | * Made the Documents Tab optional (mickeyl) |
280 | * Integrated basic support for HP iPAQ 54xx and the Jornada 5xx (chicken) | 281 | * Integrated basic support for HP iPAQ 54xx and the Jornada 5xx (chicken) |
281 | 282 | ||
282 | 2003-08-04Opie 1.0.0 | 283 | 2003-08-04Opie 1.0.0 |
283 | 284 | ||
284 | * Released as Version 1.0.0 | 285 | * Released as Version 1.0.0 |
285 | * Including a PPP module for easy dial up (tille,harlekin,zecke) | 286 | * Including a PPP module for easy dial up (tille,harlekin,zecke) |
diff --git a/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp b/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp index 3222e50..a7b0bdc 100644 --- a/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp +++ b/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp | |||
@@ -1,791 +1,793 @@ | |||
1 | 1 | ||
2 | #include "mainwindowimp.h" | 2 | #include "mainwindowimp.h" |
3 | #include "addconnectionimp.h" | 3 | #include "addconnectionimp.h" |
4 | #include "interfaceinformationimp.h" | 4 | #include "interfaceinformationimp.h" |
5 | #include "interfacesetupimp.h" | 5 | #include "interfacesetupimp.h" |
6 | #include "interfaces.h" | 6 | #include "interfaces.h" |
7 | #include "module.h" | 7 | #include "module.h" |
8 | 8 | ||
9 | /* OPIE */ | 9 | /* OPIE */ |
10 | #include <opie2/odebug.h> | 10 | #include <opie2/odebug.h> |
11 | #include <opie2/oprocess.h> | 11 | #include <opie2/oprocess.h> |
12 | #include <qpe/applnk.h> | 12 | #include <qpe/applnk.h> |
13 | #include <qpe/qcopenvelope_qws.h> | 13 | #include <qpe/qcopenvelope_qws.h> |
14 | #include <qpe/qpeapplication.h> | 14 | #include <qpe/qpeapplication.h> |
15 | #include <qpe/config.h> | 15 | #include <qpe/config.h> |
16 | #include <qpe/qlibrary.h> | 16 | #include <qpe/qlibrary.h> |
17 | #include <qpe/resource.h> | 17 | #include <qpe/resource.h> |
18 | 18 | ||
19 | /* QT */ | 19 | /* QT */ |
20 | #include <qpushbutton.h> | 20 | #include <qpushbutton.h> |
21 | #include <qlistbox.h> | 21 | #include <qlistbox.h> |
22 | #include <qlineedit.h> | 22 | #include <qlineedit.h> |
23 | #include <qlistview.h> | 23 | #include <qlistview.h> |
24 | #include <qheader.h> | 24 | #include <qheader.h> |
25 | #include <qlabel.h> | 25 | #include <qlabel.h> |
26 | #include <qtabwidget.h> // in order to disable the profiles tab | 26 | #include <qtabwidget.h> // in order to disable the profiles tab |
27 | #include <qmessagebox.h> | 27 | #include <qmessagebox.h> |
28 | #include <qtextstream.h> | 28 | #include <qtextstream.h> |
29 | #include <qregexp.h> | 29 | #include <qregexp.h> |
30 | 30 | ||
31 | 31 | ||
32 | #if QT_VERSION < 0x030000 | 32 | #if QT_VERSION < 0x030000 |
33 | #include <qlist.h> | 33 | #include <qlist.h> |
34 | #else | 34 | #else |
35 | #include <qptrlist.h> | 35 | #include <qptrlist.h> |
36 | #endif | 36 | #endif |
37 | #include <qdir.h> | 37 | #include <qdir.h> |
38 | #include <qfile.h> | 38 | #include <qfile.h> |
39 | #include <qtextstream.h> | 39 | #include <qtextstream.h> |
40 | #include <qregexp.h> | 40 | #include <qregexp.h> |
41 | 41 | ||
42 | /* STD */ | 42 | /* STD */ |
43 | #include <net/if.h> | 43 | #include <net/if.h> |
44 | #include <sys/ioctl.h> | 44 | #include <sys/ioctl.h> |
45 | #include <sys/socket.h> | 45 | #include <sys/socket.h> |
46 | 46 | ||
47 | #define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" | 47 | #define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" |
48 | #define _PROCNETDEV "/proc/net/dev" | 48 | #define _PROCNETDEV "/proc/net/dev" |
49 | 49 | ||
50 | // is this always right? | 50 | // is this always right? |
51 | #define _HOSTFILE "/etc/hostname" | 51 | #define _HOSTFILE "/etc/hostname" |
52 | #define _IRDANAME "/proc/sys/net/irda/devname" | 52 | #define _IRDANAME "/proc/sys/net/irda/devname" |
53 | 53 | ||
54 | using namespace Opie::Core; | 54 | using namespace Opie::Core; |
55 | 55 | ||
56 | MainWindowImp::MainWindowImp(QWidget *parent, const char *name, WFlags) : MainWindow(parent, name, Qt::WStyle_ContextHelp), advancedUserMode(true), scheme(DEFAULT_SCHEME) | 56 | MainWindowImp::MainWindowImp(QWidget *parent, const char *name, WFlags) : MainWindow(parent, name, Qt::WStyle_ContextHelp), advancedUserMode(true), scheme(DEFAULT_SCHEME) |
57 | { | 57 | { |
58 | connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); | 58 | connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); |
59 | connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); | 59 | connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); |
60 | connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); | 60 | connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); |
61 | connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); | 61 | connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); |
62 | 62 | ||
63 | //remove tab with no function | 63 | //remove tab with no function |
64 | tabWidget->removePage( tab ); | 64 | tabWidget->removePage( tab ); |
65 | 65 | ||
66 | // Load connections. | 66 | // Load connections. |
67 | // /usr/local/kde/lib/libinterfaces.la | 67 | // /usr/local/kde/lib/libinterfaces.la |
68 | loadModules(QPEApplication::qpeDir() + "plugins/networksettings"); | 68 | loadModules(QPEApplication::qpeDir() + "plugins/networksettings"); |
69 | getAllInterfaces(); | 69 | getAllInterfaces(); |
70 | 70 | ||
71 | Interfaces i; | 71 | Interfaces i; |
72 | QStringList list = i.getInterfaceList(); | 72 | QStringList list = i.getInterfaceList(); |
73 | QMap<QString, Interface*>::Iterator it; | 73 | QMap<QString, Interface*>::Iterator it; |
74 | for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) | 74 | for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) |
75 | { | 75 | { |
76 | /* | 76 | /* |
77 | * we skipped it in getAllInterfaces now | 77 | * we skipped it in getAllInterfaces now |
78 | * we need to ignore it as well | 78 | * we need to ignore it as well |
79 | */ | 79 | */ |
80 | if (m_handledIfaces.contains( *ni) ) | 80 | if (m_handledIfaces.contains( *ni) ) |
81 | { | 81 | { |
82 | odebug << "Not up iface handled by module" << oendl; | 82 | odebug << "Not up iface handled by module" << oendl; |
83 | continue; | 83 | continue; |
84 | } | 84 | } |
85 | bool found = false; | 85 | bool found = false; |
86 | for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ) | 86 | for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ) |
87 | { | 87 | { |
88 | if(it.key() == (*ni)) | 88 | if(it.key() == (*ni)) |
89 | found = true; | 89 | found = true; |
90 | } | 90 | } |
91 | if(!found) | 91 | if(!found) |
92 | { | 92 | { |
93 | if(!(*ni).contains("_")) | 93 | if(!(*ni).contains("_")) |
94 | { | 94 | { |
95 | Interface *i = new Interface(this, *ni, false); | 95 | Interface *i = new Interface(this, *ni, false); |
96 | i->setAttached(false); | 96 | i->setAttached(false); |
97 | i->setHardwareName(tr("Disconnected")); | 97 | i->setHardwareName(tr("Disconnected")); |
98 | interfaceNames.insert(i->getInterfaceName(), i); | 98 | interfaceNames.insert(i->getInterfaceName(), i); |
99 | updateInterface(i); | 99 | updateInterface(i); |
100 | connect(i, SIGNAL(updateInterface(Interface*)), this, SLOT(updateInterface(Interface*))); | 100 | connect(i, SIGNAL(updateInterface(Interface*)), this, SLOT(updateInterface(Interface*))); |
101 | } | 101 | } |
102 | } | 102 | } |
103 | } | 103 | } |
104 | 104 | ||
105 | //getInterfaceList(); | 105 | //getInterfaceList(); |
106 | connectionList->header()->hide(); | 106 | connectionList->header()->hide(); |
107 | 107 | ||
108 | Config cfg("NetworkSetup"); | 108 | Config cfg("NetworkSetup"); |
109 | profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); | 109 | profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); |
110 | for ( QStringList::Iterator it = profiles.begin(); | 110 | for ( QStringList::Iterator it = profiles.begin(); |
111 | it != profiles.end(); ++it) | 111 | it != profiles.end(); ++it) |
112 | profilesList->insertItem((*it)); | 112 | profilesList->insertItem((*it)); |
113 | currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); | 113 | currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); |
114 | advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); | 114 | advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); |
115 | scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); | 115 | scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); |
116 | 116 | ||
117 | QFile file(scheme); | 117 | QFile file(scheme); |
118 | if ( file.open(IO_ReadOnly) ) | 118 | if ( file.open(IO_ReadOnly) ) |
119 | { // file opened successfully | 119 | { // file opened successfully |
120 | QTextStream stream( &file ); // use a text stream | 120 | QTextStream stream( &file ); // use a text stream |
121 | while ( !stream.eof() ) | 121 | while ( !stream.eof() ) |
122 | { // until end of file... | 122 | { // until end of file... |
123 | QString line = stream.readLine(); // line of text excluding '\n' | 123 | QString line = stream.readLine(); // line of text excluding '\n' |
124 | if(line.contains("SCHEME")) | 124 | if(line.contains("SCHEME")) |
125 | { | 125 | { |
126 | line = line.mid(7, line.length()); | 126 | line = line.mid(7, line.length()); |
127 | currentProfileLabel->setText(line); | 127 | currentProfileLabel->setText(line); |
128 | break; | 128 | break; |
129 | } | 129 | } |
130 | } | 130 | } |
131 | file.close(); | 131 | file.close(); |
132 | } | 132 | } |
133 | makeChannel(); | 133 | makeChannel(); |
134 | initHostname(); | 134 | initHostname(); |
135 | } | 135 | } |
136 | 136 | ||
137 | /** | 137 | /** |
138 | * Deconstructor. Save profiles. Delete loaded libraries. | 138 | * Deconstructor. Save profiles. Delete loaded libraries. |
139 | */ | 139 | */ |
140 | MainWindowImp::~MainWindowImp() | 140 | MainWindowImp::~MainWindowImp() |
141 | { | 141 | { |
142 | // Save profiles. | 142 | // Save profiles. |
143 | Config cfg("NetworkSetup"); | 143 | Config cfg("NetworkSetup"); |
144 | cfg.setGroup("General"); | 144 | cfg.setGroup("General"); |
145 | cfg.writeEntry("Profiles", profiles.join(" ")); | 145 | cfg.writeEntry("Profiles", profiles.join(" ")); |
146 | 146 | ||
147 | // Delete all interfaces that don't have owners. | 147 | // Delete all interfaces that don't have owners. |
148 | QMap<Interface*, QListViewItem*>::Iterator iIt; | 148 | QMap<Interface*, QListViewItem*>::Iterator iIt; |
149 | for( iIt = items.begin(); iIt != items.end(); ++iIt ) | 149 | for( iIt = items.begin(); iIt != items.end(); ++iIt ) |
150 | { | 150 | { |
151 | if(iIt.key()->getModuleOwner() == NULL) | 151 | if(iIt.key()->getModuleOwner() == NULL) |
152 | delete iIt.key(); | 152 | delete iIt.key(); |
153 | } | 153 | } |
154 | 154 | ||
155 | // Delete Modules and Libraries | 155 | // Delete Modules and Libraries |
156 | QMap<Module*, QLibrary*>::Iterator it; | 156 | QMap<Module*, QLibrary*>::Iterator it; |
157 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 157 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
158 | { | 158 | { |
159 | delete it.key(); | 159 | delete it.key(); |
160 | // I wonder why I can't delete the libraries | 160 | // I wonder why I can't delete the libraries |
161 | // What fucking shit this is. | 161 | // What fucking shit this is. |
162 | //delete it.data(); | 162 | //delete it.data(); |
163 | } | 163 | } |
164 | } | 164 | } |
165 | 165 | ||
166 | /** | 166 | /** |
167 | * Query the kernel for all of the interfaces. | 167 | * Query the kernel for all of the interfaces. |
168 | */ | 168 | */ |
169 | void MainWindowImp::getAllInterfaces() | 169 | void MainWindowImp::getAllInterfaces() |
170 | { | 170 | { |
171 | int sockfd = socket(PF_INET, SOCK_DGRAM, 0); | 171 | int sockfd = socket(PF_INET, SOCK_DGRAM, 0); |
172 | if(sockfd == -1) | 172 | if(sockfd == -1) |
173 | return; | 173 | return; |
174 | 174 | ||
175 | struct ifreq ifr; | 175 | struct ifreq ifr; |
176 | QStringList ifaces; | 176 | QStringList ifaces; |
177 | QFile procFile(QString(_PROCNETDEV)); | 177 | QFile procFile(QString(_PROCNETDEV)); |
178 | int result; | 178 | int result; |
179 | Interface *i; | 179 | Interface *i; |
180 | 180 | ||
181 | if (! procFile.exists()) | 181 | if (! procFile.exists()) |
182 | { | 182 | { |
183 | struct ifreq ifrs[100]; | 183 | struct ifreq ifrs[100]; |
184 | struct ifconf ifc; | 184 | struct ifconf ifc; |
185 | ifc.ifc_len = sizeof(ifrs); | 185 | ifc.ifc_len = sizeof(ifrs); |
186 | ifc.ifc_req = ifrs; | 186 | ifc.ifc_req = ifrs; |
187 | result = ioctl(sockfd, SIOCGIFCONF, &ifc); | 187 | result = ioctl(sockfd, SIOCGIFCONF, &ifc); |
188 | 188 | ||
189 | for (unsigned int i = 0; i < ifc.ifc_len / sizeof(struct ifreq); i++) | 189 | for (unsigned int i = 0; i < ifc.ifc_len / sizeof(struct ifreq); i++) |
190 | { | 190 | { |
191 | struct ifreq *pifr = &ifrs[i]; | 191 | struct ifreq *pifr = &ifrs[i]; |
192 | 192 | if ( !QString( pifr->ifr_name ).startsWith( "wifi" ) ) ifaces += pifr->ifr_name; | |
193 | ifaces += pifr->ifr_name; | 193 | else odebug << "ignoring hostap control interface " << pifr->ifr_name << oendl; |
194 | } | 194 | } |
195 | } | 195 | } |
196 | else | 196 | else |
197 | { | 197 | { |
198 | procFile.open(IO_ReadOnly); | 198 | procFile.open(IO_ReadOnly); |
199 | QString line; | 199 | QString line; |
200 | QTextStream procTs(&procFile); | 200 | QTextStream procTs(&procFile); |
201 | int loc = -1; | 201 | int loc = -1; |
202 | 202 | ||
203 | procTs.readLine(); // eat a line | 203 | procTs.readLine(); // eat a line |
204 | procTs.readLine(); // eat a line | 204 | procTs.readLine(); // eat a line |
205 | while((line = procTs.readLine().simplifyWhiteSpace()) != QString::null) | 205 | while((line = procTs.readLine().simplifyWhiteSpace()) != QString::null) |
206 | { | 206 | { |
207 | if((loc = line.find(":")) != -1) | 207 | if((loc = line.find(":")) != -1) |
208 | { | 208 | { |
209 | ifaces += line.left(loc); | 209 | // ignore wifi* (hostap control interfaces) |
210 | if ( !line.left(loc).startsWith( "wifi" ) ) ifaces += line.left(loc); | ||
211 | else odebug << "ignoring hostap control interface " << line.left(loc) << oendl; | ||
210 | } | 212 | } |
211 | } | 213 | } |
212 | } | 214 | } |
213 | 215 | ||
214 | for (QStringList::Iterator it = ifaces.begin(); it != ifaces.end(); ++it) | 216 | for (QStringList::Iterator it = ifaces.begin(); it != ifaces.end(); ++it) |
215 | { | 217 | { |
216 | int flags = 0; | 218 | int flags = 0; |
217 | if ( m_handledIfaces.contains( (*it) ) ) | 219 | if ( m_handledIfaces.contains( (*it) ) ) |
218 | { | 220 | { |
219 | odebug << " " << (*it).latin1() << " is handled by a module" << oendl; | 221 | odebug << " " << (*it).latin1() << " is handled by a module" << oendl; |
220 | continue; | 222 | continue; |
221 | } | 223 | } |
222 | // int family; | 224 | // int family; |
223 | i = NULL; | 225 | i = NULL; |
224 | 226 | ||
225 | strcpy(ifr.ifr_name, (*it).latin1()); | 227 | strcpy(ifr.ifr_name, (*it).latin1()); |
226 | 228 | ||
227 | struct ifreq ifcopy; | 229 | struct ifreq ifcopy; |
228 | ifcopy = ifr; | 230 | ifcopy = ifr; |
229 | result = ioctl(sockfd, SIOCGIFFLAGS, &ifcopy); | 231 | result = ioctl(sockfd, SIOCGIFFLAGS, &ifcopy); |
230 | flags = ifcopy.ifr_flags; | 232 | flags = ifcopy.ifr_flags; |
231 | i = new Interface(this, ifr.ifr_name, false); | 233 | i = new Interface(this, ifr.ifr_name, false); |
232 | i->setAttached(true); | 234 | i->setAttached(true); |
233 | if ((flags & IFF_UP) == IFF_UP) | 235 | if ((flags & IFF_UP) == IFF_UP) |
234 | i->setStatus(true); | 236 | i->setStatus(true); |
235 | else | 237 | else |
236 | i->setStatus(false); | 238 | i->setStatus(false); |
237 | 239 | ||
238 | if ((flags & IFF_BROADCAST) == IFF_BROADCAST) | 240 | if ((flags & IFF_BROADCAST) == IFF_BROADCAST) |
239 | i->setHardwareName("Ethernet"); | 241 | i->setHardwareName("Ethernet"); |
240 | else if ((flags & IFF_POINTOPOINT) == IFF_POINTOPOINT) | 242 | else if ((flags & IFF_POINTOPOINT) == IFF_POINTOPOINT) |
241 | i->setHardwareName("Point to Point"); | 243 | i->setHardwareName("Point to Point"); |
242 | else if ((flags & IFF_MULTICAST) == IFF_MULTICAST) | 244 | else if ((flags & IFF_MULTICAST) == IFF_MULTICAST) |
243 | i->setHardwareName("Multicast"); | 245 | i->setHardwareName("Multicast"); |
244 | else if ((flags & IFF_LOOPBACK) == IFF_LOOPBACK) | 246 | else if ((flags & IFF_LOOPBACK) == IFF_LOOPBACK) |
245 | i->setHardwareName("Loopback"); | 247 | i->setHardwareName("Loopback"); |
246 | else | 248 | else |
247 | i->setHardwareName("Unknown"); | 249 | i->setHardwareName("Unknown"); |
248 | 250 | ||
249 | owarn << "Adding interface " << ifr.ifr_name << " to interfaceNames\n" << oendl; | 251 | owarn << "Adding interface " << ifr.ifr_name << " to interfaceNames\n" << oendl; |
250 | interfaceNames.insert(i->getInterfaceName(), i); | 252 | interfaceNames.insert(i->getInterfaceName(), i); |
251 | updateInterface(i); | 253 | updateInterface(i); |
252 | connect(i, SIGNAL(updateInterface(Interface*)), | 254 | connect(i, SIGNAL(updateInterface(Interface*)), |
253 | this, SLOT(updateInterface(Interface*))); | 255 | this, SLOT(updateInterface(Interface*))); |
254 | } | 256 | } |
255 | // now lets ask the plugins too ;) | 257 | // now lets ask the plugins too ;) |
256 | QMap<Module*, QLibrary*>::Iterator it; | 258 | QMap<Module*, QLibrary*>::Iterator it; |
257 | QList<Interface> ilist; | 259 | QList<Interface> ilist; |
258 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 260 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
259 | { | 261 | { |
260 | if(it.key()) | 262 | if(it.key()) |
261 | { | 263 | { |
262 | ilist = it.key()->getInterfaces(); | 264 | ilist = it.key()->getInterfaces(); |
263 | for( i = ilist.first(); i != 0; i = ilist.next() ) | 265 | for( i = ilist.first(); i != 0; i = ilist.next() ) |
264 | { | 266 | { |
265 | owarn << "Adding interface " << i->getInterfaceName().latin1() << " to interfaceNames\n" << oendl; | 267 | owarn << "Adding interface " << i->getInterfaceName().latin1() << " to interfaceNames\n" << oendl; |
266 | interfaceNames.insert(i->getInterfaceName(), i); | 268 | interfaceNames.insert(i->getInterfaceName(), i); |
267 | updateInterface(i); | 269 | updateInterface(i); |
268 | connect(i, SIGNAL(updateInterface(Interface*)), | 270 | connect(i, SIGNAL(updateInterface(Interface*)), |
269 | this, SLOT(updateInterface(Interface*))); | 271 | this, SLOT(updateInterface(Interface*))); |
270 | } | 272 | } |
271 | } | 273 | } |
272 | } | 274 | } |
273 | } | 275 | } |
274 | 276 | ||
275 | /** | 277 | /** |
276 | * Load all modules that are found in the path | 278 | * Load all modules that are found in the path |
277 | * @param path a directory that is scaned for any plugins that can be loaded | 279 | * @param path a directory that is scaned for any plugins that can be loaded |
278 | * and attempts to load them | 280 | * and attempts to load them |
279 | */ | 281 | */ |
280 | void MainWindowImp::loadModules(const QString &path) | 282 | void MainWindowImp::loadModules(const QString &path) |
281 | { | 283 | { |
282 | #ifdef DEBUG | 284 | #ifdef DEBUG |
283 | odebug << "MainWindowImp::loadModules: " << path.latin1() << "" << oendl; | 285 | odebug << "MainWindowImp::loadModules: " << path.latin1() << "" << oendl; |
284 | #endif | 286 | #endif |
285 | QDir d(path); | 287 | QDir d(path); |
286 | if(!d.exists()) | 288 | if(!d.exists()) |
287 | return; | 289 | return; |
288 | 290 | ||
289 | QString lang = ::getenv("LANG"); | 291 | QString lang = ::getenv("LANG"); |
290 | // Don't want sym links | 292 | // Don't want sym links |
291 | d.setFilter( QDir::Files | QDir::NoSymLinks ); | 293 | d.setFilter( QDir::Files | QDir::NoSymLinks ); |
292 | const QFileInfoList *list = d.entryInfoList(); | 294 | const QFileInfoList *list = d.entryInfoList(); |
293 | QFileInfoListIterator it( *list ); | 295 | QFileInfoListIterator it( *list ); |
294 | QFileInfo *fi; | 296 | QFileInfo *fi; |
295 | while ( (fi=it.current()) ) | 297 | while ( (fi=it.current()) ) |
296 | { | 298 | { |
297 | if(fi->fileName().contains(".so")) | 299 | if(fi->fileName().contains(".so")) |
298 | { | 300 | { |
299 | /* if loaded install translation */ | 301 | /* if loaded install translation */ |
300 | if( loadPlugin(path + "/" + fi->fileName()) != 0l ){ | 302 | if( loadPlugin(path + "/" + fi->fileName()) != 0l ){ |
301 | QTranslator *trans = new QTranslator(qApp); | 303 | QTranslator *trans = new QTranslator(qApp); |
302 | QString fn = QPEApplication::qpeDir()+"i18n/"+lang+"/"+ fi->fileName().left( fi->fileName().find(".") )+".qm"; | 304 | QString fn = QPEApplication::qpeDir()+"i18n/"+lang+"/"+ fi->fileName().left( fi->fileName().find(".") )+".qm"; |
303 | if( trans->load( fn ) ) | 305 | if( trans->load( fn ) ) |
304 | qApp->installTranslator( trans ); | 306 | qApp->installTranslator( trans ); |
305 | else | 307 | else |
306 | delete trans; | 308 | delete trans; |
307 | } | 309 | } |
308 | odebug << "loaded plugin: >" << QString(path + "/" + fi->fileName()).latin1() << "< " << oendl; | 310 | odebug << "loaded plugin: >" << QString(path + "/" + fi->fileName()).latin1() << "< " << oendl; |
309 | } | 311 | } |
310 | ++it; | 312 | ++it; |
311 | } | 313 | } |
312 | } | 314 | } |
313 | 315 | ||
314 | /** | 316 | /** |
315 | * Attempt to load a function and resolve a function. | 317 | * Attempt to load a function and resolve a function. |
316 | * @param pluginFileName - the name of the file in which to attempt to load | 318 | * @param pluginFileName - the name of the file in which to attempt to load |
317 | * @param resolveString - function pointer to resolve | 319 | * @param resolveString - function pointer to resolve |
318 | * @return pointer to the function with name resolveString or NULL | 320 | * @return pointer to the function with name resolveString or NULL |
319 | */ | 321 | */ |
320 | Module* MainWindowImp::loadPlugin(const QString &pluginFileName, const QString &resolveString) | 322 | Module* MainWindowImp::loadPlugin(const QString &pluginFileName, const QString &resolveString) |
321 | { | 323 | { |
322 | #ifdef DEBUG | 324 | #ifdef DEBUG |
323 | odebug << "MainWindowImp::loadPlugin: " << pluginFileName.latin1() << ": resolving " << resolveString.latin1() << "" << oendl; | 325 | odebug << "MainWindowImp::loadPlugin: " << pluginFileName.latin1() << ": resolving " << resolveString.latin1() << "" << oendl; |
324 | #endif | 326 | #endif |
325 | QLibrary *lib = new QLibrary(pluginFileName); | 327 | QLibrary *lib = new QLibrary(pluginFileName); |
326 | void *functionPointer = lib->resolve(resolveString); | 328 | void *functionPointer = lib->resolve(resolveString); |
327 | if( !functionPointer ) | 329 | if( !functionPointer ) |
328 | { | 330 | { |
329 | #ifdef DEBUG | 331 | #ifdef DEBUG |
330 | odebug << "MainWindowImp::loadPlugin: Warning: " << pluginFileName.latin1() << " is not a plugin" << oendl; | 332 | odebug << "MainWindowImp::loadPlugin: Warning: " << pluginFileName.latin1() << " is not a plugin" << oendl; |
331 | #endif | 333 | #endif |
332 | delete lib; | 334 | delete lib; |
333 | return 0; | 335 | return 0; |
334 | } | 336 | } |
335 | // Try to get an object. | 337 | // Try to get an object. |
336 | Module *object = ((Module* (*)()) functionPointer)(); | 338 | Module *object = ((Module* (*)()) functionPointer)(); |
337 | if(object == 0) | 339 | if(object == 0) |
338 | { | 340 | { |
339 | #ifdef DEBUG | 341 | #ifdef DEBUG |
340 | odebug << "MainWindowImp: Couldn't create object, but did load library!" << oendl; | 342 | odebug << "MainWindowImp: Couldn't create object, but did load library!" << oendl; |
341 | #endif | 343 | #endif |
342 | delete lib; | 344 | delete lib; |
343 | return 0; | 345 | return 0; |
344 | } | 346 | } |
345 | 347 | ||
346 | m_handledIfaces += object->handledInterfaceNames(); | 348 | m_handledIfaces += object->handledInterfaceNames(); |
347 | // Store for deletion later | 349 | // Store for deletion later |
348 | libraries.insert(object, lib); | 350 | libraries.insert(object, lib); |
349 | return object; | 351 | return object; |
350 | } | 352 | } |
351 | 353 | ||
352 | /** | 354 | /** |
353 | * The Add button was clicked. Bring up the add dialog and if OK is hit | 355 | * The Add button was clicked. Bring up the add dialog and if OK is hit |
354 | * load the plugin and append it to the list | 356 | * load the plugin and append it to the list |
355 | */ | 357 | */ |
356 | void MainWindowImp::addClicked() | 358 | void MainWindowImp::addClicked() |
357 | { | 359 | { |
358 | QMap<Module*, QLibrary*>::Iterator it; | 360 | QMap<Module*, QLibrary*>::Iterator it; |
359 | QMap<QString, QString> list; | 361 | QMap<QString, QString> list; |
360 | QMap<QString, Module*> newInterfaceOwners; | 362 | QMap<QString, Module*> newInterfaceOwners; |
361 | 363 | ||
362 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 364 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
363 | { | 365 | { |
364 | if(it.key()) | 366 | if(it.key()) |
365 | { | 367 | { |
366 | (it.key())->possibleNewInterfaces(list); | 368 | (it.key())->possibleNewInterfaces(list); |
367 | } | 369 | } |
368 | } | 370 | } |
369 | // See if the list has anything that we can add. | 371 | // See if the list has anything that we can add. |
370 | if(list.count() == 0) | 372 | if(list.count() == 0) |
371 | { | 373 | { |
372 | QMessageBox::information(this, "Sorry", "Nothing to add.", QMessageBox::Ok); | 374 | QMessageBox::information(this, "Sorry", "Nothing to add.", QMessageBox::Ok); |
373 | return; | 375 | return; |
374 | } | 376 | } |
375 | AddConnectionImp addNewConnection(this, "AddConnectionImp", true); | 377 | AddConnectionImp addNewConnection(this, "AddConnectionImp", true); |
376 | addNewConnection.addConnections(list); | 378 | addNewConnection.addConnections(list); |
377 | if( QDialog::Accepted == QPEApplication::execDialog( &addNewConnection ) ) | 379 | if( QDialog::Accepted == QPEApplication::execDialog( &addNewConnection ) ) |
378 | { | 380 | { |
379 | QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); | 381 | QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); |
380 | if(!item) | 382 | if(!item) |
381 | return; | 383 | return; |
382 | 384 | ||
383 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 385 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
384 | { | 386 | { |
385 | if(it.key()) | 387 | if(it.key()) |
386 | { | 388 | { |
387 | Interface *i = (it.key())->addNewInterface(item->text(0)); | 389 | Interface *i = (it.key())->addNewInterface(item->text(0)); |
388 | if(i) | 390 | if(i) |
389 | { | 391 | { |
390 | odebug << "iface name " << i->getInterfaceName().latin1() << "" << oendl; | 392 | odebug << "iface name " << i->getInterfaceName().latin1() << "" << oendl; |
391 | interfaceNames.insert(i->getInterfaceName(), i); | 393 | interfaceNames.insert(i->getInterfaceName(), i); |
392 | updateInterface(i); | 394 | updateInterface(i); |
393 | } | 395 | } |
394 | } | 396 | } |
395 | } | 397 | } |
396 | } | 398 | } |
397 | } | 399 | } |
398 | 400 | ||
399 | /** | 401 | /** |
400 | * Prompt the user to see if they really want to do this. | 402 | * Prompt the user to see if they really want to do this. |
401 | * If they do then remove from the list and unload. | 403 | * If they do then remove from the list and unload. |
402 | */ | 404 | */ |
403 | void MainWindowImp::removeClicked() | 405 | void MainWindowImp::removeClicked() |
404 | { | 406 | { |
405 | QListViewItem *item = connectionList->currentItem(); | 407 | QListViewItem *item = connectionList->currentItem(); |
406 | if(!item) | 408 | if(!item) |
407 | { | 409 | { |
408 | QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); | 410 | QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); |
409 | return; | 411 | return; |
410 | } | 412 | } |
411 | 413 | ||
412 | Interface *i = interfaceItems[item]; | 414 | Interface *i = interfaceItems[item]; |
413 | if(i->getModuleOwner() == NULL) | 415 | if(i->getModuleOwner() == NULL) |
414 | { | 416 | { |
415 | QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", QMessageBox::Ok); | 417 | QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", QMessageBox::Ok); |
416 | } | 418 | } |
417 | else | 419 | else |
418 | { | 420 | { |
419 | if(!i->getModuleOwner()->remove(i)) | 421 | if(!i->getModuleOwner()->remove(i)) |
420 | QMessageBox::information(this, tr("Error"), tr("Unable to remove."), QMessageBox::Ok); | 422 | QMessageBox::information(this, tr("Error"), tr("Unable to remove."), QMessageBox::Ok); |
421 | else | 423 | else |
422 | { | 424 | { |
423 | delete item; | 425 | delete item; |
424 | // QMessageBox::information(this, "Success", "Interface was removed.", QMessageBox::Ok); | 426 | // QMessageBox::information(this, "Success", "Interface was removed.", QMessageBox::Ok); |
425 | } | 427 | } |
426 | } | 428 | } |
427 | } | 429 | } |
428 | 430 | ||
429 | /** | 431 | /** |
430 | * Pull up the configure about the currently selected interface. | 432 | * Pull up the configure about the currently selected interface. |
431 | * Report an error if no interface is selected. | 433 | * Report an error if no interface is selected. |
432 | * If the interface has a module owner then request its configure. | 434 | * If the interface has a module owner then request its configure. |
433 | */ | 435 | */ |
434 | void MainWindowImp::configureClicked() | 436 | void MainWindowImp::configureClicked() |
435 | { | 437 | { |
436 | QListViewItem *item = connectionList->currentItem(); | 438 | QListViewItem *item = connectionList->currentItem(); |
437 | if(!item) | 439 | if(!item) |
438 | { | 440 | { |
439 | QMessageBox::information(this, tr("Sorry"),tr("Please select an interface first."), QMessageBox::Ok); | 441 | QMessageBox::information(this, tr("Sorry"),tr("Please select an interface first."), QMessageBox::Ok); |
440 | return; | 442 | return; |
441 | } | 443 | } |
442 | 444 | ||
443 | QString currentProfileText = currentProfileLabel->text(); | 445 | QString currentProfileText = currentProfileLabel->text(); |
444 | if(currentProfileText.upper() == "ALL"); | 446 | if(currentProfileText.upper() == "ALL"); |
445 | currentProfileText = ""; | 447 | currentProfileText = ""; |
446 | 448 | ||
447 | Interface *i = interfaceItems[item]; | 449 | Interface *i = interfaceItems[item]; |
448 | 450 | ||
449 | if(i->getModuleOwner()) | 451 | if(i->getModuleOwner()) |
450 | { | 452 | { |
451 | QWidget *moduleConfigure = i->getModuleOwner()->configure(i); | 453 | QWidget *moduleConfigure = i->getModuleOwner()->configure(i); |
452 | if(moduleConfigure != NULL) | 454 | if(moduleConfigure != NULL) |
453 | { | 455 | { |
454 | i->getModuleOwner()->setProfile(currentProfileText); | 456 | i->getModuleOwner()->setProfile(currentProfileText); |
455 | QPEApplication::showWidget( moduleConfigure ); | 457 | QPEApplication::showWidget( moduleConfigure ); |
456 | return; | 458 | return; |
457 | } | 459 | } |
458 | } | 460 | } |
459 | 461 | ||
460 | InterfaceSetupImpDialog *configure = new InterfaceSetupImpDialog(this, "InterfaceSetupImp", i, true, Qt::WDestructiveClose | Qt::WStyle_ContextHelp ); | 462 | InterfaceSetupImpDialog *configure = new InterfaceSetupImpDialog(this, "InterfaceSetupImp", i, true, Qt::WDestructiveClose | Qt::WStyle_ContextHelp ); |
461 | configure->setProfile(currentProfileText); | 463 | configure->setProfile(currentProfileText); |
462 | QPEApplication::showDialog( configure ); | 464 | QPEApplication::showDialog( configure ); |
463 | } | 465 | } |
464 | 466 | ||
465 | /** | 467 | /** |
466 | * Pull up the information about the currently selected interface. | 468 | * Pull up the information about the currently selected interface. |
467 | * Report an error if no interface is selected. | 469 | * Report an error if no interface is selected. |
468 | * If the interface has a module owner then request its configure. | 470 | * If the interface has a module owner then request its configure. |
469 | */ | 471 | */ |
470 | void MainWindowImp::informationClicked() | 472 | void MainWindowImp::informationClicked() |
471 | { | 473 | { |
472 | QListViewItem *item = connectionList->currentItem(); | 474 | QListViewItem *item = connectionList->currentItem(); |
473 | if(!item) | 475 | if(!item) |
474 | { | 476 | { |
475 | QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); | 477 | QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); |
476 | return; | 478 | return; |
477 | } | 479 | } |
478 | 480 | ||
479 | Interface *i = interfaceItems[item]; | 481 | Interface *i = interfaceItems[item]; |
480 | // if(!i->isAttached()){ | 482 | // if(!i->isAttached()){ |
481 | // QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok); | 483 | // QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok); |
482 | // return; | 484 | // return; |
483 | // } | 485 | // } |
484 | 486 | ||
485 | if(i->getModuleOwner()) | 487 | if(i->getModuleOwner()) |
486 | { | 488 | { |
487 | QWidget *moduleInformation = i->getModuleOwner()->information(i); | 489 | QWidget *moduleInformation = i->getModuleOwner()->information(i); |
488 | if(moduleInformation != NULL) | 490 | if(moduleInformation != NULL) |
489 | { | 491 | { |
490 | QPEApplication::showWidget( moduleInformation ); | 492 | QPEApplication::showWidget( moduleInformation ); |
491 | #ifdef DEBUG | 493 | #ifdef DEBUG |
492 | odebug << "MainWindowImp::informationClicked:: Module owner has created, we showed." << oendl; | 494 | odebug << "MainWindowImp::informationClicked:: Module owner has created, we showed." << oendl; |
493 | #endif | 495 | #endif |
494 | return; | 496 | return; |
495 | } | 497 | } |
496 | } | 498 | } |
497 | InterfaceInformationImp *information = new InterfaceInformationImp(this, "InterfaceSetupImp", i, Qt::WType_Modal | Qt::WDestructiveClose | Qt::WStyle_Dialog | Qt::WStyle_ContextHelp); | 499 | InterfaceInformationImp *information = new InterfaceInformationImp(this, "InterfaceSetupImp", i, Qt::WType_Modal | Qt::WDestructiveClose | Qt::WStyle_Dialog | Qt::WStyle_ContextHelp); |
498 | QPEApplication::showWidget( information ); | 500 | QPEApplication::showWidget( information ); |
499 | } | 501 | } |
500 | 502 | ||
501 | /** | 503 | /** |
502 | * Update this interface. If no QListViewItem exists create one. | 504 | * Update this interface. If no QListViewItem exists create one. |
503 | * @param Interface* pointer to the interface that needs to be updated. | 505 | * @param Interface* pointer to the interface that needs to be updated. |
504 | */ | 506 | */ |
505 | void MainWindowImp::updateInterface(Interface *i) | 507 | void MainWindowImp::updateInterface(Interface *i) |
506 | { | 508 | { |
507 | if(!advancedUserMode) | 509 | if(!advancedUserMode) |
508 | { | 510 | { |
509 | if(i->getInterfaceName() == "lo") | 511 | if(i->getInterfaceName() == "lo") |
510 | return; | 512 | return; |
511 | } | 513 | } |
512 | 514 | ||
513 | QListViewItem *item = NULL; | 515 | QListViewItem *item = NULL; |
514 | 516 | ||
515 | // Find the interface, making it if needed. | 517 | // Find the interface, making it if needed. |
516 | if(items.find(i) == items.end()) | 518 | if(items.find(i) == items.end()) |
517 | { | 519 | { |
518 | item = new QListViewItem(connectionList, "", "", ""); | 520 | item = new QListViewItem(connectionList, "", "", ""); |
519 | // See if you can't find a module owner for this interface | 521 | // See if you can't find a module owner for this interface |
520 | QMap<Module*, QLibrary*>::Iterator it; | 522 | QMap<Module*, QLibrary*>::Iterator it; |
521 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 523 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
522 | { | 524 | { |
523 | if(it.key()->isOwner(i)) | 525 | if(it.key()->isOwner(i)) |
524 | i->setModuleOwner(it.key()); | 526 | i->setModuleOwner(it.key()); |
525 | } | 527 | } |
526 | items.insert(i, item); | 528 | items.insert(i, item); |
527 | interfaceItems.insert(item, i); | 529 | interfaceItems.insert(item, i); |
528 | } | 530 | } |
529 | else | 531 | else |
530 | item = items[i]; | 532 | item = items[i]; |
531 | 533 | ||
532 | // Update the icons and information | 534 | // Update the icons and information |
533 | #ifdef QWS | 535 | #ifdef QWS |
534 | QPixmap pic; | 536 | QPixmap pic; |
535 | pic.convertFromImage( Resource::loadImage( i->getStatus() ? "up": "down" ).smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ) ); | 537 | pic.convertFromImage( Resource::loadImage( i->getStatus() ? "up": "down" ).smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ) ); |
536 | item->setPixmap(0, ( pic )); | 538 | item->setPixmap(0, ( pic )); |
537 | #else | 539 | #else |
538 | item->setPixmap(0, (SmallIcon(i->getStatus() ? "up": "down"))); | 540 | item->setPixmap(0, (SmallIcon(i->getStatus() ? "up": "down"))); |
539 | #endif | 541 | #endif |
540 | 542 | ||
541 | QString typeName = "lan"; | 543 | QString typeName = "lan"; |
542 | if(i->getInterfaceName() == "lo") | 544 | if(i->getInterfaceName() == "lo") |
543 | typeName = "lo"; | 545 | typeName = "lo"; |
544 | if(i->getInterfaceName().contains("irda")) | 546 | if(i->getInterfaceName().contains("irda")) |
545 | typeName = "irda"; | 547 | typeName = "irda"; |
546 | if(i->getInterfaceName().contains("wlan")) | 548 | if(i->getInterfaceName().contains("wlan")) |
547 | typeName = "wlan"; | 549 | typeName = "wlan"; |
548 | if(i->getInterfaceName().contains("usb")) | 550 | if(i->getInterfaceName().contains("usb")) |
549 | typeName = "usb"; | 551 | typeName = "usb"; |
550 | 552 | ||
551 | if(!i->isAttached()) | 553 | if(!i->isAttached()) |
552 | typeName = "connect_no"; | 554 | typeName = "connect_no"; |
553 | // Actually try to use the Module | 555 | // Actually try to use the Module |
554 | if(i->getModuleOwner() != NULL) | 556 | if(i->getModuleOwner() != NULL) |
555 | typeName = i->getModuleOwner()->getPixmapName(i); | 557 | typeName = i->getModuleOwner()->getPixmapName(i); |
556 | 558 | ||
557 | #ifdef QWS | 559 | #ifdef QWS |
558 | item->setPixmap(1, (Resource::loadPixmap(QString("networksettings/") + typeName))); | 560 | item->setPixmap(1, (Resource::loadPixmap(QString("networksettings/") + typeName))); |
559 | #else | 561 | #else |
560 | item->setPixmap(1, (SmallIcon(typeName))); | 562 | item->setPixmap(1, (SmallIcon(typeName))); |
561 | #endif | 563 | #endif |
562 | item->setText(2, i->getHardwareName()); | 564 | item->setText(2, i->getHardwareName()); |
563 | item->setText(3, QString("(%1)").arg(i->getInterfaceName())); | 565 | item->setText(3, QString("(%1)").arg(i->getInterfaceName())); |
564 | item->setText(4, (i->getStatus()) ? i->getIp() : QString("")); | 566 | item->setText(4, (i->getStatus()) ? i->getIp() : QString("")); |
565 | } | 567 | } |
566 | 568 | ||
567 | void MainWindowImp::newProfileChanged(const QString& newText) | 569 | void MainWindowImp::newProfileChanged(const QString& newText) |
568 | { | 570 | { |
569 | if(newText.length() > 0) | 571 | if(newText.length() > 0) |
570 | newProfileButton->setEnabled(true); | 572 | newProfileButton->setEnabled(true); |
571 | else | 573 | else |
572 | newProfileButton->setEnabled(false); | 574 | newProfileButton->setEnabled(false); |
573 | } | 575 | } |
574 | 576 | ||
575 | /** | 577 | /** |
576 | * Adds a new profile to the list of profiles. | 578 | * Adds a new profile to the list of profiles. |
577 | * Don't add profiles that already exists. | 579 | * Don't add profiles that already exists. |
578 | * Appends to the list and QStringList | 580 | * Appends to the list and QStringList |
579 | */ | 581 | */ |
580 | void MainWindowImp::addProfile() | 582 | void MainWindowImp::addProfile() |
581 | { | 583 | { |
582 | QString newProfileName = newProfile->text(); | 584 | QString newProfileName = newProfile->text(); |
583 | if(profiles.grep(newProfileName).count() > 0) | 585 | if(profiles.grep(newProfileName).count() > 0) |
584 | { | 586 | { |
585 | QMessageBox::information(this, "Can't Add","Profile already exists.", QMessageBox::Ok); | 587 | QMessageBox::information(this, "Can't Add","Profile already exists.", QMessageBox::Ok); |
586 | return; | 588 | return; |
587 | } | 589 | } |
588 | profiles.append(newProfileName); | 590 | profiles.append(newProfileName); |
589 | profilesList->insertItem(newProfileName); | 591 | profilesList->insertItem(newProfileName); |
590 | } | 592 | } |
591 | 593 | ||
592 | /** | 594 | /** |
593 | * Removes the currently selected profile in the combo. | 595 | * Removes the currently selected profile in the combo. |
594 | * Doesn't delete if there are less then 2 profiles. | 596 | * Doesn't delete if there are less then 2 profiles. |
595 | */ | 597 | */ |
596 | void MainWindowImp::removeProfile() | 598 | void MainWindowImp::removeProfile() |
597 | { | 599 | { |
598 | if(profilesList->count() <= 1) | 600 | if(profilesList->count() <= 1) |
599 | { | 601 | { |
600 | QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", QMessageBox::Ok); | 602 | QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", QMessageBox::Ok); |
601 | return; | 603 | return; |
602 | } | 604 | } |
603 | QString profileToRemove = profilesList->currentText(); | 605 | QString profileToRemove = profilesList->currentText(); |
604 | if(profileToRemove == "All") | 606 | if(profileToRemove == "All") |
605 | { | 607 | { |
606 | QMessageBox::information(this, "Can't remove.","Can't remove default.", QMessageBox::Ok); | 608 | QMessageBox::information(this, "Can't remove.","Can't remove default.", QMessageBox::Ok); |
607 | return; | 609 | return; |
608 | } | 610 | } |
609 | // Can't remove the curent profile | 611 | // Can't remove the curent profile |
610 | if(profileToRemove == currentProfileLabel->text()) | 612 | if(profileToRemove == currentProfileLabel->text()) |
611 | { | 613 | { |
612 | QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), QMessageBox::Ok); | 614 | QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), QMessageBox::Ok); |
613 | return; | 615 | return; |
614 | 616 | ||
615 | } | 617 | } |
616 | 618 | ||
617 | if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok) | 619 | if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok) |
618 | { | 620 | { |
619 | profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), "")); | 621 | profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), "")); |
620 | profilesList->clear(); | 622 | profilesList->clear(); |
621 | for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) | 623 | for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) |
622 | profilesList->insertItem((*it)); | 624 | profilesList->insertItem((*it)); |
623 | 625 | ||
624 | // Remove any interface settings and mappings. | 626 | // Remove any interface settings and mappings. |
625 | Interfaces interfaces; | 627 | Interfaces interfaces; |
626 | // Go through them one by one | 628 | // Go through them one by one |
627 | QMap<Interface*, QListViewItem*>::Iterator it; | 629 | QMap<Interface*, QListViewItem*>::Iterator it; |
628 | for( it = items.begin(); it != items.end(); ++it ) | 630 | for( it = items.begin(); it != items.end(); ++it ) |
629 | { | 631 | { |
630 | QString interfaceName = it.key()->getInterfaceName(); | 632 | QString interfaceName = it.key()->getInterfaceName(); |
631 | odebug << interfaceName.latin1() << oendl; | 633 | odebug << interfaceName.latin1() << oendl; |
632 | if(interfaces.setInterface(interfaceName + "_" + profileToRemove)) | 634 | if(interfaces.setInterface(interfaceName + "_" + profileToRemove)) |
633 | { | 635 | { |
634 | interfaces.removeInterface(); | 636 | interfaces.removeInterface(); |
635 | if(interfaces.setMapping(interfaceName)) | 637 | if(interfaces.setMapping(interfaceName)) |
636 | { | 638 | { |
637 | if(profilesList->count() == 1) | 639 | if(profilesList->count() == 1) |
638 | interfaces.removeMapping(); | 640 | interfaces.removeMapping(); |
639 | else | 641 | else |
640 | { | 642 | { |
641 | interfaces.removeMap("map", interfaceName + "_" + profileToRemove); | 643 | interfaces.removeMap("map", interfaceName + "_" + profileToRemove); |
642 | } | 644 | } |
643 | } | 645 | } |
644 | interfaces.write(); | 646 | interfaces.write(); |
645 | break; | 647 | break; |
646 | } | 648 | } |
647 | } | 649 | } |
648 | } | 650 | } |
649 | } | 651 | } |
650 | 652 | ||
651 | /** | 653 | /** |
652 | * A new profile has been selected, change. | 654 | * A new profile has been selected, change. |
653 | * @param newProfile the new profile. | 655 | * @param newProfile the new profile. |
654 | */ | 656 | */ |
655 | void MainWindowImp::changeProfile() | 657 | void MainWindowImp::changeProfile() |
656 | { | 658 | { |
657 | if(profilesList->currentItem() == -1) | 659 | if(profilesList->currentItem() == -1) |
658 | { | 660 | { |
659 | QMessageBox::information(this, "Can't Change.","Please select a profile.", QMessageBox::Ok); | 661 | QMessageBox::information(this, "Can't Change.","Please select a profile.", QMessageBox::Ok); |
660 | return; | 662 | return; |
661 | } | 663 | } |
662 | QString newProfile = profilesList->text(profilesList->currentItem()); | 664 | QString newProfile = profilesList->text(profilesList->currentItem()); |
663 | if(newProfile != currentProfileLabel->text()) | 665 | if(newProfile != currentProfileLabel->text()) |
664 | { | 666 | { |
665 | currentProfileLabel->setText(newProfile); | 667 | currentProfileLabel->setText(newProfile); |
666 | QFile::remove(scheme); | 668 | QFile::remove(scheme); |
667 | QFile file(scheme); | 669 | QFile file(scheme); |
668 | if ( file.open(IO_ReadWrite) ) | 670 | if ( file.open(IO_ReadWrite) ) |
669 | { | 671 | { |
670 | QTextStream stream( &file ); | 672 | QTextStream stream( &file ); |
671 | stream << QString("SCHEME=%1").arg(newProfile); | 673 | stream << QString("SCHEME=%1").arg(newProfile); |
672 | file.close(); | 674 | file.close(); |
673 | } | 675 | } |
674 | // restart all up devices? | 676 | // restart all up devices? |
675 | if(QMessageBox::information(this, "Question","Restart all running interfaces?", QMessageBox::Ok, QMessageBox::No) == QMessageBox::Ok) | 677 | if(QMessageBox::information(this, "Question","Restart all running interfaces?", QMessageBox::Ok, QMessageBox::No) == QMessageBox::Ok) |
676 | { | 678 | { |
677 | // Go through them one by one | 679 | // Go through them one by one |
678 | QMap<Interface*, QListViewItem*>::Iterator it; | 680 | QMap<Interface*, QListViewItem*>::Iterator it; |
679 | for( it = items.begin(); it != items.end(); ++it ) | 681 | for( it = items.begin(); it != items.end(); ++it ) |
680 | { | 682 | { |
681 | if(it.key()->getStatus() == true) | 683 | if(it.key()->getStatus() == true) |
682 | it.key()->restart(); | 684 | it.key()->restart(); |
683 | } | 685 | } |
684 | } | 686 | } |
685 | } | 687 | } |
686 | // TODO change the profile in the modules | 688 | // TODO change the profile in the modules |
687 | } | 689 | } |
688 | 690 | ||
689 | 691 | ||
690 | void MainWindowImp::makeChannel() | 692 | void MainWindowImp::makeChannel() |
691 | { | 693 | { |
692 | channel = new QCopChannel( "QPE/Application/networksettings", this ); | 694 | channel = new QCopChannel( "QPE/Application/networksettings", this ); |
693 | connect( channel, SIGNAL(received(const QCString&,const QByteArray&)), | 695 | connect( channel, SIGNAL(received(const QCString&,const QByteArray&)), |
694 | this, SLOT(receive(const QCString&,const QByteArray&)) ); | 696 | this, SLOT(receive(const QCString&,const QByteArray&)) ); |
695 | } | 697 | } |
696 | 698 | ||
697 | void MainWindowImp::receive(const QCString &msg, const QByteArray &arg) | 699 | void MainWindowImp::receive(const QCString &msg, const QByteArray &arg) |
698 | { | 700 | { |
699 | bool found = false; | 701 | bool found = false; |
700 | odebug << "MainWindowImp::receive QCop msg >"+msg+"<" << oendl; | 702 | odebug << "MainWindowImp::receive QCop msg >"+msg+"<" << oendl; |
701 | if (msg == "raise") | 703 | if (msg == "raise") |
702 | { | 704 | { |
703 | raise(); | 705 | raise(); |
704 | return; | 706 | return; |
705 | } | 707 | } |
706 | 708 | ||
707 | QString dest = msg.left(msg.find("(")); | 709 | QString dest = msg.left(msg.find("(")); |
708 | QCString param = msg.right(msg.length() - msg.find("(") - 1); | 710 | QCString param = msg.right(msg.length() - msg.find("(") - 1); |
709 | param = param.left( param.length() - 1 ); | 711 | param = param.left( param.length() - 1 ); |
710 | odebug << "dest >" << dest.latin1() << "< param >"+param+"<" << oendl; | 712 | odebug << "dest >" << dest.latin1() << "< param >"+param+"<" << oendl; |
711 | 713 | ||
712 | QMap<Module*, QLibrary*>::Iterator it; | 714 | QMap<Module*, QLibrary*>::Iterator it; |
713 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 715 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
714 | { | 716 | { |
715 | odebug << "plugin >" << it.key()->type().latin1() << "<" << oendl; | 717 | odebug << "plugin >" << it.key()->type().latin1() << "<" << oendl; |
716 | if(it.key()->type() == dest) | 718 | if(it.key()->type() == dest) |
717 | { | 719 | { |
718 | it.key()->receive( param, arg ); | 720 | it.key()->receive( param, arg ); |
719 | found = true; | 721 | found = true; |
720 | } | 722 | } |
721 | } | 723 | } |
722 | 724 | ||
723 | 725 | ||
724 | if (found) QPEApplication::setKeepRunning(); | 726 | if (found) QPEApplication::setKeepRunning(); |
725 | else odebug << "Huh what do ya want" << oendl; | 727 | else odebug << "Huh what do ya want" << oendl; |
726 | } | 728 | } |
727 | 729 | ||
728 | void MainWindowImp::setHostname() | 730 | void MainWindowImp::setHostname() |
729 | { | 731 | { |
730 | static QRegExp filter("[^A-Za-z0-9_\\-\\.]"); | 732 | static QRegExp filter("[^A-Za-z0-9_\\-\\.]"); |
731 | if (filter.match(m_Nameinput->text())!=-1) { | 733 | if (filter.match(m_Nameinput->text())!=-1) { |
732 | odebug << "Wrong hostname" << oendl; | 734 | odebug << "Wrong hostname" << oendl; |
733 | QMessageBox::critical(0, tr("Sorry"), tr("This is a wrong name.<br>Please use A-Z, a-z, _, - or a single dot.")); | 735 | QMessageBox::critical(0, tr("Sorry"), tr("This is a wrong name.<br>Please use A-Z, a-z, _, - or a single dot.")); |
734 | return; | 736 | return; |
735 | } | 737 | } |
736 | 738 | ||
737 | OProcess h; | 739 | OProcess h; |
738 | _procTemp=""; | 740 | _procTemp=""; |
739 | h << "hostname" << m_Nameinput->text(); | 741 | h << "hostname" << m_Nameinput->text(); |
740 | connect(&h,SIGNAL(receivedStderr(Opie::Core::OProcess*,char*,int)),this,SLOT(slotHostname(Opie::Core::OProcess*,char*,int))); | 742 | connect(&h,SIGNAL(receivedStderr(Opie::Core::OProcess*,char*,int)),this,SLOT(slotHostname(Opie::Core::OProcess*,char*,int))); |
741 | h.start(OProcess::Block,OProcess::Stderr); | 743 | h.start(OProcess::Block,OProcess::Stderr); |
742 | odebug << "Got " << _procTemp << " - " << h.exitStatus() << oendl; | 744 | odebug << "Got " << _procTemp << " - " << h.exitStatus() << oendl; |
743 | if (h.exitStatus()!=0) { | 745 | if (h.exitStatus()!=0) { |
744 | QMessageBox::critical(0, tr("Sorry"), QString(tr("Could not set name.\n%1")).arg(_procTemp.stripWhiteSpace())); | 746 | QMessageBox::critical(0, tr("Sorry"), QString(tr("Could not set name.\n%1")).arg(_procTemp.stripWhiteSpace())); |
745 | return; | 747 | return; |
746 | } | 748 | } |
747 | _procTemp=""; | 749 | _procTemp=""; |
748 | 750 | ||
749 | QFile f(_HOSTFILE); | 751 | QFile f(_HOSTFILE); |
750 | if (f.open(IO_Truncate|IO_WriteOnly)) | 752 | if (f.open(IO_Truncate|IO_WriteOnly)) |
751 | { | 753 | { |
752 | QTextStream s(&f); | 754 | QTextStream s(&f); |
753 | s << m_Nameinput->text(); | 755 | s << m_Nameinput->text(); |
754 | } else { | 756 | } else { |
755 | QMessageBox::critical(0, tr("Sorry"), tr("Could not save name.")); | 757 | QMessageBox::critical(0, tr("Sorry"), tr("Could not save name.")); |
756 | return; | 758 | return; |
757 | } | 759 | } |
758 | 760 | ||
759 | f.close(); | 761 | f.close(); |
760 | f.setName(_IRDANAME); | 762 | f.setName(_IRDANAME); |
761 | if (f.open(IO_WriteOnly)) | 763 | if (f.open(IO_WriteOnly)) |
762 | { | 764 | { |
763 | QTextStream s(&f); | 765 | QTextStream s(&f); |
764 | s << m_Nameinput->text(); | 766 | s << m_Nameinput->text(); |
765 | } else { | 767 | } else { |
766 | QMessageBox::critical(0, tr("Sorry"), tr("Could not set infrared name.")); | 768 | QMessageBox::critical(0, tr("Sorry"), tr("Could not set infrared name.")); |
767 | } | 769 | } |
768 | } | 770 | } |
769 | 771 | ||
770 | void MainWindowImp::initHostname() | 772 | void MainWindowImp::initHostname() |
771 | { | 773 | { |
772 | OProcess h; | 774 | OProcess h; |
773 | _procTemp=""; | 775 | _procTemp=""; |
774 | 776 | ||
775 | h << "hostname"; | 777 | h << "hostname"; |
776 | connect(&h,SIGNAL(receivedStdout(Opie::Core::OProcess*,char*,int)),this,SLOT(slotHostname(Opie::Core::OProcess*,char*,int))); | 778 | connect(&h,SIGNAL(receivedStdout(Opie::Core::OProcess*,char*,int)),this,SLOT(slotHostname(Opie::Core::OProcess*,char*,int))); |
777 | h.start(OProcess::Block,OProcess::AllOutput); | 779 | h.start(OProcess::Block,OProcess::AllOutput); |
778 | odebug << "Got " << _procTemp <<oendl; | 780 | odebug << "Got " << _procTemp <<oendl; |
779 | m_Nameinput->setText(_procTemp.stripWhiteSpace()); | 781 | m_Nameinput->setText(_procTemp.stripWhiteSpace()); |
780 | _procTemp=""; | 782 | _procTemp=""; |
781 | } | 783 | } |
782 | 784 | ||
783 | void MainWindowImp::slotHostname(Opie::Core::OProcess *proc, char *buffer, int buflen) | 785 | void MainWindowImp::slotHostname(Opie::Core::OProcess *proc, char *buffer, int buflen) |
784 | { | 786 | { |
785 | if (buflen < 1 || buffer==0) return; | 787 | if (buflen < 1 || buffer==0) return; |
786 | char*_t = new char[buflen+1]; | 788 | char*_t = new char[buflen+1]; |
787 | ::memset(_t,0,buflen+1); | 789 | ::memset(_t,0,buflen+1); |
788 | ::memcpy(_t,buffer,buflen); | 790 | ::memcpy(_t,buffer,buflen); |
789 | _procTemp+=_t; | 791 | _procTemp+=_t; |
790 | delete[]_t; | 792 | delete[]_t; |
791 | } | 793 | } |