summaryrefslogtreecommitdiff
path: root/Examples/python/reference/runme.py
blob: 8a96e03a7acd93c20c8da48c0a1d7d64e76f6779 (plain)
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
# file: runme.py

# This file illustrates the manipulation of C++ references in Python

import example

# ----- Object creation -----

print("Creating some objects:")
a = example.Vector(3, 4, 5)
b = example.Vector(10, 11, 12)

print("    Created %s" % a.cprint())
print("    Created %s" % b.cprint())

# ----- Call an overloaded operator -----

# This calls the wrapper we placed around
#
#      operator+(const Vector &a, const Vector &)
#
# It returns a new allocated object.

print("Adding a+b")
c = example.addv(a, b)
print("    a+b = %s" % c.cprint())

# Note: Unless we free the result, a memory leak will occur
del c

# ----- Create a vector array -----

# Note: Using the high-level interface here
print("Creating an array of vectors")
va = example.VectorArray(10)
print("    va = %s" % va)

# ----- Set some values in the array -----

# These operators copy the value of $a and $b to the vector array
va.set(0, a)
va.set(1, b)

va.set(2, example.addv(a, b))

# Get some values from the array

print("Getting some array values")
for i in range(0, 5):
    print("    va(%d) = %s" % (i, va.get(i).cprint()))

# Watch under resource meter to check on this
print("Making sure we don't leak memory.")
for i in range(0, 1000000):
    c = va.get(i % 10)

# ----- Clean up -----
print("Cleaning up")

del va
del a
del b