Source Code (Use browser search to find items of interest.)

Class Index

kdf'DiskList (./kdeutils/kdf/disklist.h:96)

class DiskList : public QObject
{  Q_OBJECT
public:
   DiskList( QObject *parent=0, const char *name=0 );
 ~DiskList();
   int readFSTAB(); 
   int readDF();
   int find(const DiskEntry* disk) {return disks->find(disk);};
   DiskEntry*  at(uint index) {return disks->at(index);};
   DiskEntry* first() {return disks->first();};
   DiskEntry* next() {return disks->next();};

signals:
   void readDFDone();
   void criticallyFull(DiskEntry *disk);

public slots:
  void loadSettings();
  void applySettings();
   
private slots:
   void receivedDFStdErrOut(KProcess *, char *data, int len);
   void dfDone();

private: 
  void replaceDeviceEntry(DiskEntry *disk);

  Disks            *disks;
  KProcess         *dfProc;
  QString           dfStringErrOut;
  bool              readingDFStdErrOut;
  KConfig           *config;
 
};
/***************************************************************************/


kdf'DiskList::DiskList() (./kdeutils/kdf/disklist.cpp:50)

DiskList::DiskList(QObject *parent, const char *name) 
    : QObject(parent,name)
{ 
  /*
#ifdef _OS_LINUX_
  debug("_OS_LINUX_");
#endif
#ifdef _OS_FREEBSD_
  debug("_OS_FREEBSD_");
#endif
#ifdef _OS_SUN_
  debug("_OS_SUN_");
#endif
#ifdef _OS_SOLARIS_
  debug("_OS_SOLARIS_");
#endif
#ifdef _OS_HPUX_
  debug("_OS_HPUX_");
#endif
#ifdef _OS_UNIX_
  debug("_OS_UNIX_");
#endif
  */

if (NO_FS_TYPE)
  debug("df gives no FS_TYPE");
   
   disks = new Disks;
   disks->setAutoDelete(TRUE);

   // BackgroundProcesses ****************************************
      dfProc = new KProcess(); CHECK_PTR(dfProc);
       connect( dfProc, SIGNAL(receivedStdout(KProcess *, char *, int) ),
           this, SLOT (receivedDFStdErrOut(KProcess *, char *, int)) );
       //connect( dfProc, SIGNAL(receivedStderr(KProcess *, char *, int) ),
       //  this, SLOT (receivedDFStdErrOut(KProcess *, char *, int)) );
       connect(dfProc,SIGNAL(processExited(KProcess *) ),
              this, SLOT(dfDone() ) );

       readingDFStdErrOut=FALSE;
       config = kapp->config();
       QString s="xclient1:/zip|/zip";
       loadSettings();
       //readFSTAB();
       //readDF();
};


/***************************************************************************
  * destructor
**/

kdf'DiskList::~DiskList() (./kdeutils/kdf/disklist.cpp:101)

DiskList::~DiskList()
{
};


/***************************************************************************
  * saves the KConfig for special mount/umount scripts
**/

kdf'DiskList::applySettings() (./kdeutils/kdf/disklist.cpp:109)

void DiskList::applySettings()
{
  debug("  DiskList::applySettings");
 QString oldgroup=config->group();
 config->setGroup("DiskList");
 QString key;
 DiskEntry *disk;
 for (disk=disks->first();disk!=0;disk=disks->next()) {
   key.sprintf("Mount%s%s%s%s",SEPARATOR,disk->deviceName().latin1()
                              ,SEPARATOR,disk->mountPoint().latin1());
   config->writeEntry(key,disk->mountCommand());
   
   key.sprintf("Umount%s%s%s%s",SEPARATOR,disk->deviceName().latin1()
                              ,SEPARATOR,disk->mountPoint().latin1());
   config->writeEntry(key,disk->umountCommand());

   key.sprintf("Icon%s%s%s%s",SEPARATOR,disk->deviceName().latin1()
                              ,SEPARATOR,disk->mountPoint().latin1());
   config->writeEntry(key,disk->realIconName());
 }
 config->sync();
 config->setGroup(oldgroup);
}


/***************************************************************************
  * reads the KConfig for special mount/umount scripts
**/

