Nuitka
The Python compiler
Loading...
Searching...
No Matches
operations_inplace_add.h
1// Copyright 2025, Kay Hayen, mailto:kay.hayen@gmail.com find license text at end of file
2
3/* WARNING, this code is GENERATED. Modify the template HelperOperationInplace.c.j2 instead! */
4
5/* This file is included from another C file, help IDEs to still parse it on its own. */
6#ifdef __IDE_ONLY__
7#include "nuitka/prelude.h"
8#endif
9
10/* C helpers for type in-place "+" (ADD) operations */
11
12#if PYTHON_VERSION < 0x300
13/* Code referring to "INT" corresponds to Python2 'int' and "INT" to Python2 'int'. */
14extern bool INPLACE_OPERATION_ADD_INT_INT(PyObject **operand1, PyObject *operand2);
15#endif
16
17#if PYTHON_VERSION < 0x300
18/* Code referring to "OBJECT" corresponds to any Python object and "INT" to Python2 'int'. */
19extern bool INPLACE_OPERATION_ADD_OBJECT_INT(PyObject **operand1, PyObject *operand2);
20#endif
21
22#if PYTHON_VERSION < 0x300
23/* Code referring to "INT" corresponds to Python2 'int' and "OBJECT" to any Python object. */
24extern bool INPLACE_OPERATION_ADD_INT_OBJECT(PyObject **operand1, PyObject *operand2);
25#endif
26
27/* Code referring to "LONG" corresponds to Python2 'long', Python3 'int' and "LONG" to Python2 'long', Python3 'int'. */
28extern bool INPLACE_OPERATION_ADD_LONG_LONG(PyObject **operand1, PyObject *operand2);
29
30/* Code referring to "OBJECT" corresponds to any Python object and "LONG" to Python2 'long', Python3 'int'. */
31extern bool INPLACE_OPERATION_ADD_OBJECT_LONG(PyObject **operand1, PyObject *operand2);
32
33/* Code referring to "LONG" corresponds to Python2 'long', Python3 'int' and "OBJECT" to any Python object. */
34extern bool INPLACE_OPERATION_ADD_LONG_OBJECT(PyObject **operand1, PyObject *operand2);
35
36/* Code referring to "FLOAT" corresponds to Python 'float' and "FLOAT" to Python 'float'. */
37extern bool INPLACE_OPERATION_ADD_FLOAT_FLOAT(PyObject **operand1, PyObject *operand2);
38
39/* Code referring to "OBJECT" corresponds to any Python object and "FLOAT" to Python 'float'. */
40extern bool INPLACE_OPERATION_ADD_OBJECT_FLOAT(PyObject **operand1, PyObject *operand2);
41
42/* Code referring to "FLOAT" corresponds to Python 'float' and "OBJECT" to any Python object. */
43extern bool INPLACE_OPERATION_ADD_FLOAT_OBJECT(PyObject **operand1, PyObject *operand2);
44
45/* Code referring to "FLOAT" corresponds to Python 'float' and "LONG" to Python2 'long', Python3 'int'. */
46extern bool INPLACE_OPERATION_ADD_FLOAT_LONG(PyObject **operand1, PyObject *operand2);
47
48/* Code referring to "LONG" corresponds to Python2 'long', Python3 'int' and "FLOAT" to Python 'float'. */
49extern bool INPLACE_OPERATION_ADD_LONG_FLOAT(PyObject **operand1, PyObject *operand2);
50
51#if PYTHON_VERSION < 0x300
52/* Code referring to "FLOAT" corresponds to Python 'float' and "INT" to Python2 'int'. */
53extern bool INPLACE_OPERATION_ADD_FLOAT_INT(PyObject **operand1, PyObject *operand2);
54#endif
55
56#if PYTHON_VERSION < 0x300
57/* Code referring to "INT" corresponds to Python2 'int' and "FLOAT" to Python 'float'. */
58extern bool INPLACE_OPERATION_ADD_INT_FLOAT(PyObject **operand1, PyObject *operand2);
59#endif
60
61#if PYTHON_VERSION < 0x300
62/* Code referring to "LONG" corresponds to Python2 'long', Python3 'int' and "INT" to Python2 'int'. */
63extern bool INPLACE_OPERATION_ADD_LONG_INT(PyObject **operand1, PyObject *operand2);
64#endif
65
66#if PYTHON_VERSION < 0x300
67/* Code referring to "INT" corresponds to Python2 'int' and "LONG" to Python2 'long', Python3 'int'. */
68extern bool INPLACE_OPERATION_ADD_INT_LONG(PyObject **operand1, PyObject *operand2);
69#endif
70
71#if PYTHON_VERSION < 0x300
72/* Code referring to "INT" corresponds to Python2 'int' and "CLONG" to C platform long value. */
73extern bool INPLACE_OPERATION_ADD_INT_CLONG(PyObject **operand1, long operand2);
74#endif
75
76/* Code referring to "LONG" corresponds to Python2 'long', Python3 'int' and "DIGIT" to C platform digit value for long
77 * Python objects. */
78extern bool INPLACE_OPERATION_ADD_LONG_DIGIT(PyObject **operand1, long operand2);
79
80/* Code referring to "LONG" corresponds to Python2 'long', Python3 'int' and "CLONG" to C platform long value. */
81extern bool INPLACE_OPERATION_ADD_LONG_CLONG(PyObject **operand1, long operand2);
82
83/* Code referring to "FLOAT" corresponds to Python 'float' and "CFLOAT" to C platform float value. */
84extern bool INPLACE_OPERATION_ADD_FLOAT_CFLOAT(PyObject **operand1, double operand2);
85
86#if PYTHON_VERSION < 0x300
87/* Code referring to "STR" corresponds to Python2 'str' and "STR" to Python2 'str'. */
88extern bool INPLACE_OPERATION_ADD_STR_STR(PyObject **operand1, PyObject *operand2);
89#endif
90
91#if PYTHON_VERSION < 0x300
92/* Code referring to "OBJECT" corresponds to any Python object and "STR" to Python2 'str'. */
93extern bool INPLACE_OPERATION_ADD_OBJECT_STR(PyObject **operand1, PyObject *operand2);
94#endif
95
96#if PYTHON_VERSION < 0x300
97/* Code referring to "STR" corresponds to Python2 'str' and "OBJECT" to any Python object. */
98extern bool INPLACE_OPERATION_ADD_STR_OBJECT(PyObject **operand1, PyObject *operand2);
99#endif
100
101/* Code referring to "UNICODE" corresponds to Python2 'unicode', Python3 'str' and "UNICODE" to Python2 'unicode',
102 * Python3 'str'. */
103extern bool INPLACE_OPERATION_ADD_UNICODE_UNICODE(PyObject **operand1, PyObject *operand2);
104
105/* Code referring to "OBJECT" corresponds to any Python object and "UNICODE" to Python2 'unicode', Python3 'str'. */
106extern bool INPLACE_OPERATION_ADD_OBJECT_UNICODE(PyObject **operand1, PyObject *operand2);
107
108/* Code referring to "UNICODE" corresponds to Python2 'unicode', Python3 'str' and "OBJECT" to any Python object. */
109extern bool INPLACE_OPERATION_ADD_UNICODE_OBJECT(PyObject **operand1, PyObject *operand2);
110
111#if PYTHON_VERSION >= 0x300
112/* Code referring to "BYTES" corresponds to Python3 'bytes' and "BYTES" to Python3 'bytes'. */
113extern bool INPLACE_OPERATION_ADD_BYTES_BYTES(PyObject **operand1, PyObject *operand2);
114#endif
115
116#if PYTHON_VERSION >= 0x300
117/* Code referring to "OBJECT" corresponds to any Python object and "BYTES" to Python3 'bytes'. */
118extern bool INPLACE_OPERATION_ADD_OBJECT_BYTES(PyObject **operand1, PyObject *operand2);
119#endif
120
121#if PYTHON_VERSION >= 0x300
122/* Code referring to "BYTES" corresponds to Python3 'bytes' and "OBJECT" to any Python object. */
123extern bool INPLACE_OPERATION_ADD_BYTES_OBJECT(PyObject **operand1, PyObject *operand2);
124#endif
125
126/* Code referring to "TUPLE" corresponds to Python 'tuple' and "TUPLE" to Python 'tuple'. */
127extern bool INPLACE_OPERATION_ADD_TUPLE_TUPLE(PyObject **operand1, PyObject *operand2);
128
129/* Code referring to "OBJECT" corresponds to any Python object and "TUPLE" to Python 'tuple'. */
130extern bool INPLACE_OPERATION_ADD_OBJECT_TUPLE(PyObject **operand1, PyObject *operand2);
131
132/* Code referring to "TUPLE" corresponds to Python 'tuple' and "OBJECT" to any Python object. */
133extern bool INPLACE_OPERATION_ADD_TUPLE_OBJECT(PyObject **operand1, PyObject *operand2);
134
135/* Code referring to "LIST" corresponds to Python 'list' and "LIST" to Python 'list'. */
136extern bool INPLACE_OPERATION_ADD_LIST_LIST(PyObject **operand1, PyObject *operand2);
137
138/* Code referring to "OBJECT" corresponds to any Python object and "LIST" to Python 'list'. */
139extern bool INPLACE_OPERATION_ADD_OBJECT_LIST(PyObject **operand1, PyObject *operand2);
140
141/* Code referring to "LIST" corresponds to Python 'list' and "OBJECT" to any Python object. */
142extern bool INPLACE_OPERATION_ADD_LIST_OBJECT(PyObject **operand1, PyObject *operand2);
143
144#if PYTHON_VERSION < 0x300
145/* Code referring to "UNICODE" corresponds to Python2 'unicode', Python3 'str' and "STR" to Python2 'str'. */
146extern bool INPLACE_OPERATION_ADD_UNICODE_STR(PyObject **operand1, PyObject *operand2);
147#endif
148
149#if PYTHON_VERSION < 0x300
150/* Code referring to "STR" corresponds to Python2 'str' and "UNICODE" to Python2 'unicode', Python3 'str'. */
151extern bool INPLACE_OPERATION_ADD_STR_UNICODE(PyObject **operand1, PyObject *operand2);
152#endif
153
154/* Code referring to "OBJECT" corresponds to any Python object and "OBJECT" to any Python object. */
155extern bool INPLACE_OPERATION_ADD_OBJECT_OBJECT(PyObject **operand1, PyObject *operand2);
156
157/* Code referring to "LIST" corresponds to Python 'list' and "TUPLE" to Python 'tuple'. */
158extern bool INPLACE_OPERATION_ADD_LIST_TUPLE(PyObject **operand1, PyObject *operand2);
159
160// Part of "Nuitka", an optimizing Python compiler that is compatible and
161// integrates with CPython, but also works on its own.
162//
163// Licensed under the Apache License, Version 2.0 (the "License");
164// you may not use this file except in compliance with the License.
165// You may obtain a copy of the License at
166//
167// http://www.apache.org/licenses/LICENSE-2.0
168//
169// Unless required by applicable law or agreed to in writing, software
170// distributed under the License is distributed on an "AS IS" BASIS,
171// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
172// See the License for the specific language governing permissions and
173// limitations under the License.