當前位置: 首頁>>代碼示例>>Python>>正文


Python ctypes.cdll方法代碼示例

本文整理匯總了Python中ctypes.cdll方法的典型用法代碼示例。如果您正苦於以下問題:Python ctypes.cdll方法的具體用法?Python ctypes.cdll怎麽用?Python ctypes.cdll使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ctypes的用法示例。


在下文中一共展示了ctypes.cdll方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: load_library

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def load_library(self, libname):
        try:
            result = LibraryLoader.load_library(self, libname)
        except ImportError:
            result = None
            if os.path.sep not in libname:
                for name in self.name_formats:
                    try:
                        result = getattr(ctypes.cdll, name % libname)
                        if result:
                            break
                    except WindowsError:
                        result = None
            if result is None:
                try:
                    result = getattr(ctypes.cdll, libname)
                except WindowsError:
                    result = None
            if result is None:
                raise ImportError("%s not found." % libname)
        return result 
開發者ID:racepwn,項目名稱:racepwn,代碼行數:23,代碼來源:librace.py

示例2: _copyWindows

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def _copyWindows(text):
    GMEM_DDESHARE = 0x2000
    CF_UNICODETEXT = 13
    d = ctypes.windll # cdll expects 4 more bytes in user32.OpenClipboard(None)
    try:  # Python 2
        if not isinstance(text, unicode):
            text = text.decode('mbcs')
    except NameError:
        if not isinstance(text, str):
            text = text.decode('mbcs')
    d.user32.OpenClipboard(None)
    d.user32.EmptyClipboard()
    hCd = d.kernel32.GlobalAlloc(GMEM_DDESHARE, len(text.encode('utf-16-le')) + 2)
    pchData = d.kernel32.GlobalLock(hCd)
    ctypes.cdll.msvcrt.wcscpy(ctypes.c_wchar_p(pchData), text)
    d.kernel32.GlobalUnlock(hCd)
    d.user32.SetClipboardData(CF_UNICODETEXT, hCd)
    d.user32.CloseClipboard() 
開發者ID:mcgreentn,項目名稱:GDMC,代碼行數:20,代碼來源:pyperclip.py

示例3: _copyCygwin

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def _copyCygwin(text):
    GMEM_DDESHARE = 0x2000
    CF_UNICODETEXT = 13
    d = ctypes.cdll
    try:  # Python 2
        if not isinstance(text, unicode):
            text = text.decode('mbcs')
    except NameError:
        if not isinstance(text, str):
            text = text.decode('mbcs')
    d.user32.OpenClipboard(None)
    d.user32.EmptyClipboard()
    hCd = d.kernel32.GlobalAlloc(GMEM_DDESHARE, len(text.encode('utf-16-le')) + 2)
    pchData = d.kernel32.GlobalLock(hCd)
    ctypes.cdll.msvcrt.wcscpy(ctypes.c_wchar_p(pchData), text)
    d.kernel32.GlobalUnlock(hCd)
    d.user32.SetClipboardData(CF_UNICODETEXT, hCd)
    d.user32.CloseClipboard() 
開發者ID:mcgreentn,項目名稱:GDMC,代碼行數:20,代碼來源:pyperclip.py

示例4: on_parent_exit

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def on_parent_exit(signame):
    """
    Return a function to be run in a child process which will trigger
    SIGNAME to be sent when the parent process dies
    """
    # On Windows, signal() can only be called with SIGABRT, SIGFPE, SIGILL, SIGINT, SIGSEGV, or SIGTERM.
    signum = getattr(signal, signame)  # SIGTERM 15  SIGKILL 9

    def set_parent_exit_signal():
        # Constant taken from http://linux.die.net/include/linux/prctl.h
        PR_SET_PDEATHSIG = 1
        # http://linux.die.net/man/2/prctl
        result = cdll['libc.so.6'].prctl(PR_SET_PDEATHSIG, signum)
        if result != 0:
            raise PrCtlError('prctl failed with error code %s' % result)

    return set_parent_exit_signal


# https://stackoverflow.com/a/19448255/10517783 
開發者ID:my8100,項目名稱:scrapydweb,代碼行數:22,代碼來源:sub_process.py

示例5: _copy_windows

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def _copy_windows(text, clear=0):
    GMEM_DDESHARE = 0x2000
    CF_UNICODETEXT = 13
    d = ctypes.windll  # cdll expects 4 more bytes in user32.OpenClipboard(0)
    if not isinstance(text, unicode):
        text = text.decode('mbcs')

    d.user32.OpenClipboard(0 if is_python2() else None)

    d.user32.EmptyClipboard()
    hCd = d.kernel32.GlobalAlloc(GMEM_DDESHARE, len(text.encode('utf-16-le')) + 2)
    pchData = d.kernel32.GlobalLock(hCd)
    ctypes.cdll.msvcrt.wcscpy(ctypes.c_wchar_p(pchData), text)
    d.kernel32.GlobalUnlock(hCd)
    d.user32.SetClipboardData(CF_UNICODETEXT, hCd)
    d.user32.CloseClipboard() 
