diff options
author | Alex Vandiver <alexmv@dropbox.com> | 2017-10-27 16:26:35 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-10-30 11:45:56 +0900 |
commit | c87fbcf7614a064877cd0323f0ed31840fed9c0c (patch) | |
tree | f143f6ae959afdbee0ff50685b76552af339277e /templates | |
parent | 11cf33bec62512f2c3f0bdcfdaa41e31e9b0c3e8 (diff) | |
download | git-c87fbcf7614a064877cd0323f0ed31840fed9c0c.tar.gz |
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-x | templates/hooks--fsmonitor-watchman.sample | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/templates/hooks--fsmonitor-watchman.sample b/templates/hooks--fsmonitor-watchman.sample index 9eba8a7409..9a082f2781 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"; |