Browse Source

Redo the templates generation and installation.

Per discussion with people interested in binary packaging,
change the default template location from /etc/git-core to
/usr/share/git-core hierarchy.  If a user wants to run git
before installing for whatever reason, in addition to adding
$src to the PATH environment variable, git-init-db can be run
with --template=$src/templates/blt/ parameter.

Signed-off-by: Junio C Hamano <junkio@cox.net>
maint
Junio C Hamano 20 years ago
parent
commit
d3af621b14
  1. 9
      Makefile
  2. 4
      cache.h
  3. 45
      init-db.c
  4. 43
      templates/Makefile
  5. 1
      templates/branches--
  6. 6
      templates/info--exclude
  7. 1
      templates/this--description

9
Makefile

@ -39,8 +39,7 @@ CFLAGS+=$(COPTS) -Wall $(DEFINES)


prefix=$(HOME) prefix=$(HOME)
bindir=$(prefix)/bin bindir=$(prefix)/bin
etcdir=$(prefix)/etc template_dir=$(prefix)/share/git-core/templates/
etcgitdir=$(etcdir)/git-core
# dest= # dest=


CC?=gcc CC?=gcc
@ -147,7 +146,6 @@ endif
endif endif


CFLAGS += '-DSHA1_HEADER=$(SHA1_HEADER)' CFLAGS += '-DSHA1_HEADER=$(SHA1_HEADER)'
CFLAGS += '-DDEFAULT_GIT_TEMPLATE_ENVIRONMENT="$(etcgitdir)/templates"'






@ -155,6 +153,8 @@ CFLAGS += '-DDEFAULT_GIT_TEMPLATE_ENVIRONMENT="$(etcgitdir)/templates"'


all: $(PROG) all: $(PROG)


all:
$(MAKE) -C templates


.PRECIOUS: %.o .PRECIOUS: %.o
git-%: %.o $(LIB_FILE) git-%: %.o $(LIB_FILE)
@ -168,6 +168,9 @@ git-ssh-push: rsh.o
git-http-pull: LIBS += -lcurl git-http-pull: LIBS += -lcurl
git-rev-list: LIBS += $(OPENSSL_LIBSSL) git-rev-list: LIBS += $(OPENSSL_LIBSSL)


init-db.o: init-db.c
$(CC) -c $(CFLAGS) -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir)"' $*.c

$(LIB_OBJS): $(LIB_H) $(LIB_OBJS): $(LIB_H)
$(DIFF_OBJS): diffcore.h $(DIFF_OBJS): diffcore.h



4
cache.h

@ -128,10 +128,6 @@ extern unsigned int active_nr, active_alloc, active_cache_changed;
#define DB_ENVIRONMENT "GIT_OBJECT_DIRECTORY" #define DB_ENVIRONMENT "GIT_OBJECT_DIRECTORY"
#define INDEX_ENVIRONMENT "GIT_INDEX_FILE" #define INDEX_ENVIRONMENT "GIT_INDEX_FILE"
#define GRAFT_ENVIRONMENT "GIT_GRAFT_FILE" #define GRAFT_ENVIRONMENT "GIT_GRAFT_FILE"
#define TEMPLATE_DIR_ENVIRONMENT "GIT_TEMPLATE_DIRECTORY"
#ifndef DEFAULT_GIT_TEMPLATE_ENVIRONMENT
#define DEFAULT_GIT_TEMPLATE_ENVIRONMENT "/etc/git-core/templates"
#endif


extern char *get_object_directory(void); extern char *get_object_directory(void);
extern char *get_refs_directory(void); extern char *get_refs_directory(void);

45
init-db.c

@ -5,6 +5,10 @@
*/ */
#include "cache.h" #include "cache.h"


#ifndef DEFAULT_GIT_TEMPLATE_DIR
#define DEFAULT_GIT_TEMPLATE_DIR "/usr/share/git-core/templates/"
#endif

