Many hyperlinks are disabled.
Use anonymous login
to enable hyperlinks.
Overview
| Comment: | First draft of the "history.md" documentation file. This file is far from complete and has not yet be integrated into the permuted index. |
|---|---|
| Downloads: | Tarball | ZIP archive |
| Timelines: | family | ancestors | descendants | both | trunk |
| Files: | files | file ages | folders |
| SHA3-256: |
8c6aca20adb26442bb006de2c21dc97a |
| User & Date: | drh 2020-04-11 20:55:06.825 |
Context
|
2020-04-11
| ||
| 23:19 | Edits to the history of Fossil. Add the history of fossil to the permuted index as a primary document, replacing the (unmaintained) FAQ. check-in: b8ad564dc5 user: drh tags: trunk | |
| 22:35 | Merged from trunk Closed-Leaf check-in: 2f24675ab5 user: ashepilko tags: api-cleanup | |
| 20:55 | First draft of the "history.md" documentation file. This file is far from complete and has not yet be integrated into the permuted index. check-in: 8c6aca20ad user: drh tags: trunk | |
| 12:15 | Add a warning to the qandc.wiki page that it is old and out-of-date. check-in: 07605f369c user: drh tags: trunk | |
Changes
Changes to www/faq.wiki.
1 2 3 | <title>Fossil FAQ</title> <h1 align="center">Frequently Asked Questions</h1> | | > > | 1 2 3 4 5 6 7 8 9 10 11 12 13 | <title>Fossil FAQ</title> <h1 align="center">Frequently Asked Questions</h1> <p>Note: This page is old and has not been kept up-to-date. See the [/finfo?name=www/faq.wiki|change history of this page].</p> <ol> <li><a href="#q1">What GUIs are available for fossil?</a></li> <li><a href="#q2">What is the difference between a "branch" and a "fork"?</a></li> <li><a href="#q3">How do I create a new branch?</a></li> <li><a href="#q4">How do I tag a check-in?</a></li> <li><a href="#q5">How do I create a private branch that won't get pushed back to the |
| ︙ | ︙ |
Added www/history.md.
> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 | # The History And Purpose Of Fossil Fossil is a [distributed version control system (DVCS)][1] written beginning in [2007][2] by the [architect of SQLite][3] for the purpose of managing the [SQLite project][4]. [1]: https://en.wikipedia.org/wiki/Distributed_version_control [2]: /timeline?a=1970-01-01&n=10 [3]: https://sqlite.org/crew.html [4]: https://sqlite.org/ Though Fossil was originally written specifically to support SQLite, it is now also used by many other projects. The SQLite architect (drh) is still the top committer to Fossil, but there are [many contributors][5]. [5]: /reports?type=ci&view=byuser ## History The SQLite project start out using [CVS][6], as CVS was the mostly commonly used version control system in that era (circa 2000). CVS was an amazing version control system for its day in that it allowed multiple developers to be editing the same file at the same time. [6]: https://en.wikipedia.org/wiki/Concurrent_Versions_System Though innovative and much loved in its time, CVS was not without problems. Among those was a lack of visibility into the project history and the lack of integrated bug tracking. To try to address these deficiencies, the SQLite author developed the [CVSTrac][7] wrapper for CVS beginning in [2002][8]. [7]: http://cvstrac.org/ [8]: http://cvstrac.org/fossil/timeline?a=19700101&n=10 CVSTrac greatly improved the usability of CVS and was adopted by other projects. CVSTrac also [inspired the design][9] of [Trac][10], which was a similar system that was (and is) far more widely used. [9]: https://trac.edgewall.org/wiki/TracHistory [10]: https://trac.edgewall.org/ Historians can see the influence of CVSTrac on the development of SQLite. [Early SQLite check-ins][11] that happened before CVSTrac was available often had a check-in comment which was just a "smiley". That was not an unreasonable check-in comment, as check-in comments were scarcely seen and of questionable utility in CVS. CVSTrac changed that, making check-in comments more visible and more useful. The SQLite developers reacted by creating [better check-in comments][12]. [11]: https://sqlite.org/src/timeline?a=19700101&n=10 [12]: https://sqlite.org/src/timeline?c=20030101&n=10&nd At about this same time, the [Monotone][13] system appeared ([website][14]). Monotone was one of the first distributed version control systems. As far as this author is aware, Monotone was the first VCS to make use of SHA1 to identify artifacts. Monotone stored its content in an SQLite database, which is what brought it to the attention of the SQLite architect. [13]: https://en.wikipedia.org/wiki/Monotone_(software) [14]: https://www.monotone.ca/ Beginning around 2005, the need for a better version control system for SQLite began to become evident. The SQLite architect looked around for a suitable replacement. Monotone, Git, and Mercurical were all considered. But that that time, none of these supported sync over ordinary HTTP, none could be run from an inexpensive shell account on a leased server (this was before the widespread availability of affordable virtual machines), and none of them supported anything resembling the wiki and ticket features of CVSTrac that had been found to be so useful. And so, the SQLite architect began writing his own DVCS. Early prototypes were done in [TCL][15]. As experiments proceeded, however, it was found that the low-level byte manipulates needed for things like delta compression and computing diffs were better implemented in plain old C. Experiments continued. Finally, a prototype capable of self-hosting was devised on [2007-07-16][16]. [15]: https://www.tcl.tk/ [16]: https://fossil-scm.org/fossil/timeline?c=200707211410&n=10 The first project hosted by Fossil was Fossil itself. After a few months of development work, the code was considered stable enough to begin hosting the [SQLite documentation repository][17] which was split off from the main SQLite CVS repository on [2007-11-12][18]. [17]: https://www.sqlite.org/docsrc/doc/trunk/README.md [18]: https://www.sqlite.org/docsrc/timeline?c=200711120345&n=10 Finally, after two years of development work on Fossil, the SQLite source code itself was transfered to Fossil on [2009-08-11][19]. [19]: https://sqlite.org/src/timeline?c=b0848925babde524&n=12&y=ci |