1997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu/* Copyright (c) 2003,2004, Stefan Haustein, Oberhausen, Rhld., Germany
2997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu *
3997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * Permission is hereby granted, free of charge, to any person obtaining a copy
4997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * of this software and associated documentation files (the "Software"), to deal
5997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * in the Software without restriction, including without limitation the rights
6997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * to use, copy, modify, merge, publish, distribute, sublicense, and/or
7997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * sell copies of the Software, and to permit persons to whom the Software is
8997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * furnished to do so, subject to the following conditions:
9997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu *
10997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * The  above copyright notice and this permission notice shall be included in
11997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * all copies or substantial portions of the Software.
12997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu *
13997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
18997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
19997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * IN THE SOFTWARE.
20997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu *
21997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * Contributor(s): John D. Beatty, F. Hunter, Renaud Tognelli
22997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu *
23997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * */
24997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
25997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yupackage org.ksoap2.serialization;
26997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
27997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yuimport java.util.Hashtable;
28997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
29997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu/**
30997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * Provides get and set methods for properties. Can be used to replace
31997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * reflection (to some extend) for "serialization-aware" classes. Currently used
32997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu * in kSOAP and the RMS based kobjects object repository
33997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu */
34997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
35997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yupublic interface KvmSerializable {
36997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
37997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    /**
38997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * Get the property at the given index
39997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     */
40997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    Object getProperty(int index);
41997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
42997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    /**
43997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * @return the number of serializable properties
44997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     */
45997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    int getPropertyCount();
46997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
47997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    /**
48997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * Sets the property with the given index to the given value.
49997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *
50997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * @param index
51997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *            the index to be set
52997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * @param value
53997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *            the value of the property
54997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     */
55997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    void setProperty(int index, Object value);
56997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
57997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    /**
58997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * Fills the given property info record.
59997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *
60997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * @param index
61997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *            the index to be queried
62997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * @param properties
63997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *            information about the (de)serializer.  Not frequently used.
64997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     * @param info
65997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *            The return parameter, to be filled with information about the
66997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     *            property with the given index.
67997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu     */
68997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu    void getPropertyInfo(int index, Hashtable properties, PropertyInfo info);
69997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu
70997171ed3fdf8baf96d8fdf9dd3201a459327d89Ryan Yu}
71