Best practice for Django project working directory structure [closed] - django
Closed. This question is opinion-based. It is not currently accepting answers.
Want to improve this question? Update the question so it can be answered with facts and citations by editing this post.
Closed 1 year ago.
The community reviewed whether to reopen this question 1 year ago and left it closed:
Original close reason(s) were not resolved
Improve this question
I know there is actually no single right way. However I've found that it's hard to create a directory structure that works well and remain clean for every developer and administrator. There is some standard structure in most projects on github. But it does not show a way to organize another files and all projects on pc.
What is the most convenient way to organize all these directories on development machine? How do you name them, and how do you connect and deploy this to server?
projects (all projects that your are working on)
source files (the application itself)
working copy of repository (I use git)
virtual environment (I prefer to place this near the project)
static root (for compiled static files)
media root (for uploaded media files)
README
LICENSE
documents
sketches
examples (an example project that uses the application provided by this project)
database (in case sqlite is used)
anything else that you usually need for successful work on project
The problems that I want to solve:
Good names of directories so that their purpose is clear.
Keeping all project files (including virtualenv) in one place, so I can easily copy, move, archive, remove whole project or estimate disk space usage.
Creating multiple copies of some selected file sets such as entire application, repository or virtualenv, while keeping single copy of another files that I don't want to clone.
Deploying right set of files to the server simply by rsyncing selected one dir.
There're two kind of Django "projects" that I have in my ~/projects/ directory, both have a bit different structure.:
Stand-alone websites
Pluggable applications
Stand-alone website
Mostly private projects, but doesn't have to be. It usually looks like this:
~/projects/project_name/
docs/ # documentation
scripts/
manage.py # installed to PATH via setup.py
project_name/ # project dir (the one which django-admin.py creates)
apps/ # project-specific applications
accounts/ # most frequent app, with custom user model
__init__.py
...
settings/ # settings for different environments, see below
__init__.py
production.py
development.py
...
__init__.py # contains project version
urls.py
wsgi.py
static/ # site-specific static files
templates/ # site-specific templates
tests/ # site-specific tests (mostly in-browser ones)
tmp/ # excluded from git
setup.py
requirements.txt
requirements_dev.txt
pytest.ini
...
Settings
The main settings are production ones. Other files (eg. staging.py,
development.py) simply import everything from production.py and override only necessary variables.
For each environment, there are separate settings files, eg. production,
development. I some projects I have also testing (for test runner), staging
(as a check before final deploy) and heroku (for deploying to heroku) settings.
Requirements
I rather specify requirements in setup.py directly. Only those required for
development/test environment I have in requirements_dev.txt.
Some services (eg. heroku) requires to have requirements.txt in root directory.
setup.py
Useful when deploying project using setuptools. It adds manage.py to PATH, so I can run manage.py directly (anywhere).
Project-specific apps
I used to put these apps into project_name/apps/ directory and import them
using relative imports.
Templates/static/locale/tests files
I put these templates and static files into global templates/static directory, not inside each app.
These files are usually edited by people, who doesn't care about project code
structure or python at all. If you are full-stack developer working alone or
in a small team, you can create per-app templates/static directory. It's really just a matter of taste.
The same applies for locale, although sometimes it's convenient to create separate locale directory.
Tests are usually better to place inside each app, but usually there is many
integration/functional tests which tests more apps working together, so global
tests directory does make sense.
Tmp directory
There is temporary directory in project root, excluded from VCS. It's used to
store media/static files and sqlite database during development. Everything in
tmp could be deleted anytime without any problems.
Virtualenv
I prefer virtualenvwrapper and place all venvs into ~/.venvs directory,
but you could place it inside tmp/ to keep it together.
Project template
I've created project template for this setup, django-start-template
Deployment
Deployment of this project is following:
source $VENV/bin/activate
export DJANGO_SETTINGS_MODULE=project_name.settings.production
git pull
pip install -r requirements.txt
# Update database, static files, locales
manage.py syncdb --noinput
manage.py migrate
manage.py collectstatic --noinput
manage.py makemessages -a
manage.py compilemessages
# restart wsgi
touch project_name/wsgi.py
You can use rsync instead of git, but still you need to run batch of commands to update your environment.
Recently, I made django-deploy app, which allows me to run single management command to update environment, but I've used it for one project only and I'm still experimenting with it.
Sketches and drafts
Draft of templates I place inside global templates/ directory. I guess one can create folder sketches/ in project root, but haven't used it yet.
Pluggable application
These apps are usually prepared to publish as open-source. I've taken example
below from django-forme
~/projects/django-app/
docs/
app/
tests/
example_project/
LICENCE
MANIFEST.in
README.md
setup.py
pytest.ini
tox.ini
.travis.yml
...
Name of directories is clear (I hope). I put test files outside app directory,
but it really doesn't matter. It is important to provide README and setup.py, so package is easily installed through pip.
My answer is inspired on my own working experience, and mostly in the book Two Scoops of Django which I highly recommend, and where you can find a more detailed explanation of everything. I just will answer some of the points, and any improvement or correction will be welcomed. But there also can be more correct manners to achieve the same purpose.
Projects
I have a main folder in my personal directory where I maintain all the projects where I am working on.
Source Files
I personally use the django project root as repository root of my projects. But in the book is recommended to separate both things. I think that this is a better approach, so I hope to start making the change progressively on my projects.
project_repository_folder/
.gitignore
Makefile
LICENSE.rst
docs/
README.rst
requirements.txt
project_folder/
manage.py
media/
app-1/
app-2/
...
app-n/
static/
templates/
project/
__init__.py
settings/
__init__.py
base.py
dev.py
local.py
test.py
production.py
ulrs.py
wsgi.py
Repository
Git or Mercurial seem to be the most popular version control systems among Django developers. And the most popular hosting services for backups GitHub and Bitbucket.
Virtual Environment
I use virtualenv and virtualenvwrapper. After installing the second one, you need to set up your working directory. Mine is on my /home/envs directory, as it is recommended on virtualenvwrapper installation guide. But I don't think the most important thing is where is it placed. The most important thing when working with virtual environments is keeping requirements.txt file up to date.
pip freeze -l > requirements.txt
Static Root
Project folder
Media Root
Project folder
README
Repository root
LICENSE
Repository root
Documents
Repository root. This python packages can help you making easier mantaining your documentation:
reStructuredText
Sphinx
Sketches
Examples
Database
I don't like to create a new settings/ directory. I simply add files named settings_dev.py and settings_production.py so I don't have to edit the BASE_DIR.
The approach below increase the default structure instead of changing it.
mysite/ # Project
conf/
locale/
en_US/
fr_FR/
it_IT/
mysite/
__init__.py
settings.py
settings_dev.py
settings_production.py
urls.py
wsgi.py
static/
admin/
css/ # Custom back end styles
css/ # Project front end styles
fonts/
images/
js/
sass/
staticfiles/
templates/ # Project templates
includes/
footer.html
header.html
index.html
myapp/ # Application
core/
migrations/
__init__.py
templates/ # Application templates
myapp/
index.html
static/
myapp/
js/
css/
images/
__init__.py
admin.py
apps.py
forms.py
models.py
models_foo.py
models_bar.py
views.py
templatetags/ # Application with custom context processors and template tags
__init__.py
context_processors.py
templatetags/
__init__.py
templatetag_extras.py
gulpfile.js
manage.py
requirements.txt
I think this:
settings.py
settings_dev.py
settings_production.py
is better than this:
settings/__init__.py
settings/base.py
settings/dev.py
settings/production.py
This concept applies to other files as well.
I usually place node_modules/ and bower_components/ in the project directory within the default static/ folder.
Sometime a vendor/ directory for Git Submodules but usually I place them in the static/ folder.
As per the Django Project Skeleton, the proper directory structure that could be followed is :
[projectname]/ <- project root
├── [projectname]/ <- Django root
│ ├── __init__.py
│ ├── settings/
│ │ ├── common.py
│ │ ├── development.py
│ │ ├── i18n.py
│ │ ├── __init__.py
│ │ └── production.py
│ ├── urls.py
│ └── wsgi.py
├── apps/
│ └── __init__.py
├── configs/
│ ├── apache2_vhost.sample
│ └── README
├── doc/
│ ├── Makefile
│ └── source/
│ └── *snap*
├── manage.py
├── README.rst
├── run/
│ ├── media/
│ │ └── README
│ ├── README
│ └── static/
│ └── README
├── static/
│ └── README
└── templates/
├── base.html
├── core
│ └── login.html
└── README
Refer https://django-project-skeleton.readthedocs.io/en/latest/structure.html for the latest directory structure.
Here is what I follow on My system.
All Projects: There is a projects directory in my home folder i.e. ~/projects. All the projects rest inside it.
Individual Project: I follow a standardized structure template used by many developers called django-skel for individual projects. It basically takes care of all your static file and media files and all.
Virtual environment: I have a virtualenvs folder inside my home to store all virtual environments in the system i.e. ~/virtualenvs . This gives me flexibility that I know what all virtual environments I have and can look use easily
The above 3 are the main partitions of My working environment.
All the other parts you mentioned are mostly dependent on project to project basis (i.e. you might use different databases for different projects). So they should reside in their individual projects.
You can use https://github.com/Mischback/django-project-skeleton repository.
Run below command:
$ django-admin startproject --template=https://github.com/Mischback/django-project-skeleton/archive/development.zip [projectname]
The structure is something like this:
[projectname]/ <- project root
├── [projectname]/ <- Django root
│ ├── __init__.py
│ ├── settings/
│ │ ├── common.py
│ │ ├── development.py
│ │ ├── i18n.py
│ │ ├── __init__.py
│ │ └── production.py
│ ├── urls.py
│ └── wsgi.py
├── apps/
│ └── __init__.py
├── configs/
│ ├── apache2_vhost.sample
│ └── README
├── doc/
│ ├── Makefile
│ └── source/
│ └── *snap*
├── manage.py
├── README.rst
├── run/
│ ├── media/
│ │ └── README
│ ├── README
│ └── static/
│ └── README
├── static/
│ └── README
└── templates/
├── base.html
├── core
│ └── login.html
└── README
Related
Ideal Architecture for Django Projects [duplicate]
Closed. This question is opinion-based. It is not currently accepting answers. Want to improve this question? Update the question so it can be answered with facts and citations by editing this post. Closed 1 year ago. The community reviewed whether to reopen this question 1 year ago and left it closed: Original close reason(s) were not resolved Improve this question I know there is actually no single right way. However I've found that it's hard to create a directory structure that works well and remain clean for every developer and administrator. There is some standard structure in most projects on github. But it does not show a way to organize another files and all projects on pc. What is the most convenient way to organize all these directories on development machine? How do you name them, and how do you connect and deploy this to server? projects (all projects that your are working on) source files (the application itself) working copy of repository (I use git) virtual environment (I prefer to place this near the project) static root (for compiled static files) media root (for uploaded media files) README LICENSE documents sketches examples (an example project that uses the application provided by this project) database (in case sqlite is used) anything else that you usually need for successful work on project The problems that I want to solve: Good names of directories so that their purpose is clear. Keeping all project files (including virtualenv) in one place, so I can easily copy, move, archive, remove whole project or estimate disk space usage. Creating multiple copies of some selected file sets such as entire application, repository or virtualenv, while keeping single copy of another files that I don't want to clone. Deploying right set of files to the server simply by rsyncing selected one dir.
There're two kind of Django "projects" that I have in my ~/projects/ directory, both have a bit different structure.: Stand-alone websites Pluggable applications Stand-alone website Mostly private projects, but doesn't have to be. It usually looks like this: ~/projects/project_name/ docs/ # documentation scripts/ manage.py # installed to PATH via setup.py project_name/ # project dir (the one which django-admin.py creates) apps/ # project-specific applications accounts/ # most frequent app, with custom user model __init__.py ... settings/ # settings for different environments, see below __init__.py production.py development.py ... __init__.py # contains project version urls.py wsgi.py static/ # site-specific static files templates/ # site-specific templates tests/ # site-specific tests (mostly in-browser ones) tmp/ # excluded from git setup.py requirements.txt requirements_dev.txt pytest.ini ... Settings The main settings are production ones. Other files (eg. staging.py, development.py) simply import everything from production.py and override only necessary variables. For each environment, there are separate settings files, eg. production, development. I some projects I have also testing (for test runner), staging (as a check before final deploy) and heroku (for deploying to heroku) settings. Requirements I rather specify requirements in setup.py directly. Only those required for development/test environment I have in requirements_dev.txt. Some services (eg. heroku) requires to have requirements.txt in root directory. setup.py Useful when deploying project using setuptools. It adds manage.py to PATH, so I can run manage.py directly (anywhere). Project-specific apps I used to put these apps into project_name/apps/ directory and import them using relative imports. Templates/static/locale/tests files I put these templates and static files into global templates/static directory, not inside each app. These files are usually edited by people, who doesn't care about project code structure or python at all. If you are full-stack developer working alone or in a small team, you can create per-app templates/static directory. It's really just a matter of taste. The same applies for locale, although sometimes it's convenient to create separate locale directory. Tests are usually better to place inside each app, but usually there is many integration/functional tests which tests more apps working together, so global tests directory does make sense. Tmp directory There is temporary directory in project root, excluded from VCS. It's used to store media/static files and sqlite database during development. Everything in tmp could be deleted anytime without any problems. Virtualenv I prefer virtualenvwrapper and place all venvs into ~/.venvs directory, but you could place it inside tmp/ to keep it together. Project template I've created project template for this setup, django-start-template Deployment Deployment of this project is following: source $VENV/bin/activate export DJANGO_SETTINGS_MODULE=project_name.settings.production git pull pip install -r requirements.txt # Update database, static files, locales manage.py syncdb --noinput manage.py migrate manage.py collectstatic --noinput manage.py makemessages -a manage.py compilemessages # restart wsgi touch project_name/wsgi.py You can use rsync instead of git, but still you need to run batch of commands to update your environment. Recently, I made django-deploy app, which allows me to run single management command to update environment, but I've used it for one project only and I'm still experimenting with it. Sketches and drafts Draft of templates I place inside global templates/ directory. I guess one can create folder sketches/ in project root, but haven't used it yet. Pluggable application These apps are usually prepared to publish as open-source. I've taken example below from django-forme ~/projects/django-app/ docs/ app/ tests/ example_project/ LICENCE MANIFEST.in README.md setup.py pytest.ini tox.ini .travis.yml ... Name of directories is clear (I hope). I put test files outside app directory, but it really doesn't matter. It is important to provide README and setup.py, so package is easily installed through pip.
My answer is inspired on my own working experience, and mostly in the book Two Scoops of Django which I highly recommend, and where you can find a more detailed explanation of everything. I just will answer some of the points, and any improvement or correction will be welcomed. But there also can be more correct manners to achieve the same purpose. Projects I have a main folder in my personal directory where I maintain all the projects where I am working on. Source Files I personally use the django project root as repository root of my projects. But in the book is recommended to separate both things. I think that this is a better approach, so I hope to start making the change progressively on my projects. project_repository_folder/ .gitignore Makefile LICENSE.rst docs/ README.rst requirements.txt project_folder/ manage.py media/ app-1/ app-2/ ... app-n/ static/ templates/ project/ __init__.py settings/ __init__.py base.py dev.py local.py test.py production.py ulrs.py wsgi.py Repository Git or Mercurial seem to be the most popular version control systems among Django developers. And the most popular hosting services for backups GitHub and Bitbucket. Virtual Environment I use virtualenv and virtualenvwrapper. After installing the second one, you need to set up your working directory. Mine is on my /home/envs directory, as it is recommended on virtualenvwrapper installation guide. But I don't think the most important thing is where is it placed. The most important thing when working with virtual environments is keeping requirements.txt file up to date. pip freeze -l > requirements.txt Static Root Project folder Media Root Project folder README Repository root LICENSE Repository root Documents Repository root. This python packages can help you making easier mantaining your documentation: reStructuredText Sphinx Sketches Examples Database
I don't like to create a new settings/ directory. I simply add files named settings_dev.py and settings_production.py so I don't have to edit the BASE_DIR. The approach below increase the default structure instead of changing it. mysite/ # Project conf/ locale/ en_US/ fr_FR/ it_IT/ mysite/ __init__.py settings.py settings_dev.py settings_production.py urls.py wsgi.py static/ admin/ css/ # Custom back end styles css/ # Project front end styles fonts/ images/ js/ sass/ staticfiles/ templates/ # Project templates includes/ footer.html header.html index.html myapp/ # Application core/ migrations/ __init__.py templates/ # Application templates myapp/ index.html static/ myapp/ js/ css/ images/ __init__.py admin.py apps.py forms.py models.py models_foo.py models_bar.py views.py templatetags/ # Application with custom context processors and template tags __init__.py context_processors.py templatetags/ __init__.py templatetag_extras.py gulpfile.js manage.py requirements.txt I think this: settings.py settings_dev.py settings_production.py is better than this: settings/__init__.py settings/base.py settings/dev.py settings/production.py This concept applies to other files as well. I usually place node_modules/ and bower_components/ in the project directory within the default static/ folder. Sometime a vendor/ directory for Git Submodules but usually I place them in the static/ folder.
As per the Django Project Skeleton, the proper directory structure that could be followed is : [projectname]/ <- project root ├── [projectname]/ <- Django root │ ├── __init__.py │ ├── settings/ │ │ ├── common.py │ │ ├── development.py │ │ ├── i18n.py │ │ ├── __init__.py │ │ └── production.py │ ├── urls.py │ └── wsgi.py ├── apps/ │ └── __init__.py ├── configs/ │ ├── apache2_vhost.sample │ └── README ├── doc/ │ ├── Makefile │ └── source/ │ └── *snap* ├── manage.py ├── README.rst ├── run/ │ ├── media/ │ │ └── README │ ├── README │ └── static/ │ └── README ├── static/ │ └── README └── templates/ ├── base.html ├── core │ └── login.html └── README Refer https://django-project-skeleton.readthedocs.io/en/latest/structure.html for the latest directory structure.
Here is what I follow on My system. All Projects: There is a projects directory in my home folder i.e. ~/projects. All the projects rest inside it. Individual Project: I follow a standardized structure template used by many developers called django-skel for individual projects. It basically takes care of all your static file and media files and all. Virtual environment: I have a virtualenvs folder inside my home to store all virtual environments in the system i.e. ~/virtualenvs . This gives me flexibility that I know what all virtual environments I have and can look use easily The above 3 are the main partitions of My working environment. All the other parts you mentioned are mostly dependent on project to project basis (i.e. you might use different databases for different projects). So they should reside in their individual projects.
You can use https://github.com/Mischback/django-project-skeleton repository. Run below command: $ django-admin startproject --template=https://github.com/Mischback/django-project-skeleton/archive/development.zip [projectname] The structure is something like this: [projectname]/ <- project root ├── [projectname]/ <- Django root │ ├── __init__.py │ ├── settings/ │ │ ├── common.py │ │ ├── development.py │ │ ├── i18n.py │ │ ├── __init__.py │ │ └── production.py │ ├── urls.py │ └── wsgi.py ├── apps/ │ └── __init__.py ├── configs/ │ ├── apache2_vhost.sample │ └── README ├── doc/ │ ├── Makefile │ └── source/ │ └── *snap* ├── manage.py ├── README.rst ├── run/ │ ├── media/ │ │ └── README │ ├── README │ └── static/ │ └── README ├── static/ │ └── README └── templates/ ├── base.html ├── core │ └── login.html └── README
Custom Robotframework Library needs to be called as MyModule.MyModule when in PIP
As I'm finishing up development of my Library/Listener I've come to the stage where I'm packaging up my files for PIP delivery. Now I'm running into an issue where I have to load my custom Robot library as MyLibrary.MyLibrary in a robot file instead of the desired singular MyLibrary. Library MyLibrary.MyLibrary some input string The corresponding python project structure is: robotframework-mylib/ ├── MyLibrary/ │ ├── __init__.py │ ├── MyLibrary.py │ ├── MyListener.py │ └──utils.py ├── LICENSE.txt ├── README.rst └── setup.py The distribution I create using the regular python setup.py sdist command. Then I install it using pip install robotframework-mylib-1.0.0.tar.gz. To my knowledge two consecutive names is condensed to a singular one, but perhaps this is dependent on something in __init__.py or setup.py but then this detail eludes me. Help and constructive criticism or questions are appreciated.
The underlying was a pure Python problem and had nothing to do with Robot Framework. In the __init__.py the required libraries were mentioned in the __all__ section, but were not imported. When I added the import the main module was accessible again through it's singular name.
Django: how to startapp inside an "apps" folder
I feel like I must be looking over something obvious because I am having trouble finding anything online about this. But basically here it is, I have a django Project, and I would like to store my apps inside of an apps folder, like thus... myproject/ client-side/ media/ static/ templates/ apps/ app1/ app2/ etc. __init__.py manage.py etc. (rest of root directory) but have been unable to figure out how to >>>python manage.py startapp newapp and have it placed into the /apps/ folder. Is it ok to simply ok to startapp at the root level and manually move them into the /apps/ folder? I greatly appreciate your thoughts and answers. FYI running python 3.4.2 and Django 1.9.5 on Windows 10
You can specify the app's directory as a second parameter: python manage.py startapp <app_name> <app_directory> Note that no directory will be created, the app's files will be created directly in the specified directory. Example: python manage.py startapp myapp apps/myapp Will result in the given directory structure: apps └── myapp ├── __init__.py ├── admin.py ├── apps.py ├── migrations │ └── __init__.py ├── models.py ├── tests.py └── views.py Also note that the command won't create the directory for you. Edit: as another (now deleted) answer pointed out, running the command from the apps directory would also work: cd apps python ../manage.py startapp myapp
You can also use the django-admin command as well. cd apps && django-admin startapp app_1 this will work as well
Importing modules in python script and figuring out layout of directory/package
I am very new to python...and I have been reading around trying to figure out a better answer... but I am still struggling. I was trying to import some script to get code talking to each other. I've tried importing as suggested via python documentation: from SomePackage.somefile import object The actual directory looks like this Foo/ ├── bin │ ├── README.txt ├── setup.py ├── development.ini ├── SomePackage │ ├── somefile │ │ ├── __init__.py │ │ ├── object.py │ ├── __init__.py Do I need to import in my .py file with? Each module has an empty init.py file. Should I move where my program is located? Any help is truly appreciated!!
I figured out the issue! I need to create a setup.py document that created the packages and modules! setup( #contents packages=['somepackage', 'somepackage.someotherpackage'], py_modules=['somepackage.module.file.py'], scripts=['bin/somescript-cmd'], #more code...
Merging an independent Git repo with another Git repo that is a conduit with Subversion: avoiding duplication when merging
I am happily developing a Django project in my own Git repo on my localhost. I am creating branches, committing and merging happily. The path is something like: /path/to/git/django/ and the structure is: project ├── README ├── REQUIREMENTS ├── __init__.py ├── fabfile.py ├── app1 ├── manage.py ├── app2 ├── app3 ├── app4 └── project The rest of my development team still use Subversion, which is one giant repo with multiple projects. When I am working with that on my localhost I am still using Git (via git-svn). The path is something like /path/to/giant-svn-repo/ Projects live under this like: giant-svn-repo |── project1 |── project2 |── project3 └── project4 When I want to work with the latest changes from the remote svn repo I just do a git-svn rebase. Then for new features I create a new branch, develop, commit, checkout master, merge branch with master, delete branch, and then a final git-svn dcommit. Cool. Everything works well. These two repositories (lets call them git-django and git-svn) are completely independent right now. Now I want to add git-django into the git-svn repo as a new project (ie. in a child directory called djangoproject). I have this working pretty well, using the following workflow: cd into git-svn repo Create a new branch in the git-svn repo Make a new directory to host my django project Add a new remote that links to my original Django project Merge the remote into my local directory Read-tree with the prefix of relative path djangoproject so it puts the codebase into the correct location based on the root of git-svn repo Commit the changes so everything gets dumped into the correct place From the command line this looks like: > cd /path/to/giant-svn-repo > git checkout -b my_django_project > mkdir /path/to/giant-svn-repo/djangoproject > git remote add -f local_django_dev /path/to/git/django/project > git merge -s ours --no-commit local_django_dev/master > git read-tree --prefix=djangoproject -u local_django_dev/master > git commit -m 'Merged local_django_dev into subdirectory djangoproject' This works, but in addition to the contents of the django git repo being in /path/to/giant-svn-repo/djangoproject it is also in the main root of the repository tree! project ├── README ├── REQUIREMENTS ├── __init__.py ├── fabfile.py ├── djangoproject │ ├── README │ ├── REQUIREMENTS │ ├── __init__.py │ ├── fabfile.py │ ├── app1 │ ├── manage.py │ ├── app2 │ ├── app3 │ ├── app4 │ └── project ├── app1 ├── manage.py ├── app2 ├── app3 ├── app4 └── project I seem to have polluted the parent directory where all the projects of the giant-svn-repo are located. Is there any way I can stop this happening? (BTW this has all been done in a test directory structure - I haven't corrupted anything yet. Just trying to figure out the best way to do it) I am sure it is just (re)defining one more argument to either git merge, git read-tree or git commit but I am pretty much at my limit of git kung-fu. Thanks in advance.