📄 a_cmsxmldocument.java
字号:
// sort the result
Collections.sort(result);
return result;
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#getValues(java.lang.String, java.util.Locale)
*/
public List getValues(String name, Locale locale) {
List result = new ArrayList();
int count = 1;
Object o;
name = CmsXmlUtils.removeXpathIndex(name);
do {
String path = CmsXmlUtils.createXpathElement(name, count);
o = getBookmark(path, locale);
if (o != null) {
result.add(o);
count++;
}
} while (o != null);
return result;
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#hasLocale(java.util.Locale)
*/
public boolean hasLocale(Locale locale) {
if (locale == null) {
throw new CmsIllegalArgumentException(Messages.get().container(Messages.ERR_NULL_LOCALE_0));
}
return m_locales.contains(locale);
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#hasValue(java.lang.String, java.util.Locale)
*/
public boolean hasValue(String name, Locale locale) {
return null != getBookmark(CmsXmlUtils.createXpath(name, 1), locale);
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#hasValue(java.lang.String, java.util.Locale, int)
*/
public boolean hasValue(String name, Locale locale, int index) {
return null != getBookmark(CmsXmlUtils.createXpath(name, index + 1), locale);
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#initDocument()
*/
public void initDocument() {
initDocument(m_document, m_encoding, getContentDefinition());
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#isEnabled(java.lang.String, java.util.Locale)
*/
public boolean isEnabled(String name, Locale locale) {
return hasValue(name, locale);
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#isEnabled(java.lang.String, java.util.Locale, int)
*/
public boolean isEnabled(String name, Locale locale, int index) {
return hasValue(name, locale, index);
}
/**
* Marshals (writes) the content of the current XML document
* into a byte array using the selected encoding.<p>
*
* @return the content of the current XML document written into a byte array
* @throws CmsXmlException if something goes wrong
*/
public byte[] marshal() throws CmsXmlException {
return ((ByteArrayOutputStream)marshal(new ByteArrayOutputStream(), m_encoding)).toByteArray();
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#moveLocale(java.util.Locale, java.util.Locale)
*/
public void moveLocale(Locale source, Locale destination) throws CmsXmlException {
copyLocale(source, destination);
removeLocale(source);
}
/**
* @see org.opencms.xml.I_CmsXmlDocument#removeLocale(java.util.Locale)
*/
public void removeLocale(Locale locale) throws CmsXmlException {
if (!hasLocale(locale)) {
throw new CmsXmlException(Messages.get().container(Messages.ERR_LOCALE_NOT_AVAILABLE_1, locale));
}
Element rootNode = m_document.getRootElement();
Iterator i = rootNode.elementIterator();
String localeStr = locale.toString();
while (i.hasNext()) {
Element element = (Element)i.next();
String language = element.attributeValue(CmsXmlContentDefinition.XSD_ATTRIBUTE_VALUE_LANGUAGE, null);
if ((language != null) && (localeStr.equals(language))) {
// detach node with the locale
element.detach();
// there can be only one node for the locale
break;
}
}
// re-initialize the document bookmarks
initDocument(m_document, m_encoding, getContentDefinition());
}
/**
* Sets the content conversion mode for this document.<p>
*
* @param conversion the conversion mode to set for this document
*/
public void setConversion(String conversion) {
m_conversion = conversion;
}
/**
* @see java.lang.Object#toString()
*/
public String toString() {
try {
return CmsXmlUtils.marshal(m_document, m_encoding);
} catch (CmsXmlException e) {
throw new CmsRuntimeException(Messages.get().container(Messages.ERR_WRITE_XML_DOC_TO_STRING_0), e);
}
}
/**
* Validates the xml structure of the document with the DTD ot schema used by the document.<p>
*
* This is required in case someone modifies the xml structure of a
* document using the "edit control code" option.<p>
*
* @param resolver the XML entitiy resolver to use
* @throws CmsXmlException if the validation fails
*/
public void validateXmlStructure(EntityResolver resolver) throws CmsXmlException {
if (m_file != null) {
byte[] xmlData = null;
// file is set, use bytes from file directly
xmlData = m_file.getContents();
CmsXmlUtils.validateXmlStructure(xmlData, resolver);
} else {
CmsXmlUtils.validateXmlStructure(m_document, m_encoding, resolver);
}
}
/**
* Adds a bookmark for the given value.<p>
*
* @param name the name to use for the bookmark
* @param locale the locale to use for the bookmark
* @param enabled if true, the value is enabled, if false it is disabled
* @param value the value to bookmark
*/
protected void addBookmark(String name, Locale locale, boolean enabled, Object value) {
// add the locale (since the locales are a set adding them more then once does not matter)
addLocale(locale);
// add a bookmark to the provided value
m_bookmarks.put(getBookmarkName(name, locale), value);
Object o;
// update mapping of element name to locale
if (enabled) {
// only include enabled elements
o = m_elementLocales.get(name);
if (o != null) {
((Set)o).add(locale);
} else {
Set set = new HashSet();
set.add(locale);
m_elementLocales.put(name, set);
}
}
// update mapping of locales to element names
o = m_elementNames.get(locale);
if (o != null) {
((Set)o).add(name);
} else {
Set set = new HashSet();
set.add(name);
m_elementNames.put(locale, set);
}
}
/**
* Adds a locale to the set of locales of the XML document.<p>
*
* @param locale the locale to add
*/
protected void addLocale(Locale locale) {
// add the locale to all locales in this dcoument
m_locales.add(locale);
}
/**
* Clears the XML document bookmarks.<p>
*/
protected void clearBookmarks() {
m_bookmarks.clear();
}
/**
* Returns the bookmarked value for the given bookmark,
* which must be a valid bookmark name.
*
* Use {@link #getBookmarks()} to get the list of all valid bookmark names.<p>
*
* @param bookmark the bookmark name to look up
* @return the bookmarked value for the given bookmark
*/
protected Object getBookmark(String bookmark) {
return m_bookmarks.get(bookmark);
}
/**
* Returns the bookmarked value for the given name.<p>
*
* @param name the name to get the bookmark for
* @param locale the locale to get the bookmark for
* @return the bookmarked value
*/
protected Object getBookmark(String name, Locale locale) {
return m_bookmarks.get(getBookmarkName(name, locale));
}
/**
* Returns the names of all bookmarked elements.<p>
*
* @return the names of all bookmarked elements
*/
protected Set getBookmarks() {
return m_bookmarks.keySet();
}
/**
* Initializes an XML document based on the provided document, encoding and content definition.<p>
*
* @param document the base XML document to use for initializing
* @param encoding the encoding to use when marshalling the document later
* @param contentDefinition the content definition to use
*/
protected abstract void initDocument(Document document, String encoding, CmsXmlContentDefinition contentDefinition);
/**
* Marshals (writes) the content of the current XML document
* into an output stream.<p>
*
* @param out the output stream to write to
* @param encoding the encoding to use
* @return the output stream with the xml content
* @throws CmsXmlException if something goes wrong
*/
protected OutputStream marshal(OutputStream out, String encoding) throws CmsXmlException {
return CmsXmlUtils.marshal(m_document, out, encoding);
}
/**
* Removes the bookmark for an element with the given name and locale.<p>
*
* @param name the name of the element
* @param locale the locale of the element
* @return the element removed from the bookmarks or null
*/
protected I_CmsXmlContentValue removeBookmark(String name, Locale locale) {
// remove mapping of element name to locale
Object o;
o = m_elementLocales.get(name);
if (o != null) {
((Set)o).remove(locale);
}
// remove mapping of locale to element name
o = m_elementNames.get(locale);
if (o != null) {
((Set)o).remove(name);
}
// remove the bookmark and return the removed element
return (I_CmsXmlContentValue)m_bookmarks.remove(getBookmarkName(name, locale));
}
/**
* Internal method to look up a value, requires that the name already has been
* "normalized" for the bookmark lookup.
*
* This is required to find names like "title/subtitle" which are stored
* internally as "title[0]/subtitle[0)" in the bookmarks.
*
* @param name the name to look up
* @param locale the locale to look up
*
* @return the value found in the bookmarks
*/
private I_CmsXmlContentValue getValueInternal(String name, Locale locale) {
Object value = getBookmark(name, locale);
if (value != null) {
return (I_CmsXmlContentValue)value;
}
return null;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -