Fossil

Artifact [8b55a3bf]
Login

Artifact 8b55a3bfa37e1bbd00264b1471392c311f0523dfe2d241ed7c12e3ab5cd6794a:

Wiki page [Fossil-NG] by drh 2017-11-18 20:32:20.
D 2017-11-18T20:32:20.872
L Fossil-NG
N text/x-markdown
U drh
W 1614
## Overview

This is a discussion format and record of ideas for the
"Fossil - Next Generation" or Fossil-NG.  As this sentence is
being written (2017-11-18) there is no code in place for Fossil-NG.

## Goals

The first goal of Fossil-NG is to enhance and improve the Fossil user
experience based on lessons learned from 11 years using and maintaining
legacy Fossil.  New capabilities include:

  +  **Shallow Clones** - the ability to clone just the recent history
     of a project

  +  **Narrow Clones** - the ability to clone a subset of a project,
     for example to clone only the files in the "src/" directory and
     omit all of the files in the "test/" directory.

  +  **Selective Sync** - the ability to push/pull/sync since branches.

In the 11 years since Fossil was created, Git has become the dominate
version control system.  This is unfortunate, because of the various
version control systems available today, Git is the least user-friendly.
Nevertheless, there is no denying that any new version control system
(VCS) will need to deal effectively with the Git legacy.  For this
reason, one important goal of Fossil-NG is to allow seamless integration
with legacy Git repositories.

The primary and most important purpose of Fossil is to support the
development of the [SQLite](https://sqlite.org/) project.  Legacy
Fossil has succeeded fabulously in that respect.  Any changes implemented
for Fossil-NG must respect that history.  In particular, Fossil-NG
must be able to import the complete SQLite history intact, without
any changes to hash identifiers.


Z b2822024d1c42052024795c1c62e24f3