1*408a4873SAndrew Rist/************************************************************** 2cdf0e10cSrcweir * 3*408a4873SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*408a4873SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*408a4873SAndrew Rist * distributed with this work for additional information 6*408a4873SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*408a4873SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*408a4873SAndrew Rist * "License"); you may not use this file except in compliance 9*408a4873SAndrew Rist * with the License. You may obtain a copy of the License at 10*408a4873SAndrew Rist * 11*408a4873SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*408a4873SAndrew Rist * 13*408a4873SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*408a4873SAndrew Rist * software distributed under the License is distributed on an 15*408a4873SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*408a4873SAndrew Rist * KIND, either express or implied. See the License for the 17*408a4873SAndrew Rist * specific language governing permissions and limitations 18*408a4873SAndrew Rist * under the License. 19*408a4873SAndrew Rist * 20*408a4873SAndrew Rist *************************************************************/ 21*408a4873SAndrew Rist 22*408a4873SAndrew Rist 23cdf0e10cSrcweir#ifndef __com_sun_star_beans_XPropertyWithState_idl__ 24cdf0e10cSrcweir#define __com_sun_star_beans_XPropertyWithState_idl__ 25cdf0e10cSrcweir 26cdf0e10cSrcweir#ifndef __com_sun_star_uno_XInterface_idl__ 27cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl> 28cdf0e10cSrcweir#endif 29cdf0e10cSrcweir 30cdf0e10cSrcweir#ifndef __com_sun_star_beans_PropertyState_idl__ 31cdf0e10cSrcweir#include <com/sun/star/beans/PropertyState.idl> 32cdf0e10cSrcweir#endif 33cdf0e10cSrcweir 34cdf0e10cSrcweir#ifndef __com_sun_star_lang_WrappedTargetException_idl__ 35cdf0e10cSrcweir#include <com/sun/star/lang/WrappedTargetException.idl> 36cdf0e10cSrcweir#endif 37cdf0e10cSrcweir 38cdf0e10cSrcweir//============================================================================= 39cdf0e10cSrcweir 40cdf0e10cSrcweirmodule com { module sun { module star { module beans { 41cdf0e10cSrcweir 42cdf0e10cSrcweir//============================================================================= 43cdf0e10cSrcweir 44cdf0e10cSrcweir/** makes it possible to query information about the state of 45cdf0e10cSrcweir this object, seen as a property contained in a property set. 46cdf0e10cSrcweir 47cdf0e10cSrcweir <p> This interface provides direct access to operations 48cdf0e10cSrcweir that are available if the containing property set 49cdf0e10cSrcweir implements <type>XPropertyState</type>. 50cdf0e10cSrcweir </p> 51cdf0e10cSrcweir 52cdf0e10cSrcweir <p>The state contains the information if:</p> 53cdf0e10cSrcweir <ul> 54cdf0e10cSrcweir <li>a value is available or void</li> 55cdf0e10cSrcweir <li>the value is stored in the object itself, or if a default value is being used</li> 56cdf0e10cSrcweir <li>or if the value cannot be determined, due to ambiguity 57cdf0e10cSrcweir (multi selection with multiple values).</li> 58cdf0e10cSrcweir </ul> 59cdf0e10cSrcweir 60cdf0e10cSrcweir <p> Generally objects that implement this interface 61cdf0e10cSrcweir also implement <type>XProperty</type>. 62cdf0e10cSrcweir </p> 63cdf0e10cSrcweir */ 64cdf0e10cSrcweirpublished interface XPropertyWithState: com::sun::star::uno::XInterface 65cdf0e10cSrcweir{ 66cdf0e10cSrcweir //------------------------------------------------------------------------- 67cdf0e10cSrcweir 68cdf0e10cSrcweir /** @returns 69cdf0e10cSrcweir the state of this as a property. 70cdf0e10cSrcweir */ 71cdf0e10cSrcweir com::sun::star::beans::PropertyState getStateAsProperty( ); 72cdf0e10cSrcweir 73cdf0e10cSrcweir //------------------------------------------------------------------------- 74cdf0e10cSrcweir 75cdf0e10cSrcweir /** sets this to its default value. 76cdf0e10cSrcweir 77cdf0e10cSrcweir <p> The value depends on the implementation of this interface. 78cdf0e10cSrcweir If this is a bound property, the value changes before 79cdf0e10cSrcweir the change events are fired. If this is a constrained property, 80cdf0e10cSrcweir the vetoable event is fired before the property value changes. 81cdf0e10cSrcweir </p> 82cdf0e10cSrcweir 83cdf0e10cSrcweir @throws com::sun::star::lang::WrappedTargetException 84cdf0e10cSrcweir if the implementation has an internal reason for the exception. 85cdf0e10cSrcweir In this case the original exception is wrapped into that 86cdf0e10cSrcweir <type scope="com::sun::star::lang">WrappedTargetException</type>. 87cdf0e10cSrcweir */ 88cdf0e10cSrcweir void setToDefaultAsProperty( ) 89cdf0e10cSrcweir raises( com::sun::star::lang::WrappedTargetException ); 90cdf0e10cSrcweir 91cdf0e10cSrcweir //------------------------------------------------------------------------- 92cdf0e10cSrcweir 93cdf0e10cSrcweir /** @returns 94cdf0e10cSrcweir an object representing the default state of this object (as a property). 95cdf0e10cSrcweir 96cdf0e10cSrcweir <p> If no default exists, is not known or is void, 97cdf0e10cSrcweir then the return value is <NULL/>. 98cdf0e10cSrcweir </p> 99cdf0e10cSrcweir 100cdf0e10cSrcweir @throws com::sun::star::lang::WrappedTargetException 101cdf0e10cSrcweir if the implementation has an internal reason for the exception. 102cdf0e10cSrcweir In this case the original exception is wrapped into that 103cdf0e10cSrcweir <type scope="com::sun::star::lang">WrappedTargetException</type>. 104cdf0e10cSrcweir */ 105cdf0e10cSrcweir com::sun::star::uno::XInterface getDefaultAsProperty( ) 106cdf0e10cSrcweir raises( com::sun::star::lang::WrappedTargetException ); 107cdf0e10cSrcweir}; 108cdf0e10cSrcweir 109cdf0e10cSrcweir//============================================================================= 110cdf0e10cSrcweir 111cdf0e10cSrcweir}; }; }; }; 112cdf0e10cSrcweir 113cdf0e10cSrcweir#endif 114