You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
258 lines
6.3 KiB
258 lines
6.3 KiB
/* This file is part of the KDE Project
|
|
Copyright (c) 2004 Kévin Ottens <ervin ipsquad net>
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public
|
|
License version 2 as published by the Free Software Foundation.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#include "medium.h"
|
|
|
|
#include <kconfig.h>
|
|
#include <klocale.h>
|
|
|
|
const TQString Medium::SEPARATOR = "---";
|
|
|
|
Medium::Medium(const TQString &id, const TQString &name)
|
|
{
|
|
m_properties+= id; /* ID */
|
|
m_properties+= name; /* NAME */
|
|
m_properties+= name; /* LABEL */
|
|
m_properties+= TQString::null; /* USER_LABEL */
|
|
|
|
m_properties+= "false"; /* MOUNTABLE */
|
|
m_properties+= TQString::null; /* DEVICE_NODE */
|
|
m_properties+= TQString::null; /* MOUNT_POINT */
|
|
m_properties+= TQString::null; /* FS_TYPE */
|
|
m_properties+= "false"; /* MOUNTED */
|
|
m_properties+= TQString::null; /* BASE_URL */
|
|
m_properties+= TQString::null; /* MIME_TYPE */
|
|
m_properties+= TQString::null; /* ICON_NAME */
|
|
m_properties+= "false"; /* ENCRYPTED */
|
|
m_properties+= TQString::null; /* CLEAR_DEVICE_UDI */
|
|
|
|
loadUserLabel();
|
|
|
|
m_halmounted = false;
|
|
}
|
|
|
|
Medium::Medium()
|
|
{
|
|
m_properties+= TQString::null; /* ID */
|
|
m_properties+= TQString::null; /* NAME */
|
|
m_properties+= TQString::null; /* LABEL */
|
|
m_properties+= TQString::null; /* USER_LABEL */
|
|
|
|
m_properties+= TQString::null; /* MOUNTABLE */
|
|
m_properties+= TQString::null; /* DEVICE_NODE */
|
|
m_properties+= TQString::null; /* MOUNT_POINT */
|
|
m_properties+= TQString::null; /* FS_TYPE */
|
|
m_properties+= TQString::null; /* MOUNTED */
|
|
m_properties+= TQString::null; /* BASE_URL */
|
|
m_properties+= TQString::null; /* MIME_TYPE */
|
|
m_properties+= TQString::null; /* ICON_NAME */
|
|
m_properties+= TQString::null; /* ENCRYPTED */
|
|
m_properties+= TQString::null; /* CLEAR_DEVICE_UDI */
|
|
|
|
m_halmounted = false;
|
|
}
|
|
|
|
const Medium Medium::create(const TQStringList &properties)
|
|
{
|
|
Medium m;
|
|
|
|
if ( properties.size() >= PROPERTIES_COUNT )
|
|
{
|
|
m.m_properties[ID] = properties[ID];
|
|
m.m_properties[NAME] = properties[NAME];
|
|
m.m_properties[LABEL] = properties[LABEL];
|
|
m.m_properties[USER_LABEL] = properties[USER_LABEL];
|
|
|
|
m.m_properties[MOUNTABLE] = properties[MOUNTABLE];
|
|
m.m_properties[DEVICE_NODE] = properties[DEVICE_NODE];
|
|
m.m_properties[MOUNT_POINT] = properties[MOUNT_POINT];
|
|
m.m_properties[FS_TYPE] = properties[FS_TYPE];
|
|
m.m_properties[MOUNTED] = properties[MOUNTED];
|
|
m.m_properties[BASE_URL] = properties[BASE_URL];
|
|
m.m_properties[MIME_TYPE] = properties[MIME_TYPE];
|
|
m.m_properties[ICON_NAME] = properties[ICON_NAME];
|
|
m.m_properties[ENCRYPTED] = properties[ENCRYPTED];
|
|
m.m_properties[CLEAR_DEVICE_UDI] = properties[CLEAR_DEVICE_UDI];
|
|
}
|
|
|
|
return m;
|
|
}
|
|
|
|
Medium::List Medium::createList(const TQStringList &properties)
|
|
{
|
|
List l;
|
|
|
|
if ( properties.size() % (PROPERTIES_COUNT+1) == 0)
|
|
{
|
|
int media_count = properties.size()/(PROPERTIES_COUNT+1);
|
|
|
|
TQStringList props = properties;
|
|
|
|
for(int i=0; i<media_count; i++)
|
|
{
|
|
const Medium m = create(props);
|
|
l.append(m);
|
|
|
|
TQStringList::iterator first = props.begin();
|
|
TQStringList::iterator last = props.find(SEPARATOR);
|
|
++last;
|
|
props.erase(first, last);
|
|
}
|
|
}
|
|
|
|
return l;
|
|
}
|
|
|
|
|
|
void Medium::setName(const TQString &name)
|
|
{
|
|
m_properties[NAME] = name;
|
|
}
|
|
|
|
void Medium::setLabel(const TQString &label)
|
|
{
|
|
m_properties[LABEL] = label;
|
|
}
|
|
|
|
void Medium::setEncrypted(bool state)
|
|
{
|
|
m_properties[ENCRYPTED] = ( state ? "true" : "false" );
|
|
}
|
|
|
|
void Medium::setUserLabel(const TQString &label)
|
|
{
|
|
KConfig cfg("mediamanagerrc");
|
|
cfg.setGroup("UserLabels");
|
|
|
|
TQString entry_name = m_properties[ID];
|
|
|
|
if ( label.isNull() )
|
|
{
|
|
cfg.deleteEntry(entry_name);
|
|
}
|
|
else
|
|
{
|
|
cfg.writeEntry(entry_name, label);
|
|
}
|
|
|
|
m_properties[USER_LABEL] = label;
|
|
}
|
|
|
|
void Medium::loadUserLabel()
|
|
{
|
|
KConfig cfg("mediamanagerrc");
|
|
cfg.setGroup("UserLabels");
|
|
|
|
TQString entry_name = m_properties[ID];
|
|
|
|
if ( cfg.hasKey(entry_name) )
|
|
{
|
|
m_properties[USER_LABEL] = cfg.readEntry(entry_name);
|
|
}
|
|
else
|
|
{
|
|
m_properties[USER_LABEL] = TQString::null;
|
|
}
|
|
}
|
|
|
|
|
|
bool Medium::mountableState(bool mounted)
|
|
{
|
|
if ( m_properties[DEVICE_NODE].isEmpty()
|
|
|| ( mounted && m_properties[MOUNT_POINT].isEmpty() ) )
|
|
{
|
|
return false;
|
|
}
|
|
|
|
m_properties[MOUNTABLE] = "true";
|
|
m_properties[MOUNTED] = ( mounted ? "true" : "false" );
|
|
|
|
return true;
|
|
}
|
|
|
|
void Medium::mountableState(const TQString &deviceNode,
|
|
const TQString &mountPoint,
|
|
const TQString &fsType, bool mounted)
|
|
{
|
|
m_properties[MOUNTABLE] = "true";
|
|
m_properties[DEVICE_NODE] = deviceNode;
|
|
m_properties[MOUNT_POINT] = mountPoint;
|
|
m_properties[FS_TYPE] = fsType;
|
|
m_properties[MOUNTED] = ( mounted ? "true" : "false" );
|
|
}
|
|
|
|
void Medium::mountableState(const TQString &deviceNode,
|
|
const TQString &clearDeviceUdi,
|
|
const TQString &mountPoint,
|
|
const TQString &fsType, bool mounted)
|
|
{
|
|
m_properties[MOUNTABLE] = "true";
|
|
m_properties[DEVICE_NODE] = deviceNode;
|
|
m_properties[CLEAR_DEVICE_UDI] = clearDeviceUdi;
|
|
m_properties[MOUNT_POINT] = mountPoint;
|
|
m_properties[FS_TYPE] = fsType;
|
|
m_properties[MOUNTED] = ( mounted ? "true" : "false" );
|
|
}
|
|
|
|
void Medium::unmountableState(const TQString &baseURL)
|
|
{
|
|
m_properties[MOUNTABLE] = "false";
|
|
m_properties[BASE_URL] = baseURL;
|
|
}
|
|
|
|
void Medium::setMimeType(const TQString &mimeType)
|
|
{
|
|
m_properties[MIME_TYPE] = mimeType;
|
|
}
|
|
|
|
void Medium::setIconName(const TQString &iconName)
|
|
{
|
|
m_properties[ICON_NAME] = iconName;
|
|
}
|
|
|
|
bool Medium::needMounting() const
|
|
{
|
|
return isMountable() && !isMounted();
|
|
}
|
|
|
|
bool Medium::needDecryption() const
|
|
{
|
|
return isEncrypted() && clearDeviceUdi().isEmpty();
|
|
}
|
|
|
|
KURL Medium::prettyBaseURL() const
|
|
{
|
|
if ( !baseURL().isEmpty() )
|
|
return baseURL();
|
|
|
|
return KURL( mountPoint() );
|
|
}
|
|
|
|
TQString Medium::prettyLabel() const
|
|
{
|
|
if ( !userLabel().isEmpty() )
|
|
{
|
|
return userLabel();
|
|
}
|
|
else
|
|
{
|
|
return label();
|
|
}
|
|
}
|
|
|