summaryrefslogtreecommitdiff
path: root/offapi/com/sun/star/ucb/ContentAction.idl
blob: cc01eec741f64523876092793c23c7286179fb08 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
/*************************************************************************
 *
 *  $RCSfile: ContentAction.idl,v $
 *
 *  $Revision: 1.5 $
 *
 *  last change: $Author: kso $ $Date: 2001-02-12 15:53:18 $
 *
 *  The Contents of this file are made available subject to the terms of
 *  either of the following licenses
 *
 *         - GNU Lesser General Public License Version 2.1
 *         - Sun Industry Standards Source License Version 1.1
 *
 *  Sun Microsystems Inc., October, 2000
 *
 *  GNU Lesser General Public License Version 2.1
 *  =============================================
 *  Copyright 2000 by Sun Microsystems, Inc.
 *  901 San Antonio Road, Palo Alto, CA 94303, USA
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License version 2.1, as published by the Free Software Foundation.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *  MA  02111-1307  USA
 *
 *
 *  Sun Industry Standards Source License Version 1.1
 *  =================================================
 *  The contents of this file are subject to the Sun Industry Standards
 *  Source License Version 1.1 (the "License"); You may not use this file
 *  except in compliance with the License. You may obtain a copy of the
 *  License at http://www.openoffice.org/license.html.
 *
 *  Software provided under this License is provided on an "AS IS" basis,
 *  WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
 *  WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
 *  MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
 *  See the License for the specific provisions governing your rights and
 *  obligations concerning the Software.
 *
 *  The Initial Developer of the Original Code is: Sun Microsystems, Inc.
 *
 *  Copyright: 2000 by Sun Microsystems, Inc.
 *
 *  All Rights Reserved.
 *
 *  Contributor(s): _______________________________________
 *
 *
 ************************************************************************/
#ifndef __com_sun_star_ucb_ContentAction_idl__
#define __com_sun_star_ucb_ContentAction_idl__


//=============================================================================

module com { module sun { module star { module ucb {

//=============================================================================
/** specifies actions which can be transported with content events.

    <p>
    The situations under which contents will send ContentEvents of the various
    action types are described below.  The description is broken into a list of
    useful definitions, a list of events that happen to contents, and a list of
    reactions taken by contents in response to those events.
    </p>

    <p>
    The definitions are as follows:
    </p>

    <table border =1>
    <tr><td>D1</td><td>A content C has an identifier id(C).</td></tr>
    <tr><td>D2</td><td>A content C is in one of two states, Alive or Deleted.
                       </td></tr>
    <tr><td>D3</td><td>A folder content F has a set of children H(F) that is a
                       set of content identifiers. For example, an "open"
                       command will usualy return a subset of the contents
                       denoted by H(F).</td></tr>
    </table>

    <p>
    The events that can happen to contents (and that are of interest in this
    context) are listed next.  Note that 'event' here does not mean an
    ContentEvent, but rather some event that occurs either because some content
    processes a command, or because a content gets informed about a relevant
    change in the underlying system it represents.
    </p>

    <table border =1>
    <tr><td>E1</td><td>The identifier of a content C changes from id1(C) == A
                       to id2(C) == B, denoted as E1(C: A->B). For example,
                       this event may occur when content C processes a
                       "setPropertyValues" command changing its "Title" propery,
                       or when afolder that hierarchicaly contains C changes
                       its identity.</td></tr>
    <tr><td>E2</td><td>The state of a content C changes from Alive to Deleted,
                       denoted as E2(C). For example, this event may occur when
                       content C processes a "delete"   command, or when a content
                       representing an IMAP message gets informed   by the IMAP
                       server that the message has been deleted.</td></tr>
    <tr><td>E3</td><td>The set of children of a folder content F is enlarged by
                       some identifier A (that was not previously in that set,
                       i.e., !(A in H1(F)) && (A in H2(F))), denoted as E3(F, A).
                       For example, this event may occur when a new content
                       created at folder F processes its "insert" command, or
                       when a folder representing   an IMAP mailbox gets informed
                       by the IMAP server that a new message has arrived at that
                       mailbox.</td></tr>
    </table>

    <p>
    Finally, the list of reactions taken by contents in response to the above
    events gives a description of what kinds of ContentEvents are sent in which
    situations:
    </p>

    <table border =1>
    <tr><td>R1</td><td>E1(C: A->B) results in C sending an EXCHANGED
                       ContentEvent, which then results in the following: All
                       folders F that used to have A as a child, but will not
                       have B as a child, i.e., (A in H1(F)) && !(B in H2(F)),
                       send a REMOVED ContentEvent.</td></tr>
    <tr><td>R2</td><td>E2(C) results in C sending a DELETED ContentEvent,
                       which then results in the following:  All folders F that
                       used to have A as a child, but will not continue to have
                       A as a child, i.e., (A in H1(F)) && !(A in H2(F)), send
                       a REMOVED event.</td></tr>
    <tr><td>R3</td><td>E3(F, A) results in F sending an INSERTED event.</td></tr>
    </table>
*/
constants ContentAction
{
    //-------------------------------------------------------------------------
    /** A content was inserted into a folder content (i.e., while updating the
        folder).

        <p>This action must be notified at the listeners of the folder content.
    */
    const long INSERTED = 0;

    //-------------------------------------------------------------------------
    /** A content was removed from a folder content, but not physically
        destroyed (i.e., due to rules just applied to the folder).

        <p>This action must be notified at the listeners of the folder content.
    */
    const long REMOVED = 1;

    //-------------------------------------------------------------------------
    /** A content was physically destroyed.

        <p>Events containing this action may be generated at any time. So a
        content event listener should be prepared to get notified the "death"
        of the related content!

        <p>This action must be notified at the listeners of the deleted
        content.
    */
    const long DELETED = 2;

    //-------------------------------------------------------------------------
    /** This Action indicates that a content has changed its identity (i.e.
        after renaming a file system folder).

        <p>This action must be notified at the listeners of the exchanged
        content.
    */
    const long EXCHANGED = 4;

    //-------------------------------------------------------------------------
    /** This is obsolete and should no longer be used.

        @deprecated
    */
    const long SEARCH_MATCHED = 128;

};

//=============================================================================

}; }; }; };

#endif