Qpid Proton C++  0.13.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Pages
source_options.hpp
1 #ifndef PROTON_SOURCE_OPTIONS_HPP
2 #define PROTON_SOURCE_OPTIONS_HPP
3 
4 /*
5  *
6  * Licensed to the Apache Software Foundation (ASF) under one
7  * or more contributor license agreements. See the NOTICE file
8  * distributed with this work for additional information
9  * regarding copyright ownership. The ASF licenses this file
10  * to you under the Apache License, Version 2.0 (the
11  * "License"); you may not use this file except in compliance
12  * with the License. You may obtain a copy of the License at
13  *
14  * http://www.apache.org/licenses/LICENSE-2.0
15  *
16  * Unless required by applicable law or agreed to in writing,
17  * software distributed under the License is distributed on an
18  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
19  * KIND, either express or implied. See the License for the
20  * specific language governing permissions and limitations
21  * under the License.
22  *
23  */
24 
25 #include "./internal/config.hpp"
26 #include "./internal/export.hpp"
27 #include "./internal/pn_unique_ptr.hpp"
28 #include "./types.hpp"
29 #include "./delivery_mode.hpp"
30 #include "./source.hpp"
31 
32 #include <vector>
33 #include <string>
34 
35 namespace proton {
36 
37 class proton_handler;
38 
46  public:
47 
49  PN_CPP_EXTERN source_options();
50 
52  PN_CPP_EXTERN source_options(const source_options&);
53 
54  PN_CPP_EXTERN ~source_options();
55 
57  PN_CPP_EXTERN source_options& operator=(const source_options&);
58 
60  PN_CPP_EXTERN source_options& address(const std::string&);
61 
64  PN_CPP_EXTERN source_options& dynamic(bool);
65 
67  PN_CPP_EXTERN source_options& distribution_mode(enum source::distribution_mode);
68 
70  PN_CPP_EXTERN source_options& durability_mode(enum source::durability_mode);
71 
73  PN_CPP_EXTERN source_options& timeout(duration);
74 
76  PN_CPP_EXTERN source_options& expiry_policy(enum source::expiry_policy);
77 
81  PN_CPP_EXTERN source_options& filters(const source::filter_map&);
82 
83  private:
84  void apply(source&) const;
85 
86  class impl;
87  internal::pn_unique_ptr<impl> impl_;
88 
90  friend class source;
91  friend class sender_options;
92  friend class receiver_options;
94 };
95 
96 } // proton
97 
98 #endif // PROTON_SOURCE_OPTIONS_HPP
source_options & timeout(duration)
The expiry period after which the source is discarded.
distribution_mode
The policy for distributing messages.
Definition: source.hpp:51
source_options & durability_mode(enum source::durability_mode)
Control the persistence of source state.
Options for creating a sender.
Definition: sender_options.hpp:64
A span of time in milliseconds.
Definition: duration.hpp:34
source_options & distribution_mode(enum source::distribution_mode)
Control whether messsages are browsed or consumed.
Include the definitions of all proton types used to represent AMQP types.
source_options()
Create an empty set of options.
A point of origin for messages.
Definition: source.hpp:41
source_options & expiry_policy(enum source::expiry_policy)
Control when the clock for expiration begins.
source_options & operator=(const source_options &)
Copy options.
std::map< symbol, value > filter_map
Experimental - A map of AMQP symbol keys and filter specifiers.
Definition: source.hpp:45
durability_mode
The persistence mode of the source or target.
Definition: terminus.hpp:49
source_options & address(const std::string &)
Set the address for the source. Ignored if dynamic is true.
Options for creating a source node for a sender or receiver.
Definition: source_options.hpp:45
Options for creating a receiver.
Definition: receiver_options.hpp:62
source_options & filters(const source::filter_map &)
Experimental - Specify a filter mechanism on the source that restricts message flow to a subset of th...
expiry_policy
When expiration of the source or target begins.
Definition: terminus.hpp:59
source_options & dynamic(bool)
Request a dynamically created node to be created by the remote peer.