ctkXnatObject.cpp 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. /*=============================================================================
  2. Plugin: org.commontk.xnat
  3. Copyright (c) University College London,
  4. Centre for Medical Image Computing
  5. Licensed under the Apache License, Version 2.0 (the "License");
  6. you may not use this file except in compliance with the License.
  7. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. =============================================================================*/
  15. #include "ctkXnatObject.h"
  16. #include "ctkXnatObjectPrivate.h"
  17. #include "ctkXnatConnection.h"
  18. #include "ctkXnatServer.h"
  19. #include <QDebug>
  20. #include <QVariant>
  21. ctkXnatObject::ctkXnatObject(const QString& schemaType)
  22. : d_ptr(new ctkXnatObjectPrivate())
  23. {
  24. Q_D(ctkXnatObject);
  25. d->schemaType = schemaType;
  26. }
  27. ctkXnatObject::ctkXnatObject(ctkXnatObjectPrivate& dd, const QString& schemaType)
  28. : d_ptr(&dd)
  29. {
  30. Q_D(ctkXnatObject);
  31. d->schemaType = schemaType;
  32. }
  33. ctkXnatObject::~ctkXnatObject()
  34. {
  35. Q_D(ctkXnatObject);
  36. foreach (ctkXnatObject* child, d->children)
  37. {
  38. delete child;
  39. }
  40. }
  41. QString ctkXnatObject::id() const
  42. {
  43. return property("ID");
  44. }
  45. void ctkXnatObject::setId(const QString& id)
  46. {
  47. setProperty("ID", id);
  48. }
  49. QString ctkXnatObject::uri() const
  50. {
  51. return property("URI");
  52. }
  53. void ctkXnatObject::setUri(const QString& uri)
  54. {
  55. setProperty("URI", uri);
  56. }
  57. QString ctkXnatObject::schemaType() const
  58. {
  59. Q_D(const ctkXnatObject);
  60. return d->schemaType;
  61. }
  62. QString ctkXnatObject::name() const
  63. {
  64. return property("name");
  65. }
  66. void ctkXnatObject::setName(const QString& name)
  67. {
  68. setProperty("name", name);
  69. }
  70. QString ctkXnatObject::description() const
  71. {
  72. return property("description");
  73. }
  74. void ctkXnatObject::setDescription(const QString& description)
  75. {
  76. setProperty("description", description);
  77. }
  78. QString ctkXnatObject::property(const QString& name) const
  79. {
  80. Q_D(const ctkXnatObject);
  81. ctkXnatObjectPrivate::PropertyMapConstInterator iter = d->properties.find(name);
  82. if (iter != d->properties.end())
  83. {
  84. return iter.value();
  85. }
  86. return QString::null;
  87. }
  88. void ctkXnatObject::setProperty(const QString& name, const QVariant& value)
  89. {
  90. Q_D(ctkXnatObject);
  91. d->properties.insert(name, value.toString());
  92. }
  93. QList<QString> ctkXnatObject::properties()
  94. {
  95. Q_D(ctkXnatObject);
  96. QList<QString> value;
  97. QMapIterator<QString, QString> it(d->properties);
  98. while (it.hasNext())
  99. {
  100. it.next();
  101. value.push_back (it.key());
  102. }
  103. return value;
  104. }
  105. ctkXnatObject* ctkXnatObject::parent() const
  106. {
  107. Q_D(const ctkXnatObject);
  108. return d->parent;
  109. }
  110. void ctkXnatObject::setParent(ctkXnatObject* parent)
  111. {
  112. Q_D(ctkXnatObject);
  113. if (d->parent != parent)
  114. {
  115. if (d->parent)
  116. {
  117. d->parent->remove(this);
  118. }
  119. if (parent)
  120. {
  121. parent->add(this);
  122. }
  123. d->parent = parent;
  124. }
  125. }
  126. QList<ctkXnatObject*> ctkXnatObject::children() const
  127. {
  128. Q_D(const ctkXnatObject);
  129. return d->children;
  130. }
  131. void ctkXnatObject::add(ctkXnatObject* child)
  132. {
  133. Q_D(ctkXnatObject);
  134. if (child->parent() != this)
  135. {
  136. child->setParent(this);
  137. }
  138. if (!d->children.contains(child))
  139. {
  140. d->children.push_back(child);
  141. }
  142. }
  143. void ctkXnatObject::remove(ctkXnatObject* child)
  144. {
  145. Q_D(ctkXnatObject);
  146. if (!d->children.removeOne(child))
  147. {
  148. qWarning() << "ctkXnatObject::removeChild(): Child does not exist";
  149. }
  150. }
  151. void ctkXnatObject::reset()
  152. {
  153. Q_D(ctkXnatObject);
  154. // d->properties.clear();
  155. d->children.clear();
  156. d->fetched = false;
  157. }
  158. bool ctkXnatObject::isFetched() const
  159. {
  160. Q_D(const ctkXnatObject);
  161. return d->fetched;
  162. }
  163. void ctkXnatObject::fetch()
  164. {
  165. Q_D(ctkXnatObject);
  166. if (!d->fetched)
  167. {
  168. this->fetchImpl();
  169. d->fetched = true;
  170. }
  171. }
  172. ctkXnatConnection* ctkXnatObject::connection() const
  173. {
  174. const ctkXnatObject* xnatObject = this;
  175. const ctkXnatServer* server;
  176. do {
  177. xnatObject = xnatObject->parent();
  178. server = dynamic_cast<const ctkXnatServer*>(xnatObject);
  179. }
  180. while (xnatObject && !server);
  181. return server ? xnatObject->connection() : 0;
  182. }
  183. void ctkXnatObject::download(const QString& /*zipFilename*/)
  184. {
  185. }
  186. void ctkXnatObject::upload(const QString& /*zipFilename*/)
  187. {
  188. }