亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? zipfile.vb

?? ZIP things into smaller pakage
?? VB
字號:
 '-----------------------------------------------------------------------
'  This file is part of the Microsoft .NET SDK Code Samples.
' 
'  Copyright (C) Microsoft Corporation.  All rights reserved.
' 
'This source code is intended only as a supplement to Microsoft
'Development Tools and/or on-line documentation.  See these other
'materials for detailed information regarding Microsoft code samples.
' 
'THIS CODE AND INFORMATION ARE PROVIDED AS IS WITHOUT WARRANTY OF ANY
'KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
'IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
'PARTICULAR PURPOSE.
'-----------------------------------------------------------------------
Imports System
Imports System.Collections.Generic
Imports System.IO


'/ <summary>
'/ This class represents a Zip archive.  You can ask for the contained
'/ entries, or get an uncompressed file for a file entry.  
'/ </summary>

Public Class ZipFile
    Private zipEntries As List(Of ZipEntry)
    Private thisReader As ZipReader
    Private thisWriter As ZipWriter
    
    Private baseStream As Stream ' Stream to which the writer writes 
    ' both header and data, the reader
    ' reads this
    Private zipName As String
    
    
    '/ <summary>
    '/ Created a new Zip file with the given name.
    '/ </summary>
    '/ <param name="method"> Gzip or deflate</param>
    '/ <param name="name"> Zip name</param>
    Public Sub New(ByVal name As String, ByVal method As Byte, ByVal mode As FileMode) 
        Try
            zipName = name
            
            baseStream = New FileStream(zipName, mode)
            thisWriter = New ZipWriter(baseStream)
            thisWriter.Method = method
            
            'New File
            thisWriter.WriteSuperHeader(0, method)
            
            Dim index1 As Integer = zipName.IndexOf(ZipConstants.Dot)
            Dim index2 As Integer = zipName.LastIndexOf(ZipConstants.BackSlash)
            thisReader = New ZipReader(baseStream, zipName.Substring(index2, index1 - index2))
            
            zipEntries = thisReader.GetAllEntries()
            CompressionForm.statusMessage = String.Format(System.Threading.Thread.CurrentThread.CurrentUICulture, ZipConstants.NewMessage, name)
        Catch ex As IOException
            ZipConstants.ShowError(ZipConstants.IOError)
        End Try

    End Sub 'New


    '/ <summary>
    '/ Opens a Zip file with the given name.
    '/ </summary>
    '/ <param name="name"> Zip name</param>
    Public Sub New(ByVal name As String)
        Try
            zipName = name
            baseStream = New FileStream(zipName, FileMode.Open)
            thisWriter = New ZipWriter(baseStream)

            Dim index1 As Integer = zipName.IndexOf(ZipConstants.Dot)
            Dim index2 As Integer = zipName.LastIndexOf(ZipConstants.BackSlash)
            thisReader = New ZipReader(baseStream, zipName.Substring(index2, index1 - index2))

            zipEntries = thisReader.GetAllEntries()
            thisWriter.Method = thisReader.Method
            If CompressionForm.statusMessage = Nothing Or CompressionForm.statusMessage <> String.Empty Then
                CompressionForm.statusMessage = String.Format(System.Threading.Thread.CurrentThread.CurrentUICulture, ZipConstants.OpenMessage, name)
            End If
        Catch ex As IOException
            ZipConstants.ShowError("Error opening the file")
        Catch ex As ArgumentOutOfRangeException
            ZipConstants.ShowError(ZipConstants.CorruptedError)
        End Try

    End Sub 'New



    '/ <summary>
    '/ Gets offset to which the jump should be made by summing up 
    '/ all the individual lengths.
    '/ </summary>
    '/ <returns>
    '/ the offset from SeekOrigin.Begin
    '/ </returns>
    Private Function GetOffset(ByVal index As Integer) As Long
        If index > zipEntries.Count Then
            Return -1
        End If
        Dim jump As Integer = ZipConstants.SuperHeaderSize
        Dim i As Integer

        i = 0
        While i < index - 1
            Dim entry As ZipEntry = zipEntries(i)
            jump += ZipConstants.FixedHeaderSize + entry.NameLength + entry.CompressedSize
            i += 1
        End While
        Return jump

    End Function 'GetOffset


    Public Sub Add(ByVal fileName As String)
        Dim ci As System.Globalization.CultureInfo = System.Threading.Thread.CurrentThread.CurrentUICulture
        If fileName.ToLower(ci).Equals(zipName.ToLower(ci)) Then
            ZipConstants.ShowError("Cannot add the current xip file")
            CompressionForm.statusMessage = String.Empty
            Return
        End If
        Dim entry As New ZipEntry(fileName)
        thisWriter.Add(entry)

        If CompressionForm.statusMessage.Length <> 0 Then
            zipEntries.Add(entry)
            thisWriter.CloseHeaders(CType(zipEntries.Count, Int16))
        End If

    End Sub 'Add


    Public Sub Extract(ByVal index As Integer, ByVal path As String)

        If index < 0 OrElse index >= zipEntries.Count Then
            ZipConstants.ShowError("Argument out of range" + "exception")
            Return
        End If
        thisReader.Extract(zipEntries(index), GetOffset((index + 1)), path)

    End Sub 'Extract


    Public Sub ExtractAll(ByVal path As String)
        thisReader.ExtractAll(zipEntries, path)

    End Sub 'ExtractAll


    '/ <summary>
    '/ Closes the ZipFile.  This also closes all input streams given by
    '/ this class.  After this is called, no further method should be
    '/ called.
    '/ </summary>
    Public Sub Close()
        If Not (baseStream Is Nothing) Then
            baseStream.Close()
        End If

    End Sub 'Close 
    '/ <summary>
    '/ Gets the entries of compressed files.
    '/ </summary>
    '/ <returns>
    '/ Collection of ZipEntries
    '/ </returns>
    Public ReadOnly Property Entries() As List(Of ZipEntry)
        Get
            Return zipEntries
        End Get
    End Property


    Public Function CompressionMethod() As Byte
        Return thisWriter.Method

    End Function 'CompressionMethod


    Public Function CheckFileExists(ByVal fileName As String) As Integer
        Dim ci As System.Globalization.CultureInfo = System.Threading.Thread.CurrentThread.CurrentUICulture
        Dim i As Integer = -1
        Dim eachEntry As ZipEntry
        For Each eachEntry In zipEntries
            i += 1
            If eachEntry.Name.ToLower(ci).Equals(fileName.ToLower(ci)) Then
                Return i
            End If
        Next eachEntry
        Return -1

    End Function 'CheckFileExists


    '/ <summary>
    '/ Remove an entry from the archive
    '/ </summary>
    '/ <param name="index">
    '/ The index of the entry that is to be removed
    '/ </param>
    Private Sub DeleteEntryFromFile(ByVal index As Integer)
        Dim jump As Long = ZipConstants.SuperHeaderSize
        Dim i As Integer

        While i < index
            jump += ZipConstants.FixedHeaderSize + zipEntries(i).NameLength + zipEntries(i).CompressedSize
            i += 1
        End While
        Dim entry As ZipEntry = zipEntries(index)
        Dim fileJump As Long = ZipConstants.FixedHeaderSize + entry.NameLength + entry.CompressedSize
        baseStream.Seek(jump + fileJump, SeekOrigin.Begin)
        Dim length As Long = baseStream.Length - fileJump - jump
        Dim b(length) As Byte
        baseStream.Read(b, 0, CType(length, Integer))
        baseStream.Seek(jump, SeekOrigin.Begin)
        baseStream.Write(b, 0, CType(length, Integer))
        baseStream.SetLength(baseStream.Length - fileJump)
        CompressionForm.statusMessage = "Removed successfully"

    End Sub 'DeleteEntryFromFile


    '/ <summary>
    '/ Remove an entry from the archive
    '/ </summary>
    '/ <param name="index">
    '/ The index of the entry that is to be removed
    '/ </param>
    Public Sub Remove(ByVal index As Integer)
        Dim jump As Long = ZipConstants.SuperHeaderSize
        Dim i As Integer

        While i < index
            jump += ZipConstants.FixedHeaderSize + zipEntries(i).NameLength + zipEntries(i).CompressedSize
            i += 1
        End While
        thisWriter.Remove(jump, zipEntries(index))
        zipEntries.RemoveAt(index)
        If CompressionForm.statusMessage.Length <> 0 Then
            thisWriter.CloseHeaders(CType(zipEntries.Count, Int16))
        End If

    End Sub 'Remove
