summaryrefslogtreecommitdiff
path: root/noncore/tools/formatter/formatter.cpp
authorllornkcor <llornkcor>2002-04-25 00:11:44 (UTC)
committer llornkcor <llornkcor>2002-04-25 00:11:44 (UTC)
commitfd9fe8316525d3d7dac85d8d71dd8267b5abbd8f (patch) (side-by-side diff)
treefaf04b23270a222baae30e5ea29c77f308f0328e /noncore/tools/formatter/formatter.cpp
parent5d3d95245768f7949208d367db1b5dc1d7f5e314 (diff)
downloadopie-fd9fe8316525d3d7dac85d8d71dd8267b5abbd8f.zip
opie-fd9fe8316525d3d7dac85d8d71dd8267b5abbd8f.tar.gz
opie-fd9fe8316525d3d7dac85d8d71dd8267b5abbd8f.tar.bz2
initial commit
Diffstat (limited to 'noncore/tools/formatter/formatter.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/tools/formatter/formatter.cpp419
1 files changed, 419 insertions, 0 deletions
diff --git a/noncore/tools/formatter/formatter.cpp b/noncore/tools/formatter/formatter.cpp
new file mode 100644
index 0000000..8c8ef2a
--- a/dev/null
+++ b/noncore/tools/formatter/formatter.cpp
@@ -0,0 +1,419 @@
+/****************************************************************************
+** formatter.cpp
+**
+** Copyright: Thu Apr 11 11:01:13 2002
+** by: L. J. Potter
+**
+****************************************************************************/
+
+#include "formatter.h"
+#include "inputDialog.h"
+#include "output.h"
+
+#include <qpe/qpemenubar.h>
+#include <qpe/qpetoolbar.h>
+#include <qpe/qpeapplication.h>
+#include <qpe/resource.h>
+#include <qpe/config.h>
+#include <qpe/mimetype.h>
+#include <qpe/qcopenvelope_qws.h>
+#include <qpe/storage.h>
+
+#include <qmultilineedit.h>
+#include <qstring.h>
+#include <qlist.h>
+#include <qstringlist.h>
+#include <qdir.h>
+#include <qfile.h>
+
+#include <qtstream.h>
+
+#include <qcombobox.h>
+#include <qpopupmenu.h>
+#include <qmessagebox.h>
+#include <qregexp.h>
+
+#include <qlabel.h>
+#include <qlineedit.h>
+#include <qpushbutton.h>
+#include <qtabwidget.h>
+#include <qwidget.h>
+#include <qlayout.h>
+#include <qvariant.h>
+
+#include <unistd.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/vfs.h>
+#include <mntent.h>
+
+#define BLANK ' '
+#define DELIMITER '#'
+
+/*
+Blah blah blah blah */
+FormatterApp::FormatterApp( QWidget* parent, const char* name, bool modal, WFlags fl )
+ : QMainWindow( parent, name, fl )
+// : QDialog( parent, name, modal, fl )
+{
+ if ( !name )
+ setName( "FormatterApp" );
+ connect( qApp,SIGNAL( aboutToQuit()),SLOT( cleanUp()) );
+
+ setCaption( tr( "Formatter" ) );
+ FormatterAppLayout = new QGridLayout( this );
+ FormatterAppLayout->setSpacing( 2);
+ FormatterAppLayout->setMargin( 2 );
+
+ TabWidget = new QTabWidget( this, "TabWidget" );
+
+ tab = new QWidget( TabWidget, "tab" );
+ tabLayout = new QGridLayout( tab );
+ tabLayout->setSpacing( 6);
+ tabLayout->setMargin( 11);
+
+ storageComboBox = new QComboBox( FALSE, tab, "storageComboBox" );
+
+ tabLayout->addMultiCellWidget( storageComboBox, 0, 0, 0, 1 );
+
+ TextLabel4 = new QLabel( tab, "TextLabel4" );
+ TextLabel4->setText( tr( "Storage Type" ) );
+
+ tabLayout->addMultiCellWidget( TextLabel4, 1, 1, 0, 1 );
+
+ TextLabel2 = new QLabel( tab, "TextLabel2" );
+ TextLabel2->setText( tr( "File Systems" ) );
+
+ tabLayout->addMultiCellWidget( TextLabel2, 4, 4, 0, 1 );
+
+ fileSystemsCombo = new QComboBox( FALSE, tab, "fileSystemsCombo" );
+
+ tabLayout->addMultiCellWidget( fileSystemsCombo, 3, 3, 0, 1 );
+ QSpacerItem* spacer = new QSpacerItem( 20, 20, QSizePolicy::Minimum, QSizePolicy::Expanding );
+ tabLayout->addItem( spacer, 2, 1 );
+
+ formatPushButton = new QPushButton( tab, "formatPushButton" );
+ formatPushButton->setText( tr( "Format" ) );
+
+ tabLayout->addMultiCellWidget( formatPushButton, 6, 6, 0, 1 );
+ QSpacerItem* spacer_2 = new QSpacerItem( 20, 20, QSizePolicy::Minimum, QSizePolicy::Expanding );
+ tabLayout->addItem( spacer_2, 5, 0 );
+ TabWidget->insertTab( tab, tr( "Main" ) );
+
+ tab_2 = new QWidget( TabWidget, "tab_2" );
+ tabLayout_2 = new QGridLayout( tab_2 );
+ tabLayout_2->setSpacing( 6);
+ tabLayout_2->setMargin( 11);
+
+ mountPointLineEdit = new QLineEdit( tab_2, "mountPointLineEdit" );
+
+ tabLayout_2->addMultiCellWidget( mountPointLineEdit, 0, 0, 0, 1 );
+
+ deviceComboBox = new QComboBox( FALSE, tab_2, "deviceComboBox" );
+
+ tabLayout_2->addMultiCellWidget( deviceComboBox, 3, 3, 0, 1 );
+
+ TextLabel5 = new QLabel( tab_2, "TextLabel5" );
+ TextLabel5->setText( tr( "CAUTION:\n"
+ "Changing parameters on this \n"
+ "page may cause your system \n"
+ "to stop functioning properly!!" ) );//idiot message
+
+ tabLayout_2->addMultiCellWidget( TextLabel5, 6, 6, 0, 1 );
+
+ editPushButton = new QPushButton( tab_2, "editPushButton" );
+ editPushButton->setText( tr( "Edit fstab" ) );
+
+ tabLayout_2->addMultiCellWidget( editPushButton, 7, 7, 0, 0 );
+
+ fsckButton = new QPushButton( tab_2, "fsckPushButton" );
+ fsckButton->setText( tr( "Check Disk" ) );
+
+ tabLayout_2->addMultiCellWidget( fsckButton, 7, 7, 1, 1 );
+
+ TextLabel3 = new QLabel( tab_2, "TextLabel3" );
+ TextLabel3->setText( tr( "Device" ) );
+
+ tabLayout_2->addMultiCellWidget( TextLabel3, 4, 4, 0, 1 );
+ QSpacerItem* spacer_3 = new QSpacerItem( 20, 20, QSizePolicy::Minimum, QSizePolicy::Expanding );
+ tabLayout_2->addItem( spacer_3, 5, 0 );
+
+ TextLabel1 = new QLabel( tab_2, "TextLabel1" );
+ TextLabel1->setText( tr( "Mount Point" ) );
+
+ tabLayout_2->addMultiCellWidget( TextLabel1, 1, 1, 0, 1 );
+ QSpacerItem* spacer_4 = new QSpacerItem( 20, 20, QSizePolicy::Minimum, QSizePolicy::Expanding );
+ tabLayout_2->addItem( spacer_4, 2, 1 );
+ TabWidget->insertTab( tab_2, tr( "Advanced" ) );
+
+ FormatterAppLayout->addWidget( TabWidget, 0, 0 );
+
+ connect( formatPushButton ,SIGNAL(released()),this,SLOT( doFormat()) );
+ connect( editPushButton ,SIGNAL(released()),this,SLOT( editFstab()) );
+ connect( fsckButton ,SIGNAL(released()),this,SLOT( doFsck()) );
+
+ connect( fileSystemsCombo,SIGNAL(activated(int)),this,SLOT( fsComboSelected(int ) ));
+ connect( storageComboBox,SIGNAL(activated(int)),this,SLOT( storageComboSelected(int ) ));
+ connect( deviceComboBox,SIGNAL(activated(int)),this,SLOT( deviceComboSelected(int ) ));
+
+
+ fillCombos();
+}
+
+/*
+ * Destroys the object and frees any allocated resources
+ frickin no duh?!?
+ */
+FormatterApp::~FormatterApp()
+{
+
+}
+
+void FormatterApp::doFormat() {
+ int err=0;
+ Output *outDlg;
+ QString umountS, remountS;
+ QString text = storageComboBox->currentText();
+ QString currentText = storageComboBox->currentText();
+ QString cmd = currentText.right( currentText.length() - currentText.find(" -> ",0,TRUE) - 4);
+ QString fs = fileSystemsCombo->currentText();
+
+ if( currentText.find("CF",0,TRUE) != -1) {
+ umountS = "/sbin/cardctl eject";
+ remountS = "/sbin/cardctl insert";
+ }
+ if( currentText.find("SD",0,TRUE) != -1) {
+ umountS = "/etc/sdcontrol compeject";
+ remountS = "/etc/sdcontrol insert";
+ }
+
+ switch ( QMessageBox::warning(this,tr("Format?!?"),tr("Really format\n") + currentText +
+ tr("\nwith ") + fs + tr(" filesystem?!?"),tr("Yes"),tr("No"),0,1,1) ) {
+ case 0: {
+ if(fs == "vfat")
+ cmd = "mkdosfs " + cmd;
+ else if(fs == "ext2")
+ cmd = "mke2fs " + cmd;
+ else {
+ QMessageBox::warning(this, tr("Formatter"),tr("Could not format.\nUnknown type"), tr("Ok"));
+ break;
+ }
+// cmd = "ls -l";
+ outDlg = new Output(this, tr("Formatter Output"),FALSE);
+ outDlg->showMaximized();
+ outDlg->show();
+ qApp->processEvents();
+ FILE *fp;
+ char line[130];
+ outDlg->OutputEdit->append( tr("Trying to eject.") + currentText );
+ sleep(1);
+ fp = popen( (const char *) umountS, "r");
+ if ( !fp ) {
+ qDebug("Could not execute '" + umountS + "'! err=%d", fp);
+ QMessageBox::warning( this, tr("CardMonitor"), tr("Card eject failed!"), tr("&OK") );
+ pclose(fp);
+ return;
+ } else {
+ outDlg->OutputEdit->append( currentText + tr("\nhas been successfully ejected."));
+
+ while ( fgets( line, sizeof line, fp)) {
+ outDlg->OutputEdit->append(line);
+ }
+ }
+ pclose(fp);
+// err = system( (const char *) umountS);
+
+ qDebug("Command would be: "+cmd);
+ outDlg->OutputEdit->append( tr("Trying to format.") );
+
+ fp = popen( (const char *) cmd, "r");
+ while ( fgets( line, sizeof line, fp)) {
+ outDlg->OutputEdit->append(line);
+ }
+ outDlg->OutputEdit->append( currentText + tr("\nhas been successfully formatted."));
+ pclose(fp);
+
+ outDlg->OutputEdit->append( tr("Trying to insert.") + currentText );
+ fp = popen( (const char *) remountS, "r");
+ if ( !fp) {
+ qDebug("Could not execute '" + remountS + "'! err=%d", err);
+ QMessageBox::warning( this, tr("Formatter"), tr("Card insert failed!"), tr("&OK") );
+
+ } else {
+ outDlg->OutputEdit->append( currentText + tr("\nhas been successfully inserted."));
+ while ( fgets( line, sizeof line, fp)) {
+ outDlg->OutputEdit->append(line);
+ }
+ }
+ pclose(fp);
+ sleep(1);
+
+ outDlg->OutputEdit->append(tr("You can now close the output window."));
+ outDlg->close();
+ if(outDlg)
+ delete outDlg;
+ }
+ break;
+ };
+}
+
+void FormatterApp::fillCombos() {
+
+ StorageInfo storageInfo;
+ const QList<FileSystem> &fs = storageInfo.fileSystems();
+ QListIterator<FileSystem> it ( fs );
+ QString storage;
+ for( ; it.current(); ++it ){
+ const QString name = (*it)->name();
+ const QString path = (*it)->path();
+ const QString disk = (*it)->disk();
+ const QString options = (*it)->options();
+ if( name.find( tr("Internal"),0,TRUE) == -1) {
+ storageComboBox->insertItem(name +" -> "+disk);
+ }
+ deviceComboBox->insertItem(disk);
+ }
+ parsetab();
+ fileSystemsCombo->insertStringList( fsList,-1);
+// for(int i = 0; i < fileSystemsCombo->count(); i++) {
+// if( fsType == fileSystemsCombo->text(i))
+// fileSystemsCombo->setCurrentItem(i);
+// }
+ storageComboSelected(0);
+ deviceComboSelected(0);
+}
+
+
+void FormatterApp::fsComboSelected(int index) {
+
+}
+
+void FormatterApp::storageComboSelected(int index ) {
+
+ QString currentText = storageComboBox->text(index);
+ QString nameS = currentText.left( currentText.find("->",0,TRUE));
+
+ TextLabel4->setText( tr( "Storage Type : ") + nameS );
+ currentText = currentText.right( currentText.length() - currentText.find(" -> ",0,TRUE) - 4);
+
+ QString fsType = getFileSystemType((const QString &) currentText);
+// qDebug(fsType);
+ for(int i = 0; i < fileSystemsCombo->count(); i++) {
+ if( fsType == fileSystemsCombo->text(i))
+ fileSystemsCombo->setCurrentItem(i);
+ }
+// deviceComboSelected(index);
+}
+
+void FormatterApp::deviceComboSelected(int index) {
+
+ StorageInfo storageInfo;
+ QString totalS, usedS, avS, diskS, nameS, fsType, selectedText;
+
+ selectedText = deviceComboBox->text(index);
+
+ const QList<FileSystem> &fs = storageInfo.fileSystems();
+ QListIterator<FileSystem> it ( fs );
+ QString storage;
+ for( ; it.current(); ++it ){
+ const QString name = (*it)->name();
+ const QString path = (*it)->path();
+ const QString disk = (*it)->disk();
+// const QString options = (*it)->options();
+ if( selectedText == disk) {
+ diskS = disk; nameS= name;
+ mountPointLineEdit->setText(path);
+ long mult = (*it)->blockSize() / 1024;
+ long div = 1024 / (*it)->blockSize();
+ if ( !mult ) mult = 1;
+ if ( !div ) div = 1;
+ long total = (*it)->totalBlocks() * mult / div;
+ long totalMb = total/1024;
+ long avail = (*it)->availBlocks() * mult / div;
+ long availMb = avail/1024;
+ long used = total - avail;
+ long usedMb = used/1024;
+ totalS.sprintf(tr("Total: %1 kB ( %d mB)\n").arg( total ), totalMb );
+ usedS.sprintf(tr("Used: %1 kB ( %d mB)\n").arg(used) ,usedMb);
+ avS.sprintf( tr("Available: %1 kB ( %d mB)").arg(avail), availMb );
+ }
+ }
+ fsType = getFileSystemType((const QString &)selectedText);
+
+ TextLabel5->setText("Type: "+ nameS+" Formatted with "+ fsType + " \n" + totalS + usedS + avS);
+// storageComboSelected(0);
+}
+
+void FormatterApp::cleanUp() {
+
+}
+
+
+void FormatterApp::editFstab() {
+ QCopEnvelope e("QPE/Application/textedit","setDocument(QString)");
+ e << (const QString &)"/etc/fstab";
+}
+
+void FormatterApp::parsetab() {
+
+ fileSystemTypeList.clear();
+ fsList.clear();
+ struct mntent *me;
+ FILE *mntfp = setmntent( "/etc/mtab", "r" );
+ if ( mntfp ) {
+ while ( (me = getmntent( mntfp )) != 0 ) {
+ QString deviceName = me->mnt_fsname;
+ QString filesystemType = me->mnt_type;
+ if(deviceName != "none") {
+ if( fsList.contains(filesystemType) == 0
+ & filesystemType.find("proc",0,TRUE) == -1
+ & filesystemType.find("cramfs",0,TRUE) == -1)
+ fsList << filesystemType;
+ fileSystemTypeList << deviceName+"::"+filesystemType;
+ }
+ }
+ }
+ endmntent( mntfp );
+
+// QFile f("/etc/fstab");
+// if ( f.open(IO_ReadOnly) ) {
+// QTextStream t (&f);
+// QString s;
+// while (! t.eof()) {
+// s=t.readLine();
+// s=s.simplifyWhiteSpace();
+// if ( (!s.isEmpty() ) && (s.find(" ")!=0) ) {
+// s=s.remove(0,s.find(BLANK)+1 ); // devicename
+// s=s.remove(0,s.find(BLANK)+1 ); // mountpoint
+// s=s.remove(0,s.find(BLANK)+1 ); // fs
+// }
+// }
+// }
+// f.close();
+}
+
+QString FormatterApp::getFileSystemType(const QString &currentText) {
+
+ parsetab(); //why did TT forget filesystem type?
+
+ for ( QStringList::Iterator it = fileSystemTypeList.begin(); it != fileSystemTypeList.end(); ++it ) {
+ QString temp = (*it);
+ if( temp.find( currentText,0,TRUE) != -1) {
+ return temp.right( temp.length() - temp.find("::",0,TRUE) - 2);
+// qDebug(fsType);
+ }
+ }
+ return "";
+}
+
+void FormatterApp::doFsck() {
+
+ QString selectedDevice = deviceComboBox->currentText();
+ QString fsType = getFileSystemType((const QString &)selectedDevice);
+ QString cmd;
+ qDebug( selectedDevice +" "+ fsType);
+ if(fsType == "vfat") cmd = "dosfsck -vy ";
+ if(fsType == "ext2") cmd = "e2fsck -cpvy ";
+ cmd += selectedDevice;
+
+}