Add new formatting option %(raw), it means that we want to print
all the file without any changes. It will help further
to migrate all cat-file formatting logic from cat-file
to ref-filter. For now, we just treat it as the empty string.

Signed-off-by: Olga Telezhnaia <olyatelezhn...@gmail.com>
---
 ref-filter.c | 13 +++++++++++++
 1 file changed, 13 insertions(+)

diff --git a/ref-filter.c b/ref-filter.c
index 68d9741a56468..bb963a4110fb2 100644
--- a/ref-filter.c
+++ b/ref-filter.c
@@ -208,6 +208,15 @@ static int remote_ref_atom_parser(const struct ref_format 
*format, struct used_a
        return 0;
 }
 
+static int raw_atom_parser(const struct ref_format *format, struct used_atom 
*atom,
+                          const char *arg, struct strbuf *err)
+{
+       if (arg)
+               return strbuf_addf_ret(err, -1, _("%%(raw) does not take 
arguments"));
+       oi.info.typep = &oi.type;
+       return 0;
+}
+
 static int objecttype_atom_parser(const struct ref_format *format, struct 
used_atom *atom,
                                  const char *arg, struct strbuf *err)
 {
@@ -478,6 +487,7 @@ static struct {
        { "then", SOURCE_NONE },
        { "else", SOURCE_NONE },
        { "rest", SOURCE_NONE },
+       { "raw", SOURCE_NONE, FIELD_STR, raw_atom_parser },
 };
 
 #define REF_FORMATTING_STATE_INIT  { 0, NULL }
@@ -1619,6 +1629,9 @@ static int populate_value(struct ref_array_item *ref, 
struct strbuf *err)
                } else if (starts_with(name, "rest")) {
                        v->s = xstrdup(ref->request_rest ? ref->request_rest : 
"");
                        continue;
+               } else if (!strcmp(name, "raw")) {
+                       v->s = xstrdup("");
+                       continue;
                } else if (starts_with(name, "align")) {
                        v->handler = align_atom_handler;
                        v->s = xstrdup("");

--
https://github.com/git/git/pull/568

Reply via email to