Glenn Pierce | 3 Mar 09:32 2016
Picon

Passing self though to callbacks

Hi I am having trouble getting self passed through to callbacks.
I know ctypes usually takes care of this but in my case it does not
because the c API I am wrapping requires the function pointers to be
placed into a structure
which then is passed to the function that sets up the connection. I
believe this stops the ctypes self propagation from working.
Is there a way to get it working in this case  ?

An example is below.

The functions I have wrap except a context which is just callback
data. So I have tried passing id through this
like

self.handle = self._Create(C.byref(self.callback_structure),
C.c_void_p(id(self)))

in the callback I cast back like

self = C.cast(context, C.py_object).value

This does not seem to work well though. With one object it is find but
when adding different callback objects of the same style the cast back
sometimes returns the wrong object.
Not sure why though. Neither object gets garbage collected so id
should be valid unique.

I would try to pass a unique int / dict mapping though context but how
can I pass an int through a void*   ?

(Continue reading)

Yang Liu | 22 Feb 08:52 2016
Picon

why sturct size different between C and Python ctypes?

Hi,all

I am using ctypes today and a sturct size is differet in C and Python ctypes code
here is my code

C: 
#include<linux/netlink.h>
#include<linux/inet_diag.h>

int main(int argc, char *argv[])
{
    struct {
        struct nlmsghdr      nlh;
        struct inet_diag_req req;
     } nlreq;
    printf("nlreq: %d\n", sizeof(nlreq));
    return 0;
}

out:
nlreq: 76


Python:
class nlmsghdr(ctypes.Structure):
    _fields_ = [
        ("len", ctypes.c_uint32),
        ("type", ctypes.c_uint16),
        ("flags", ctypes.c_uint16),
        ("seq", ctypes.c_uint32),
        ("pid", ctypes.c_uint32)]

class Inet_diag_sockid(ctypes.Structure):
    _fields_ = [
        ("idiag_sport", ctypes.c_uint16.__ctype_be__),
        ("idiag_dport", ctypes.c_uint16.__ctype_be__),
        ("idiag_src", ctypes.c_uint32.__ctype_be__ * 4),
        ("idiag_dst", ctypes.c_uint32.__ctype_be__ * 4),
        ("idiag_if", ctypes.c_uint32),
        ("idiag_cookie", ctypes.c_uint32 * 2),
    ]

class inet_diag_req(ctypes.Structure):
    _fields_ = [
        ("idiag_family", ctypes.c_uint8),
        ("idiag_src_len", ctypes.c_uint8),
        ("idiag_dst_len", ctypes.c_uint8),
        ("idiag_ext", ctypes.c_uint8),
        ("id", ctypes.POINTER(Inet_diag_sockid)),
        ("idiag_states", ctypes.c_uint32),
        ("idiag_dbs", ctypes.c_uint32)
    ]

class nlmsg(ctypes.Structure):
    _fields_ = [
        ("nlh", nlmsghdr),
        ("req", Inet_diag_req)
    ]

print ctypes.sizeof(nlmsg)

out: 
24


why the same struct size is 76 inC and 24 in ctypes ?

Thanks
------------------------------------------------------------------------------
Site24x7 APM Insight: Get Deep Visibility into Application Performance
APM + Mobile APM + RUM: Monitor 3 App instances at just $35/Month
Monitor end-to-end web transactions and take corrective actions now
Troubleshoot faster and improve end-user experience. Signup Now!
http://pubads.g.doubleclick.net/gampad/clk?id=272487151&iu=/4140
_______________________________________________
ctypes-users mailing list
ctypes-users <at> lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ctypes-users
Carlos Pita | 6 Feb 15:25 2016
Picon
Gravatar

Structure inheritance and tail padding

Hi all,

just from observation I arrived to the unconfirmed conclusion that
Structure inheritance adds tail padding. For example:

class A(Structure):
  _fields_ = [('a', c_double), ('b', c_char)]

