Class: Tmuxinator::Config
- Inherits:
-
Object
- Object
- Tmuxinator::Config
- Defined in:
- lib/tmuxinator/config.rb
Constant Summary collapse
- LOCAL_DEFAULTS =
["./.tmuxinator.yml", "./.tmuxinator.yaml"].freeze
- NO_LOCAL_FILE_MSG =
"Project file at ./.tmuxinator.yml doesn't exist."
- NO_PROJECT_FOUND_MSG =
"Project could not be found."
- TMUX_MASTER_VERSION =
Float::INFINITY
Class Method Summary collapse
-
.active_sessions ⇒ Object
List of all active tmux sessions.
- .config_file_basenames ⇒ Object
-
.configs(active: nil) ⇒ Array<String>
Sorted list of all project .yml file basenames, including duplicates.
- .default ⇒ Object
- .default? ⇒ Boolean
- .default_or_sample ⇒ Object
- .default_path_option ⇒ Object
- .default_project(name) ⇒ Object
-
.directories ⇒ Object
Existent directories which may contain project files Listed in search order Used by ‘implode` and `list` commands.
-
.directory ⇒ Object
(also: root)
The directory (created if needed) in which to store new projects.
-
.environment ⇒ Object
$TMUXINATOR_CONFIG (and create directory) or “”.
- .environment? ⇒ Boolean
- .exist?(name: nil, path: nil) ⇒ Boolean
-
.global_project(name) ⇒ Object
(also: project_in_root)
Pathname of given project searching only global directories.
- .home ⇒ Object
- .home? ⇒ Boolean
- .local? ⇒ Boolean
- .local_project ⇒ Object (also: project_in_local)
-
.project(name) ⇒ Object
Pathname of the given project.
- .sample ⇒ Object
- .stop_template ⇒ Object
- .template ⇒ Object
- .valid_local_project?(name) ⇒ Boolean
- .valid_project_config?(project_config) ⇒ Boolean
- .valid_standard_project?(name) ⇒ Boolean
- .validate(options = {}) ⇒ Object
- .version ⇒ Object
- .wemux_template ⇒ Object
-
.xdg ⇒ Object
~/.config/tmuxinator unless $XDG_CONFIG_HOME has been configured to use a custom value.
- .xdg? ⇒ Boolean
Class Method Details
.active_sessions ⇒ Object
List of all active tmux sessions
130 131 132 |
# File 'lib/tmuxinator/config.rb', line 130 def active_sessions `tmux list-sessions -F "#S"`.split("\n") end |
.config_file_basenames ⇒ Object
150 151 152 153 154 155 156 |
# File 'lib/tmuxinator/config.rb', line 150 def config_file_basenames directories.flat_map do |directory| Dir["#{directory}/**/*.yml"].map do |path| path.gsub("#{directory}/", "").gsub(".yml", "") end end.sort end |
.configs(active: nil) ⇒ Array<String>
Sorted list of all project .yml file basenames, including duplicates
138 139 140 141 142 143 144 145 146 147 148 |
# File 'lib/tmuxinator/config.rb', line 138 def configs(active: nil) configs = config_file_basenames if active == true configs &= active_sessions elsif active == false configs -= active_sessions end configs end |
.default ⇒ Object
62 63 64 |
# File 'lib/tmuxinator/config.rb', line 62 def default "#{directory}/default.yml" end |
.default? ⇒ Boolean
66 67 68 |
# File 'lib/tmuxinator/config.rb', line 66 def default? exist?(name: "default") end |
.default_or_sample ⇒ Object
54 55 56 |
# File 'lib/tmuxinator/config.rb', line 54 def default_or_sample default? ? default : sample end |
.default_path_option ⇒ Object
82 83 84 |
# File 'lib/tmuxinator/config.rb', line 82 def default_path_option version && version < 1.8 ? "default-path" : "-c" end |
.default_project(name) ⇒ Object
108 109 110 |
# File 'lib/tmuxinator/config.rb', line 108 def default_project(name) "#{directory}/#{name}.yml" end |
.directories ⇒ Object
Existent directories which may contain project files Listed in search order Used by ‘implode` and `list` commands
161 162 163 164 165 166 167 |
# File 'lib/tmuxinator/config.rb', line 161 def directories if environment? [environment] else [xdg, home].select { |d| File.directory? d } end end |
.directory ⇒ Object Also known as: root
The directory (created if needed) in which to store new projects
12 13 14 15 16 17 18 19 20 |
# File 'lib/tmuxinator/config.rb', line 12 def directory return environment if environment? return xdg if xdg? return home if home? # No project directory specified or existent, default to XDG: FileUtils::mkdir_p(xdg) xdg end |
.environment ⇒ Object
$TMUXINATOR_CONFIG (and create directory) or “”.
42 43 44 45 46 47 48 |
# File 'lib/tmuxinator/config.rb', line 42 def environment environment = ENV["TMUXINATOR_CONFIG"] return "" if environment.to_s.empty? # variable is unset (nil) or blank FileUtils::mkdir_p(environment) unless File.directory?(environment) environment end |
.environment? ⇒ Boolean
50 51 52 |
# File 'lib/tmuxinator/config.rb', line 50 def environment? File.directory?(environment) end |
.exist?(name: nil, path: nil) ⇒ Boolean
86 87 88 89 90 91 |
# File 'lib/tmuxinator/config.rb', line 86 def exist?(name: nil, path: nil) return File.exist?(path) if path return File.exist?(project(name)) if name false end |
.global_project(name) ⇒ Object Also known as: project_in_root
Pathname of given project searching only global directories
98 99 100 101 102 |
# File 'lib/tmuxinator/config.rb', line 98 def global_project(name) project_in(environment, name) || project_in(xdg, name) || project_in(home, name) end |
.home ⇒ Object
22 23 24 |
# File 'lib/tmuxinator/config.rb', line 22 def home ENV["HOME"] + "/.tmuxinator" end |
.home? ⇒ Boolean
26 27 28 |
# File 'lib/tmuxinator/config.rb', line 26 def home? File.directory?(home) end |
.local? ⇒ Boolean
93 94 95 |
# File 'lib/tmuxinator/config.rb', line 93 def local? local_project end |
.local_project ⇒ Object Also known as: project_in_local
104 105 106 |
# File 'lib/tmuxinator/config.rb', line 104 def local_project LOCAL_DEFAULTS.detect { |f| File.exist?(f) } end |
.project(name) ⇒ Object
Pathname of the given project
113 114 115 |
# File 'lib/tmuxinator/config.rb', line 113 def project(name) global_project(name) || local_project || default_project(name) end |
.sample ⇒ Object
58 59 60 |
# File 'lib/tmuxinator/config.rb', line 58 def sample asset_path "sample.yml" end |
.stop_template ⇒ Object
121 122 123 |
# File 'lib/tmuxinator/config.rb', line 121 def stop_template asset_path "template-stop.erb" end |
.template ⇒ Object
117 118 119 |
# File 'lib/tmuxinator/config.rb', line 117 def template asset_path "template.erb" end |
.valid_local_project?(name) ⇒ Boolean
178 179 180 181 182 183 |
# File 'lib/tmuxinator/config.rb', line 178 def valid_local_project?(name) return false if name raise NO_LOCAL_FILE_MSG unless local? true end |
.valid_project_config?(project_config) ⇒ Boolean
169 170 171 172 173 174 175 176 |
# File 'lib/tmuxinator/config.rb', line 169 def valid_project_config?(project_config) return false unless project_config unless exist?(path: project_config) raise "Project config (#{project_config}) doesn't exist." end true end |
.valid_standard_project?(name) ⇒ Boolean
185 186 187 188 189 190 |
# File 'lib/tmuxinator/config.rb', line 185 def valid_standard_project?(name) return false unless name raise "Project #{name} doesn't exist." unless exist?(name: name) true end |
.validate(options = {}) ⇒ Object
192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 |
# File 'lib/tmuxinator/config.rb', line 192 def validate( = {}) name = [:name] [:force_attach] ||= false [:force_detach] ||= false project_config = .fetch(:project_config) { false } project_file = if valid_project_config?(project_config) project_config elsif valid_local_project?(name) local_project elsif valid_standard_project?(name) project(name) else # This branch should never be reached, # but just in case ... raise NO_PROJECT_FOUND_MSG end Tmuxinator::Project.load(project_file, ).validate! end |
.version ⇒ Object
70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/tmuxinator/config.rb', line 70 def version if Tmuxinator::Doctor.installed? tmux_version = `tmux -V`.split(" ")[1] if tmux_version == "master" TMUX_MASTER_VERSION else tmux_version.to_s[/\d+(?:\.\d+)?/, 0].to_f end end end |
.wemux_template ⇒ Object
125 126 127 |
# File 'lib/tmuxinator/config.rb', line 125 def wemux_template asset_path "wemux_template.erb" end |
.xdg ⇒ Object
~/.config/tmuxinator unless $XDG_CONFIG_HOME has been configured to use a custom value. (e.g. if $XDG_CONFIG_HOME is set to ~/my-config, the return value will be ~/my-config/tmuxinator)
33 34 35 |
# File 'lib/tmuxinator/config.rb', line 33 def xdg XDG["CONFIG"].to_s + "/tmuxinator" end |
.xdg? ⇒ Boolean
37 38 39 |
# File 'lib/tmuxinator/config.rb', line 37 def xdg? File.directory?(xdg) end |