Library of Assembled Shared Sources
export_traits_optional.h
Go to the documentation of this file.
1/** @file
2 * @author Bram de Greve (bram@cocamware.com)
3 * @author Tom De Muer (tom@cocamware.com)
4 *
5 * *** BEGIN LICENSE INFORMATION ***
6 *
7 * The contents of this file are subject to the Common Public Attribution License
8 * Version 1.0 (the "License"); you may not use this file except in compliance with
9 * the License. You may obtain a copy of the License at
10 * http://lass.sourceforge.net/cpal-license. The License is based on the
11 * Mozilla Public License Version 1.1 but Sections 14 and 15 have been added to cover
12 * use of software over a computer network and provide for limited attribution for
13 * the Original Developer. In addition, Exhibit A has been modified to be consistent
14 * with Exhibit B.
15 *
16 * Software distributed under the License is distributed on an "AS IS" basis, WITHOUT
17 * WARRANTY OF ANY KIND, either express or implied. See the License for the specific
18 * language governing rights and limitations under the License.
19 *
20 * The Original Code is LASS - Library of Assembled Shared Sources.
21 *
22 * The Initial Developer of the Original Code is Bram de Greve and Tom De Muer.
23 * The Original Developer is the Initial Developer.
24 *
25 * All portions of the code written by the Initial Developer are:
26 * Copyright (C) 2022-2025 the Initial Developer.
27 * All Rights Reserved.
28 *
29 * Contributor(s):
30 *
31 * Alternatively, the contents of this file may be used under the terms of the
32 * GNU General Public License Version 2 or later (the GPL), in which case the
33 * provisions of GPL are applicable instead of those above. If you wish to allow use
34 * of your version of this file only under the terms of the GPL and not to allow
35 * others to use your version of this file under the CPAL, indicate your decision by
36 * deleting the provisions above and replace them with the notice and other
37 * provisions required by the GPL License. If you do not delete the provisions above,
38 * a recipient may use your version of this file under either the CPAL or the GPL.
39 *
40 * *** END LICENSE INFORMATION ***
41 */
42
43#pragma once
44
45#include "python_common.h"
46#include "export_traits.h"
47
48#include <optional>
49
50namespace lass
51{
52namespace python
53{
54
55/** Uses None to represent a std::optional without value.
56 *
57 * If None is also a valid value for the type T (such as pointers), then it
58 * will be impossible to differentiate between an unset std::optional, and
59 * a set std::optional with a value for None.
60 *
61 * @ingroup PyExportTraits
62 */
63template <typename T>
64struct PyExportTraits< std::optional<T> >
65{
66 static constexpr const char* py_typing = "T | None";
67
68 static PyObject* build(const std::optional<T>& value)
69 {
70 if (!value)
71 {
72 Py_RETURN_NONE;
73 }
74 return PyExportTraits<T>::build(*value);
75 }
76 static int get(PyObject* obj, std::optional<T>& value)
77 {
78 if (obj == Py_None)
79 {
80 value.reset();
81 return 0;
82 }
83 T tmp;
84 if (PyExportTraits<T>::get(obj, tmp) != 0)
85 {
86 return 1;
87 }
88 value = std::move(tmp);
89 return 0;
90 }
91};
92
93
94
95/** MaybeNone<std::optional<T>> type-hints a type as `T | MaybeNone`
96 *
97 * @ingroup PyExportTraits
98 * @sa MaybeNone
99 * @sa PyExportTraitsMaybeNone
100 */
101template <typename T>
102struct PyExportTraits< MaybeNone< std::optional<T> > > : public PyExportTraitsMaybeNone< std::optional<T> >
103{
104};
105
106}
107}
Wrapper to type-hint return values in Python that maybe None but not likely.
Definition maybe_none.h:82
Comprehensive C++ to Python binding library.
Library for Assembled Shared Sources.
Definition config.h:53
Helper class to create PyExportTraits for MaybeNone wrapped types.
by copy, general case assumes shadow type or PyObjectPlus based type.