End Class 'ZipFile 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久久久久久久久夜| 亚洲视频在线一区二区| 99视频一区二区| 国产精品一区二区久久精品爱涩 | 91社区在线播放| 成人激情开心网| 处破女av一区二区| 不卡在线视频中文字幕| 欧美一区二区三区视频在线观看 | 亚洲视频中文字幕| 精品一区二区久久久| 国内精品伊人久久久久av影院| 久久66热re国产| 欧美日本高清视频在线观看| 9191成人精品久久| 精品电影一区二区| 国产午夜精品理论片a级大结局| 国产精品入口麻豆原神| 亚洲三级视频在线观看| 国产福利精品一区| 91老师片黄在线观看| 国产亚洲精久久久久久| 国产在线精品不卡| 99视频精品免费视频| 欧美激情在线观看视频免费| 一区二区三区在线观看国产| 午夜av一区二区| 国产成人高清在线| 久久一区二区视频| 一区二区三区精品久久久| www.久久久久久久久| 国产精品乱人伦| 99久久久久久99| 91精品国产乱| 蜜桃久久精品一区二区| 99久久精品久久久久久清纯| 国产精品久久久久久久久免费樱桃| 天天影视色香欲综合网老头| 欧美色精品天天在线观看视频| 欧美一二三区精品| 中文字幕日韩一区| 久久69国产一区二区蜜臀| 26uuu亚洲| 丁香婷婷综合色啪| 欧美成人一区二区三区片免费| 一区二区三区在线观看动漫 | 丁香亚洲综合激情啪啪综合| 国产偷国产偷亚洲高清人白洁| 成人av在线一区二区三区| 亚洲免费在线视频| 成人小视频免费观看| 17c精品麻豆一区二区免费| 91黄色在线观看| 久久久国产精品不卡| 成人免费毛片高清视频| 亚洲欧美电影一区二区| 欧美日韩另类一区| 另类专区欧美蜜桃臀第一页| 欧美性大战久久| 亚洲免费观看高清完整版在线观看| 在线国产亚洲欧美| 樱桃国产成人精品视频| 波多野洁衣一区| 亚洲成人免费电影| 在线观看av不卡| 国产自产v一区二区三区c| 国产精品久久久久aaaa樱花| 欧美日本一区二区三区四区| 看电影不卡的网站| 亚洲日本va午夜在线影院| 欧美欧美欧美欧美首页| 成人综合婷婷国产精品久久| 亚洲一区在线视频| 色噜噜狠狠一区二区三区果冻| 日韩二区三区四区| 日韩一卡二卡三卡| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 欧美伊人久久久久久午夜久久久久| 视频一区在线播放| 91精品国产乱| 色婷婷亚洲综合| 亚洲午夜精品一区二区三区他趣| 91国偷自产一区二区使用方法| 蜜臀国产一区二区三区在线播放| 国产精品国产三级国产aⅴ中文| 欧美一区二区三区播放老司机| av亚洲精华国产精华精| 国产在线精品视频| 午夜精品一区在线观看| 亚洲欧洲www| 久久精品一区八戒影视| 欧美一区二区三区视频免费| 欧美伊人久久久久久久久影院 | 中文字幕在线不卡| 精品99999| 制服丝袜亚洲播放| 欧美性xxxxxxxx| 色综合天天在线| 亚洲国产综合91精品麻豆| 国产精品久久久久影院| 国产亚洲精品资源在线26u| 3d成人h动漫网站入口| 99国产精品国产精品毛片| 丁香桃色午夜亚洲一区二区三区| 另类欧美日韩国产在线| 午夜精品久久久久| 性感美女极品91精品| 亚洲一级在线观看| 亚洲国产一区视频| 亚洲一区二区三区美女| 一区二区三区不卡视频在线观看 | 五月婷婷另类国产| 亚洲永久精品国产| 亚洲韩国一区二区三区| 亚洲综合一区二区| 亚洲午夜一区二区| 婷婷国产v国产偷v亚洲高清| 视频一区二区三区在线| 日日欢夜夜爽一区| 久久精品国产亚洲a| 久久99最新地址| 国产成人精品一区二| av一区二区三区黑人| 91久久精品一区二区三区| 欧美专区日韩专区| 欧美一区二区三区人| 26uuu精品一区二区在线观看| 久久久影院官网| 国产精品成人免费| 洋洋成人永久网站入口| 日韩成人免费电影| 国产精品一区免费视频| 91免费在线看| 91精品国产综合久久久久久久 | 国产精品视频麻豆| 亚洲精品乱码久久久久久日本蜜臀| 一二三四区精品视频| 六月丁香婷婷色狠狠久久| 国产成人亚洲精品狼色在线| 97久久精品人人做人人爽50路| 色噜噜夜夜夜综合网| 337p亚洲精品色噜噜噜| 久久香蕉国产线看观看99| 亚洲欧洲日本在线| 日本欧美肥老太交大片| 国产成人啪免费观看软件| 在线影院国内精品| 2021久久国产精品不只是精品| 国产精品美女久久久久久久网站| 亚洲午夜一区二区| 国产一区二区在线观看视频| 91蜜桃婷婷狠狠久久综合9色| 欧美日韩国产中文| 中文字幕国产一区二区| 午夜欧美在线一二页| 国产91精品免费| 欧美日本精品一区二区三区| 国产亚洲成av人在线观看导航 | 久久99久久久久| 色欧美片视频在线观看在线视频| 日韩欧美国产一区二区在线播放 | 丝袜亚洲另类欧美综合| 大胆亚洲人体视频| 欧美日韩国产一级片| 国产精品久久久久久久浪潮网站 | 亚洲一区二区三区在线| 国产福利一区在线| 91精品蜜臀在线一区尤物| 亚洲人成在线播放网站岛国 | 欧美韩国一区二区| 日韩有码一区二区三区| 91同城在线观看| 久久综合九色综合久久久精品综合| 亚洲一区二区三区在线播放| 成人免费视频国产在线观看| 日韩精品最新网址| 日韩影视精彩在线| 欧美三级电影在线观看| 亚洲人成网站影音先锋播放| 国产精品亚洲一区二区三区妖精| 欧美精品xxxxbbbb| 精品国产乱码久久久久久图片| 亚洲资源在线观看| 99久久亚洲一区二区三区青草| 久久久不卡影院| 国产在线视频一区二区三区| 欧美一二区视频| 日韩av电影一区| 69av一区二区三区| 天堂av在线一区| 5月丁香婷婷综合| 婷婷国产在线综合| 欧美酷刑日本凌虐凌虐| 午夜欧美电影在线观看| 欧美网站一区二区| 亚洲小说欧美激情另类| 欧美日韩黄色影视| 丝袜亚洲精品中文字幕一区| 制服丝袜成人动漫| 日本不卡一区二区|