2002-02-13 21:01:50 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/volume.h
|
|
|
|
// Purpose: wxFSVolume - encapsulates system volume information
|
|
|
|
// Author: George Policello
|
|
|
|
// Modified by:
|
|
|
|
// Created: 28 Jan 02
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) 2002 George Policello
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2002-02-13 21:01:50 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxFSVolume represents a volume/drive/mount point in a file system
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#ifndef _WX_FSVOLUME_H_
|
|
|
|
#define _WX_FSVOLUME_H_
|
|
|
|
|
2003-08-09 12:38:21 +00:00
|
|
|
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
2002-02-13 21:01:50 +00:00
|
|
|
#pragma interface "fsvolume.h"
|
|
|
|
#endif
|
|
|
|
|
2002-02-24 00:19:01 +00:00
|
|
|
#include "wx/defs.h"
|
|
|
|
|
|
|
|
#if wxUSE_FSVOLUME
|
|
|
|
|
2002-02-13 21:01:50 +00:00
|
|
|
// the volume flags
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
// is the volume mounted?
|
|
|
|
wxFS_VOL_MOUNTED = 0x0001,
|
|
|
|
|
|
|
|
// is the volume removable (floppy, CD, ...)?
|
|
|
|
wxFS_VOL_REMOVABLE = 0x0002,
|
|
|
|
|
|
|
|
// read only? (otherwise read write)
|
|
|
|
wxFS_VOL_READONLY = 0x0004,
|
|
|
|
|
|
|
|
// network resources
|
|
|
|
wxFS_VOL_REMOTE = 0x0008
|
|
|
|
};
|
|
|
|
|
|
|
|
// the volume types
|
|
|
|
enum wxFSVolumeKind
|
|
|
|
{
|
|
|
|
wxFS_VOL_FLOPPY,
|
|
|
|
wxFS_VOL_DISK,
|
|
|
|
wxFS_VOL_CDROM,
|
|
|
|
wxFS_VOL_DVDROM,
|
|
|
|
wxFS_VOL_NETWORK,
|
|
|
|
wxFS_VOL_OTHER,
|
|
|
|
wxFS_VOL_MAX
|
|
|
|
};
|
|
|
|
|
2003-07-02 01:59:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxFSVolumeBase
|
2002-02-13 21:01:50 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// return the array containing the names of the volumes
|
|
|
|
//
|
|
|
|
// only the volumes with the flags such that
|
|
|
|
// (flags & flagsSet) == flagsSet && !(flags & flagsUnset)
|
|
|
|
// are returned (by default, all mounted ones)
|
|
|
|
static wxArrayString GetVolumes(int flagsSet = wxFS_VOL_MOUNTED,
|
|
|
|
int flagsUnset = 0);
|
|
|
|
|
|
|
|
// stop execution of GetVolumes() called previously (should be called from
|
|
|
|
// another thread, of course)
|
|
|
|
static void CancelSearch();
|
|
|
|
|
|
|
|
// create the volume object with this name (should be one of those returned
|
|
|
|
// by GetVolumes()).
|
2003-06-24 00:56:19 +00:00
|
|
|
wxFSVolumeBase();
|
|
|
|
wxFSVolumeBase(const wxString& name);
|
2002-02-13 21:01:50 +00:00
|
|
|
bool Create(const wxString& name);
|
|
|
|
|
|
|
|
// accessors
|
|
|
|
// ---------
|
|
|
|
|
|
|
|
// is this a valid volume?
|
|
|
|
bool IsOk() const;
|
|
|
|
|
|
|
|
// kind of this volume?
|
|
|
|
wxFSVolumeKind GetKind() const;
|
|
|
|
|
|
|
|
// flags of this volume?
|
|
|
|
int GetFlags() const;
|
|
|
|
|
|
|
|
// can we write to this volume?
|
|
|
|
bool IsWritable() const { return !(GetFlags() & wxFS_VOL_READONLY); }
|
|
|
|
|
|
|
|
// get the name of the volume and the name which should be displayed to the
|
|
|
|
// user
|
|
|
|
wxString GetName() const { return m_volName; }
|
|
|
|
wxString GetDisplayName() const { return m_dispName; }
|
|
|
|
|
|
|
|
// TODO: operatios (Mount(), Unmount(), Eject(), ...)?
|
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
protected:
|
|
|
|
// the internal volume name
|
2002-02-13 21:01:50 +00:00
|
|
|
wxString m_volName;
|
2003-06-24 00:56:19 +00:00
|
|
|
|
|
|
|
// the volume name as it is displayed to the user
|
2002-02-13 21:01:50 +00:00
|
|
|
wxString m_dispName;
|
2003-06-24 00:56:19 +00:00
|
|
|
|
|
|
|
// have we been initialized correctly?
|
|
|
|
bool m_isOk;
|
|
|
|
};
|
|
|
|
|
2002-02-13 21:01:50 +00:00
|
|
|
#if wxUSE_GUI
|
2003-06-24 00:56:19 +00:00
|
|
|
|
|
|
|
#include "wx/icon.h"
|
|
|
|
#include "wx/iconbndl.h" // only for wxIconArray
|
|
|
|
|
|
|
|
enum wxFSIconType
|
|
|
|
{
|
|
|
|
wxFS_VOL_ICO_SMALL = 0,
|
|
|
|
wxFS_VOL_ICO_LARGE,
|
|
|
|
wxFS_VOL_ICO_SEL_SMALL,
|
|
|
|
wxFS_VOL_ICO_SEL_LARGE,
|
|
|
|
wxFS_VOL_ICO_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
// wxFSVolume adds GetIcon() to wxFSVolumeBase
|
|
|
|
class wxFSVolume : public wxFSVolumeBase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxFSVolume() : wxFSVolumeBase() { InitIcons(); }
|
|
|
|
wxFSVolume(const wxString& name) : wxFSVolumeBase(name) { InitIcons(); }
|
|
|
|
|
|
|
|
wxIcon GetIcon(wxFSIconType type) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void InitIcons();
|
|
|
|
|
|
|
|
// the different icons for this volume (created on demand)
|
2002-02-13 21:01:50 +00:00
|
|
|
wxIconArray m_icons;
|
2003-06-24 00:56:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#else // !wxUSE_GUI
|
2002-02-13 21:01:50 +00:00
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
// wxFSVolume is the same thing as wxFSVolume in wxBase
|
2004-01-31 14:49:51 +00:00
|
|
|
typedef wxFSVolumeBase wxFSVolume;
|
2002-02-13 21:01:50 +00:00
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
#endif // wxUSE_GUI/!wxUSE_GUI
|
|
|
|
|
2002-02-24 00:19:01 +00:00
|
|
|
#endif // wxUSE_FSVOLUME
|
|
|
|
|
2002-02-13 21:01:50 +00:00
|
|
|
#endif // _WX_FSVOLUME_H_
|
|
|
|
|