forked from I2P_Developers/i2p.i2p

Mac OS X launcher: * UI built on Swift * Why? * Apple seems to on purpose make it harder to get into Objective-C these days * Swift is compiled to native code, but has easiness of Javascript in programming * Perfect for the OS X UI, many guides & tutorials as well * "Backend" in Objective-C++ / C++14 * Why? * Originally written in Objective-C / C++14 with C++17 backports * Only for backend because of the time the development takes * Short summary of features: * Java * It can detect java from: * JAVA_HOME environment variable * "Internet Plug-Ins" Apple stuff * By the /usr/libexec/java_home binary helper * It can unpack a new version of I2P * Unpacks to ~/Library/I2P * Can check currently unpacked version in ~/Library/I2P via i2p.jar's "net.i2p.CoreVersion" * User Interface (a popover, see https://youtu.be/k8L3lQ5rUq0 for example of this concept) * Router control tab view * It can start the router * It can stop the router * It can detect already running router, then avoid fireing up one * It can show basic information about the router state & version * Log view tab (not yet done) * While left-click triggers popover, right-click draws a minimal context menu
64 lines
1.7 KiB
Swift
64 lines
1.7 KiB
Swift
//
|
|
// ExecutionResult.swift
|
|
// I2PLauncher
|
|
//
|
|
// Created by Mikal Villa on 17/09/2018.
|
|
// Copyright © 2018 The I2P Project. All rights reserved.
|
|
//
|
|
|
|
import Foundation
|
|
|
|
public struct ExecutionResult {
|
|
|
|
/// Whether the output was captured
|
|
public let didCaptureOutput : Bool
|
|
|
|
/// The return status of the last subprocess
|
|
public var status: Int32 {
|
|
return pipelineStatuses.last!
|
|
}
|
|
|
|
/// Return status of all subprocesses in the pipeline
|
|
public let pipelineStatuses : [Int32]
|
|
|
|
/// The output of the subprocess. Empty string if no output was produced or not captured
|
|
public let output: String
|
|
|
|
/// The error output of the last subprocess. Empty string if no error output was produced or not captured
|
|
public var errors : String {
|
|
return pipelineErrors?.last ?? ""
|
|
}
|
|
|
|
/// The error output of all subprocesses in the pipeline. Empty string if no error output was produced or not captured
|
|
public let pipelineErrors : [String]?
|
|
|
|
/// The output, split by newline
|
|
/// - SeeAlso: `output`
|
|
public var outputLines : [String] {
|
|
return self.output.splitByNewline()
|
|
}
|
|
|
|
/// The error output, split by newline
|
|
/// - SeeAlso: `output`
|
|
public var errorsLines : [String] {
|
|
return self.errors.splitByNewline()
|
|
}
|
|
|
|
/// An execution result where no output was captured
|
|
init(pipelineStatuses: [Int32]) {
|
|
self.pipelineStatuses = pipelineStatuses
|
|
self.didCaptureOutput = false
|
|
self.pipelineErrors = nil
|
|
self.output = ""
|
|
}
|
|
|
|
/// An execution result where output was captured
|
|
init(pipelineStatuses: [Int32], pipelineErrors : [String], output : String) {
|
|
self.pipelineStatuses = pipelineStatuses
|
|
self.pipelineErrors = pipelineErrors
|
|
self.output = output
|
|
self.didCaptureOutput = true
|
|
}
|
|
}
|
|
|