1*b1cdbd2cSJim Jagielski/**************************************************************
2*b1cdbd2cSJim Jagielski *
3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski *
11*b1cdbd2cSJim Jagielski *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski *
13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski * under the License.
19*b1cdbd2cSJim Jagielski *
20*b1cdbd2cSJim Jagielski *************************************************************/
21*b1cdbd2cSJim Jagielski
22*b1cdbd2cSJim Jagielski
23*b1cdbd2cSJim Jagielski
24*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_xml_dom_XCharacterData_idl__
25*b1cdbd2cSJim Jagielski#define __com_sun_star_xml_dom_XCharacterData_idl__
26*b1cdbd2cSJim Jagielski
27*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_xml_dom_XNode_idl__
28*b1cdbd2cSJim Jagielski#include <com/sun/star/xml/dom/XNode.idl>
29*b1cdbd2cSJim Jagielski#endif
30*b1cdbd2cSJim Jagielski
31*b1cdbd2cSJim Jagielskimodule com { module sun { module star { module xml { module dom {
32*b1cdbd2cSJim Jagielski
33*b1cdbd2cSJim Jagielskiinterface XCharacterData: XNode
34*b1cdbd2cSJim Jagielski{
35*b1cdbd2cSJim Jagielski    /**
36*b1cdbd2cSJim Jagielski    Append the string to the end of the character data of the node.
37*b1cdbd2cSJim Jagielski    Throws:
38*b1cdbd2cSJim Jagielski        DOMException - NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
39*b1cdbd2cSJim Jagielski    */
40*b1cdbd2cSJim Jagielski    void appendData([in] string arg) raises (DOMException);
41*b1cdbd2cSJim Jagielski
42*b1cdbd2cSJim Jagielski    /**
43*b1cdbd2cSJim Jagielski    Remove a range of 16-bit units from the node.
44*b1cdbd2cSJim Jagielski    Throws:
45*b1cdbd2cSJim Jagielski        DOMException - INDEX_SIZE_ERR: Raised if the specified offset is negative or greater
46*b1cdbd2cSJim Jagielski            than the number of 16-bit units in data, or if the specified count is negative.
47*b1cdbd2cSJim Jagielski        NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
48*b1cdbd2cSJim Jagielski    */
49*b1cdbd2cSJim Jagielski    void deleteData([in] long offset, [in] long count) raises (DOMException);
50*b1cdbd2cSJim Jagielski
51*b1cdbd2cSJim Jagielski    /**
52*b1cdbd2cSJim Jagielski    Return the character data of the node that implements this interface.
53*b1cdbd2cSJim Jagielski    Throws:
54*b1cdbd2cSJim Jagielski        DOMException - NO_MODIFICATION_ALLOWED_ERR: Raised when the node is readonly.
55*b1cdbd2cSJim Jagielski        DOMException - DOMSTRING_SIZE_ERR: Raised when it would return more characters
56*b1cdbd2cSJim Jagielski            than fit in a DOMString variable on the implementation platform.
57*b1cdbd2cSJim Jagielski
58*b1cdbd2cSJim Jagielski
59*b1cdbd2cSJim Jagielski    */
60*b1cdbd2cSJim Jagielski    string getData() raises (DOMException);
61*b1cdbd2cSJim Jagielski
62*b1cdbd2cSJim Jagielski    /**
63*b1cdbd2cSJim Jagielski    The number of 16-bit units that are available through data and the
64*b1cdbd2cSJim Jagielski    substringData method below.
65*b1cdbd2cSJim Jagielski    */
66*b1cdbd2cSJim Jagielski    long getLength();
67*b1cdbd2cSJim Jagielski
68*b1cdbd2cSJim Jagielski    /**
69*b1cdbd2cSJim Jagielski    Insert a string at the specified 16-bit unit offset.
70*b1cdbd2cSJim Jagielski    Throws:
71*b1cdbd2cSJim Jagielski    DOMException - INDEX_SIZE_ERR: Raised if the specified offset is negative or greater than
72*b1cdbd2cSJim Jagielski                                   the number of 16-bit units in data.
73*b1cdbd2cSJim Jagielski                   NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
74*b1cdbd2cSJim Jagielski    */
75*b1cdbd2cSJim Jagielski    void insertData([in] long offset, [in] string arg) raises (DOMException);
76*b1cdbd2cSJim Jagielski
77*b1cdbd2cSJim Jagielski    /**
78*b1cdbd2cSJim Jagielski    Replace the characters starting at the specified 16-bit unit offset
79*b1cdbd2cSJim Jagielski    with the specified string.
80*b1cdbd2cSJim Jagielski    Throws;
81*b1cdbd2cSJim Jagielski    DOMException - INDEX_SIZE_ERR: Raised if the specified offset is negative or greater than
82*b1cdbd2cSJim Jagielski                      the number of 16-bit units in data, or if the specified count is negative.
83*b1cdbd2cSJim Jagielski                   NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
84*b1cdbd2cSJim Jagielski    */
85*b1cdbd2cSJim Jagielski    void replaceData([in] long offset, [in] long count, [in] string arg) raises (DOMException);
86*b1cdbd2cSJim Jagielski
87*b1cdbd2cSJim Jagielski    /**
88*b1cdbd2cSJim Jagielski    Set the character data of the node that implements this interface.
89*b1cdbd2cSJim Jagielski    Throws:
90*b1cdbd2cSJim Jagielski        DOMException - NO_MODIFICATION_ALLOWED_ERR: Raised when the node is readonly.
91*b1cdbd2cSJim Jagielski        DOMException - DOMSTRING_SIZE_ERR: Raised when it would return more characters than
92*b1cdbd2cSJim Jagielski            fit in a DOMString variable on the implementation platform.
93*b1cdbd2cSJim Jagielski    */
94*b1cdbd2cSJim Jagielski    void setData([in] string data) raises (DOMException);
95*b1cdbd2cSJim Jagielski
96*b1cdbd2cSJim Jagielski    /**
97*b1cdbd2cSJim Jagielski    Extracts a range of data from the node.
98*b1cdbd2cSJim Jagielski    Throws:
99*b1cdbd2cSJim Jagielski        DOMException - INDEX_SIZE_ERR: Raised if the specified offset is negative or greater
100*b1cdbd2cSJim Jagielski            than the number of 16-bit units in data, or if the specified count is negative.
101*b1cdbd2cSJim Jagielski        DOMSTRING_SIZE_ERR: Raised if the specified range of text does not fit into a DOMString.
102*b1cdbd2cSJim Jagielski    */
103*b1cdbd2cSJim Jagielski    string subStringData([in] long offset, [in] long count) raises (DOMException);
104*b1cdbd2cSJim Jagielski
105*b1cdbd2cSJim Jagielski};
106*b1cdbd2cSJim Jagielski};};};};};
107*b1cdbd2cSJim Jagielski
108*b1cdbd2cSJim Jagielski#endif
109