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

F79659-03

coherence/util/Optional.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_OPTIONAL_HPP
00008 #define COH_OPTIONAL_HPP
00009 
00010 #include "coherence/lang.ns"
00011 
00012 #include "coherence/io/pof/PortableObject.hpp"
00013 #include "coherence/io/pof/PofReader.hpp"
00014 #include "coherence/io/pof/PofWriter.hpp"
00015 
00016 COH_OPEN_NAMESPACE2(coherence,util)
00017 
00018 using coherence::io::pof::PofReader;
00019 using coherence::io::pof::PofWriter;
00020 using coherence::io::pof::PortableObject;
00021 
00022 /**
00023  * C++ port of java.util.Optional, a container object which may or may not
00024  * contain a non-NULL value.  If a value is present, isPresent() will return
00025  * true and get() will return the value.
00026  *
00027  * @author as,lh  2015.06.09
00028  * @since Coherence 12.2.1
00029  */
00030 class COH_EXPORT Optional
00031     : public class_spec<Optional,
00032         extends<Object>,
00033         implements<PortableObject> >
00034     {
00035     friend class factory<Optional>;
00036 
00037     // ----- constructors ---------------------------------------------------
00038 
00039     protected:
00040         /**
00041          * Default constructor.
00042          */
00043         Optional();
00044 
00045     private:
00046         /**
00047          * Constructs an instance with the value present.
00048          *
00049          * @param voValue  the object value it wraps
00050          */
00051         Optional(Object::Holder oh);
00052 
00053         /**
00054          * Blocked copy constructor.
00055          */
00056         Optional(const Optional&);
00057 
00058     public:
00059         /**
00060          * Return an Optional instance with NULL object value.
00061          *
00062          * @return an Optional instance with NULL object value
00063          */
00064         static Optional::View empty();
00065 
00066         /**
00067          * Return an Optional instance with the given object value.
00068          *
00069          * @param voValue  the object value it wraps
00070          *
00071          * @return an Optional instance with the given object value
00072          */
00073         static Optional::View of(Object::Holder oh);
00074 
00075         /**
00076          * Return an Optional instance with the given value, if non-NULL.
00077          * Otherwise, return an empty Optional.
00078          *
00079          * @param oh  the object value it wraps
00080          *
00081          * @return an Optional instance with the given nullable value.
00082          */
00083         static Optional::View ofNullable(Object::Holder oh);
00084 
00085         /**
00086          * Return the object value.
00087          *
00088          * @return the object value
00089          */
00090         virtual Object::Holder get() const;
00091 
00092         /**
00093          * Return true if there is a value present, otherwise false.
00094          *
00095          * @return true if there is a value present, otherwise, false
00096          */
00097         virtual bool isPresent() const;
00098 
00099         /**
00100          * Return value if present, otherwise, the given object.
00101          *
00102          * @param oh the default object value to return
00103          *
00104          * @return the value if present, otherwise, return the given object
00105          */
00106         virtual Object::Holder orElse(Object::Holder oh) const;
00107 
00108     // ----- PortableObject interface ---------------------------------------
00109 
00110     public:
00111         /**
00112          * {@inheritDoc}
00113          */
00114         virtual void readExternal(PofReader::Handle hIn);
00115 
00116         /**
00117          * {@inheritDoc}
00118          */
00119         virtual void writeExternal(PofWriter::Handle hOut) const;
00120 
00121     // ----- Object interface -----------------------------------------------
00122 
00123     public:
00124         /**
00125          * {@inheritDoc}
00126          */
00127         virtual bool equals(Object::View v) const;
00128 
00129         /**
00130          * {@inheritDoc}
00131          */
00132         virtual size32_t hashCode() const;
00133 
00134         /**
00135          * {@inheritDoc}
00136          */
00137         virtual TypedHandle<const String> toString() const;
00138 
00139     // ----- constants ------------------------------------------------------
00140 
00141     public:
00142         /**
00143          * Return an empty Optional instance.
00144          *
00145          * @return the empty Optional
00146          */
00147         static Optional::View emptyInstance();
00148 
00149         // ----- data members ---------------------------------------------------
00150 
00151     private:
00152         /**
00153          * The value this class wraps.  May be NULL.
00154          */
00155         FinalHolder<Object> f_oh;
00156     };
00157 
00158 COH_CLOSE_NAMESPACE2
00159 
00160 #endif // COH_OPTIONAL_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.