From dee3cecfe564f9f647d68eb9dd942327ca636070 Mon Sep 17 00:00:00 2001 From: Francesco Paolo Severino Date: Tue, 10 Sep 2024 09:06:03 +0200 Subject: [PATCH] Try removing permission on Windows --- Sources/Zip/Zip.swift | 26 +++----------------------- Tests/ZipTests/ZipTests.swift | 1 - 2 files changed, 3 insertions(+), 24 deletions(-) diff --git a/Sources/Zip/Zip.swift b/Sources/Zip/Zip.swift index 484000e1..d65184a3 100644 --- a/Sources/Zip/Zip.swift +++ b/Sources/Zip/Zip.swift @@ -8,9 +8,6 @@ import Foundation @_implementationOnly import CMinizip -#if os(Windows) -import WinSDK -#endif /// Main class that handles zipping and unzipping of files. public class Zip { @@ -165,28 +162,11 @@ public class Zip { throw ZipError.unzipFail } + // TODO: Set permissions properly on Windows + #if !os(Windows) // Set file permissions from current `fileInfo` if fileInfo.external_fa != 0 { let permissions = (fileInfo.external_fa >> 16) & 0x1FF - // TODO: Set permissions properly on Windows - #if os(Windows) - // Convert POSIX permissions to Windows attributes - var attributes: UInt32 = 0 - if permissions & 0o400 != 0 { // Owner read - attributes |= UInt32(FILE_ATTRIBUTE_READONLY) - } - if permissions & 0o200 != 0 { // Owner write - attributes &= ~UInt32(FILE_ATTRIBUTE_READONLY) - } - if permissions & 0o100 != 0 { // Owner execute - // Windows does not have a direct equivalent for execute permissions - // You might need to handle this separately if required - } - // Set the file attributes on Windows - if !SetFileAttributesW(fullPath.utf16.map { WCHAR($0) } + [0], attributes) { - print("Failed to set permissions to file \(fullPath), error: \(GetLastError())") - } - #else // We will define a valid permission range between Owner read only to full access if permissions >= 0o400 && permissions <= 0o777 { do { @@ -195,8 +175,8 @@ public class Zip { print("Failed to set permissions to file \(fullPath), error: \(error)") } } - #endif } + #endif ret = unzGoToNextFile(zip) diff --git a/Tests/ZipTests/ZipTests.swift b/Tests/ZipTests/ZipTests.swift index 13546116..579971da 100644 --- a/Tests/ZipTests/ZipTests.swift +++ b/Tests/ZipTests/ZipTests.swift @@ -335,7 +335,6 @@ final class ZipTests: XCTestCase { } // Tests if https://github.com/vapor-community/Zip/issues/4 does not occur anymore. - // TODO: Fix on Windows func testRoundTripping() throws { // "prod-apple-swift-metrics-main-e6a00d36.zip" is the original zip file from the issue. let zipFilePath = url(forResource: "prod-apple-swift-metrics-main-e6a00d36", withExtension: "zip")!