kdf'DiskList::loadSettings() (./kdeutils/kdf/disklist.cpp:137)

void DiskList::loadSettings()
{
  debug("DiskList::loadSettings");
 config->setGroup("DiskList");
 QString key;
 DiskEntry *disk;
 for (disk=disks->first();disk!=0;disk=disks->next()) {
   key.sprintf("Mount%s%s%s%s",SEPARATOR,disk->deviceName().latin1()
                              ,SEPARATOR,disk->mountPoint().latin1());
   disk->setMountCommand(config->readEntry(key,""));

   key.sprintf("Umount%s%s%s%s",SEPARATOR,disk->deviceName().latin1()
                              ,SEPARATOR,disk->mountPoint().latin1());
   disk->setUmountCommand(config->readEntry(key,""));

   key.sprintf("Icon%s%s%s%s",SEPARATOR,disk->deviceName().latin1()
                              ,SEPARATOR,disk->mountPoint().latin1());
   QString icon=config->readEntry(key,"");
   if (!icon.isEmpty()) disk->setIconName(icon);
 }
}

/***************************************************************************
  * tries to figure out the possibly mounted fs
**/

kdf'DiskList::readFSTAB() (./kdeutils/kdf/disklist.cpp:162)

int DiskList::readFSTAB()
{
  if (readingDFStdErrOut || dfProc->isRunning()) return -1;
  debug("DiskList::readFSTAB");

QFile f(FSTAB);
  if ( f.open(IO_ReadOnly) ) {
    QTextStream t (&f);
    QString s;
    DiskEntry *disk;

    //disks->clear(); // ############

    while (! t.eof()) {
      s=t.readLine();
      s=s.simplifyWhiteSpace();
      if ( (!s.isEmpty() ) && (s.find(DELIMITER)!=0) ) {
               // not empty or commented out by '#'
	debug("GOT: [%s]",s.latin1() );
	disk = new DiskEntry();// CHECK_PTR(disk);	
        disk->setMounted(FALSE);
        disk->setDeviceName(s.left(s.find(BLANK)) );
            s=s.remove(0,s.find(BLANK)+1 );
	    debug("    deviceName:    [%s]",(const char*)disk->deviceName() );
#ifdef _OS_SOLARIS_
            //device to fsck
            s=s.remove(0,s.find(BLANK)+1 );
#endif        
         disk->setMountPoint(s.left(s.find(BLANK)) );
            s=s.remove(0,s.find(BLANK)+1 );
	    debug("    MountPoint:    [%s]",(const char*)disk->mountPoint() );
	    debug("    Icon:          [%s]",(const char*)disk->iconName() );
         disk->setFsType(s.left(s.find(BLANK)) );
            s=s.remove(0,s.find(BLANK)+1 );
	    debug("    FS-Type:       [%s]",(const char*)disk->fsType() );
         disk->setMountOptions(s.left(s.find(BLANK)) );
            s=s.remove(0,s.find(BLANK)+1 );
	    debug("    Mount-Options: [%s]",(const char*)disk->mountOptions() );
         if ( (disk->deviceName() != "none") && (disk->fsType() != "swap") 
                             && (disk->mountPoint() != "/dev/swap")
                             && (disk->mountPoint() != "/proc") )
	   replaceDeviceEntry(disk); 
         else
           delete disk;

      } //if not empty
    } //while
    f.close();
  } //if f.open

  loadSettings(); //to get the mountCommands

  debug("DiskList::readFSTAB DONE");
  return 1;
}


/***************************************************************************
  * is called, when the df-command writes on StdOut or StdErr
**/

kdf'DiskList::receivedDFStdErrOut() (./kdeutils/kdf/disklist.cpp:222)

void DiskList::receivedDFStdErrOut(KProcess *, char *data, int len )
{
  debug("DiskList::receivedDFStdErrOut");

  /* ATTENTION: StdERR no longer connected to this... 
   * Do we really need StdErr?? on HP-UX there was eg. a line
   * df: /home_tu1/ijzerman/floppy: Stale NFS file handle
   * but this shouldn't cause a real problem
   */
  
  QString tmp = QString(data) + QString("\0");  // adds a zero-byte
  tmp.truncate(len);
  
  dfStringErrOut.append(tmp);
}

