File: python_richcompare.i

package info (click to toggle)
swig 4.3.0-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 46,232 kB
  • sloc: cpp: 54,631; ansic: 29,122; java: 17,530; python: 12,505; cs: 10,369; ruby: 7,232; yacc: 6,477; makefile: 5,965; javascript: 5,520; sh: 5,415; perl: 4,187; php: 3,693; ml: 2,187; lisp: 2,056; tcl: 1,991; xml: 115
file content (122 lines) | stat: -rw-r--r-- 2,528 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* Test the tp_richcompare functions generated with the -builtin option */

%module python_richcompare

%inline {

class BaseClass {
public:
    BaseClass (int i_) : i(i_) {}
    ~BaseClass () {}

    int getValue () const
    { return i; }
    
    bool operator< (const BaseClass& x) const
    { return this->i < x.i; }

    bool operator> (const BaseClass& x) const
    { return this->i > x.i; }

    bool operator<= (const BaseClass& x) const
    { return this->i <= x.i; }

    bool operator>= (const BaseClass& x) const
    { return this->i >= x.i; }

    bool operator== (const BaseClass& x) const
    { return this->i == x.i; }

    bool operator!= (const BaseClass& x) const
    { return this->i != x.i; }

    int i;
};

class SubClassA : public BaseClass {
public:
    SubClassA (int i_) : BaseClass(i_) {}
    ~SubClassA () {}

    bool operator== (const SubClassA& x) const
    { return true; }

    bool operator== (const BaseClass& x) const
    { return false; }
};

class SubClassB : public BaseClass {
public:
    SubClassB (int i_) : BaseClass(i_) {}
    ~SubClassB () {}

    bool operator== (const SubClassB& x) const
    { return true; }

    bool operator== (const SubClassA& x) const
    { return false; }
};
}

// Test custom exceptions can still be thrown in operators which use %pythonmaybecall
%{
struct ZeroValueProblem {
    ZeroValueProblem() {}
};
%}

%exception ExceptionThrower::operator< {
    try
    {
        $action
    }
    catch(const ZeroValueProblem&)
    {
        PyErr_SetString(PyExc_ValueError, "Zero not liked in operator<");
        SWIG_fail;
    }
}

%inline {
class ExceptionThrower {
    int i;
public:
    ExceptionThrower (int i_) : i(i_) {}
    bool operator< (const ExceptionThrower& rhs) const {
        if (rhs.i == 0 || i == 0)
            throw ZeroValueProblem();
        return this->i < rhs.i;
    }
};
}

%exception SubClassCThrower::operator== {
    try
    {
        $action
    }
    catch(const ZeroValueProblem&)
    {
        PyErr_SetString(PyExc_ValueError, "Zero not liked in operator==");
        SWIG_fail;
    }
}

// Overloaded operators and custom exceptions
%inline {
class SubClassCThrower : public BaseClass {
public:
    SubClassCThrower (int i_) : BaseClass(i_) {}
    ~SubClassCThrower () {}

    bool operator== (const SubClassCThrower& rhs) const
    {
        if (rhs.i == 0 || i == 0)
            throw ZeroValueProblem();
        return rhs.i == i;
    }

    bool operator== (const SubClassA& rhs) const
    { return rhs.i == i; }
};
}