class B(A):
  _fields_ = [('c', c_int)]

will not show the same layout than:

class C(Structure):
  _fields_ = [('a', c_double), ('b', c_char), ('c', c_int)]

Supposing my conclusion is right, what is the intention of this feature:

i. To support c++ pod subclassing? (most compilers reuse the tail
padding for non-pod subclassing).

ii. To support a more oo view of c struct composition? (btw, it
complements the ms-extensions very well).

Thank you in advance
--
Carlos

------------------------------------------------------------------------------
Site24x7 APM Insight: Get Deep Visibility into Application Performance
APM + Mobile APM + RUM: Monitor 3 App instances at just $35/Month
Monitor end-to-end web transactions and take corrective actions now
Troubleshoot faster and improve end-user experience. Signup Now!
http://pubads.g.doubleclick.net/gampad/clk?id=272487151&iu=/4140
Carlos Pita | 26 Jan 03:37 2016
Picon
Gravatar

resize content, not type

Hi all,

for the resize function the ctypes tutorial states:

> Another way to use variable-sized data types with ctypes is to use the dynamic
> nature of Python, and (re-)define the data type after the required size is already
> known, on a case by case basis.

What does this mean? I tried monkey-patching the __class__ attribute,
also changing the _length_ attribute, but to no avail. This is not
surprising as the relevant length attribute is part of the C-side
object state, which doesn't seem to be exposed to the python API and
won't change just because I changed the type after construction.

Another option is to resize and then create a new array from_address,
but it won't own the memory so it's a problematic approach.

Cheers
--
Carlos

------------------------------------------------------------------------------
Site24x7 APM Insight: Get Deep Visibility into Application Performance
APM + Mobile APM + RUM: Monitor 3 App instances at just $35/Month
Monitor end-to-end web transactions and take corrective actions now
Troubleshoot faster and improve end-user experience. Signup Now!
http://pubads.g.doubleclick.net/gampad/clk?id=267308311&iu=/4140
Andrew Robert Whalley | 21 Dec 13:48 2015
Picon

Library Import

Hi All,

I would like to use Python / ctypes to test a C library that contains 
some dependencies. Is it possible to satisfy those dependencies from 
within the Python interpreter, by using ctypes to define callables 
(similar to the callback function mechanism)? Or do any dependencies 
have to be defined in other, loadable, libraries?

Regards,

Rob Whalley

------------------------------------------------------------------------------
Cristian Badescu | 28 Oct 13:31 2015
Picon

NtQuerySystemInformation

Hello,

I am trying to get handles information by using NtQuerySystemInformation but my code fails for some reason. I am using the following code to call NtQuerySystemInformation:

from ctypes import *
from ctypes.util import *

class SYSTEM_HANDLE(Structure):

_fields_ = [("ProcessId", c_ulong),
("ObjetTypeNumber", c_byte),
("Flags", c_byte),
("Handle", c_ushort),
("Object", c_void_p ),
("GrantedAccess", c_ulong)
]

class SYSTEM_HANDLE_INFORMATION(Structure):

_fields_ = [("HandleCount", c_ulong),
("Handles", SYSTEM_HANDLE * 1)
]

handleInfoSize = 65536

SystemHandleInformation = 16

c_lib=CDLL(find_library("c"))
malloc=c_lib.malloc
malloc.restype=c_void_p
handleInfo = malloc(handleInfoSize)

pHandleInfo = cast(handleInfo, POINTER(SYSTEM_HANDLE_INFORMATION))

retVal = cdll.ntdll.NtQuerySystemInformation(SystemHandleInformation, pHandleInfo, handleInfoSize, None)
------------------------------------------------------------------------------
_______________________________________________
ctypes-users mailing list
ctypes-users <at> lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ctypes-users
TuX RaceR | 19 Aug 22:18 2015
Picon

Python ctypes program works on 3.2 but fails on 3.4

Hello List

