mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-20 16:20:52 +01:00
Allow copy of elements from a project to another with the actions copy/paste
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@4581 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
@@ -18,6 +18,7 @@
|
|||||||
#include "elementcollectionhandler.h"
|
#include "elementcollectionhandler.h"
|
||||||
#include "renamedialog.h"
|
#include "renamedialog.h"
|
||||||
#include "xmlelementcollection.h"
|
#include "xmlelementcollection.h"
|
||||||
|
#include "qetproject.h"
|
||||||
#include "qetxml.h"
|
#include "qetxml.h"
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
@@ -360,6 +361,49 @@ ElementsLocation ElementCollectionHandler::createDir(ElementsLocation &parent, c
|
|||||||
return ElementsLocation();
|
return ElementsLocation();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ElementCollectionHandler::importFromProject
|
||||||
|
* Import the element represented by @location to the embedded collection of @project at the same path.
|
||||||
|
* @location must represente an element owned by a project embedded collection
|
||||||
|
* @param project : project where copy the element
|
||||||
|
* @param location : location to copy
|
||||||
|
* @return true if import with success
|
||||||
|
*/
|
||||||
|
bool ElementCollectionHandler::importFromProject(QETProject *project, ElementsLocation &location)
|
||||||
|
{
|
||||||
|
if (!(location.isElement() && location.exist() && location.isProject())) return false;
|
||||||
|
|
||||||
|
ElementsLocation destination(location.collectionPath(false), project);
|
||||||
|
if (destination.exist()) return true;
|
||||||
|
|
||||||
|
QList <QString> names;
|
||||||
|
|
||||||
|
//Get the parent of location and find if exist in embedded collection of project
|
||||||
|
ElementsLocation source = location.parent();
|
||||||
|
names.append(location.fileName());
|
||||||
|
|
||||||
|
destination = ElementsLocation(source.collectionPath(), project);
|
||||||
|
|
||||||
|
//Go back until to find an existing directory in destination
|
||||||
|
while (!destination.exist()) {
|
||||||
|
names.append(source.fileName());
|
||||||
|
source = source.parent();
|
||||||
|
destination = ElementsLocation(source.collectionPath(), project);
|
||||||
|
}
|
||||||
|
|
||||||
|
XmlElementCollection *collection = project->embeddedElementCollection();
|
||||||
|
|
||||||
|
while (!names.isEmpty()) {
|
||||||
|
source.addToPath(names.takeLast());
|
||||||
|
destination = collection->copy(source, destination, QString(), false);
|
||||||
|
|
||||||
|
if (!destination.exist())
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief ElementCollectionHandler::setNames
|
* @brief ElementCollectionHandler::setNames
|
||||||
* Set the names stored in @name_list as the names of the item represented by location
|
* Set the names stored in @name_list as the names of the item represented by location
|
||||||
|
|||||||
@@ -92,6 +92,7 @@ class ElementCollectionHandler
|
|||||||
|
|
||||||
ElementsLocation copy(ElementsLocation &source, ElementsLocation &destination);
|
ElementsLocation copy(ElementsLocation &source, ElementsLocation &destination);
|
||||||
ElementsLocation createDir(ElementsLocation &parent, const QString &name, const NamesList &name_list);
|
ElementsLocation createDir(ElementsLocation &parent, const QString &name, const NamesList &name_list);
|
||||||
|
bool importFromProject (QETProject *project, ElementsLocation &location);
|
||||||
bool setNames(ElementsLocation &location, const NamesList &name_list);
|
bool setNames(ElementsLocation &location, const NamesList &name_list);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|||||||
@@ -657,10 +657,10 @@ ElementsLocation XmlElementCollection::copyDirectory(ElementsLocation &source, E
|
|||||||
|
|
||||||
//Remove the previous directory with the same path
|
//Remove the previous directory with the same path
|
||||||
QDomElement element = child(destination.collectionPath(false) + "/" + new_dir_name);
|
QDomElement element = child(destination.collectionPath(false) + "/" + new_dir_name);
|
||||||
if (!element.isNull())
|
if (!element.isNull()) {
|
||||||
element.parentNode().removeChild(element);
|
element.parentNode().removeChild(element);
|
||||||
|
emit directoryRemoved(destination.collectionPath(false) + "/" + new_dir_name);
|
||||||
|
}
|
||||||
|
|
||||||
ElementsLocation created_location;
|
ElementsLocation created_location;
|
||||||
|
|
||||||
@@ -703,7 +703,15 @@ ElementsLocation XmlElementCollection::copyDirectory(ElementsLocation &source, E
|
|||||||
{
|
{
|
||||||
if (!source.projectCollection()) return ElementsLocation();
|
if (!source.projectCollection()) return ElementsLocation();
|
||||||
|
|
||||||
QDomNode other_collection_node = source.projectCollection()->child(source.collectionPath(false)).cloneNode(true);
|
QDomNode other_collection_node = source.projectCollection()->child(source.collectionPath(false)).cloneNode(deep_copy);
|
||||||
|
|
||||||
|
//We don't make a deep copy, but we must to get the local names of the copied directory
|
||||||
|
if (!deep_copy) {
|
||||||
|
QDomNode names = source.projectCollection()->child(source.collectionPath(false)).namedItem("names");
|
||||||
|
if (!names.isNull() && names.isElement())
|
||||||
|
other_collection_node.appendChild(names.cloneNode(true));
|
||||||
|
}
|
||||||
|
|
||||||
if (other_collection_node.isNull()) return ElementsLocation();
|
if (other_collection_node.isNull()) return ElementsLocation();
|
||||||
|
|
||||||
QDomElement other_collection_dom_dir = other_collection_node.toElement();
|
QDomElement other_collection_dom_dir = other_collection_node.toElement();
|
||||||
@@ -713,6 +721,7 @@ ElementsLocation XmlElementCollection::copyDirectory(ElementsLocation &source, E
|
|||||||
created_location.setPath(destination.projectCollectionPath() + "/" + new_dir_name);
|
created_location.setPath(destination.projectCollectionPath() + "/" + new_dir_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
emit directorieAdded(created_location.collectionPath(false));
|
||||||
return created_location;
|
return created_location;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -34,6 +34,8 @@
|
|||||||
#include "terminal.h"
|
#include "terminal.h"
|
||||||
#include "elementtextsmover.h"
|
#include "elementtextsmover.h"
|
||||||
#include "diagrameventinterface.h"
|
#include "diagrameventinterface.h"
|
||||||
|
#include "qetapp.h"
|
||||||
|
#include "elementcollectionhandler.h"
|
||||||
|
|
||||||
const int Diagram::xGrid = 10;
|
const int Diagram::xGrid = 10;
|
||||||
const int Diagram::yGrid = 10;
|
const int Diagram::yGrid = 10;
|
||||||
@@ -466,6 +468,12 @@ QDomDocument Diagram::toXml(bool whole_content) {
|
|||||||
racine.setAttribute("conductorAutonum", m_conductors_autonum_name);
|
racine.setAttribute("conductorAutonum", m_conductors_autonum_name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
//this method with whole_content to false,
|
||||||
|
//is often use to copy and paste the current selection
|
||||||
|
//so we add the id of the project where copy occur.
|
||||||
|
racine.setAttribute("projectId", QETApp::projectId(m_project));
|
||||||
|
}
|
||||||
document.appendChild(racine);
|
document.appendChild(racine);
|
||||||
|
|
||||||
// si le schema ne contient pas d'element (et donc pas de conducteurs), on retourne de suite le document XML
|
// si le schema ne contient pas d'element (et donc pas de conducteurs), on retourne de suite le document XML
|
||||||
@@ -660,6 +668,27 @@ bool Diagram::fromXml(QDomElement &document, QPointF position, bool consider_inf
|
|||||||
m_project -> state() == QETProject::ProjectParsingRunning
|
m_project -> state() == QETProject::ProjectParsingRunning
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//If paste from another project
|
||||||
|
if (root.hasAttribute("projectId")) {
|
||||||
|
QETProject *other_project = QETApp::project(root.attribute("projectId", "-1").toInt());
|
||||||
|
|
||||||
|
//We try to paste from another project, then befor paste elements,
|
||||||
|
//we must to import the definition of the pasted elements (owned by other project)
|
||||||
|
//in the embedded collection of this project
|
||||||
|
if (other_project && other_project != m_project) {
|
||||||
|
ElementCollectionHandler ech;
|
||||||
|
foreach (QDomElement element_xml, QET::findInDomElement(root, "elements", "element")) {
|
||||||
|
if (!Element::valideXml(element_xml)) continue;
|
||||||
|
|
||||||
|
QString type_id = element_xml.attribute("type");
|
||||||
|
|
||||||
|
if (type_id.startsWith("embed://")) {
|
||||||
|
ElementsLocation location(type_id, other_project);
|
||||||
|
ech.importFromProject(m_project, location);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
//Load all elements from the XML
|
//Load all elements from the XML
|
||||||
QList<Element *> added_elements;
|
QList<Element *> added_elements;
|
||||||
QHash<int, Terminal *> table_adr_id;
|
QHash<int, Terminal *> table_adr_id;
|
||||||
|
|||||||
Reference in New Issue
Block a user