]>
git.madduck.net Git - code/myrepos.git/commitdiff
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
c1903b7 )
The .mrconfig file uses a variant of the INI file format. Lines starting with
"#" are comments. Lines ending with "\" are continued on to the next line.
The .mrconfig file uses a variant of the INI file format. Lines starting with
"#" are comments. Lines ending with "\" are continued on to the next line.
-The "default " section allows setting default values for the sections that
+The "DEFAULT " section allows setting default values for the sections that
-The "alias " section allows adding aliases for actions. Each parameter
+The "ALIAS " section allows adding aliases for actions. Each parameter
is an alias, and its value is the action to use.
All other sections specify where each repository is located, relative to the
is an alias, and its value is the action to use.
All other sections specify where each repository is located, relative to the
}
if ($action eq 'help') {
}
if ($action eq 'help') {
- exec($config{''}{default }{help});
+ exec($config{''}{DEFAULT }{help});
}
# work out what repos to act on
}
# work out what repos to act on
my $nochdir=0;
foreach my $topdir (sort keys %config) {
foreach my $subdir (sort keys %{$config{$topdir}}) {
my $nochdir=0;
foreach my $topdir (sort keys %config) {
foreach my $subdir (sort keys %{$config{$topdir}}) {
- next if $subdir eq 'default ';
+ next if $subdir eq 'DEFAULT ';
my $dir=$topdir.$subdir;
next if $dir ne $directory && $dir !~ /^\Q$directory\E\//;
push @repos, [$dir, $topdir, $subdir];
my $dir=$topdir.$subdir;
next if $dir ne $directory && $dir !~ /^\Q$directory\E\//;
push @repos, [$dir, $topdir, $subdir];
# fallback to find a leaf repo
LEAF: foreach my $topdir (reverse sort keys %config) {
foreach my $subdir (reverse sort keys %{$config{$topdir}}) {
# fallback to find a leaf repo
LEAF: foreach my $topdir (reverse sort keys %config) {
foreach my $subdir (reverse sort keys %{$config{$topdir}}) {
- next if $subdir eq 'default ';
+ next if $subdir eq 'DEFAULT ';
my $dir=$topdir.$subdir;
my $d=$directory;
$dir.="/" unless $dir=~/\/$/;
my $dir=$topdir.$subdir;
my $d=$directory;
$dir.="/" unless $dir=~/\/$/;
my $parent=$dir;
while ($parent=~s/^(.*)\/[^\/]+\/?$/$1/) {
if (exists $config{$parent} &&
my $parent=$dir;
while ($parent=~s/^(.*)\/[^\/]+\/?$/$1/) {
if (exists $config{$parent} &&
- exists $config{$parent}{default }) {
- $config{$dir}{default}={ %{$config{$parent}{default }} };
+ exists $config{$parent}{DEFAULT }) {
+ $config{$dir}{DEFAULT}={ %{$config{$parent}{DEFAULT }} };
if (! defined $section) {
die "$f line $.: parameter ($parameter) not in section\n";
}
if (! defined $section) {
die "$f line $.: parameter ($parameter) not in section\n";
}
- if ($section ne 'alias ' &&
+ if ($section ne 'ALIAS ' &&
! exists $config{$dir}{$section} &&
! exists $config{$dir}{$section} &&
- exists $config{$dir}{default }) {
+ exists $config{$dir}{DEFAULT }) {
- $config{$dir}{$section}={ %{$config{$dir}{default }} };
+ $config{$dir}{$section}={ %{$config{$dir}{DEFAULT }} };
- if ($section eq 'alias ') {
+ if ($section eq 'ALIAS ') {
$alias{$parameter}=$value;
}
elsif ($parameter eq 'lib') {
$alias{$parameter}=$value;
}
elsif ($parameter eq 'lib') {
$config{$dir}{$section}{$parameter}=$value;
$knownactions{$parameter}=1;
if ($parameter eq 'chain' &&
$config{$dir}{$section}{$parameter}=$value;
$knownactions{$parameter}=1;
if ($parameter eq 'chain' &&
- length $dir && $section ne "default " &&
+ length $dir && $section ne "DEFAULT " &&
-e $dir.$section."/.mrconfig" &&
system($value) >> 8 == 0) {
push @toload, $dir.$section."/.mrconfig";
-e $dir.$section."/.mrconfig" &&
system($value) >> 8 == 0) {
push @toload, $dir.$section."/.mrconfig";
# Finally, some useful actions that mr knows about by default.
# These can be overridden in ~/.mrconfig.
__DATA__
# Finally, some useful actions that mr knows about by default.
# These can be overridden in ~/.mrconfig.
__DATA__
co = checkout
ci = commit
ls = list
co = checkout
ci = commit
ls = list
lib = \
error() { \
echo "mr: $@" >&2; \
lib = \
error() { \
echo "mr: $@" >&2; \
# An example config file for the mr(1) command.
# An example config file for the mr(1) command.
# Teach mr how to run svn cleanup.
cleanup = if [ -d "$MR_REPO"/.svn ]; then svn cleanup ; fi
# Tests used in the skips below.
# Teach mr how to run svn cleanup.
cleanup = if [ -d "$MR_REPO"/.svn ]; then svn cleanup ; fi
# Tests used in the skips below.