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

F79659-03

coherence/util/extractor/ConditionalExtractor.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_CONDITIONAL_EXTRACTOR_HPP
00008 #define COH_CONDITIONAL_EXTRACTOR_HPP
00009 
00010 #include "coherence/lang.ns"
00011 
00012 #include "coherence/io/pof/PofReader.hpp"
00013 #include "coherence/io/pof/PofWriter.hpp"
00014 #include "coherence/util/Comparator.hpp"
00015 #include "coherence/util/Filter.hpp"
00016 #include "coherence/util/Map.hpp"
00017 #include "coherence/util/MapIndex.hpp"
00018 #include "coherence/util/ValueExtractor.hpp"
00019 #include "coherence/util/extractor/AbstractExtractor.hpp"
00020 #include "coherence/util/extractor/IndexAwareExtractor.hpp"
00021 
00022 COH_OPEN_NAMESPACE3(coherence,util,extractor)
00023 
00024 using coherence::io::pof::PofReader;
00025 using coherence::io::pof::PofWriter;
00026 using coherence::util::Comparator;
00027 using coherence::util::Filter;
00028 using coherence::util::MapIndex;
00029 using coherence::util::ValueExtractor;
00030 
00031 
00032 /**
00033 * An IndexAwareExtractor implementation that is only used to create a
00034 * coherence::util::ConditionalIndex.
00035 * <p/>
00036 * Note: the underlying ValueExtractor is used for value extraction during
00037 * index creation and is the extractor that is associated with the created
00038 * coherence::util::ConditionalIndex in the given index map.  Using the
00039 * ConditionalExtractor to extract values is not supported.
00040 *
00041 * @author tb/lh  2010.08.31
00042 * @since Coherence 3.6
00043 */
00044 class COH_EXPORT ConditionalExtractor
00045     : public class_spec<ConditionalExtractor,
00046         extends<AbstractExtractor>,
00047         implements<IndexAwareExtractor, PortableObject> >
00048     {
00049     friend class factory<ConditionalExtractor>;
00050 
00051     // ----- constructors ---------------------------------------------------
00052 
00053     protected:
00054         /**
00055         * Construct the ConditionalExtractor.
00056         */
00057         ConditionalExtractor();
00058 
00059         /**
00060         * Construct the ConditionalExtractor.
00061         *
00062         * @param vFilter        the filter used by this extractor to create a
00063         *                       ConditionalIndex; must not be NULL
00064         * @param vExtractor     the extractor used by this extractor to create
00065         *                       a ConditionalIndex; Note that the created index
00066         *                       will be associated with this extractor in
00067         *                       the given index map; must not be NULL
00068         * @param fForwardIndex  specifies whether or not this extractor
00069         *                       will create a ConditionalIndex that
00070         *                       supports a forward map
00071         */
00072         ConditionalExtractor(Filter::View vFilter,
00073             ValueExtractor::View vExtractor,
00074             bool fForwardIndex);
00075 
00076 
00077     // ----- IndexAwareExtractor interface ----------------------------------
00078 
00079     public:
00080         /**
00081         * {@inheritDoc}
00082         */
00083         virtual MapIndex::Handle createIndex(bool fOrdered, Comparator::View vComparator,
00084             Map::Handle hMapIndex) const;
00085 
00086         /**
00087         * {@inheritDoc}
00088         */
00089         virtual MapIndex::Handle destroyIndex(Map::Handle hMapIndex) const;
00090 
00091 
00092     // ----- ValueExtractor interface ---------------------------------------
00093 
00094     public:
00095         /**
00096         * Using a ConditionalExtractor to extract values in not supported.
00097         *
00098         * @throws UnsupportedOperationException always
00099         */
00100         virtual Object::Holder extract(Object::Holder ohTarget) const;
00101 
00102 
00103     // ----- PortableObject interface ---------------------------------------
00104 
00105     public:
00106         /**
00107         * {@inheritDoc}
00108         */
00109         virtual void readExternal(PofReader::Handle hIn);
00110 
00111         /**
00112         * {@inheritDoc}
00113         */
00114         virtual void writeExternal(PofWriter::Handle hOut) const;
00115 
00116 
00117     // ----- Object methods -------------------------------------------------
00118 
00119     public:
00120         /**
00121         * {@inheritDoc}
00122         */
00123         virtual TypedHandle<const String> toString() const;
00124 
00125         /**
00126         * {@inheritDoc}
00127         */
00128         virtual bool equals(Object::View v) const;
00129 
00130         /**
00131         * {@inheritDoc}
00132         */
00133         virtual size32_t hashCode() const;
00134 
00135 
00136     // ----- data members ---------------------------------------------------
00137 
00138     protected:
00139         /**
00140         * The filter used by this extractor.
00141         */
00142         FinalView<Filter> f_vFilter;
00143 
00144         /**
00145         * The underlying extractor.
00146         */
00147         FinalView<ValueExtractor> f_vExtractor;
00148 
00149         /**
00150         * Specifies whether or not this extractor will create a
00151         * coherence::util::ConditionalIndex that supports a forward index.
00152         */
00153         bool m_fForwardIndex;
00154     };
00155 
00156 COH_CLOSE_NAMESPACE3
00157 
00158 #endif // COH_CONDITIONAL_EXTRACTOR_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.