]> git.ipfire.org Git - thirdparty/git.git/blobdiff - archive.h
Merge branch 'en/merge-ort-api-null-impl'
[thirdparty/git.git] / archive.h
index 3bd96bf6bba7ecaacb6b50e1f02080f95d11f17c..e3d04e8ab313d2a86f7c040492999bf43d0874e8 100644 (file)
--- a/archive.h
+++ b/archive.h
@@ -9,6 +9,7 @@ struct repository;
 struct archiver_args {
        struct repository *repo;
        const char *refname;
+       const char *prefix;
        const char *base;
        size_t baselen;
        struct tree *tree;
@@ -20,6 +21,7 @@ struct archiver_args {
        unsigned int worktree_attributes : 1;
        unsigned int convert : 1;
        int compression_level;
+       struct string_list extra_files;
 };
 
 /* main api */
@@ -34,6 +36,7 @@ const char *archive_format_from_filename(const char *filename);
 
 #define ARCHIVER_WANT_COMPRESSION_LEVELS 1
 #define ARCHIVER_REMOTE 2
+#define ARCHIVER_HIGH_COMPRESSION_LEVELS 4
 struct archiver {
        const char *name;
        int (*write_archive)(const struct archiver *, struct archiver_args *);
@@ -49,12 +52,9 @@ void init_archivers(void);
 typedef int (*write_archive_entry_fn_t)(struct archiver_args *args,
                                        const struct object_id *oid,
                                        const char *path, size_t pathlen,
-                                       unsigned int mode);
+                                       unsigned int mode,
+                                       void *buffer, unsigned long size);
 
 int write_archive_entries(struct archiver_args *args, write_archive_entry_fn_t write_entry);
-void *object_file_to_archive(const struct archiver_args *args,
-                            const char *path, const struct object_id *oid,
-                            unsigned int mode, enum object_type *type,
-                            unsigned long *sizep);
 
 #endif /* ARCHIVE_H */