<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE erlref SYSTEM "erlref.dtd">

<erlref>
  <header>
    <copyright>
      <year>2000</year><year>2013</year>
      <holder>Ericsson AB. All Rights Reserved.</holder>
    </copyright>
    <legalnotice>
      The contents of this file are subject to the Erlang Public License,
      Version 1.1, (the "License"); you may not use this file except in
      compliance with the License. You should have received a copy of the
      Erlang Public License along with this software. If not, it can be
      retrieved online at http://www.erlang.org/.
    
      Software distributed under the License is distributed on an "AS IS"
      basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
      the License for the specific language governing rights and limitations
      under the License.
    
    </legalnotice>

    <title>CosPropertyService_PropertySetDef</title>
    <prepared></prepared>
    <docno></docno>
    <checked></checked>
    <date>2000-07-25</date>
    <rev>1.0</rev>
  </header>
  <module>CosPropertyService_PropertySetDef</module>
  <modulesummary>This module implements the OMG CosPropertyService::PropertySetDef interface.</modulesummary>
  <description>
    <p>To get access to the record definitions for the structures use:      <br></br>
<c>-include_lib("cosProperty/include/CosPropertyService.hrl").</c></p>
    <p>This module also exports the functions described in</p>
    <p><seealso marker="CosPropertyService_PropertySet">CosPropertyService_PropertySet</seealso></p>
  </description>
  <funcs>
    <func>
      <name>get_allowed_property_types(PropertySetDef) -> Reply</name>
      <fsummary>Return allowed TypeCodes for the target object</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>Reply = {ok, PropertyTypes}</v>
        <v>PropertyTypes = [CORBA::TypeCode]</v>
      </type>
      <desc>
        <p>This operation return the TypeCodes which we are allowed to use when adding
          new properties.</p>
      </desc>
    </func>
    <func>
      <name>get_allowed_properties(PropertySetDef) -> Reply</name>
      <fsummary>Return a sequence of the allowed properties</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>Reply = {ok, PropertyDefs}</v>
        <v>PropertyDefs = [#'CosPropertyService_PropertyDef'{property_name = Name, property_value = Value, property_mode = Mode}]</v>
        <v>Name = string()</v>
        <v>Value = #any</v>
        <v>Mode = normal | read_only | fixed_normal | fixed_readonly | undefined</v>
      </type>
      <desc>
        <p>This operation a sequence of the allowed properties we may alter; depends on
          which mode associated with a certain property.</p>
      </desc>
    </func>
    <func>
      <name>define_property_with_mode(PropertySetDef, Name, Value, Mode) -> Reply</name>
      <fsummary>Associate a new property with the target object</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>Name = non-empty string()</v>
        <v>Value = #any</v>
        <v>Mode =  normal | read_only | fixed_normal | fixed_readonly | undefined</v>
        <v>Reply = ok | {'EXCEPTION', #CosPropertyService_InvalidPropertyName{}} | {'EXCEPTION', #CosPropertyService_ConflictingProperty{}} | {'EXCEPTION', #CosPropertyService_UnsupportedTypeCode{}} | {'EXCEPTION', #CosPropertyService_UnsupportedProperty{}} | {'EXCEPTION', #CosPropertyService_UnsupportedMode{}} | {'EXCEPTION', #CosPropertyService_ReadOnlyProperty{}}</v>
      </type>
      <desc>
        <p>This operation attempts to associate a new property with the target object.
          If we fail to do so the appropriate exception is raised.</p>
      </desc>
    </func>
    <func>
      <name>define_properties_with_modes(PropertySetDef, PropertyDefs) -> Reply</name>
      <fsummary>Associate the given Property Definitions with the target object</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>PropertyDefs = [#'CosPropertyService_PropertyDef'{property_name = Name, property_value = Value, property_mode = Mode}]</v>
        <v>Name = string()</v>
        <v>Value = #any</v>
        <v>Mode = normal | read_only | fixed_normal | fixed_readonly | undefined</v>
        <v>Reply = ok | {'EXCEPTION', #CosPropertyService_MultipleExceptions{exceptions = Excs}}</v>
        <v>Excs = [#'CosPropertyService_PropertyException{reason = Reason, failing_property_name = Name}]</v>
        <v>Reason = invalid_property_name | conflicting_property | property_not_found | unsupported_type_code | unsupported_property | unsupported_mode | fixed_property | read_only_property</v>
      </type>
      <desc>
        <p>This operation attempts to associate the given Property Definitions with the
          target object. If one or more attempts fail an exception is raised 
          describing which properties we where not able to create.</p>
      </desc>
    </func>
    <func>
      <name>get_property_mode(PropertySetDef, Name) -> Reply</name>
      <fsummary>Return the mode of the given property</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>Name = string()</v>
        <v>Reply = Mode | {'EXCEPTION', #CosPropertyService_InvalidPropertyName{}} | {'EXCEPTION', #CosPropertyService_PropertyNotFound{}}</v>
        <v>Mode = normal | read_only | fixed_normal | fixed_readonly | undefined</v>
      </type>
      <desc>
        <p>This operation returns the type of the given property.</p>
      </desc>
    </func>
    <func>
      <name>get_property_modes(PropertySetDef, Names) -> Reply</name>
      <fsummary>Return the modes of the given properties</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>Names = [string()]</v>
        <v>Reply = {boolean(), PropertyModes}</v>
        <v>PropertyModes = [#'CosPropertyService_PropertyMode'{property_name = Name, property_mode = Mode}]</v>
        <v>Name = string()</v>
        <v>Mode = normal | read_only | fixed_normal | fixed_readonly | undefined</v>
      </type>
      <desc>
        <p>This operation returns the modes of the listed properties. If the boolean
          flag is false, all properties with mode <c>undefined</c> this operation
          failed to comply.</p>
      </desc>
    </func>
    <func>
      <name>set_property_mode(PropertySetDef, Name, Mode) -> Reply</name>
      <fsummary>Change the given property's mode</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>Name = string()</v>
        <v>Mode = normal | read_only | fixed_normal | fixed_readonly | undefined</v>
        <v>Reply = ok | {'EXCEPTION', #CosPropertyService_InvalidPropertyName{}} | {'EXCEPTION', #CosPropertyService_UnsupportedMode{}} | {'EXCEPTION', #CosPropertyService_PropertyNotFound{}}</v>
      </type>
      <desc>
        <p>This operation changes the given property's mode. Return the appropriate
          exception if not able to fulfill the request.</p>
      </desc>
    </func>
    <func>
      <name>set_property_modes(PropertySetDef, PropertyModes) -> Reply</name>
      <fsummary>Change the listed properties mode's</fsummary>
      <type>
        <v>PropertySetDef = #objref</v>
        <v>PropertyModes = [#'CosPropertyService_PropertyMode'{property_name = Name, property_mode = Mode}]</v>
        <v>Name = string()</v>
        <v>Mode = normal | read_only | fixed_normal | fixed_readonly | undefined</v>
        <v>Reply = ok | {'EXCEPTION', #CosPropertyService_MultipleExceptions{exceptions = Excs}}</v>
        <v>Excs = [#'CosPropertyService_PropertyException{reason = Reason, failing_property_name = Name}]</v>
        <v>Reason = invalid_property_name | conflicting_property | property_not_found | unsupported_type_code | unsupported_property | unsupported_mode | fixed_property | read_only_property</v>
      </type>
      <desc>
        <p>This operation attempts to update the listed properties mode's. Raises an 
          exception which describe which and why an operation failed.</p>
      </desc>
    </func>
  </funcs>
  
</erlref>