summaryrefslogtreecommitdiffstats
path: root/vendor/xflags-macros/tests/it/smoke.rs
blob: e22c4f1f633616c79b8b7a9405ad75d6de32b21e (plain)
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#![allow(unused)]
use std::{ffi::OsString, path::PathBuf};

#[derive(Debug)]
pub struct RustAnalyzer {
    pub workspace: PathBuf,
    pub jobs: Option<u32>,

    pub log_file: Option<PathBuf>,
    pub verbose: u32,
    pub number: u32,
    pub data: Vec<OsString>,
    pub emoji: bool,
}

impl RustAnalyzer {
    pub const HELP: &'static str = Self::HELP_;

    #[allow(dead_code)]
    pub fn from_env() -> xflags::Result<Self> {
        Self::from_env_()
    }

    #[allow(dead_code)]
    pub fn from_vec(args: Vec<std::ffi::OsString>) -> xflags::Result<Self> {
        Self::from_vec_(args)
    }
}

impl RustAnalyzer {
    fn from_env_() -> xflags::Result<Self> {
        let mut p = xflags::rt::Parser::new_from_env();
        Self::parse_(&mut p)
    }
    fn from_vec_(args: Vec<std::ffi::OsString>) -> xflags::Result<Self> {
        let mut p = xflags::rt::Parser::new(args);
        Self::parse_(&mut p)
    }
}

impl RustAnalyzer {
    fn parse_(p_: &mut xflags::rt::Parser) -> xflags::Result<Self> {
        let mut log_file = Vec::new();
        let mut verbose = Vec::new();
        let mut number = Vec::new();
        let mut data = Vec::new();
        let mut emoji = Vec::new();

        let mut workspace = (false, Vec::new());
        let mut jobs = (false, Vec::new());

        while let Some(arg_) = p_.pop_flag() {
            match arg_ {
                Ok(flag_) => match flag_.as_str() {
                    "--log-file" => log_file.push(p_.next_value(&flag_)?.into()),
                    "--verbose" | "-v" => verbose.push(()),
                    "--number" | "-n" => number.push(p_.next_value_from_str::<u32>(&flag_)?),
                    "--data" => data.push(p_.next_value(&flag_)?.into()),
                    "--emoji" => emoji.push(()),
                    _ => return Err(p_.unexpected_flag(&flag_)),
                },
                Err(arg_) => {
                    if let (done_ @ false, buf_) = &mut workspace {
                        buf_.push(arg_.into());
                        *done_ = true;
                        continue;
                    }
                    if let (done_ @ false, buf_) = &mut jobs {
                        buf_.push(p_.value_from_str::<u32>("jobs", arg_)?);
                        *done_ = true;
                        continue;
                    }
                    return Err(p_.unexpected_arg(arg_));
                }
            }
        }
        Ok(Self {
            workspace: p_.required("workspace", workspace.1)?,
            jobs: p_.optional("jobs", jobs.1)?,

            log_file: p_.optional("--log-file", log_file)?,
            verbose: verbose.len() as u32,
            number: p_.required("--number", number)?,
            data: data,
            emoji: p_.optional("--emoji", emoji)?.is_some(),
        })
    }
}
impl RustAnalyzer {
    const HELP_: &'static str = "\
rust-analyzer
  LSP server for rust.

ARGS:
    <workspace>

    [jobs]
      Number of concurrent jobs.

OPTIONS:
    --log-file <path>
      Path to log file. By default, logs go to stderr.

    -v, --verbose

    -n, --number <n>

    --data <value>

    --emoji
";
}