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
use crate::commands::constants::*;
use crate::TmuxCommand;
use std::borrow::Cow;

pub type UnlinkW<'a> = UnlinkWindow<'a>;

/// Unlink `target-window`
///
/// # Manual
///
/// tmux ^1.0:
/// ```text
/// unlink-window [-k] [-t target-window]
/// (alias: unlinkw)
/// ```
///
/// tmux ^0.8:
/// ```text
/// unlink-window [-t target-window]
/// (alias: unlinkw)
/// ```
#[derive(Clone, Eq, PartialEq, Ord, PartialOrd, Hash, Debug, Default)]
pub struct UnlinkWindow<'a> {
    /// `[-k]`
    #[cfg(feature = "tmux_1_0")]
    pub detach_other: bool,

    /// `[-t target-window]`
    #[cfg(feature = "tmux_0_8")]
    pub target_window: Option<Cow<'a, str>>,
}

impl<'a> UnlinkWindow<'a> {
    pub fn new() -> Self {
        Default::default()
    }

    /// `[-k]`
    #[cfg(feature = "tmux_1_0")]
    pub fn detach_other(mut self) -> Self {
        self.detach_other = true;
        self
    }

    /// `[-t target-window]`
    #[cfg(feature = "tmux_0_8")]
    pub fn target_window<S: Into<Cow<'a, str>>>(mut self, target_window: S) -> Self {
        self.target_window = Some(target_window.into());
        self
    }

    pub fn build(self) -> TmuxCommand<'a> {
        let mut cmd = TmuxCommand::new();

        cmd.name(UNLINK_WINDOW);

        // `[-k]`
        #[cfg(feature = "tmux_1_0")]
        if self.detach_other {
            cmd.push_flag(K_LOWERCASE_KEY);
        }

        // `[-t target-window]`
        #[cfg(feature = "tmux_0_8")]
        if let Some(target_window) = self.target_window {
            cmd.push_option(T_LOWERCASE_KEY, target_window);
        }

        cmd
    }
}