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


Python win32file._get_osfhandle方法代碼示例

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


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

示例1: unlock_and_close

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock_and_close(self):
      """Close and unlock the file using the win32 primitive."""
      if self._locked:
        try:
          hfile = win32file._get_osfhandle(self._fh.fileno())
          win32file.UnlockFileEx(hfile, 0, -0x10000, pywintypes.OVERLAPPED())
        except pywintypes.error as e:
          if e[0] != _Win32Opener.FILE_ALREADY_UNLOCKED_ERROR:
            raise
      self._locked = False
      if self._fh:
        self._fh.close() 
開發者ID:mortcanty,項目名稱:earthengine,代碼行數:14,代碼來源:locked_file.py

示例2: unlock_and_close

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock_and_close(self):
      """Close and unlock the file using the win32 primitive."""
      if self._locked:
        try:
          hfile = win32file._get_osfhandle(self._fh.fileno())
          win32file.UnlockFileEx(hfile, 0, -0x10000, pywintypes.OVERLAPPED())
        except pywintypes.error, e:
          if e[0] != _Win32Opener.FILE_ALREADY_UNLOCKED_ERROR:
            raise 
開發者ID:splunk,項目名稱:splunk-ref-pas-code,代碼行數:11,代碼來源:locked_file.py

示例3: _acquire_lock

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def _acquire_lock(self, for_save=False):
        assert self.__locked_fh is None, 'double lock'

        while True:
            try:
                fd = os.open(self._store,
                             os.O_RDWR | (os.O_CREAT * int(for_save)))
            except FileNotFoundError:
                if not for_save:
                    raise qubes.exc.QubesException(
                        'Qubes XML store {!r} is missing; '
                        'use qubes-create tool'.format(self._store))
                raise

            # While we were waiting for lock, someone could have unlink()ed
            # (or rename()d) our file out of the filesystem. We have to
            # ensure we got lock on something linked to filesystem.
            # If not, try again.
            if os.fstat(fd) != os.stat(self._store):
                os.close(fd)
                continue

            if self.__load_timestamp and \
                    os.path.getmtime(self._store) != self.__load_timestamp:
                os.close(fd)
                raise qubes.exc.QubesException(
                    'Someone else modified qubes.xml in the meantime')

            break

        if os.name == 'posix':
            fcntl.lockf(fd, fcntl.LOCK_EX)
        elif os.name == 'nt':
            # pylint: disable=protected-access
            overlapped = pywintypes.OVERLAPPED()
            win32file.LockFileEx(
                win32file._get_osfhandle(fd),
                win32con.LOCKFILE_EXCLUSIVE_LOCK, 0, -0x10000, overlapped)

        self.__locked_fh = os.fdopen(fd, 'r+b')
        return self.__locked_fh 
開發者ID:QubesOS,項目名稱:qubes-core-admin,代碼行數:43,代碼來源:app.py

示例4: _LockImplWin

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def _LockImplWin(target_file, flags):
  hfile = win32file._get_osfhandle(target_file.fileno())
  try:
    win32file.LockFileEx(hfile, flags, 0, -0x10000, _OVERLAPPED)
  except pywintypes.error, exc_value:
    if exc_value[0] == 33:
      raise LockException('Error trying acquiring lock of %s: %s' %
                          (target_file.name, exc_value[2]))
    else:
      raise 
開發者ID:FSecureLABS,項目名稱:Jandroid,代碼行數:12,代碼來源:lock.py

示例5: _UnlockImplWin

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def _UnlockImplWin(target_file):
  hfile = win32file._get_osfhandle(target_file.fileno())
  try:
    win32file.UnlockFileEx(hfile, 0, -0x10000, _OVERLAPPED)
  except pywintypes.error, exc_value:
    if exc_value[0] == 158:
      # error: (158, 'UnlockFileEx', 'The segment is already unlocked.')
      # To match the 'posix' implementation, silently ignore this error
      pass
    else:
      # Q:  Are there exceptions/codes we should be dealing with here?
      raise 
開發者ID:FSecureLABS,項目名稱:Jandroid,代碼行數:14,代碼來源:lock.py

示例6: unlock_and_close

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock_and_close(self):
        """Close and unlock the file using the win32 primitive."""
        if self._locked:
            try:
                hfile = win32file._get_osfhandle(self._fh.fileno())
                win32file.UnlockFileEx(hfile, 0, -0x10000,
                                       pywintypes.OVERLAPPED())
            except pywintypes.error as e:
                if e[0] != _Win32Opener.FILE_ALREADY_UNLOCKED_ERROR:
                    raise
        self._locked = False
        if self._fh:
            self._fh.close() 
開發者ID:Deltares,項目名稱:aqua-monitor,代碼行數:15,代碼來源:_win32_opener.py

示例7: lock

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def lock(file, flags):
        hfile = win32file._get_osfhandle(_getfd(file))
        try:
            win32file.LockFileEx(hfile, flags, 0, -0x10000, __overlapped)
        except pywintypes.error, exc_value:
            # error: (33, 'LockFileEx', 'The process cannot access the file because another process has locked a portion of the file.')
            if exc_value[0] == 33:
                raise LockException(LockException.LOCK_FAILED, exc_value[2])
            else:
                # Q:  Are there exceptions/codes we should be dealing with here?
                raise 
開發者ID:harryliu,項目名稱:edwin,代碼行數:13,代碼來源:portalocker.py

