/emf-2.8.0/org.eclipse.xsd/src/org/eclipse/xsd/XSDConcreteComponent.java

# · Java · 576 lines · 52 code · 49 blank · 475 comment · 0 complexity · 59d7a8cc5faa94ad14dfb1dadb081a79 MD5 · raw file

  1. /**
  2. * Copyright (c) 2002-2006 IBM Corporation and others.
  3. * All rights reserved. This program and the accompanying materials
  4. * are made available under the terms of the Eclipse Public License v1.0
  5. * which accompanies this distribution, and is available at
  6. * http://www.eclipse.org/legal/epl-v10.html
  7. *
  8. * Contributors:
  9. * IBM - Initial API and implementation
  10. */
  11. package org.eclipse.xsd;
  12. import java.util.Collection;
  13. import org.w3c.dom.Element;
  14. import org.eclipse.emf.common.util.EList;
  15. import org.eclipse.emf.ecore.EObject;
  16. /**
  17. * <!-- begin-user-doc -->
  18. * A representation of the model object '<em><b>Concrete Component</b></em>'.
  19. * It is the root of all concrete components.
  20. * <!-- end-user-doc -->
  21. *
  22. * <p>
  23. * The following features are supported:
  24. * <ul>
  25. * <li>{@link org.eclipse.xsd.XSDConcreteComponent#getElement <em>Element</em>}</li>
  26. * <li>{@link org.eclipse.xsd.XSDConcreteComponent#getContainer <em>Container</em>}</li>
  27. * <li>{@link org.eclipse.xsd.XSDConcreteComponent#getRootContainer <em>Root Container</em>}</li>
  28. * <li>{@link org.eclipse.xsd.XSDConcreteComponent#getSchema <em>Schema</em>}</li>
  29. * <li>{@link org.eclipse.xsd.XSDConcreteComponent#getDiagnostics <em>Diagnostics</em>}</li>
  30. * </ul>
  31. * </p>
  32. *
  33. * @see org.eclipse.xsd.XSDPackage#getXSDConcreteComponent()
  34. * @model abstract="true"
  35. * @generated
  36. */
  37. public interface XSDConcreteComponent extends EObject
  38. {
  39. /**
  40. * Returns the value of the '<em><b>Element</b></em>' attribute.
  41. * <!-- begin-user-doc -->
  42. * <p>
  43. * This is the underlying DOM element associated with this component,
  44. * i.e., the {@link #updateElement() serialization} of this component.
  45. * </p>
  46. * <!-- end-user-doc -->
  47. * @return the value of the '<em>Element</em>' attribute.
  48. * @see #setElement(Element)
  49. * @see org.eclipse.xsd.XSDPackage#getXSDConcreteComponent_Element()
  50. * @model dataType="org.eclipse.xsd.DOMElement"
  51. * @generated
  52. */
  53. Element getElement();
  54. /**
  55. * Sets the value of the '{@link org.eclipse.xsd.XSDConcreteComponent#getElement <em>Element</em>}' attribute.
  56. * <!-- begin-user-doc -->
  57. * <!-- end-user-doc -->
  58. * @param value the new value of the '<em>Element</em>' attribute.
  59. * @see #getElement()
  60. * @generated
  61. */
  62. void setElement(Element value);
  63. /**
  64. * Ensures that the underlying DOM {@link #getElement element} both exists and is up-to-date with respect to the model,
  65. * i.e., it serializes the component and maintains an association with that serialization.
  66. * @see #updateElement(boolean)
  67. * @see #getElement
  68. */
  69. void updateElement();
  70. /**
  71. * Ensures that the underlying DOM {@link #getElement element} both exists and is up-to-date with respect to the model,
  72. * i.e., it serializes the component and maintains an association with that serialization.
  73. * For <code>deep == true</code>,
  74. * or when <code>{@link #getElement getElement()} == null</code>,
  75. * this does the same thing as {@link #updateElement()};
  76. * otherwise, it updates just the DOM element associated with this component to reflect the current state.
  77. * @see #updateElement()
  78. * @see #getElement
  79. */
  80. void updateElement(boolean deep);
  81. /**
  82. * Returns the value of the '<em><b>Container</b></em>' reference.
  83. * <!-- begin-user-doc -->
  84. * <p>
  85. * This represents the concrete container of this component,
  86. * i.e., the inverse of the black diamond relations in the UML model.
  87. * </p>
  88. * <!-- end-user-doc -->
  89. * @return the value of the '<em>Container</em>' reference.
  90. * @see org.eclipse.xsd.XSDPackage#getXSDConcreteComponent_Container()
  91. * @model resolveProxies="false" transient="true" changeable="false" volatile="true"
  92. * @generated
  93. */
  94. XSDConcreteComponent getContainer();
  95. /**
  96. * Returns the value of the '<em><b>Root Container</b></em>' reference.
  97. * <!-- begin-user-doc -->
  98. * <p>
  99. * This walks the {@link #getContainer() containers}
  100. * until it hits one that has no container.
  101. * </p>
  102. * <!-- end-user-doc -->
  103. * @return the value of the '<em>Root Container</em>' reference.
  104. * @see org.eclipse.xsd.XSDPackage#getXSDConcreteComponent_RootContainer()
  105. * @model resolveProxies="false" required="true" transient="true" changeable="false" volatile="true"
  106. * @generated
  107. */
  108. XSDConcreteComponent getRootContainer();
  109. /**
  110. * Returns the value of the '<em><b>Schema</b></em>' reference.
  111. * <!-- begin-user-doc -->
  112. * <p>
  113. * This walks the {@link #getContainer() containers}
  114. * until it reaches a schema.
  115. * </p>
  116. * <!-- end-user-doc -->
  117. * @return the value of the '<em>Schema</em>' reference.
  118. * @see org.eclipse.xsd.XSDPackage#getXSDConcreteComponent_Schema()
  119. * @model resolveProxies="false" transient="true" changeable="false" volatile="true"
  120. * @generated
  121. */
  122. XSDSchema getSchema();
  123. /**
  124. * Returns the value of the '<em><b>Diagnostics</b></em>' containment reference list.
  125. * The list contents are of type {@link org.eclipse.xsd.XSDDiagnostic}.
  126. * <!-- begin-user-doc -->
  127. * <p>
  128. * These diagnostics are produced by {@link #validate() validation}.
  129. * </p>
  130. * <!-- end-user-doc -->
  131. * @return the value of the '<em>Diagnostics</em>' containment reference list.
  132. * @see org.eclipse.xsd.XSDPackage#getXSDConcreteComponent_Diagnostics()
  133. * @model containment="true" transient="true"
  134. * @generated
  135. */
  136. EList<XSDDiagnostic> getDiagnostics();
  137. /**
  138. * Called to indicate that the given element has changed;
  139. * the element should typically be the same as the one returned {@link #getElement}.
  140. * It is expected that clients will not call this themselves
  141. * since the DOM event listeners attached to the underlying DOM will invoke these automatically.
  142. */
  143. void elementChanged(Element changedElement);
  144. /**
  145. * Called to indicate that the given element has changed attributes;
  146. * the element should typically be the same as the one returned {@link #getElement}.
  147. * It is expected that clients will not call this themselves
  148. * since the DOM event listeners attached to the underlying DOM will invoke these automatically.
  149. */
  150. void elementAttributesChanged(Element changedElement);
  151. /**
  152. * Called to indicate that the given element has changed contents;
  153. * the element should typically be the same as the one returned {@link #getElement}.
  154. * It is expected that clients will not call this themselves
  155. * since the DOM event listeners attached to the underlying DOM will invoke these automatically.
  156. */
  157. void elementContentsChanged(Element changedElement);
  158. /**
  159. * Returns the resolved type definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  160. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  161. * @see #resolveTypeDefinition(java.lang.String, java.lang.String)
  162. * @see #resolveTypeDefinition(java.lang.String)
  163. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  164. * @param uri the URI to resolve.
  165. * @return the resolved type definition.
  166. */
  167. XSDTypeDefinition resolveTypeDefinitionURI(String uri);
  168. /**
  169. * Returns the resolved type definition of the given
  170. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  171. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  172. * @see #resolveTypeDefinitionURI(java.lang.String)
  173. * @see #resolveTypeDefinition(java.lang.String)
  174. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  175. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  176. * @param namespace the namespace to resolve.
  177. * @param localName the name to resolve.
  178. * @return the resolved type definition.
  179. */
  180. XSDTypeDefinition resolveTypeDefinition(String namespace, String localName);
  181. /**
  182. * Returns the resolved type definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  183. * within the {@link #getSchema() schema}.
  184. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  185. * @see #getSchema()
  186. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  187. * @see #resolveTypeDefinitionURI(java.lang.String)
  188. * @see #resolveTypeDefinition(java.lang.String, java.lang.String)
  189. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  190. * @param localName the name to resolve.
  191. * @return the resolved type definition.
  192. */
  193. XSDTypeDefinition resolveTypeDefinition(String localName);
  194. /**
  195. * Returns the resolved simple type definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  196. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  197. * @see #resolveSimpleTypeDefinition(java.lang.String, java.lang.String)
  198. * @see #resolveSimpleTypeDefinition(java.lang.String)
  199. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  200. * @param uri the URI to resolve.
  201. * @return the resolved simple type definition.
  202. */
  203. XSDSimpleTypeDefinition resolveSimpleTypeDefinitionURI(String uri);
  204. /**
  205. * Returns the resolved simple type definition of the given
  206. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  207. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  208. * @see #resolveSimpleTypeDefinitionURI(java.lang.String)
  209. * @see #resolveSimpleTypeDefinition(java.lang.String)
  210. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  211. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  212. * @param namespace the namespace to resolve.
  213. * @param localName the name to resolve.
  214. * @return the resolved simple type definition.
  215. */
  216. XSDSimpleTypeDefinition resolveSimpleTypeDefinition(String namespace, String localName);
  217. /**
  218. * Returns the resolved simple type definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  219. * within the {@link #getSchema() schema}.
  220. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  221. * @see #getSchema()
  222. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  223. * @see #resolveSimpleTypeDefinitionURI(java.lang.String)
  224. * @see #resolveSimpleTypeDefinition(java.lang.String, java.lang.String)
  225. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  226. * @param localName the name to resolve.
  227. * @return the resolved simple type definition.
  228. */
  229. XSDSimpleTypeDefinition resolveSimpleTypeDefinition(String localName);
  230. /**
  231. * Returns the resolved complex type definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  232. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  233. * @see #resolveComplexTypeDefinition(java.lang.String, java.lang.String)
  234. * @see #resolveComplexTypeDefinition(java.lang.String)
  235. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  236. * @param uri the URI to resolve.
  237. * @return the resolved complex type definition.
  238. */
  239. XSDComplexTypeDefinition resolveComplexTypeDefinitionURI(String uri);
  240. /**
  241. * Returns the resolved complex type definition of the given
  242. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  243. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  244. * @see #resolveComplexTypeDefinitionURI(java.lang.String)
  245. * @see #resolveComplexTypeDefinition(java.lang.String)
  246. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  247. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  248. * @param namespace the namespace to resolve.
  249. * @param localName the name to resolve.
  250. * @return the resolved complex type definition.
  251. */
  252. XSDComplexTypeDefinition resolveComplexTypeDefinition(String namespace, String localName);
  253. /**
  254. * Returns the resolved complex type definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  255. * within the {@link #getSchema() schema}.
  256. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  257. * @see #getSchema()
  258. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  259. * @see #resolveComplexTypeDefinitionURI(java.lang.String)
  260. * @see #resolveComplexTypeDefinition(java.lang.String, java.lang.String)
  261. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  262. * @param localName the name to resolve.
  263. * @return the resolved complex type definition.
  264. */
  265. XSDComplexTypeDefinition resolveComplexTypeDefinition(String localName);
  266. /**
  267. * Returns the resolved attribute declaration of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  268. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  269. * @see #resolveAttributeDeclaration(java.lang.String, java.lang.String)
  270. * @see #resolveAttributeDeclaration(java.lang.String)
  271. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  272. * @param uri the URI to resolve.
  273. * @return the resolved attribute declaration.
  274. */
  275. XSDAttributeDeclaration resolveAttributeDeclarationURI(String uri);
  276. /**
  277. * Returns the resolved attribute declaration of the given
  278. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  279. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  280. * @see #resolveAttributeDeclarationURI(java.lang.String)
  281. * @see #resolveAttributeDeclaration(java.lang.String)
  282. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  283. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  284. * @param namespace the namespace to resolve.
  285. * @param localName the name to resolve.
  286. * @return the resolved attribute declaration.
  287. */
  288. XSDAttributeDeclaration resolveAttributeDeclaration(String namespace, String localName);
  289. /**
  290. * Returns the resolved attribute declaration of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  291. * within the {@link #getSchema() schema}.
  292. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  293. * @see #getSchema()
  294. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  295. * @see #resolveAttributeDeclarationURI(java.lang.String)
  296. * @see #resolveAttributeDeclaration(java.lang.String, java.lang.String)
  297. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  298. * @param localName the name to resolve.
  299. * @return the resolved attribute declaration.
  300. */
  301. XSDAttributeDeclaration resolveAttributeDeclaration(String localName);
  302. /**
  303. * Returns the resolved element declaration of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  304. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  305. * @see #resolveElementDeclaration(java.lang.String, java.lang.String)
  306. * @see #resolveElementDeclaration(java.lang.String)
  307. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  308. * @param uri the URI to resolve.
  309. * @return the resolved element declaration.
  310. */
  311. XSDElementDeclaration resolveElementDeclarationURI(String uri);
  312. /**
  313. * Returns the resolved element declaration of the given
  314. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  315. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  316. * @see #resolveElementDeclarationURI(java.lang.String)
  317. * @see #resolveElementDeclaration(java.lang.String)
  318. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  319. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  320. * @param namespace the namespace to resolve.
  321. * @param localName the name to resolve.
  322. * @return the resolved element declaration.
  323. */
  324. XSDElementDeclaration resolveElementDeclaration(String namespace, String localName);
  325. /**
  326. * Returns the resolved element declaration of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  327. * within the {@link #getSchema() schema}.
  328. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  329. * @see #getSchema()
  330. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  331. * @see #resolveElementDeclarationURI(java.lang.String)
  332. * @see #resolveElementDeclaration(java.lang.String, java.lang.String)
  333. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  334. * @param localName the name to resolve.
  335. * @return the resolved element declaration.
  336. */
  337. XSDElementDeclaration resolveElementDeclaration(String localName);
  338. /**
  339. * Returns the resolved attribute group definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  340. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  341. * @see #resolveAttributeGroupDefinition(java.lang.String, java.lang.String)
  342. * @see #resolveAttributeGroupDefinition(java.lang.String)
  343. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  344. * @param uri the URI to resolve.
  345. * @return the resolved attribute group definition.
  346. */
  347. XSDAttributeGroupDefinition resolveAttributeGroupDefinitionURI(String uri);
  348. /**
  349. * Returns the resolved attribute group definition the given
  350. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  351. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  352. * @see #resolveAttributeGroupDefinitionURI(java.lang.String)
  353. * @see #resolveAttributeGroupDefinition(java.lang.String)
  354. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  355. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  356. * @param namespace the namespace to resolve.
  357. * @param localName the name to resolve.
  358. * @return the resolved attribute group definition
  359. */
  360. XSDAttributeGroupDefinition resolveAttributeGroupDefinition(String namespace, String localName);
  361. /**
  362. * Returns the resolved attribute group definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  363. * within the {@link #getSchema() schema}.
  364. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  365. * @see #getSchema()
  366. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  367. * @see #resolveAttributeGroupDefinitionURI(java.lang.String)
  368. * @see #resolveAttributeGroupDefinition(java.lang.String, java.lang.String)
  369. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  370. * @param localName the name to resolve.
  371. * @return the resolved attribute group definition.
  372. */
  373. XSDAttributeGroupDefinition resolveAttributeGroupDefinition(String localName);
  374. /**
  375. * Returns the resolved model group definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  376. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  377. * @see #resolveModelGroupDefinition(java.lang.String, java.lang.String)
  378. * @see #resolveModelGroupDefinition(java.lang.String)
  379. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  380. * @param uri the URI to resolve.
  381. * @return the resolved model group definition.
  382. */
  383. XSDModelGroupDefinition resolveModelGroupDefinitionURI(String uri);
  384. /**
  385. * Returns the resolved model group definition of the given
  386. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  387. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  388. * @see #resolveModelGroupDefinitionURI(java.lang.String)
  389. * @see #resolveModelGroupDefinition(java.lang.String)
  390. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  391. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  392. * @param namespace the namespace to resolve.
  393. * @param localName the name to resolve.
  394. * @return the resolved model group definition.
  395. */
  396. XSDModelGroupDefinition resolveModelGroupDefinition(String namespace, String localName);
  397. /**
  398. * Returns the resolved model group definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  399. * within the {@link #getSchema() schema}.
  400. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  401. * @see #getSchema()
  402. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  403. * @see #resolveModelGroupDefinitionURI(java.lang.String)
  404. * @see #resolveModelGroupDefinition(java.lang.String, java.lang.String)
  405. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  406. * @param localName the name to resolve.
  407. * @return the resolved model group definition.
  408. */
  409. XSDModelGroupDefinition resolveModelGroupDefinition(String localName);
  410. /**
  411. * Returns the resolved identity constraint definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  412. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  413. * @see #resolveIdentityConstraintDefinition(java.lang.String, java.lang.String)
  414. * @see #resolveIdentityConstraintDefinition(java.lang.String)
  415. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  416. * @param uri the URI to resolve.
  417. * @return the resolved identity constraint definition.
  418. */
  419. XSDIdentityConstraintDefinition resolveIdentityConstraintDefinitionURI(String uri);
  420. /**
  421. * Returns the resolved identity constraint definition of the given
  422. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  423. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  424. * @see #resolveIdentityConstraintDefinitionURI(java.lang.String)
  425. * @see #resolveIdentityConstraintDefinition(java.lang.String)
  426. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  427. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  428. * @param namespace the namespace to resolve.
  429. * @param localName the name to resolve.
  430. * @return the resolved identity constraint definition.
  431. */
  432. XSDIdentityConstraintDefinition resolveIdentityConstraintDefinition(String namespace, String localName);
  433. /**
  434. * Returns the resolved identity constraint definition of the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  435. * within the {@link #getSchema() schema}.
  436. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  437. * @see #getSchema()
  438. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  439. * @see #resolveIdentityConstraintDefinitionURI(java.lang.String)
  440. * @see #resolveIdentityConstraintDefinition(java.lang.String, java.lang.String)
  441. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  442. * @param localName the name to resolve.
  443. * @return the resolved identity constraint definition.
  444. */
  445. XSDIdentityConstraintDefinition resolveIdentityConstraintDefinition(String localName);
  446. /**
  447. * Returns the resolved notation declaration of the given {@link org.eclipse.xsd.XSDNamedComponent#getURI() URI}.
  448. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  449. * @see #resolveNotationDeclaration(java.lang.String, java.lang.String)
  450. * @see #resolveNotationDeclaration(java.lang.String)
  451. * @see org.eclipse.xsd.XSDNamedComponent#getURI()
  452. * @param uri the URI to resolve.
  453. * @return the resolved notation declaration.
  454. */
  455. XSDNotationDeclaration resolveNotationDeclarationURI(String uri);
  456. /**
  457. * Returns the resolved notation declaration of the given
  458. * {@link org.eclipse.xsd.XSDNamedComponent#getTargetNamespace() namespace} and {@link org.eclipse.xsd.XSDNamedComponent#getName() name}.
  459. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  460. * @see #resolveNotationDeclarationURI(java.lang.String)
  461. * @see #resolveNotationDeclaration(java.lang.String)
  462. * @see org.eclipse.xsd.XSDNamedComponent#getTargetNamespace()
  463. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  464. * @param namespace the namespace to resolve.
  465. * @param localName the name to resolve.
  466. * @return the resolved notation declaration.
  467. */
  468. XSDNotationDeclaration resolveNotationDeclaration(String namespace, String localName);
  469. /**
  470. * Returns the resolved notation declaration the given {@link org.eclipse.xsd.XSDNamedComponent#getName() name}
  471. * within the {@link #getSchema() schema}.
  472. * An unresolved instance is synthesized to hold the namespace and name if an existing instance cannot be found.
  473. * @see #getSchema()
  474. * @see org.eclipse.xsd.XSDSchema#getTargetNamespace()
  475. * @see #resolveNotationDeclarationURI(java.lang.String)
  476. * @see #resolveNotationDeclaration(java.lang.String, java.lang.String)
  477. * @see org.eclipse.xsd.XSDNamedComponent#getName()
  478. * @param localName the name to resolve.
  479. * @return the resolved notation declaration
  480. */
  481. XSDNotationDeclaration resolveNotationDeclaration(String localName);
  482. /**
  483. * Returns the collection of components that have an {@link org.eclipse.xsd.XSDAnnotation annotation}
  484. * containing an {@link org.eclipse.xsd.XSDAnnotation#getApplicationInformation() appinfo} with given source URI.
  485. * @see org.eclipse.xsd.XSDAnnotation#getApplicationInformationSources()
  486. * @param sourceURI the source URI to match.
  487. * @return the collection of matching components.
  488. */
  489. Collection<XSDConcreteComponent> getComponentsWithApplicationInformation(String sourceURI);
  490. /**
  491. * Returns the collection of components that have an {@link org.eclipse.xsd.XSDAnnotation annotation}
  492. * containing a {@link org.eclipse.xsd.XSDAnnotation#getUserInformation() documentation} with given source URI.
  493. * @see org.eclipse.xsd.XSDAnnotation#getApplicationInformationSources()
  494. * @param sourceURI the source URI to match.
  495. * @return the collection of matching components.
  496. */
  497. Collection<XSDConcreteComponent> getComponentsWithUserInformation(String sourceURI);
  498. /**
  499. * Validates whether this component conforms to the constraints defined in the XML Schema standard.
  500. * {@link #getDiagnostics() Diagnostics} are produced to report any problems.
  501. * The effect of calling this for a component not directly or indirectly contained by a {@link org.eclipse.xsd.XSDSchema schema}
  502. * is undefined, and is likely to result in null pointer exceptions.
  503. * @see #getDiagnostics()
  504. * @see #clearDiagnostics()
  505. */
  506. void validate();
  507. /**
  508. * Clears any {@link #getDiagnostics() diagnostics} associated with the component and all those it contains.
  509. * @see #validate()
  510. * @see #getDiagnostics()
  511. */
  512. void clearDiagnostics();
  513. /**
  514. * Creates a clone of the component.
  515. * The clone may be deep and may share the DOM of this component.
  516. * @param deep whether the clone should be deep.
  517. * @param shareDOM whether the clone should share the original DOM
  518. * @return a clone of the component.
  519. */
  520. XSDConcreteComponent cloneConcreteComponent(boolean deep, boolean shareDOM);
  521. /**
  522. * Returns whether the given component is contained by this component.
  523. * @param xsdConcreteComponent a component.
  524. * @return whether the component is contained by this component.
  525. */
  526. boolean contains(XSDConcreteComponent xsdConcreteComponent);
  527. }