Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
grunt-git-archive
Advanced tools
An implementation git archive command
This plugin requires Grunt ~0.4.5
If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
npm install grunt-git-archive --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-git-archive');
Run this task with the grunt git-archive
command.
Task targets, files and options may be specified according to the grunt Configuring tasks guide.
module.exports = function (grunt) {
grunt.config.init({
'git-archive': {
archive: {
options: {
'extra' : 6,
'format' : 'tar.gz',
'output' : 'file.tar.gz',
'tree-ish': 'master',
}
}
}
});
grunt.loadNpmTasks('grunt-git-archive');
grunt.registerTask('archive', ['git-archive']);
grunt.registerTask('default', [archive]);
};
Type: String
Default: tar
Format of the resulting archive: tar or zip. If this option is not given, and the output file is specified, the format is inferred from the filename if possible (e.g. writing to "foo.zip" makes the output to be in the zip format). Otherwise the output format is tar.
'git-archive': {
archive: {
options: {
'output' : 'file.tar.gz',
'tree-ish': 'master'
'format' : 'tar.gz'
}
}
}
Type: Boolean
Default: false
Report progress to stderr.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master'
'verbose' : true
}
}
}
Type: String
Prepend / to each filename in the archive.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master'
'prefix' : 'path/' // path/file.tar
}
}
}
Type: String|Function (helper)
Write the archive to instead of stdout.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master'
}
}
}
'git-archive': {
archive: {
options: {
'output' : function () {
return 'file.tar';
},
'tree-ish': 'master'
}
}
}
Type: String
Look for attributes in .gitattributes files in the working tree as well
export-ignore
Files and directories with the attribute export-ignore won’t be added to archive files. See gitattributes for details.
export-subst
If the attribute export-subst is set for a file then Git will expand several placeholders when adding this file to an archive. See gitattributes for details.
Note that attributes are by default taken from the .gitattributes files in the tree that is being archived. If you want to tweak the way the output is generated after the fact (e.g. you committed without adding an appropriate export-ignore in its .gitattributes), adjust the checked out .gitattributes file as necessary and use --worktree-attributes option. Alternatively you can keep necessary attributes that should apply while archiving any tree in your $GIT_DIR/info/attributes file.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish' : 'master'
'worktree-attributes' : true
}
}
}
Type: Number
This can be any options that the archiver backend understands.
-0
Store the files instead of deflating them.
-9
Highest and slowest compression level. You can specify any number from 1 to 9 to adjust compression speed and ratio.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master'
'extra' : 6
}
}
}
Type: String
Instead of making a tar archive from the local repository, retrieve a tar archive from a remote repository. Note that the remote repository may place restrictions on which sha1 expressions may be allowed in . See git-upload-archive for details.
Type: String
Used with --remote to specify the path to the git-upload-archive on the remote side.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master/tasks', // Archive only the tasks directory in master branch
'remote' : 'origin v1.0:Documentation'
}
}
}
Type: String
The tree or commit to produce an archive for.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master/tasks', // Archive only the tasks directory in master branch
}
}
}
A complete list of commit-ish and tree-ish identifiers
Commit-ish/Tree-ish | Examples |
---|---|
1. | dae86e1950b1277e545cee180551750029cfe735 |
2. | v1.7.4.2-679-g3bee7fb |
3. | master, heads/master, refs/heads/master |
4. @{} | master@{yesterday}, HEAD@{5 minutes ago} |
5. @{} | master@{1} |
6. @{} | @{1} |
7. @{-} | @{-1} |
8. @{upstream} | master@{upstream}, @{u} |
9. ^ | HEAD^, v1.5.1^0 |
10. ~ | master~3 |
11. ^{} | v0.99.8^{commit} |
12. ^{} | v0.99.8^{} |
13. ^{/} | HEAD^{/fix nasty bug} |
14. :/ | :/fix nasty bug |
Tree-ish only | Examples |
15. : | HEAD:README.txt, master:sub-directory/ |
Tree-ish? | Examples |
16. :: | :0:README, :README |
Identifiers #1-14
are all "commit-ish", because they all lead to commits, but because commits also point to directory trees, they all ultimately lead to (sub)directory tree objects, and can therefore also be used as "tree-ish".
#15
can also be used as tree-ish when it refers to a (sub)directory, but it can also be used to identify specific files. When it refers to files, I'm not sure if it's still considered "tree-ish", or if acts more like "blob-ish" (Git refers to files as "blobs").
For more info see specifying revisions
Type: String
Without an optional path parameter, all files and subdirectories of the current working directory are included in the archive. If one or more paths are specified, only these are included.
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master',
'path' : '.gitignore .npmignore package.json', // Archive only this files
}
}
}
Type: Function (file)
Context: options
Callback
'git-archive': {
archive: {
options: {
'output' : 'file.tar',
'tree-ish': 'master',
'complete': function (file) {
grunt.log.write('Creating the %s archive completed!', file);
}
}
}
}
Type: Object
Context: options
Optional commands that can be set as an output
option.
'git-archive': {
archive: {
options: {
'output': function (helper) {
return helper.branch + '.tar'; // master.tar
},
'tree-ish': 'master',
'helpers' : {
'branch': 'git rev-parse --abbrev-ref HEAD'
}
}
}
}
The most popular helpers:
{
'user' : 'git config --get user.name',
'email' : 'git config --get user.email',
'branch' : 'git rev-parse --abbrev-ref HEAD',
'directory' : 'basename `git rev-parse --show-toplevel`'
}
Task submitted by Alexander Abashkin
FAQs
Create an archive of files from a named tree
The npm package grunt-git-archive receives a total of 9 weekly downloads. As such, grunt-git-archive popularity was classified as not popular.
We found that grunt-git-archive demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.