I suspect a bug in ctypes;
I asked the question below on stackoverflow:
http://stackoverflow.com/questions/32100067/python-ctypes-program-works-on-3-2-but-incompatiable-on-3-4

Any idea of why the same code would fail (return a blank string) on 3.4?

Thanks
TR

------------------------------------------------------------------------------
Jan Wagner | 13 Aug 07:19 2015

contribute ctypeslib patch?

Hi list, it seems this project is quite dead and I'm not sure how to contribute a feature fix (not even to https://pypi.python.org/pypi/ctypeslib/). Perhaps someone on the list is able to do it? There is an issue in ctypeslib codegenerator.py that affects xml2py.py option "-r" for which usage says that "-r EXPRESSION regular expression for symbols to include". The expression is actually never evaluated as a regular expression. Only exact name matches are selected. The below patch changes the behaviour to be consistent with the usage instructions (and makes -r behaviour more useful). cheers, Jan --- /usr/lib/pymodules/python2.5/ctypeslib/codegen/codegenerator.py 2009-01-17 03:50:18.000000000 +0900 +++ codegenerator.py 2015-04-08 18:34:06.000000000 +0900 <at> <at> -859,6 +859,12 <at> <at> if match and match.group() == i.name: todo.append(i) break + # above selects only *exact* matches, now include partial/regexp name matches: + match = s.search(i.name) + if match: + todo.append(i) + break + if symbols or expressions: items = todo
------------------------------------------------------------------------------
_______________________________________________
ctypes-users mailing list
ctypes-users <at> lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ctypes-users
Timothy W. Grove | 19 Mar 17:11 2015

Calling Objective C functions with ctypes

I have been trying to get the following code copied from another forum to work on my system (OSX 10.6, 10.8, Python 3.3 installed via MacPorts), and it just won't. It seems to be finding the 'AppKit' and 'objc' libraries okay, but it is not getting the classes 'NSSpeechSynthesizer' or 'NSAutoreleasePool', so 'count' ends up as '0' and everything falls over from there.

I did notice from the "print voiceNames" statement that this code must be pre-python 3, so are there any obvious changes needed to bring this up to date? Thanks for any help or suggestions.