/***************************************************************************
  * reads the df-commands results
**/

kdf'DiskList::readDF() (./kdeutils/kdf/disklist.cpp:241)

int DiskList::readDF()
{ 
  if (readingDFStdErrOut || dfProc->isRunning()) return -1; 
  debug("DiskList::readDF");
  dfStringErrOut=""; // yet no data received
  dfProc->clearArguments();
  (*dfProc) << DF_COMMAND << DF_ARGS;
  if (!dfProc->start( KProcess::NotifyOnExit, KProcess::AllOutput ))
     fatal(i18n("could not execute [%s]"),DF_COMMAND);
  return 1;
}


/***************************************************************************
  * is called, when the df-command has finished
**/

kdf'DiskList::dfDone() (./kdeutils/kdf/disklist.cpp:257)

void DiskList::dfDone()
{
  debug("DiskList::dfDone");
  readingDFStdErrOut=TRUE;
  for ( DiskEntry *disk=disks->first(); disk != 0; disk=disks->next() )
    disk->setMounted(FALSE);  // set all devs unmounted

  QTextStream t (dfStringErrOut, IO_ReadOnly);
  QString s=t.readLine();
  if ( (s.isEmpty()) || ( s.left(10) != "Filesystem" ) ) 
    fatal("Error running df command... got [%s]",s.latin1());
  while ( !t.atEnd() ) {
    QString u,v;
    DiskEntry *disk;
    s=t.readLine();
    s=s.simplifyWhiteSpace();
    if ( !s.isEmpty() ) {
      disk = new DiskEntry(); CHECK_PTR(disk);
      
      if (s.find(BLANK)<0)      // devicename was too long, rest in next line
	if ( !t.eof() ) {       // just appends the next line
            v=t.readLine();
            s=s.append(v.latin1() );
            s=s.simplifyWhiteSpace();
            debug("SPECIAL GOT: [%s]",s.latin1() );
	 }//if silly linefeed

      debug("EFFECTIVELY GOT %i chars: [%s]",s.length(),s.latin1() );
	 
      disk->setDeviceName(s.left(s.find(BLANK)) );
      s=s.remove(0,s.find(BLANK)+1 );
      debug("    DeviceName:    [%s]",(const char*)disk->deviceName() );

      if (NO_FS_TYPE) {
	debug("THERE IS NO FS_TYPE_FIELD!");
         disk->setFsType("?");
      } else {
         disk->setFsType(s.left(s.find(BLANK)) );
         s=s.remove(0,s.find(BLANK)+1 );
      };
      debug("    FS-Type:       [%s]",(const char*)disk->fsType() );
      debug("    Icon:          [%s]",(const char*)disk->iconName() );

      u=s.left(s.find(BLANK));
      disk->setKBSize(u.toInt() );
      s=s.remove(0,s.find(BLANK)+1 );
      debug("    Size:       [%d]",disk->kBSize() );

      u=s.left(s.find(BLANK));
      disk->setKBUsed(u.toInt() );
      s=s.remove(0,s.find(BLANK)+1 );
      debug("    Used:       [%d]",disk->kBUsed() );
    
      u=s.left(s.find(BLANK));
      disk->setKBAvail(u.toInt() );
      s=s.remove(0,s.find(BLANK)+1 );
      debug("    Avail:       [%d]",disk->kBAvail() );
    

      s=s.remove(0,s.find(BLANK)+1 );  // delete the capacity 94%
      disk->setMountPoint(s.left(s.find(BLANK)) );
      s=s.remove(0,s.find(BLANK)+1 );
      debug("    MountPoint:       [%s]",(const char*)disk->mountPoint() );
  
      if (disk->kBSize() > 0) {
        disk->setMounted(TRUE);    // its now mounted (df lists only mounted)
        replaceDeviceEntry(disk);
      } else {
       warning("[%s] has a kBSize == 0!",disk->deviceName().latin1());
       delete disk;
      }
    }//if not header
  }//while further lines available

  readingDFStdErrOut=FALSE;
  loadSettings(); //to get the mountCommands
  emit readDFDone();
}


/***************************************************************************
  * updates or creates a new DiskEntry in the KDFList and TabListBox
**/