static void safe_create_dir(const char *dir) static void safe_create_dir(const char *dir)
{ {
if (mkdir(dir, 0777) < 0) { if (mkdir(dir, 0777) < 0) {
@ -127,36 +131,37 @@ static void copy_templates_1(char *path, int baselen,
} }
} }


static void copy_templates(const char *git_dir) static void copy_templates(const char *git_dir, int len, char *template_dir)
{ {
char path[PATH_MAX]; char path[PATH_MAX];
char template_path[PATH_MAX]; char template_path[PATH_MAX];
char *template_dir; int template_len;
int len, template_len;
DIR *dir; DIR *dir;


strcpy(path, git_dir);
len = strlen(path);
template_dir = gitenv(TEMPLATE_DIR_ENVIRONMENT);
if (!template_dir) if (!template_dir)
template_dir = DEFAULT_GIT_TEMPLATE_ENVIRONMENT; template_dir = DEFAULT_GIT_TEMPLATE_DIR;
strcpy(template_path, template_dir); strcpy(template_path, template_dir);
template_len = strlen(template_path); template_len = strlen(template_path);
if (template_path[template_len-1] != '/') { if (template_path[template_len-1] != '/') {
template_path[template_len++] = '/'; template_path[template_len++] = '/';
template_path[template_len] = 0; template_path[template_len] = 0;
} }

dir = opendir(template_path); dir = opendir(template_path);
if (!dir) if (!dir) {
fprintf(stderr, "warning: templates not found %s\n",
template_dir);
return; return;
}

memcpy(path, git_dir, len);
copy_templates_1(path, len, copy_templates_1(path, len,
template_path, template_len, template_path, template_len,
dir); dir);
closedir(dir); closedir(dir);
} }


static void create_default_files(const char *git_dir) static void create_default_files(const char *git_dir,
char *template_path)
{ {
unsigned len = strlen(git_dir); unsigned len = strlen(git_dir);
static char path[PATH_MAX]; static char path[PATH_MAX];
@ -189,10 +194,12 @@ static void create_default_files(const char *git_dir)
exit(1); exit(1);
} }
} }
path[len] = 0; copy_templates(path, len, template_path);
copy_templates(path);
} }


static const char init_db_usage[] =
"git-init-db [--template=<template-directory>]";

/* /*
* If you want to, you can share the DB area with any number of branches. * If you want to, you can share the DB area with any number of branches.
* That has advantages: you can save space by sharing all the SHA1 objects. * That has advantages: you can save space by sharing all the SHA1 objects.
@ -203,9 +210,19 @@ int main(int argc, char **argv)
{ {
const char *git_dir; const char *git_dir;
const char *sha1_dir; const char *sha1_dir;
char *path; char *path, *template_dir = NULL;
int len, i; int len, i;


for (i = 1; i < argc; i++, argv++) {
char *arg = argv[1];
if (arg[0] != '-')
break;
else if (!strncmp(arg, "--template=", 11))
template_dir = arg+11;
else
die(init_db_usage);
}

/* /*
* Set up the default .git directory contents * Set up the default .git directory contents
*/ */
@ -215,7 +232,7 @@ int main(int argc, char **argv)
fprintf(stderr, "defaulting to local storage area\n"); fprintf(stderr, "defaulting to local storage area\n");
} }
safe_create_dir(git_dir); safe_create_dir(git_dir);
create_default_files(git_dir); create_default_files(git_dir, template_dir);


/* /*
* And set up the object store. * And set up the object store.

43
templates/Makefile

@ -1,19 +1,38 @@
# make # make and install sample templates


INSTALL=install INSTALL=install
prefix=$(HOME) prefix=$(HOME)
etcdir=$(prefix)/etc template_dir=$(prefix)/share/git-core/templates/
etcgitdir=$(etcdir)/git-core
templatedir=$(etcgitdir)/templates
# dest= # dest=


all: all: boilerplates custom
find blt

# Put templates that can be copied straight from the source
# in a file direc--tory--file in the source. They will be
# just copied to the destination.
boilerplates:
ls *--* 2>/dev/null | \
while read boilerplate; \
do \
case "$$boilerplate" in *~) continue ;; esac && \
dst=`echo "$$boilerplate" | sed -e 's|^this|.|;s|--|/|g'` && \
dir=`expr "$$dst" : '\(.*\)/'` && \
mkdir -p blt/$$dir && \
case "$$boilerplate" in \
*--) ;; \
*) cp $$boilerplate blt/$$dst ;; \
esac || exit; \
done || exit

# If you need build-tailored templates, build them into blt/
# directory yourself here.
custom:
: no custom templates yet

clean: clean:
rm -rf blt


install: install: all
$(INSTALL) -d -m755 $(dest)$(templatedir)/hooks/ $(INSTALL) -d -m755 $(dest)$(template_dir)
$(foreach s,$(wildcard hooks--*),\ tar Ccf blt - . | tar Cxf $(dest)$(template_dir) -
$(INSTALL) -m644 $s \
$(dest)$(templatedir)/hooks/$(patsubst hooks--%,%,$s);)
$(INSTALL) -d -m755 $(dest)$(templatedir)/info
$(INSTALL) -d -m755 $(dest)$(templatedir)/branches

1
templates/branches--

@ -0,0 +1 @@
: this is just to ensure the directory exists.

6
templates/info--exclude

@ -0,0 +1,6 @@
# git-ls-files --others --exclude-from=.git/info/exclude
# Lines that start with '#' are comments.
# For a project mostly in C, the following would be a good set of
# exclude patterns (uncomment them if you want to use them):
# *.[oa]
# *~

1
templates/this--description

@ -0,0 +1 @@
Unnamed repository; edit this file to name it for gitweb.
Loading…
Cancel
Save