File: type-references.rst

package info (click to toggle)
llvmlite 0.46.0-0.1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 2,140 kB
  • sloc: python: 13,605; cpp: 3,192; makefile: 185; sh: 168
file content (87 lines) | stat: -rw-r--r-- 2,625 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
=================
Type references
=================

.. currentmodule:: llvmlite.binding

A type reference wraps an LLVM type. It allows accessing type's name and 
IR representation. It is also accepted by methods like 
:meth:`TargetData.get_abi_size`.

The TypeRef class
------------------

.. class:: TypeRef

    A wrapper around an LLVM type. The attributes available are:

    * .. attribute:: name

        This type's name, as a string. 

    * .. attribute:: is_struct

        * ``True``---The type is a struct type
        * ``False``---The type is not a struct type

    * .. attribute:: is_pointer

        * ``True``---The type is a pointer type
        * ``False``---The type is not a pointer type

    * .. attribute:: is_array

        * ``True``---The type is an array type
        * ``False``---The type is not an array type

    * .. attribute:: is_vector

        * ``True``---The type is a vector type
        * ``False``---The type is not a vector type

    * .. attribute:: is_function_vararg

        * ``True``--- The function type accepts a variable number of arguments
        * ``False``---The function type accepts a fixed number of arguments

    * .. attribute:: elements

        Returns an iterator over enclosing types. For example,
        the elements of an array or members of a struct.

    * .. attribute:: element_type

        If the type is a pointer, return the pointed-to type. Raises a
        ValueError if the type is not a pointer type.

    * .. attribute:: element_count

        Returns the number of elements in an array or a vector. For scalable
        vectors, returns minimum number of elements. When the type is neither
        an array nor a vector, raises exception.

    * .. attribute:: type_width

        Return the basic size of this type if it is a primitive type. These are
        fixed by LLVM and are not target-dependent.
        This will return zero if the type does not have a size or is not a
        primitive type.

        If this is a scalable vector type, the scalable property will be set and
        the runtime size will be a positive integer multiple of the base size.

        Note that this may not reflect the size of memory allocated for an
        instance of the type or the number of bytes that are written when an
        instance of the type is stored to memory.

    * .. attribute:: type_kind

        Returns the ``LLVMTypeKind`` enumeration of this type.

    * .. method:: as_ir(self, ir_ctx)

        Convert into an ``llvmlite.ir.Type``.

    * .. method:: __str__(self)

        Get the string IR representation of the type.