summaryrefslogtreecommitdiff
path: root/templates
diff options
context:
space:
mode:
authorAlex Vandiver <alexmv@dropbox.com>2017-10-27 23:26:35 (GMT)
committerJunio C Hamano <gitster@pobox.com>2017-10-30 02:45:56 (GMT)
commitc87fbcf7614a064877cd0323f0ed31840fed9c0c (patch)
treef143f6ae959afdbee0ff50685b76552af339277e /templates
parent11cf33bec62512f2c3f0bdcfdaa41e31e9b0c3e8 (diff)
downloadgit-c87fbcf7614a064877cd0323f0ed31840fed9c0c.zip
git-c87fbcf7614a064877cd0323f0ed31840fed9c0c.tar.gz
git-c87fbcf7614a064877cd0323f0ed31840fed9c0c.tar.bz2
fsmonitor: don't bother pretty-printing JSON from watchman
This provides modest performance savings. Benchmarking with the following program, with and without `--no-pretty`, we find savings of 23% (0.316s -> 0.242s) in the git repository, and savings of 8% (5.24s -> 4.86s) on a large repository with 580k files in the working copy. #!/usr/bin/perl use strict; use warnings; use IPC::Open2; use JSON::XS; my $pid = open2(\*CHLD_OUT, \*CHLD_IN, "watchman -j @ARGV") or die "open2() failed: $!\n" . "Falling back to scanning...\n"; my $query = qq|["query", "$ENV{PWD}", {}]|; print CHLD_IN $query; close CHLD_IN; my $response = do {local $/; <CHLD_OUT>}; JSON::XS->new->utf8->decode($response); Signed-off-by: Alex Vandiver <alexmv@dropbox.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'templates')
-rwxr-xr-xtemplates/hooks--fsmonitor-watchman.sample2
1 files changed, 1 insertions, 1 deletions
diff --git a/templates/hooks--fsmonitor-watchman.sample b/templates/hooks--fsmonitor-watchman.sample
index 9eba8a7..9a082f2 100755
--- a/templates/hooks--fsmonitor-watchman.sample
+++ b/templates/hooks--fsmonitor-watchman.sample
@@ -49,7 +49,7 @@ launch_watchman();
sub launch_watchman {
- my $pid = open2(\*CHLD_OUT, \*CHLD_IN, 'watchman -j')
+ my $pid = open2(\*CHLD_OUT, \*CHLD_IN, 'watchman -j --no-pretty')
or die "open2() failed: $!\n" .
"Falling back to scanning...\n";