File: pointer.rst

package info (click to toggle)
neuron 8.2.6-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 34,768 kB
  • sloc: cpp: 149,571; python: 58,449; ansic: 50,329; sh: 3,510; xml: 213; pascal: 51; makefile: 35; sed: 5
file content (94 lines) | stat: -rw-r--r-- 2,163 bytes parent folder | download | duplicates (3)
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

.. _hoc_pointer:

Pointer Class
-------------



.. hoc:class:: Pointer


    Syntax:
        ``Pointer(&x)``

        ``Pointer("variable")``

        ``Pointer(&x, "stmt that may contain $1")``

        ``Pointer("variable", "stmt that may contain $1 or variable name")``


    Description:
        Holds a reference to a variable. When memory for the variable is freed, 
        the Pointer will return an error if used. 
         
        See :hoc:meth:`Pointer.assign` for the meaning of the optional second arg.

----



.. hoc:method:: Pointer.val


    Syntax:
        ``x = ptr.val``

        ``ptr.val = expr``


    Description:
        Returns the value of the variable pointed to by ptr or, if the left 
        hand side of an assignment, sets the value of the variable. 

         

----



.. hoc:method:: Pointer.s


    Syntax:
        ``str = ptr.s``


    Description:
        If the Pointer was constructed with the name of a variable, that name 
        can be retrieved as a strdef. 

         

----



.. hoc:method:: Pointer.assign


    Syntax:
        ``x = ptr.assign(val)``


    Description:
        Sets the value of the pointer variable to val. If  prt was constructed 
        with a second arg then the execution depends on its form. If the 
        second arg string contains one or more $1 tokens, then the tokens 
        are replaced by :hoc:data:`hoc_ac_`, :hoc:data:`hoc_ac_` is set to the val and the resulting
        statement is executed. Otherwise the second arg string is assumed to 
        be a variable name and a statement of the form 
        variablename = :hoc:data:`hoc_ac_` is executed.
        Note that the compiling of these statements takes place just once when 
        the Pointer is constructed. Thus ptr.assign(val) is marginally 
        faster than execute("stmt with val"). 
         
        (following not implemented) And if the stmt is a variablename 
        then the pointer is used and all interpreter overhead is avoided. 
        Also note that on construction, the second arg variable is executed with the 
        value of the first arg pointer. So 
         
        Returns val.