kdf'DiskList::replaceDeviceEntry() (./kdeutils/kdf/disklist.cpp:340)

void DiskList::replaceDeviceEntry(DiskEntry *disk)
{ 
  //
  // The 'disks' may already already contain the 'disk'. If it do 
  // we will replace some data. Otherwise 'disk' will be added to the list
  //

  //
  // 1999-27-11 Espen Sand:
  // I can't get find() to work. The Disks::compareItems(..) is 
  // never called.
  //
  //int pos=disks->find(disk);

  int pos = -1;
  for( u_int i=0; i<disks->count(); i++ )
  {
    DiskEntry *item = disks->at(i);
    int res = strcmp( disk->deviceName(), item->deviceName() );
    if( res == 0 )
    {
      res = strcmp( disk->mountPoint(), item->mountPoint() );
    }
    if( res == 0 )
    {
      pos = i;
      break;
    }
  }

  if ((pos == -1) && (disk->mounted()) )
    // no matching entry found for mounted disk
    if ((disk->fsType() == "?") || (disk->fsType() == "cachefs")) {
      //search for fitting cachefs-entry in static /etc/vfstab-data
      debug("search for [%s]",(const char *)disk->deviceName());
      DiskEntry* olddisk = disks->first();
      QString odiskName;
      while (olddisk != 0) {
        int p;
        // cachefs deviceNames have no / behind the host-column
	// eg. /cache/cache/.cfs_mnt_points/srv:_home_jesus
	//                                      ^    ^
        odiskName = olddisk->deviceName().copy();
        int ci=odiskName.find(':'); // goto host-column
        while ((ci =odiskName.find('/',ci)) > 0) {
           odiskName.replace(ci,1,"_");
        }//while
        debug("     check against [%s]",(const char *)olddisk->deviceName());
        // check if there is something that is exactly the tail
	// eg. [srv:/tmp3] is exact tail of [/cache/.cfs_mnt_points/srv:_tmp3]
        if ( ( (p=disk->deviceName().findRev(odiskName
	            ,disk->deviceName().length()) )
                != -1) 
	      && (p + odiskName.length()
	          == disk->deviceName().length()) ) 
        {
             pos = disks->at(); //store the actual position
	     debug("   FOUND [%s] at pos %i at ListPos %i",olddisk->deviceName().latin1(),p,pos);
             disk->setDeviceName(olddisk->deviceName());
             olddisk=0;
	} else 
          olddisk=disks->next();       
      }// while
    }// if fsType == "?" or "cachefs"
  

#ifdef NO_FS_TYPE
  if (pos != -1) {
     DiskEntry * olddisk = disks->at(pos);
     if (olddisk)
        disk->setFsType(olddisk->fsType());     
  }
#endif  

  if (pos != -1) {  // replace
    debug("dev %s is replaced",disk->deviceName().latin1());
      DiskEntry * olddisk = disks->at(pos);
      if ( (-1!=olddisk->mountOptions().find("user")) &&
           (-1==disk->mountOptions().find("user")) ) {
          // add "user" option to new diskEntry
          QString s=disk->mountOptions();
          if (s.length()>0) s.append(",");
          s.append("user");
          disk->setMountOptions(s);
       }
      disk->setMountCommand(olddisk->mountCommand());
      disk->setUmountCommand(olddisk->umountCommand());
   
      //FStab after an older DF ... needed for critFull
      //so the DF-KBUsed survive a FStab lookup...
      //but also an unmounted disk may then have a kbused set...
      if ( (olddisk->mounted()) && (!disk->mounted()) ) {
         disk->setKBSize(olddisk->kBSize());
         disk->setKBUsed(olddisk->kBUsed());
         disk->setKBAvail(olddisk->kBAvail());
      }
          if ( (olddisk->percentFull() != -1) && 
               (olddisk->percentFull() <  FULL_PERCENT) && 
                  (disk->percentFull() >= FULL_PERCENT) ) {
             debug("Device %s is critFull! %f--%f"
                      ,(const char *)disk->deviceName()
                      ,olddisk->percentFull(), disk->percentFull() );
            emit criticallyFull(disk);
	  }
      disks->remove(pos); // really deletes old one
      disks->insert(pos,disk);
  } else {
    disks->append(disk);
  }//if 

}