Show More
@@ -6,9 +6,10 | |||||
6 | // GNU General Public License version 2 or any later version. |
|
6 | // GNU General Public License version 2 or any later version. | |
7 |
|
7 | |||
8 | use crate::error::CommandError; |
|
8 | use crate::error::CommandError; | |
9 |
use crate::ui:: |
|
9 | use crate::ui::Ui; | |
10 | use crate::utils::path_utils::relativize_paths; |
|
10 | use crate::utils::path_utils::relativize_paths; | |
11 | use clap::{Arg, SubCommand}; |
|
11 | use clap::{Arg, SubCommand}; | |
|
12 | use format_bytes::format_bytes; | |||
12 | use hg; |
|
13 | use hg; | |
13 | use hg::config::Config; |
|
14 | use hg::config::Config; | |
14 | use hg::dirstate::{has_exec_bit, TruncatedTimestamp}; |
|
15 | use hg::dirstate::{has_exec_bit, TruncatedTimestamp}; | |
@@ -20,7 +21,6 use hg::utils::files::get_bytes_from_os_ | |||||
20 | use hg::utils::hg_path::{hg_path_to_os_string, HgPath}; |
|
21 | use hg::utils::hg_path::{hg_path_to_os_string, HgPath}; | |
21 | use hg::{HgPathCow, StatusOptions}; |
|
22 | use hg::{HgPathCow, StatusOptions}; | |
22 | use log::{info, warn}; |
|
23 | use log::{info, warn}; | |
23 | use std::borrow::Cow; |
|
|||
24 |
|
24 | |||
25 | pub const HELP_TEXT: &str = " |
|
25 | pub const HELP_TEXT: &str = " | |
26 | Show changed files in the working directory |
|
26 | Show changed files in the working directory | |
@@ -82,6 +82,12 pub fn args() -> clap::App<'static, 'sta | |||||
82 | .short("-i") |
|
82 | .short("-i") | |
83 | .long("--ignored"), |
|
83 | .long("--ignored"), | |
84 | ) |
|
84 | ) | |
|
85 | .arg( | |||
|
86 | Arg::with_name("no-status") | |||
|
87 | .help("hide status prefix") | |||
|
88 | .short("-n") | |||
|
89 | .long("--no-status"), | |||
|
90 | ) | |||
85 | } |
|
91 | } | |
86 |
|
92 | |||
87 | /// Pure data type allowing the caller to specify file states to display |
|
93 | /// Pure data type allowing the caller to specify file states to display | |
@@ -182,6 +188,7 pub fn run(invocation: &crate::CliInvoca | |||||
182 | requested |
|
188 | requested | |
183 | } |
|
189 | } | |
184 | }; |
|
190 | }; | |
|
191 | let no_status = args.is_present("no-status"); | |||
185 |
|
192 | |||
186 | let repo = invocation.repo?; |
|
193 | let repo = invocation.repo?; | |
187 | let mut dmap = repo.dirstate_map_mut()?; |
|
194 | let mut dmap = repo.dirstate_map_mut()?; | |
@@ -240,25 +247,74 pub fn run(invocation: &crate::CliInvoca | |||||
240 | } |
|
247 | } | |
241 | } |
|
248 | } | |
242 | if display_states.modified { |
|
249 | if display_states.modified { | |
243 | display_status_paths(ui, repo, config, &mut ds_status.modified, b"M")?; |
|
250 | display_status_paths( | |
|
251 | ui, | |||
|
252 | repo, | |||
|
253 | config, | |||
|
254 | no_status, | |||
|
255 | &mut ds_status.modified, | |||
|
256 | b"M", | |||
|
257 | )?; | |||
244 | } |
|
258 | } | |
245 | if display_states.added { |
|
259 | if display_states.added { | |
246 | display_status_paths(ui, repo, config, &mut ds_status.added, b"A")?; |
|
260 | display_status_paths( | |
|
261 | ui, | |||
|
262 | repo, | |||
|
263 | config, | |||
|
264 | no_status, | |||
|
265 | &mut ds_status.added, | |||
|
266 | b"A", | |||
|
267 | )?; | |||
247 | } |
|
268 | } | |
248 | if display_states.removed { |
|
269 | if display_states.removed { | |
249 | display_status_paths(ui, repo, config, &mut ds_status.removed, b"R")?; |
|
270 | display_status_paths( | |
|
271 | ui, | |||
|
272 | repo, | |||
|
273 | config, | |||
|
274 | no_status, | |||
|
275 | &mut ds_status.removed, | |||
|
276 | b"R", | |||
|
277 | )?; | |||
250 | } |
|
278 | } | |
251 | if display_states.deleted { |
|
279 | if display_states.deleted { | |
252 | display_status_paths(ui, repo, config, &mut ds_status.deleted, b"!")?; |
|
280 | display_status_paths( | |
|
281 | ui, | |||
|
282 | repo, | |||
|
283 | config, | |||
|
284 | no_status, | |||
|
285 | &mut ds_status.deleted, | |||
|
286 | b"!", | |||
|
287 | )?; | |||
253 | } |
|
288 | } | |
254 | if display_states.unknown { |
|
289 | if display_states.unknown { | |
255 | display_status_paths(ui, repo, config, &mut ds_status.unknown, b"?")?; |
|
290 | display_status_paths( | |
|
291 | ui, | |||
|
292 | repo, | |||
|
293 | config, | |||
|
294 | no_status, | |||
|
295 | &mut ds_status.unknown, | |||
|
296 | b"?", | |||
|
297 | )?; | |||
256 | } |
|
298 | } | |
257 | if display_states.ignored { |
|
299 | if display_states.ignored { | |
258 | display_status_paths(ui, repo, config, &mut ds_status.ignored, b"I")?; |
|
300 | display_status_paths( | |
|
301 | ui, | |||
|
302 | repo, | |||
|
303 | config, | |||
|
304 | no_status, | |||
|
305 | &mut ds_status.ignored, | |||
|
306 | b"I", | |||
|
307 | )?; | |||
259 | } |
|
308 | } | |
260 | if display_states.clean { |
|
309 | if display_states.clean { | |
261 | display_status_paths(ui, repo, config, &mut ds_status.clean, b"C")?; |
|
310 | display_status_paths( | |
|
311 | ui, | |||
|
312 | repo, | |||
|
313 | config, | |||
|
314 | no_status, | |||
|
315 | &mut ds_status.clean, | |||
|
316 | b"C", | |||
|
317 | )?; | |||
262 | } |
|
318 | } | |
263 | Ok(()) |
|
319 | Ok(()) | |
264 | } |
|
320 | } | |
@@ -269,6 +325,7 fn display_status_paths( | |||||
269 | ui: &Ui, |
|
325 | ui: &Ui, | |
270 | repo: &Repo, |
|
326 | repo: &Repo, | |
271 | config: &Config, |
|
327 | config: &Config, | |
|
328 | no_status: bool, | |||
272 | paths: &mut [HgPathCow], |
|
329 | paths: &mut [HgPathCow], | |
273 | status_prefix: &[u8], |
|
330 | status_prefix: &[u8], | |
274 | ) -> Result<(), CommandError> { |
|
331 | ) -> Result<(), CommandError> { | |
@@ -277,23 +334,23 fn display_status_paths( | |||||
277 | relative = config |
|
334 | relative = config | |
278 | .get_option(b"commands", b"status.relative")? |
|
335 | .get_option(b"commands", b"status.relative")? | |
279 | .unwrap_or(relative); |
|
336 | .unwrap_or(relative); | |
|
337 | let print_path = |path: &[u8]| { | |||
|
338 | // TODO optim, probably lots of unneeded copies here, especially | |||
|
339 | // if out stream is buffered | |||
|
340 | if no_status { | |||
|
341 | ui.write_stdout(&format_bytes!(b"{}\n", path)) | |||
|
342 | } else { | |||
|
343 | ui.write_stdout(&format_bytes!(b"{} {}\n", status_prefix, path)) | |||
|
344 | } | |||
|
345 | }; | |||
|
346 | ||||
280 | if relative && !ui.plain() { |
|
347 | if relative && !ui.plain() { | |
281 | relativize_paths( |
|
348 | relativize_paths(repo, paths.iter().map(Ok), |path| { | |
282 |
|
|
349 | print_path(&path) | |
283 | paths.iter().map(Ok), |
|
350 | })?; | |
284 | |path: Cow<[u8]>| -> Result<(), UiError> { |
|
|||
285 | ui.write_stdout( |
|
|||
286 | &[status_prefix, b" ", path.as_ref(), b"\n"].concat(), |
|
|||
287 | ) |
|
|||
288 | }, |
|
|||
289 | )?; |
|
|||
290 | } else { |
|
351 | } else { | |
291 | for path in paths { |
|
352 | for path in paths { | |
292 | // Same TODO as in commands::root |
|
353 | print_path(path.as_bytes())? | |
293 | let bytes: &[u8] = path.as_bytes(); |
|
|||
294 | // TODO optim, probably lots of unneeded copies here, especially |
|
|||
295 | // if out stream is buffered |
|
|||
296 | ui.write_stdout(&[status_prefix, b" ", bytes, b"\n"].concat())?; |
|
|||
297 | } |
|
354 | } | |
298 | } |
|
355 | } | |
299 | Ok(()) |
|
356 | Ok(()) |
@@ -222,6 +222,13 hg status: | |||||
222 | ! deleted |
|
222 | ! deleted | |
223 | ? unknown |
|
223 | ? unknown | |
224 |
|
224 | |||
|
225 | hg status -n: | |||
|
226 | $ env RHG_STATUS=1 RHG_ON_UNSUPPORTED=abort hg status -n | |||
|
227 | added | |||
|
228 | removed | |||
|
229 | deleted | |||
|
230 | unknown | |||
|
231 | ||||
225 | hg status modified added removed deleted unknown never-existed ignored: |
|
232 | hg status modified added removed deleted unknown never-existed ignored: | |
226 |
|
233 | |||
227 | $ hg status modified added removed deleted unknown never-existed ignored |
|
234 | $ hg status modified added removed deleted unknown never-existed ignored |
General Comments 0
You need to be logged in to leave comments.
Login now