示例8: unlock

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock(file):
        hfile = win32file._get_osfhandle(_getfd(file))
        try:
            win32file.UnlockFileEx(hfile, 0, -0x10000, __overlapped)
        except pywintypes.error, exc_value:
            if exc_value[0] == 158:
                # error: (158, 'UnlockFileEx', 'The segment is already unlocked.')
                # To match the 'posix' implementation, silently ignore this error
                pass
            else:
                # Q:  Are there exceptions/codes we should be dealing with here?
                raise 
開發者ID:harryliu,項目名稱:edwin,代碼行數:14,代碼來源:portalocker.py

示例9: lock

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def lock(file, flags):
        hfile = win32file._get_osfhandle(fd(file))
        win32file.LockFileEx(hfile, flags, 0, -0x10000, __overlapped) 
開發者ID:blackye,項目名稱:luscan-devel,代碼行數:5,代碼來源:locks.py

示例10: unlock

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock(file):
        hfile = win32file._get_osfhandle(fd(file))
        win32file.UnlockFileEx(hfile, 0, -0x10000, __overlapped) 
開發者ID:blackye,項目名稱:luscan-devel,代碼行數:5,代碼來源:locks.py

示例11: unlock_and_close

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock_and_close(self):
            """Close and unlock the file using the win32 primitive."""
            if self._locked:
                try:
                    hfile = win32file._get_osfhandle(self._fh.fileno())
                    win32file.UnlockFileEx(hfile, 0, -0x10000,
                                           pywintypes.OVERLAPPED())
                except pywintypes.error as e:
                    if e[0] != _Win32Opener.FILE_ALREADY_UNLOCKED_ERROR:
                        raise
            self._locked = False
            if self._fh:
                self._fh.close() 
開發者ID:luci,項目名稱:luci-py,代碼行數:15,代碼來源:locked_file.py

示例12: unlock

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def unlock(file_):
        try:
            savepos = file_.tell()
            if savepos:
                file_.seek(0)

            try:
                msvcrt.locking(file_.fileno(), constants.LOCK_UN, lock_length)
            except IOError as exc_value:
                if exc_value.strerror == 'Permission denied':
                    import pywintypes
                    import win32file
                    import winerror
                    __overlapped = pywintypes.OVERLAPPED()
                    hfile = win32file._get_osfhandle(file_.fileno())
                    try:
                        win32file.UnlockFileEx(
                            hfile, 0, -0x10000, __overlapped)
                    except pywintypes.error as exc_value:
                        if exc_value.winerror == winerror.ERROR_NOT_LOCKED:
                            # error: (158, 'UnlockFileEx',
                            #         'The segment is already unlocked.')
                            # To match the 'posix' implementation, silently
                            # ignore this error
                            pass
                        else:
                            # Q:  Are there exceptions/codes we should be
                            # dealing with here?
                            raise
                else:
                    raise exceptions.LockException(
                        exceptions.LockException.LOCK_FAILED,
                        exc_value.strerror,
                        fh=file_)
            finally:
                if savepos:
                    file_.seek(savepos)
        except IOError as exc_value:
            raise exceptions.LockException(
                exceptions.LockException.LOCK_FAILED, exc_value.strerror,
                fh=file_) 
開發者ID:allegroai,項目名稱:trains,代碼行數:43,代碼來源:portalocker.py

示例13: make_file_sparse

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def make_file_sparse(path, f, length=0):
        supported = get_sparse_files_support(path)
        if not supported:
            return

        handle = win32file._get_osfhandle(f.fileno())
        _sparse_magic(handle, length) 
開發者ID:kenorb-contrib,項目名稱:BitTorrent,代碼行數:9,代碼來源:Storage_base.py

示例14: get_allocated_regions

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def get_allocated_regions(path, f=None, begin=0, length=None):
    supported = get_sparse_files_support(path)
    if not supported:
        return
    if os.name == 'nt':
        if not os.path.exists(path):
            return False
        if f is None:
            f = file(path, 'r')
        handle = win32file._get_osfhandle(f.fileno())
        if length is None:
            length = os.path.getsize(path) - begin
        a = SparseSet()
        run = 128
        i = begin
        end = begin + length
        while i < end:
            d = struct.pack("<QQ", i, length)
            try:
                r = win32file.DeviceIoControl(handle, FSCTL_QUERY_ALLOCATED_RANGES,
                                              d, struct.calcsize("<QQ")*run, None)
            except pywintypes.error, e:
                if e.args[0] == winerror.ERROR_MORE_DATA:
                    run *= 2
                    continue
                # I've also seen:
                # error: (1784, 'DeviceIoControl', 'The supplied user buffer is not valid for the requested operation.')
                return
            if not r:
                break
            for c in xrange(0, len(r), 16):
                qq = struct.unpack("<QQ", r[c:c+16])
                b = qq[0]
                e = b + qq[1]
                a.add(b, e)
                i = max(i, e)

        return a 
開發者ID:kenorb-contrib,項目名稱:BitTorrent,代碼行數:40,代碼來源:platform.py

示例15: __init__

# 需要導入模塊: import win32file [as 別名]
# 或者: from win32file import _get_osfhandle [as 別名]
def __init__(self, handle):
        from twisted.internet import reactor
        self.reactor = reactor
        self.handle = handle
        self.osfhandle = win32file._get_osfhandle(self.handle.fileno())
        self.mode = self.handle.mode
        # CloseHandle automatically calls CancelIo
        self.close = self.handle.close
        self.fileno = self.handle.fileno
        self.read_op = ReadFileOp()
        self.write_op = WriteFileOp()
        self.readbuf = self.reactor.AllocateReadBuffer(self.buffer_size) 
開發者ID:kenorb-contrib,項目名稱:BitTorrent,代碼行數:14,代碼來源:Storage_IOCP.py


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