開發者ID:marcwebbie,項目名稱:passpie,代碼行數:18,代碼來源:clipboard.py

示例6: statx

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def statx(fileno, path, flags, mask):
    global _libc_statx
    if not _libc_statx:
        _libc_statx = ctypes.cdll[ctypes.util.find_library("c")]["statx"]

    buf = struct_statx()
    r = _libc_statx(ctypes.c_int(fileno),
                    ctypes.c_char_p(path.encode()),
                    ctypes.c_int(flags),
                    ctypes.c_uint(mask),
                    ctypes.byref(buf))

    e = ctypes.get_errno()
    # TODO: how do I make errno actually work and be non-zero
    if r == 0:
        return buf
    else:
        raise OSError(e, "statx failed for %r" % path) 
開發者ID:grawity,項目名稱:code,代碼行數:20,代碼來源:statx.py

示例7: load

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def load(self,path):
        """Given a path to a library, load it."""
        try:
            # Darwin requires dlopen to be called with mode RTLD_GLOBAL instead
            # of the default RTLD_LOCAL.  Without this, you end up with
            # libraries not being loadable, resulting in "Symbol not found"
            # errors
            if sys.platform == 'darwin':
                return ctypes.CDLL(path, ctypes.RTLD_GLOBAL)
            else:
                return ctypes.cdll.LoadLibrary(path)
        except OSError as e:
            raise ImportError(e) 
開發者ID:racepwn,項目名稱:racepwn,代碼行數:15,代碼來源:librace.py

示例8: __init__

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def __init__(self, path):
        self.cdll = ctypes.cdll.LoadLibrary(path)
        self.windll = ctypes.windll.LoadLibrary(path) 
開發者ID:racepwn,項目名稱:racepwn,代碼行數:5,代碼來源:librace.py

示例9: __getattr__

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def __getattr__(self, name):
        try: return getattr(self.cdll,name)
        except AttributeError:
            try: return getattr(self.windll,name)
            except AttributeError:
                raise 
開發者ID:racepwn,項目名稱:racepwn,代碼行數:8,代碼來源:librace.py

示例10: load_library

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def load_library(libname, loader_path):
        if ctypes.__version__ < '1.0.1':
            import warnings
            warnings.warn("All features of ctypes interface may not work " \
                          "with ctypes < 1.0.1")

        ext = os.path.splitext(libname)[1]
        if not ext:
            # Try to load library with platform-specific name, otherwise
            # default to libname.[so|pyd].  Sometimes, these files are built
            # erroneously on non-linux platforms.
            from numpy.distutils.misc_util import get_shared_lib_extension
            so_ext = get_shared_lib_extension()
            libname_ext = [libname + so_ext]
            # mac, windows and linux >= py3.2 shared library and loadable
            # module have different extensions so try both
            so_ext2 = get_shared_lib_extension(is_python_ext=True)
            if not so_ext2 == so_ext:
                libname_ext.insert(0, libname + so_ext2)
        else:
            libname_ext = [libname]

        loader_path = os.path.abspath(loader_path)
        if not os.path.isdir(loader_path):
            libdir = os.path.dirname(loader_path)
        else:
            libdir = loader_path

        for ln in libname_ext:
            libpath = os.path.join(libdir, ln)
            if os.path.exists(libpath):
                try:
                    return ctypes.cdll[libpath]
                except OSError:
                    ## defective lib file
                    raise
        ## if no successful return in the libname_ext loop:
        raise OSError("no file with expected extension") 
開發者ID:ktraunmueller,項目名稱:Computable,代碼行數:40,代碼來源:ctypeslib.py

示例11: load

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def load(self,path):
        """Given a path to a library, load it."""
        try:
            # Darwin requires dlopen to be called with mode RTLD_GLOBAL instead
            # of the default RTLD_LOCAL.  Without this, you end up with
            # libraries not being loadable, resulting in "Symbol not found"
            # errors
            if sys.platform == 'darwin':
                return ctypes.CDLL(path, ctypes.RTLD_GLOBAL)
            else:
                return ctypes.cdll.LoadLibrary(path)
        except OSError,e:
            raise ImportError(e) 
開發者ID:stevegt,項目名稱:librabinpoly,代碼行數:15,代碼來源:rabinpoly.py

示例12: _pasteCygwin

# 需要導入模塊: import ctypes [as 別名]
# 或者: from ctypes import cdll [as 別名]
def _pasteCygwin():
    CF_UNICODETEXT = 13
    d = ctypes.cdll
    d.user32.OpenClipboard(None)
    handle = d.user32.GetClipboardData(CF_UNICODETEXT)
    data = ctypes.c_wchar_p(handle).value
    d.user32.CloseClipboard()
    return data 
開發者ID:mcgreentn,項目名稱:GDMC,代碼行數:10,代碼來源:pyperclip.py


注:本文中的ctypes.cdll方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。