/usr/share/cagefs-skeleton/usr/libexec/git-core
#!/usr/bin/sh OPTIONS_KEEPDASHDASH= OPTIONS_STUCKLONG= OPTIONS_SPEC="\ git quiltimport [options] -- n,dry-run dry run author= author name and email address for patches without any patches= path to the quilt patches series= path to the quilt series file keep-non-patch Pass -b to git mailinfo " SUBDIRECTORY_ON=Yes . git-sh-setup dry_run="" quilt_author="" while test $# != 0 do case "$1" in --author) shift quilt_author="$1" ;; -n|--dry-run) dry_run=1 ;; --patches) shift QUILT_PATCHES="$1" ;; --series) shift QUILT_SERIES="$1" ;; --keep-non-patch) MAILINFO_OPT="-b" ;; --) shift break;; *) usage ;; esac shift done # Quilt Author if [ -n "$quilt_author" ] ; then quilt_author_name=$(expr "z$quilt_author" : 'z\(.*[^ ]\) *<.*') && quilt_author_email=$(expr "z$quilt_author" : '.*<\([^>]*\)') && test '' != "$quilt_author_name" && test '' != "$quilt_author_email" || die "malformed --author parameter" fi # Quilt patch directory : ${QUILT_PATCHES:=patches} if ! [ -d "$QUILT_PATCHES" ] ; then echo "The \"$QUILT_PATCHES\" directory does not exist." exit 1 fi # Quilt series file : ${QUILT_SERIES:=$QUILT_PATCHES/series} if ! [ -e "$QUILT_SERIES" ] ; then echo "The \"$QUILT_SERIES\" file does not exist." exit 1 fi # Temporary directories tmp_dir="$GIT_DIR"/rebase-apply tmp_msg="$tmp_dir/msg" tmp_patch="$tmp_dir/patch" tmp_info="$tmp_dir/info" # Find the initial commit commit=$(git rev-parse HEAD) mkdir $tmp_dir || exit 2 while read patch_name level garbage <&3 do case "$patch_name" in ''|'#'*) continue;; esac case "$level" in -p*) ;; ''|'#'*) level=;; *) echo "unable to parse patch level, ignoring it." level=;; esac case "$garbage" in ''|'#'*);; *) echo "trailing garbage found in series file: $garbage" exit 1;; esac if ! [ -f "$QUILT_PATCHES/$patch_name" ] ; then echo "$patch_name doesn't exist. Skipping." continue fi echo $patch_name git mailinfo $MAILINFO_OPT "$tmp_msg" "$tmp_patch" \ <"$QUILT_PATCHES/$patch_name" >"$tmp_info" || exit 3 test -s "$tmp_patch" || { echo "Patch is empty. Was it split wrong?" exit 1 } # Parse the author information GIT_AUTHOR_NAME=$(sed -ne 's/Author: //p' "$tmp_info") GIT_AUTHOR_EMAIL=$(sed -ne 's/Email: //p' "$tmp_info") export GIT_AUTHOR_NAME GIT_AUTHOR_EMAIL while test -z "$GIT_AUTHOR_EMAIL" && test -z "$GIT_AUTHOR_NAME" ; do if [ -n "$quilt_author" ] ; then GIT_AUTHOR_NAME="$quilt_author_name"; GIT_AUTHOR_EMAIL="$quilt_author_email"; elif [ -n "$dry_run" ]; then echo "No author found in $patch_name" >&2; GIT_AUTHOR_NAME="dry-run-not-found"; GIT_AUTHOR_EMAIL="dry-run-not-found"; else echo "No author found in $patch_name" >&2; echo "---" cat $tmp_msg printf "Author: "; read patch_author echo "$patch_author" patch_author_name=$(expr "z$patch_author" : 'z\(.*[^ ]\) *<.*') && patch_author_email=$(expr "z$patch_author" : '.*<\([^>]*\)') && test '' != "$patch_author_name" && test '' != "$patch_author_email" && GIT_AUTHOR_NAME="$patch_author_name" && GIT_AUTHOR_EMAIL="$patch_author_email" fi done GIT_AUTHOR_DATE=$(sed -ne 's/Date: //p' "$tmp_info") SUBJECT=$(sed -ne 's/Subject: //p' "$tmp_info") export GIT_AUTHOR_DATE SUBJECT if [ -z "$SUBJECT" ] ; then SUBJECT=$(echo $patch_name | sed -e 's/.patch$//') fi if [ -z "$dry_run" ] ; then git apply --index -C1 ${level:+"$level"} "$tmp_patch" && tree=$(git write-tree) && commit=$( { echo "$SUBJECT"; echo; cat "$tmp_msg"; } | git commit-tree $tree -p $commit) && git update-ref -m "quiltimport: $patch_name" HEAD $commit || exit 4 fi done 3<"$QUILT_SERIES" rm -rf $tmp_dir || exit 5
.
Edit
..
Edit
git
Edit
git-add
Edit
git-am
Edit
git-annotate
Edit
git-apply
Edit
git-archive
Edit
git-bisect
Edit
git-blame
Edit
git-branch
Edit
git-bugreport
Edit
git-bundle
Edit
git-cat-file
Edit
git-check-attr
Edit
git-check-ignore
Edit
git-check-mailmap
Edit
git-check-ref-format
Edit
git-checkout
Edit
git-checkout--worker
Edit
git-checkout-index
Edit
git-cherry
Edit
git-cherry-pick
Edit
git-clean
Edit
git-clone
Edit
git-column
Edit
git-commit
Edit
git-commit-graph
Edit
git-commit-tree
Edit
git-config
Edit
git-contacts
Edit
git-count-objects
Edit
git-credential
Edit
git-credential-cache
Edit
git-credential-cache--daemon
Edit
git-credential-netrc
Edit
git-credential-store
Edit
git-describe
Edit
git-diagnose
Edit
git-diff
Edit
git-diff-files
Edit
git-diff-index
Edit
git-diff-tree
Edit
git-difftool
Edit
git-difftool--helper
Edit
git-fast-export
Edit
git-fast-import
Edit
git-fetch
Edit
git-fetch-pack
Edit
git-filter-branch
Edit
git-fmt-merge-msg
Edit
git-for-each-ref
Edit
git-for-each-repo
Edit
git-format-patch
Edit
git-fsck
Edit
git-fsck-objects
Edit
git-fsmonitor--daemon
Edit
git-gc
Edit
git-get-tar-commit-id
Edit
git-grep
Edit
git-hash-object
Edit
git-help
Edit
git-hook
Edit
git-http-backend
Edit
git-http-fetch
Edit
git-http-push
Edit
git-imap-send
Edit
git-index-pack
Edit
git-init
Edit
git-init-db
Edit
git-interpret-trailers
Edit
git-log
Edit
git-ls-files
Edit
git-ls-remote
Edit
git-ls-tree
Edit
git-mailinfo
Edit
git-mailsplit
Edit
git-maintenance
Edit
git-merge
Edit
git-merge-base
Edit
git-merge-file
Edit
git-merge-index
Edit
git-merge-octopus
Edit
git-merge-one-file
Edit
git-merge-ours
Edit
git-merge-recursive
Edit
git-merge-resolve
Edit
git-merge-subtree
Edit
git-merge-tree
Edit
git-mergetool
Edit
git-mergetool--lib
Edit
git-mktag
Edit
git-mktree
Edit
git-multi-pack-index
Edit
git-mv
Edit
git-name-rev
Edit
git-notes
Edit
git-pack-objects
Edit
git-pack-redundant
Edit
git-pack-refs
Edit
git-patch-id
Edit
git-prune
Edit
git-prune-packed
Edit
git-pull
Edit
git-push
Edit
git-quiltimport
Edit
git-range-diff
Edit
git-read-tree
Edit
git-rebase
Edit
git-receive-pack
Edit
git-reflog
Edit
git-refs
Edit
git-remote
Edit
git-remote-ext
Edit
git-remote-fd
Edit
git-remote-ftp
Edit
git-remote-ftps
Edit
git-remote-http
Edit
git-remote-https
Edit
git-repack
Edit
git-replace
Edit
git-replay
Edit
git-request-pull
Edit
git-rerere
Edit
git-reset
Edit
git-restore
Edit
git-rev-list
Edit
git-rev-parse
Edit
git-revert
Edit
git-rm
Edit
git-send-pack
Edit
git-sh-i18n
Edit
git-sh-i18n--envsubst
Edit
git-sh-setup
Edit
git-shell
Edit
git-shortlog
Edit
git-show
Edit
git-show-branch
Edit
git-show-index
Edit
git-show-ref
Edit
git-sparse-checkout
Edit
git-stage
Edit
git-stash
Edit
git-status
Edit
git-stripspace
Edit
git-submodule
Edit
git-submodule--helper
Edit
git-switch
Edit
git-symbolic-ref
Edit
git-tag
Edit
git-unpack-file
Edit
git-unpack-objects
Edit
git-update-index
Edit
git-update-ref
Edit
git-update-server-info
Edit
git-upload-archive
Edit
git-upload-pack
Edit
git-var
Edit
git-verify-commit
Edit
git-verify-pack
Edit
git-verify-tag
Edit
git-version
Edit
git-web--browse
Edit
git-whatchanged
Edit
git-worktree
Edit
git-write-tree
Edit
mergetools
Edit
scalar
Edit