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#ifndef __com_sun_star_ucb_ContentInfo_idl__
24*b1cdbd2cSJim Jagielski#define __com_sun_star_ucb_ContentInfo_idl__
25*b1cdbd2cSJim Jagielski
26*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_beans_Property_idl__
27*b1cdbd2cSJim Jagielski#include <com/sun/star/beans/Property.idl>
28*b1cdbd2cSJim Jagielski#endif
29*b1cdbd2cSJim Jagielski
30*b1cdbd2cSJim Jagielski//=============================================================================
31*b1cdbd2cSJim Jagielski
32*b1cdbd2cSJim Jagielskimodule com { module sun { module star { module ucb {
33*b1cdbd2cSJim Jagielski
34*b1cdbd2cSJim Jagielski//=============================================================================
35*b1cdbd2cSJim Jagielski/** A structure for information about contents.
36*b1cdbd2cSJim Jagielski
37*b1cdbd2cSJim Jagielski	@see XContentCreator
38*b1cdbd2cSJim Jagielski	@see XCommandProcessor
39*b1cdbd2cSJim Jagielski*/
40*b1cdbd2cSJim Jagielskipublished struct ContentInfo
41*b1cdbd2cSJim Jagielski{
42*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
43*b1cdbd2cSJim Jagielski	/** A type identifier string for a content.
44*b1cdbd2cSJim Jagielski
45*b1cdbd2cSJim Jagielski	    <p>This is an implementation specific string characterizing the
46*b1cdbd2cSJim Jagielski		kind of a content (e.g. "application/vnd.sun.star.hierarchy-link").
47*b1cdbd2cSJim Jagielski		The value of this member should match the value returned by
48*b1cdbd2cSJim Jagielski		<member>XContent::getContentType</member> of an appropriate content.
49*b1cdbd2cSJim Jagielski	*/
50*b1cdbd2cSJim Jagielski	string Type;
51*b1cdbd2cSJim Jagielski
52*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
53*b1cdbd2cSJim Jagielski	/** Additional attributes.
54*b1cdbd2cSJim Jagielski
55*b1cdbd2cSJim Jagielski	    <p>These flags contain extra information on the content, like its kind
56*b1cdbd2cSJim Jagielski		(KIND_FOLDER, KIND_DOCUMENT, KIND_LINK).
57*b1cdbd2cSJim Jagielski
58*b1cdbd2cSJim Jagielski		<p>It is highly recommended to fill these flags very accurately, as
59*b1cdbd2cSJim Jagielski		they are very important when transferring contents between different
60*b1cdbd2cSJim Jagielski		<type>ContentProvider</type>s.
61*b1cdbd2cSJim Jagielski
62*b1cdbd2cSJim Jagielski		<p>The value can be one of the <type>ContentInfoAttribute</type>
63*b1cdbd2cSJim Jagielski		   constants.
64*b1cdbd2cSJim Jagielski	*/
65*b1cdbd2cSJim Jagielski	long Attributes;
66*b1cdbd2cSJim Jagielski
67*b1cdbd2cSJim Jagielski	//-------------------------------------------------------------------------
68*b1cdbd2cSJim Jagielski	/** This field contains a list with the properties which must be set at
69*b1cdbd2cSJim Jagielski	    a content that was just created using
70*b1cdbd2cSJim Jagielski		<member>XContentCreator::createNewContent</member> before it can be
71*b1cdbd2cSJim Jagielski		committed (by executing the command "insert" at the new content).
72*b1cdbd2cSJim Jagielski
73*b1cdbd2cSJim Jagielski		<p>If one of the properties is missing, the insert command will fail.
74*b1cdbd2cSJim Jagielski
75*b1cdbd2cSJim Jagielski		<p>In example, a new file system folder content will need a title. The
76*b1cdbd2cSJim Jagielski		Properties member of the ContentInfo provided for this kind of
77*b1cdbd2cSJim Jagielski		content must include the property "Title".
78*b1cdbd2cSJim Jagielski
79*b1cdbd2cSJim Jagielski		<p><b>Important:</b> The required properties must have one of the
80*b1cdbd2cSJim Jagielski		following basic data types (in order to make it possible to implement
81*b1cdbd2cSJim Jagielski		client applications with a small set of generic input methods for the
82*b1cdbd2cSJim Jagielski		values):
83*b1cdbd2cSJim Jagielski
84*b1cdbd2cSJim Jagielski		<p>
85*b1cdbd2cSJim Jagielski		<ul>
86*b1cdbd2cSJim Jagielski		<li>boolean
87*b1cdbd2cSJim Jagielski		<li>char
88*b1cdbd2cSJim Jagielski		<li>byte
89*b1cdbd2cSJim Jagielski		<li>string
90*b1cdbd2cSJim Jagielski		<li>short
91*b1cdbd2cSJim Jagielski		<li>long
92*b1cdbd2cSJim Jagielski		<li>hyper
93*b1cdbd2cSJim Jagielski		<li>float
94*b1cdbd2cSJim Jagielski		<li>double
95*b1cdbd2cSJim Jagielski		</ul>
96*b1cdbd2cSJim Jagielski	*/
97*b1cdbd2cSJim Jagielski	sequence< com::sun::star::beans::Property > Properties;
98*b1cdbd2cSJim Jagielski};
99*b1cdbd2cSJim Jagielski
100*b1cdbd2cSJim Jagielski//=============================================================================
101*b1cdbd2cSJim Jagielski
102*b1cdbd2cSJim Jagielski}; }; }; };
103*b1cdbd2cSJim Jagielski
104*b1cdbd2cSJim Jagielski#endif
105