Includes test cases.

Signed-off-by: Joey Hess <jo...@joeyh.name>
---
 sha1_file.c           | 44 ++++++++++++++++++++++++++++++++++++++------
 t/t0021-conversion.sh | 36 ++++++++++++++++++++++++++++++++++++
 2 files changed, 74 insertions(+), 6 deletions(-)

diff --git a/sha1_file.c b/sha1_file.c
index 55604b6..df62eaf 100644
--- a/sha1_file.c
+++ b/sha1_file.c
@@ -3339,6 +3339,31 @@ static int index_stream_convert_blob(unsigned char 
*sha1, int fd,
        return ret;
 }
 
+static int index_from_file_convert_blob(unsigned char *sha1,
+                                     const char *path, unsigned flags)
+{
+       int ret;
+       const int write_object = flags & HASH_WRITE_OBJECT;
+       const int valid_sha1 = flags & HASH_USE_SHA_NOT_PATH;
+       struct strbuf sbuf = STRBUF_INIT;
+
+       assert(path);
+       assert(can_clean_from_file(path));
+
+       convert_to_git_filter_from_file(path, &sbuf,
+                                write_object ? safe_crlf : SAFE_CRLF_FALSE,
+                                valid_sha1 ? sha1 : NULL);
+
+       if (write_object)
+               ret = write_sha1_file(sbuf.buf, sbuf.len, typename(OBJ_BLOB),
+                                     sha1);
+       else
+               ret = hash_sha1_file(sbuf.buf, sbuf.len, typename(OBJ_BLOB),
+                                    sha1);
+       strbuf_release(&sbuf);
+       return ret;
+}
+
 static int index_pipe(unsigned char *sha1, int fd, enum object_type type,
                      const char *path, unsigned flags)
 {
@@ -3433,12 +3458,19 @@ int index_path(unsigned char *sha1, const char *path, 
struct stat *st, unsigned
 
        switch (st->st_mode & S_IFMT) {
        case S_IFREG:
-               fd = open(path, O_RDONLY);
-               if (fd < 0)
-                       return error_errno("open(\"%s\")", path);
-               if (index_fd(sha1, fd, st, OBJ_BLOB, path, flags) < 0)
-                       return error("%s: failed to insert into database",
-                                    path);
+               if (can_clean_from_file(path)) {
+                       if (index_from_file_convert_blob(sha1, path, flags) < 0)
+                               return error("%s: failed to insert into 
database",
+                                            path);
+               }
+               else {
+                       fd = open(path, O_RDONLY);
+                       if (fd < 0)
+                               return error_errno("open(\"%s\")", path);
+                       if (index_fd(sha1, fd, st, OBJ_BLOB, path, flags) < 0)
+                               return error("%s: failed to insert into 
database",
+                                            path);
+               }
                break;
        case S_IFLNK:
                if (strbuf_readlink(&sb, path, st->st_size))
diff --git a/t/t0021-conversion.sh b/t/t0021-conversion.sh
index 7bac2bc..407d5d6 100755
--- a/t/t0021-conversion.sh
+++ b/t/t0021-conversion.sh
@@ -12,6 +12,14 @@ tr \
 EOF
 chmod +x rot13.sh
 
+cat <<EOF >rot13-from-file.sh
+#!$SHELL_PATH
+fsfile="\$1"
+touch rot13-from-file.ran
+cat "\$fsfile" | ./rot13.sh
+EOF
+chmod +x rot13-from-file.sh
+
 test_expect_success setup '
        git config filter.rot13.smudge ./rot13.sh &&
        git config filter.rot13.clean ./rot13.sh &&
@@ -268,4 +276,32 @@ test_expect_success 'disable filter with empty override' '
        test_must_be_empty err
 '
 
+test_expect_success 'cleanFromFile filter is used when adding a file' '
+       test_config filter.rot13.cleanFromFile ./rot13-from-file.sh &&
+
+       echo "*.t filter=rot13" >.gitattributes &&
+
+       cat test >fstest.t &&
+       git add fstest.t &&
+       test -e rot13-from-file.ran &&
+       rm -f rot13-from-file.ran &&
+
+       rm -f fstest.t &&
+       git checkout -- fstest.t &&
+       cmp test fstest.t
+'
+
+test_expect_success 'cleanFromFile filter is not used when clean filter is not 
configured' '
+       test_config filter.noclean.smudge ./rot13.sh &&
+       test_config filter.noclean.cleanFromFile ./rot13-from-file.sh &&
+
+       echo "*.no filter=noclean" >.gitattributes &&
+
+       cat test >test.no &&
+       git add test.no &&
+       test ! -e rot13-from-file.ran &&
+       git cat-file blob :test.no >actual &&
+       cmp test actual
+'
+
 test_done
-- 
2.9.0.587.ga3bedf2

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to