-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
74 lines (55 loc) · 2.08 KB
/
README
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
======================================
hkvc simple source version control
======================================
v20200401IST0938, HanishKVC
Intro
=======
Allows one to track changes to a set of files in a simple way,
which doesnt require any special filesystem support, other than
hidden directory for now (even this requirement can be avoided
by updating the dictionary of paths at the beginning of the
code).
Useful for example, when storing or managing files on a plan 9
filesystem as used by chrome os (and inturn chromebooks) for the
shared folders between chrome os and its virtual containerised
linux instances.
It doesnt track meta data like owner info or date or permission
changes etc.
It provides a basic set of operations like
init
add
diff
commit
log
editcmsg
For Future
============
TODOs
----------
TODO01: do_diff fallback to checking working dir file against
copyDir version of the file, in case cacheDir doesnt have the
corresponding file (but has other files in it, due to which
autofall back to copyDir at the global level wont trigger).
TODO02: Implement commit -a, that is bring back the old
behavior for the cases, where one wants to commit all the
files which have changed in the working dir, without having
to first go thro the staging area in cacheDir, by calling
add for each file individually. Useful if too many files
have been changed.
TODO03: diff a specific file
TODO4: Remove the press key prompt when auto falling back
to copyDir based diff check, when cacheDir is empty.
Done
--------
Done01: Commit only select files
Make add copy to a temp cache dir within ssvc repository.
Inturn commit only commits changes which are there between
the temp cache dir and previously commited files.
This also ensures that the same logic can apply irrespective
of whether one is adding a file for the 1st time, or adding
it later after some changes have been made. Currently add
does commit related operations, which can be avoided with
this above logic.
This also gives more freedom to user to decide when to commit
what, rather than forcing everything to be commited at the
same time.