17#include <QXmlStreamWriter>
19#include "ControlDisplayProperties.h"
20#include "ControlNet.h"
22#include "IException.h"
53 m_id =
new QUuid(QUuid::createUuid());
75 m_id =
new QUuid(QUuid::createUuid());
99 m_id =
new QUuid(QUuid::createUuid());
223 m_modified = modified;
263 return m_id->toString().remove(QRegExp(
"[{}]"));
278 QString newNetworkPath = project->
cnetRoot(newProjectRoot.
toString()) +
"/" +
290 if (!QFile::copy(oldNetworkPath,newNetworkPath) ) {
318 tr(
"Could not remove file [%1]").arg(
m_fileName),
340 original.
dir().dirName() +
"/" + original.
name());
355 stream.writeStartElement(
"controlNet");
356 stream.writeAttribute(
"id",
m_id->toString());
362 stream.writeEndElement();
This is the GUI communication mechanism for cubes.
QString id() const
Access the unique ID associated with this Control.
ControlNet * controlNet()
Open and return a pointer to the ControlNet for this Control.
ControlDisplayProperties * displayProperties()
Access a pointer to the display properties for the control network.
QString m_fileName
Project associated with this control.
void deleteFromDisk()
Delete the control net from disk.
Control(QString cnetFileName, QObject *parent=0)
Create a Control from control net located on disk.
bool write()
@description Write control net to disk.
void copyToNewProjectRoot(const Project *project, FileName newProjectRoot)
Copies the files of the given Project to the given location.
void setModified(bool modified=true)
@description Sets the modification state of this control.
ControlNet * m_controlNet
A pointer to the ControlNet object associated with this Control object.
bool isModified()
@description Has this control been modified?
~Control()
Destroys Control object.
void updateFileName(Project *)
Change the on-disk file name for this control to be where the control ought to be in the given projec...
void save(QXmlStreamWriter &stream, const Project *project, FileName newProjectRoot) const
Method to write this Control object's member data to an XML stream.
void openControlNet()
Sets the ControlNet from the control net file name provided in the constructor.
QString fileName() const
Access the name of the control network file associated with this Control.
ControlDisplayProperties * m_displayProperties
Contains the display properties for this Control object.
QUuid * m_id
A unique ID for this Control.
void closeControlNet()
Cleans up the ControlNet pointer.
void Write(const QString &filename, bool pvl=false)
Writes out the control network.
void SetMutex(QMutex *mutex)
Set mutex to lock for making Naif calls.
File name manipulation and expansion.
QDir dir() const
Returns the path of the file's parent directory as a QDir object.
QString name() const
Returns the name of the file excluding the path and the attributes in the file name.
QString toString() const
Returns a QString of the full file name including the file path, excluding the attributes with any Is...
@ Programmer
This error is for when a programmer made an API call that was illegal.
@ Io
A type of error that occurred when performing an actual I/O operation.
The main project for ipce.
static QString cnetRoot(QString projectRoot)
Appends the root directory name 'cnets' to the project.
QMutex * mutex()
Return mutex used for Naif calls.
QString projectRoot() const
Get the top-level folder of the project.
This is free and unencumbered software released into the public domain.
QString toString(bool boolToConvert)
Global function to convert a boolean to a string.