author | llornkcor <llornkcor> | 2002-07-20 19:24:20 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-07-20 19:24:20 (UTC) |
commit | 2ba2f7293e6b7b7b54e733ff84e0b57f0dbc3dfc (patch) (unidiff) | |
tree | 54721319a2e07ebda9def3f139f7302c64fef886 | |
parent | 8c335cfdfffede8b7a864566ec4d9507a2978684 (diff) | |
download | opie-2ba2f7293e6b7b7b54e733ff84e0b57f0dbc3dfc.zip opie-2ba2f7293e6b7b7b54e733ff84e0b57f0dbc3dfc.tar.gz opie-2ba2f7293e6b7b7b54e733ff84e0b57f0dbc3dfc.tar.bz2 |
ok, here ya go.
-rw-r--r-- | noncore/settings/sysinfo/storage.cpp | 26 |
1 files changed, 10 insertions, 16 deletions
diff --git a/noncore/settings/sysinfo/storage.cpp b/noncore/settings/sysinfo/storage.cpp index f76fbdb..b369ff1 100644 --- a/noncore/settings/sysinfo/storage.cpp +++ b/noncore/settings/sysinfo/storage.cpp | |||
@@ -94,147 +94,141 @@ void StorageInfo::updateMounts() | |||
94 | QString mount = me->mnt_dir; | 94 | QString mount = me->mnt_dir; |
95 | mountList.append(mount); | 95 | mountList.append(mount); |
96 | QString t = me->mnt_type; | 96 | QString t = me->mnt_type; |
97 | fsT.append(t); | 97 | fsT.append(t); |
98 | if ( !disks.find(d) ) | 98 | if ( !disks.find(d) ) |
99 | rebuild = TRUE; | 99 | rebuild = TRUE; |
100 | } | 100 | } |
101 | } | 101 | } |
102 | endmntent( mntfp ); | 102 | endmntent( mntfp ); |
103 | } | 103 | } |
104 | if ( rebuild || n != (int)disks.count() ) { | 104 | if ( rebuild || n != (int)disks.count() ) { |
105 | disks.clear(); | 105 | disks.clear(); |
106 | lines.clear(); | 106 | lines.clear(); |
107 | delete vb; | 107 | delete vb; |
108 | vb = new QVBoxLayout( this, n > 3 ? 1 : 5 ); | 108 | vb = new QVBoxLayout( this, n > 3 ? 1 : 5 ); |
109 | bool frst=TRUE; | 109 | bool frst=TRUE; |
110 | QStringList::ConstIterator it=curdisks.begin(); | 110 | QStringList::ConstIterator it=curdisks.begin(); |
111 | QStringList::ConstIterator fsit=curfs.begin(); | 111 | QStringList::ConstIterator fsit=curfs.begin(); |
112 | QStringList::ConstIterator fsmount=mountList.begin(); | 112 | QStringList::ConstIterator fsmount=mountList.begin(); |
113 | QStringList::ConstIterator fsTit=fsT.begin(); | 113 | QStringList::ConstIterator fsTit=fsT.begin(); |
114 | 114 | ||
115 | for (; it!=curdisks.end(); ++it, ++fsit) { | 115 | for (; it!=curdisks.end(); ++it, ++fsit) { |
116 | if ( !frst ) { | 116 | if ( !frst ) { |
117 | QFrame *f = new QFrame( this ); | 117 | QFrame *f = new QFrame( this ); |
118 | vb->addWidget(f); | 118 | vb->addWidget(f); |
119 | f->setFrameStyle( QFrame::HLine | QFrame::Sunken ); | 119 | f->setFrameStyle( QFrame::HLine | QFrame::Sunken ); |
120 | lines.append(f); | 120 | lines.append(f); |
121 | f->show(); | 121 | f->show(); |
122 | } frst=FALSE; | 122 | } frst=FALSE; |
123 | QString humanname=*it; | 123 | QString humanname=*it; |
124 | // qDebug(humanname); | 124 | // qDebug(humanname); |
125 | if ( isCF(humanname) ) | 125 | if ( isCF(humanname) ) |
126 | humanname = tr("CF Card: "+*fsmount+" "+*fsTit+" "); | 126 | humanname = tr("CF Card: "+*fsmount+" "+*fsTit+" "); |
127 | else if ( humanname == "/dev/hda1" ) | 127 | else if ( humanname == "/dev/hda1" ) |
128 | humanname = tr("Hard Disk "+*fsmount+" "+*fsTit+" "); | 128 | humanname = tr("Hard Disk "+*fsmount+" "+*fsTit+" "); |
129 | else if ( humanname.left(9) == "/dev/mmcd" ) | 129 | else if ( humanname.left(9) == "/dev/mmcd" ) |
130 | humanname = tr("SD Card "+*fsmount+" "+*fsTit+" "); | 130 | humanname = tr("SD Card "+*fsmount+" "+*fsTit+" "); |
131 | else if ( humanname.left(7) == "/dev/hd" ) | 131 | else if ( humanname.left(7) == "/dev/hd" ) |
132 | humanname = tr("Hard Disk") + " " + humanname.mid(7)+" "+*fsmount+" "+*fsTit+" "; | 132 | humanname = tr("Hard Disk") + " " + humanname.mid(7)+" "+*fsmount+" "+*fsTit+" "; |
133 | else if ( humanname.left(7) == "/dev/sd" ) | 133 | else if ( humanname.left(7) == "/dev/sd" ) |
134 | humanname = tr("SCSI Hard Disk") + " " + humanname.mid(7)+" "+*fsmount+" "+*fsTit+" "; | 134 | humanname = tr("SCSI Hard Disk") + " " + humanname.mid(7)+" "+*fsmount+" "+*fsTit+" "; |
135 | else if ( humanname == "/dev/mtdblock1" || humanname == "/dev/mtdblock/1" ) | 135 | else if ( humanname == "/dev/mtdblock1" || humanname == "/dev/mtdblock/1" ) |
136 | humanname = tr("Int. Storage "+*fsmount+" "+*fsTit+"\n"); | 136 | humanname = tr("Int. Storage "+*fsmount+" "+*fsTit+"\n"); |
137 | else if ( humanname.left(14) == "/dev/mtdblock/" ) | 137 | else if ( humanname.left(14) == "/dev/mtdblock/" ) |
138 | humanname = tr("Int. Storage") + " " + humanname.mid(14)+" "+*fsmount+" "+*fsTit+" "; | 138 | humanname = tr("Int. Storage") + " " + humanname.mid(14)+" "+*fsmount+" "+*fsTit+" "; |
139 | else if ( humanname.left(13) == "/dev/mtdblock" ) | 139 | else if ( humanname.left(13) == "/dev/mtdblock" ) |
140 | humanname = tr("Int. Storage") + " " + humanname.mid(13)+" "+*fsmount+" "+*fsTit+" "; | 140 | humanname = tr("Int. Storage") + " " + humanname.mid(13)+" "+*fsmount+" "+*fsTit+" "; |
141 | else if ( humanname.left(9) == "/dev/root" ) | 141 | else if ( humanname.left(9) == "/dev/root" ) |
142 | humanname = tr("Int. Storage "+*fsmount+" "+*fsTit+" "); | 142 | humanname = tr("Int. Storage "+*fsmount+" "+*fsTit+" "); |
143 | // etc. | 143 | // etc. |
144 | MountInfo* mi = new MountInfo( *fsit, humanname, this ); | 144 | MountInfo* mi = new MountInfo( *fsit, humanname, this ); |
145 | vb->addWidget(mi); | 145 | vb->addWidget(mi); |
146 | disks.insert(*fsit,mi); | 146 | disks.insert(*fsit,mi); |
147 | mi->show(); | 147 | mi->show(); |
148 | fsmount++;fsTit++; | 148 | fsmount++;fsTit++; |
149 | } | 149 | } |
150 | vb->addStretch(); | 150 | vb->addStretch(); |
151 | } else { | 151 | } else { |
152 | // just update them | 152 | // just update them |
153 | for (QDictIterator<MountInfo> i(disks); i.current(); ++i) | 153 | for (QDictIterator<MountInfo> i(disks); i.current(); ++i) |
154 | i.current()->updateData(); | 154 | i.current()->updateData(); |
155 | } | 155 | } |
156 | #endif | 156 | #endif |
157 | } | 157 | } |
158 | 158 | ||
159 | 159 | ||
160 | MountInfo::MountInfo( const QString &path, const QString &ttl, QWidget *parent, const char *name ) | 160 | MountInfo::MountInfo( const QString &path, const QString &ttl, QWidget *parent, const char *name ) |
161 | : QWidget( parent, name ), title(ttl) | 161 | : QWidget( parent, name ), title(ttl) |
162 | { | 162 | { |
163 | qDebug("new path is "+path); | 163 | qDebug("new path is "+path); |
164 | fs = new FileSystem( path ); | 164 | fs = new FileSystem( path ); |
165 | QVBoxLayout *vb = new QVBoxLayout( this, 3 ); | 165 | QVBoxLayout *vb = new QVBoxLayout( this, 3 ); |
166 | 166 | ||
167 | totalSize = new QLabel( this ); | 167 | totalSize = new QLabel( this ); |
168 | vb->addWidget( totalSize ); | 168 | vb->addWidget( totalSize ); |
169 | 169 | ||
170 | data = new GraphData(); | 170 | data = new GraphData(); |
171 | graph = new BarGraph( this ); | 171 | graph = new BarGraph( this ); |
172 | graph->setFrameStyle( QFrame::Panel | QFrame::Sunken ); | 172 | graph->setFrameStyle( QFrame::Panel | QFrame::Sunken ); |
173 | vb->addWidget( graph, 1 ); | 173 | vb->addWidget( graph, 1 ); |
174 | graph->setData( data ); | 174 | graph->setData( data ); |
175 | 175 | ||
176 | legend = new GraphLegend( this ); | 176 | legend = new GraphLegend( this ); |
177 | legend->setOrientation(Horizontal); | 177 | legend->setOrientation(Horizontal); |
178 | vb->addWidget( legend ); | 178 | vb->addWidget( legend ); |
179 | legend->setData( data ); | 179 | legend->setData( data ); |
180 | 180 | ||
181 | updateData(); | 181 | updateData(); |
182 | } | 182 | } |
183 | 183 | ||
184 | MountInfo::~MountInfo() | 184 | MountInfo::~MountInfo() |
185 | { | 185 | { |
186 | delete data; | 186 | delete data; |
187 | delete fs; | 187 | delete fs; |
188 | } | 188 | } |
189 | 189 | ||
190 | void MountInfo::updateData() | 190 | void MountInfo::updateData() |
191 | { | 191 | { |
192 | fs->update(); | 192 | fs->update(); |
193 | 193 | ||
194 | long mult = fs->blockSize() / 1024; | 194 | long mult = fs->blockSize() / 1024; |
195 | long div = 1024 / fs->blockSize(); | 195 | long div = 1024 / fs->blockSize(); |
196 | if ( !mult ) mult = 1; | 196 | if ( !mult ) mult = 1; |
197 | if ( !div ) div = 1; | 197 | if ( !div ) div = 1; |
198 | long total = fs->totalBlocks() * mult / div; | 198 | long total = fs->totalBlocks() * mult / div; |
199 | long avail = fs->availBlocks() * mult / div; | 199 | long avail = fs->availBlocks() * mult / div; |
200 | long used = total - avail; | 200 | long used = total - avail; |
201 | totalSize->setText( title + tr(" : %1 kB").arg( total ) ); | 201 | totalSize->setText( title + tr(" : %1 kB").arg( total ) ); |
202 | data->clear(); | 202 | data->clear(); |
203 | data->addItem( tr("Used (%1 kB)").arg(used), used ); | 203 | data->addItem( tr("Used (%1 kB)").arg(used), used ); |
204 | data->addItem( tr("Available (%1 kB)").arg(avail), avail ); | 204 | data->addItem( tr("Available (%1 kB)").arg(avail), avail ); |
205 | graph->repaint( FALSE ); | 205 | graph->repaint( FALSE ); |
206 | legend->update(); | 206 | legend->update(); |
207 | graph->show(); | 207 | graph->show(); |
208 | legend->show(); | 208 | legend->show(); |
209 | } | 209 | } |
210 | 210 | ||
211 | //--------------------------------------------------------------------------- | 211 | //--------------------------------------------------------------------------- |
212 | 212 | ||
213 | FileSystem::FileSystem( const QString &p ) | 213 | FileSystem::FileSystem( const QString &p ) |
214 | : fspath( p ), blkSize(512), totalBlks(0), availBlks(0) | 214 | : fspath( p ), blkSize(512), totalBlks(0), availBlks(0) |
215 | { | 215 | { |
216 | update(); | 216 | update(); |
217 | } | 217 | } |
218 | 218 | ||
219 | void FileSystem::update() | 219 | void FileSystem::update() |
220 | { | 220 | { |
221 | #if defined(_OS_LINUX_) || defined(Q_OS_LINUX) | 221 | #if defined(_OS_LINUX_) || defined(Q_OS_LINUX) |
222 | struct statfs fs; | 222 | struct statfs fs; |
223 | if ( !statfs( fspath.latin1(), &fs ) ) { | 223 | if ( !statfs( fspath.latin1(), &fs ) ) { |
224 | if( fspath.left(8) == "/mnt/ram") { //ugly hack openzaurus | 224 | blkSize = fs.f_bsize; |
225 | blkSize = fs.f_bsize; | 225 | totalBlks = fs.f_blocks; |
226 | totalBlks = fs.f_blocks; | 226 | availBlks = fs.f_bavail; |
227 | availBlks = fs.f_ffree; | 227 | } else { |
228 | } else { | 228 | blkSize = 0; |
229 | blkSize = fs.f_bsize; | 229 | totalBlks = 0; |
230 | totalBlks = fs.f_blocks; | 230 | availBlks = 0; |
231 | availBlks = fs.f_bavail; | 231 | } |
232 | } | ||
233 | } else { | ||
234 | blkSize = 0; | ||
235 | totalBlks = 0; | ||
236 | availBlks = 0; | ||
237 | } | ||
238 | #endif | 232 | #endif |
239 | } | 233 | } |
240 | 234 | ||