File: InitOptions.swift

package info (click to toggle)
swiftlang 6.1.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,791,532 kB
  • sloc: cpp: 9,901,743; ansic: 2,201,431; asm: 1,091,827; python: 308,252; objc: 82,166; f90: 80,126; lisp: 38,358; pascal: 25,559; sh: 20,429; ml: 5,058; perl: 4,745; makefile: 4,484; awk: 3,535; javascript: 3,018; xml: 918; fortran: 664; cs: 573; ruby: 396
file content (69 lines) | stat: -rw-r--r-- 2,455 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2024 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import ArgumentParser
import Foundation

/// Resolves and validates the arguments needed to run the init catalog actions.
///
/// These options are used by the ``Docc/Init`` subcommand.

public struct InitOptions: ParsableArguments {
    
    public init() { }
    
    /// The catalog directory name.
    @Option(
        name: .long,
        help: ArgumentHelp(
            "Name to use as the catalog directory name",
            valueName: "name"
        )
    )
    public var name: String
    
    /// A user-provided location where the init action writes the generated catalog documentation.
    @Option(
        name: [.customLong("output-dir"), .customShort("o")],
        help: ArgumentHelp(
            "The location where the documention catalog will be written",
            valueName: "output-dir"
        ),
        transform: URL.init(fileURLWithPath:)
    )
    public var providedCatalogOutputDirURL: URL
    
    public func validate() throws {
        // Verify that the directory exist for the output location.
        var isDirectory: ObjCBool = false
        guard FileManager.default.fileExists(atPath: providedCatalogOutputDirURL.path, isDirectory: &isDirectory), isDirectory.boolValue else {
            throw ValidationError("No directory exists at '\(providedCatalogOutputDirURL.path)'.")
        }
    }
    
    /// The catalog template to initialize.
    @Option(
        name: .customLong("template"),
        help: ArgumentHelp(
            "The catalog template to initialize.",
            discussion: """
            The provided templates are:
            
            - articleOnly: This template contains the minimal needed for creating article-only reference documentation not tied to symbols. It includes a catalog with just one markdown file and a references folder.
            
            - tutorial: This template contains the necessary structure and directives to get started on authoring tutorials.
            """,
            valueName: "template-name"
        )
    )
    public var catalogTemplate: CatalogTemplateKind
}

extension CatalogTemplateKind: ExpressibleByArgument {}