Best regards,
Tim Grove
[from http://stackoverflow.com/questions/1490039/calling-objective-c-functions-from-python/1490644#1490644]
import ctypes
import ctypes.util

# Need to do this to load the NSSpeechSynthesizer class, which is in AppKit.framework
appkit = ctypes.cdll.LoadLibrary(ctypes.util.find_library('AppKit'))
objc = ctypes.cdll.LoadLibrary(ctypes.util.find_library('objc'))

objc.objc_getClass.restype = ctypes.c_void_p
objc.sel_registerName.restype = ctypes.c_void_p
objc.objc_msgSend.restype = ctypes.c_void_p
objc.objc_msgSend.argtypes = [ctypes.c_void_p, ctypes.c_void_p]

# Without this, it will still work, but it'll leak memory
NSAutoreleasePool = objc.objc_getClass('NSAutoreleasePool')
pool = objc.objc_msgSend(NSAutoreleasePool, objc.sel_registerName('alloc'))
pool = objc.objc_msgSend(pool, objc.sel_registerName('init'))

NSSpeechSynthesizer = objc.objc_getClass('NSSpeechSynthesizer')
availableVoices = objc.objc_msgSend(NSSpeechSynthesizer, objc.sel_registerName('availableVoices'))

count = objc.objc_msgSend(availableVoices, objc.sel_registerName('count'))
voiceNames = [
  ctypes.string_at(
    objc.objc_msgSend(
      objc.objc_msgSend(availableVoices, objc.sel_registerName('objectAtIndex:'), i),
      objc.sel_registerName('UTF8String')))
  for i in range(count)]
print voiceNames

objc.objc_msgSend(pool, objc.sel_registerName('release'))
------------------------------------------------------------------------------
Dive into the World of Parallel Programming The Go Parallel Website, sponsored
by Intel and developed in partnership with Slashdot Media, is your hub for all
things parallel software development, from weekly thought leadership blogs to
news, videos, case studies, tutorials and more. Take a look and join the 
conversation now. http://goparallel.sourceforge.net/
_______________________________________________
ctypes-users mailing list
ctypes-users <at> lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ctypes-users
狂禅 | 11 Mar 03:49 2015

who can tell me the difference in ctypes.sizeof between Ironpython and python in using ctypes to create structure?

recently i meet a problem in using Ironpython.
    import ctypes as ct
   
    class Data(ct.LittleEndianStructure):         
        _pack_      = 2
        _fields_    = [
           
            ('a',ct.c_ubyte),
            ('b',ct.c_ubyte),
            ('c',ct.c_ubyte),
            ('d',ct.c_ushort),
            ('e',ct.c_uint),
            ('f',ct.c_ubyte),            
        ]
    if __name__ == "__main__":
        a = Data()
        print ct.sizeof(a)
as is show above.when i used this script running in python ,it prints 12.
but when running in Ironpython ,it is 14.
in fact ,i tried it in c like that:

    #include<stdio.h>
    void main()
    {
    #pragma pack(2)
 struct{
  unsigned char a;
  unsigned char b;
  unsigned char c;
  unsigned short d;
  unsigned int e;
  unsigned char f;
 }A;
    #pragma pack()
 printf("%d\n",sizeof(A));
    }
it is 12.

can you tell me why it is and how i can crrect it in Ironpython???
------------------------------------------------------------------------------
Dive into the World of Parallel Programming The Go Parallel Website, sponsored
by Intel and developed in partnership with Slashdot Media, is your hub for all
things parallel software development, from weekly thought leadership blogs to
news, videos, case studies, tutorials and more. Take a look and join the 
conversation now. http://goparallel.sourceforge.net/
_______________________________________________
ctypes-users mailing list
ctypes-users <at> lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ctypes-users
West, Peter | 30 Dec 18:15 2014
Picon
Picon

Data_as

Hi

I need to pass a DLL a pointer to an array of pointers to c arrays of unsigned 16 bit integers.

I started to do this using data_as(POINTER( type ) on sub-arrays.  This caused access violations. When I
looked at what was in the pointer arrays I discovered that they all pointed to the same location.  After
poking around a bit is seems that the problem is not to do with using sub-arrays as I expected but with the way
in which I have approached the problem and I can't see what I'm doing wrong.  Here is a very simple example

from ctypes import POINTER, c_uint16
import numpy as  np

if __name__ == '__main__':

   pointerArrayType = POINTER( c_uint16 ) * 2      # an array of pointers type length 2
   pointers = pointerArrayType()                           # the actual array

   frame1 = np.zeros(( 100, 100 ), dtype = np.uint16, order = 'C' )   # Ensure C contiguous layout
   frame2 = np.zeros(( 100, 100 ), dtype = np.uint16, order = 'C' )

   pointers[ 0 ] = frame1.ctypes.data_as( POINTER( c_uint16 ))
   pointers[ 1 ] = frame2.ctypes.data_as( POINTER( c_uint16 ))

   print pointers[ 0 ]
   print pointers[ 1 ]

This prints 
<__main__.LP_c_ushort object at 0x00000000025132C8>
<__main__.LP_c_ushort object at 0x00000000025132C8>

This suggests that the data arrays for frame1 and frame2 are at the same location.  Clearly I've done
something wrong but can't see what.  

Any help would be gratefully received.
------------------------------------------------------------------------------
Dive into the World of Parallel Programming! The Go Parallel Website,
sponsored by Intel and developed in partnership with Slashdot Media, is your
hub for all things parallel software development, from weekly thought
leadership blogs to news, videos, case studies, tutorials and more. Take a
look and join the conversation now. http://goparallel.sourceforge.net

Gmane