C++ Client API Reference for Oracle Coherence
14c (14.1.2.0.0)

F79659-03

coherence/io/pof/SimplePofContext.hpp

00001 /*
00002  * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
00003  *
00004  * Licensed under the Universal Permissive License v 1.0 as shown at
00005  * http://oss.oracle.com/licenses/upl.
00006  */
00007 #ifndef COH_SIMPLE_POF_CONTEXT_HPP
00008 #define COH_SIMPLE_POF_CONTEXT_HPP
00009 
00010 #include "coherence/lang.ns"
00011 
00012 #include "coherence/io/ReadBuffer.hpp"
00013 #include "coherence/io/WriteBuffer.hpp"
00014 #include "coherence/io/pof/PofContext.hpp"
00015 #include "coherence/io/pof/PofSerializer.hpp"
00016 #include "coherence/util/LongArray.hpp"
00017 #include "coherence/util/Map.hpp"
00018 
00019 COH_OPEN_NAMESPACE3(coherence,io,pof)
00020 
00021 using coherence::io::ReadBuffer;
00022 using coherence::io::WriteBuffer;
00023 using coherence::util::LongArray;
00024 using coherence::util::Map;
00025 
00026 
00027 /**
00028 * Basic PofContext implementation.
00029 *
00030 * @author gm  2008.10.24
00031 *
00032 * @see PortableObjectSerializer
00033 */
00034 class COH_EXPORT SimplePofContext
00035     : public cloneable_spec<SimplePofContext,
00036         extends<Object>,
00037         implements<PofContext> >
00038     {
00039     friend class factory<SimplePofContext>;
00040 
00041     // ----- constructors ---------------------------------------------------
00042 
00043     protected:
00044         /**
00045         * @internal
00046         */
00047         SimplePofContext();
00048 
00049         /**
00050         * Copy constructor.
00051         */
00052         SimplePofContext(const SimplePofContext& that);
00053 
00054 
00055     // ----- SimplePofContext interface -------------------------------------
00056 
00057     public:
00058         /**
00059         * Associate a user type with a type identifier and
00060         * {@link PofSerializer}.
00061         *
00062         * @param nTypeId      the type identifier of the specified user type;
00063         *                     must be greater or equal to 0
00064         * @param vClass       the user type to register with this PofContext;
00065         *                     must not be NULL
00066         * @param vSerializer  the PofSerializer that will be used to
00067         *                     serialize and deserialize objects of the
00068         *                     specified class; must not be NULL
00069         *
00070         * @throws coherence::lang::IllegalArgumentException on invalid type
00071         *         identifer, class, or PofSerializer
00072         */
00073         virtual void registerUserType(int32_t nTypeId, Class::View vClass,
00074                 PofSerializer::View vSerializer);
00075 
00076         /**
00077         * Unregister a user type previously registered using the specified
00078         * type identifier.
00079         *
00080         * @param nTypeId  the type identifier of the user type to unregister
00081         *
00082         * @throws coherence::lang::IllegalArgumentException  if the specified
00083         *         user type identifier is unknown to this PofContext
00084         */
00085         virtual void unregisterUserType(int32_t nTypeId);
00086 
00087 
00088     // ----- PofContext interface -------------------------------------------
00089 
00090     public:
00091         /**
00092         * {@inheritDoc}
00093         */
00094         virtual PofSerializer::View getPofSerializer(int32_t nTypeId) const;
00095 
00096         /**
00097         * {@inheritDoc}
00098         */
00099         virtual int32_t getUserTypeIdentifier(Object::View v) const;
00100 
00101         /**
00102         * {@inheritDoc}
00103         */
00104         virtual int32_t getUserTypeIdentifier(Class::View vClass) const;
00105 
00106         /**
00107         * {@inheritDoc}
00108         */
00109         virtual int32_t getUserTypeIdentifier(String::View vsClass) const;
00110 
00111         /**
00112         * {@inheritDoc}
00113         */
00114         virtual String::View getClassName(int32_t nTypeId) const;
00115 
00116         /**
00117         * {@inheritDoc}
00118         */
00119         virtual Class::View getClass(int32_t nTypeId) const;
00120 
00121         /**
00122         * {@inheritDoc}
00123         */
00124         virtual bool isUserType(Object::View v) const;
00125 
00126         /**
00127         * {@inheritDoc}
00128         */
00129         virtual bool isUserType(Class::View vClass) const;
00130 
00131         /**
00132         * {@inheritDoc}
00133         */
00134         virtual bool isUserType(String::View vsClass) const;
00135 
00136 
00137     // ----- Serializer interface -------------------------------------------
00138 
00139     public:
00140         /**
00141         * {@inheritDoc}
00142         */
00143         virtual void serialize(WriteBuffer::BufferOutput::Handle hOut,
00144                 Object::View v) const;
00145 
00146         /**
00147         * {@inheritDoc}
00148         */
00149         virtual Object::Holder deserialize(
00150                 ReadBuffer::BufferInput::Handle hIn) const;
00151 
00152 
00153     // ----- Object interface -----------------------------------------------
00154 
00155     public:
00156         /**
00157         * {@inheritDoc}
00158         */
00159         virtual TypedHandle<const String> toString() const;
00160 
00161 
00162     // ----- internal methods -----------------------------------------------
00163 
00164     protected:
00165         /**
00166         * Ensure that the given user type identifier is valid.
00167         *
00168         * @param nTypeId  the user type identifier to validate
00169         *
00170         * @throws coherence::lang::IllegalArgumentException if the given user
00171         *         type identifier is negative
00172         */
00173         virtual void validateTypeId(int32_t nTypeId) const;
00174 
00175 
00176     // ----- accessors ------------------------------------------------------
00177 
00178     public:
00179         /**
00180         * Determine if Identity/Reference type support is enabled for this
00181         * SimplePofContext.
00182         *
00183         * @return true if Identity/Reference type support is enabled
00184         *
00185         * @since Coherence 3.7.1
00186         */
00187         virtual bool isReferenceEnabled() const;
00188 
00189         /**
00190         * Enable or disable POF Identity/Reference type support for this
00191         * SimplePofContext.
00192         *
00193         * @param fEnabled  true to enable POF Identity/Reference type support;
00194         *                  false to disable
00195         *
00196         * @since Coherence 3.7.1
00197         */
00198         virtual void setReferenceEnabled(bool fEnabled);
00199 
00200         /**
00201         * Enable or disable POF Identity/Reference type support for this
00202         * SimplePofContext.
00203         *
00204         * @param fEnabled  true to enable POF Identity/Reference type support;
00205         *                  false to disable
00206         *
00207         * @since Coherence 3.7.1
00208         */
00209         virtual void setReferenceEnabled(bool fEnabled) const;
00210 
00211 
00212     // ----- data members ---------------------------------------------------
00213 
00214     protected:
00215         /**
00216         * A LongArray of user types, indexed by type identifier.
00217         */
00218         FinalHandle<LongArray> f_hlaClass;
00219 
00220         /**
00221         * A LongArray of PofSerializer objects, indexed by type identifier.
00222         */
00223         FinalHandle<LongArray> f_hlaSerializer;
00224 
00225         /**
00226         * A Map that contains mappings from a registered class name to type
00227         * identifier.
00228         */
00229         FinalHandle<Map> f_hMapClassName;
00230 
00231         /**
00232         * True if POF Identity/Reference type support is enabled.
00233         */
00234         mutable bool m_fReferenceEnabled;
00235     };
00236 
00237 COH_CLOSE_NAMESPACE3
00238 
00239 #endif // COH_SIMPLE_POF_CONTEXT_HPP
Copyright © 2000, 2025, Oracle and/or its affiliates. Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl.