summaryrefslogtreecommitdiff
path: root/fsck-cache.c
AgeCommit message (Collapse)AuthorFilesLines
2005-04-20Do SHA1 hash _before_ compression.Libravatar Linus Torvalds1-5/+6
And add a "convert-cache" program to convert from old-style to new-style.
2005-04-18Make fsck-cache print the object type for unreachable objects.Libravatar Linus Torvalds1-1/+1
This got lost when I updated to Daniel's new object model.
2005-04-18Merge the new object model thing from Daniel BarkalowLibravatar Linus Torvalds1-70/+35
This was a real git merge with conflicts. I'll commit the scripts I used to do the merge next. Not pretty, but it's half-way functional.
2005-04-18[PATCH] Port fsck-cache to use parsing functionsLibravatar Daniel Barkalow1-70/+36
This ports fsck-cache to use parsing functions. Note that performance could be improved here by only reading each object once, but this requires somewhat more complicated flow control. Signed-Off-By: Daniel Barkalow <barkalow@iabervon.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
2005-04-17Make the revision tracking track the object types too.Libravatar Linus Torvalds1-12/+12
This allows fsck to verify not just that an object exists, but also that it has the type it was expected to have.
2005-04-17Make "revision.h" slightly better to use.Libravatar Linus Torvalds1-1/+1
- mark_reachable() can be more generic, marking the reachable revisions with an arbitrary mask. - date parsing will parse to a date of 0 rather than ULONG_MAX for the bad old case, sorting the dates correctly.
2005-04-13Use common "revision.h" header for both fsck and rev-tree.Libravatar Linus Torvalds1-110/+1
It's really a very generic thing: the notion of one sha1 revision referring to another one. "fsck" uses it for all nodes, and "rev-tree" only tracks commit-node relationships, but the code was already the same - now we just make that explicit by moving it to a common header file.
2005-04-13Make 'fsck' able to take an arbitrary number of parents on theLibravatar Linus Torvalds1-14/+19
command line. "arbitrary" is a bit wrong, since it is limited by the argument size limit (128kB or so), but let's see if anybody ever cares. Arguably you should prune your tree before you have a few thousand dangling heads in your archive. We can fix it by passing in a file listing if we ever care.
2005-04-13Make fsck reachability avoid doing unnecessary work forLibravatar Linus Torvalds1-0/+3
parents that we reach multiple ways. This doesn't matter right now. It _will_ matter once we have complex revision graphs.
2005-04-13Make "fsck-cache" use the same revision tracking structure as "rev-tree".Libravatar Linus Torvalds1-76/+133
This makes things a lot more efficient, and makes it trivial to do things like reachability analysis. Add command line flags to tell what the head is, and whether to warn about unreachable objects.
2005-04-13[PATCH] Consolidate the error handlingLibravatar Petr Baudis1-2/+1
Now there is error() for "library" errors and die() for fatal "application" errors. usage() is now used strictly only for usage errors. Signed-off-by: Petr Baudis <pasky@ucw.cz>
2005-04-10Oops. Fix bad initialization of the "seen" array, causing us to notLibravatar Linus Torvalds1-1/+1
properly clear the reference count at init time. It happened to work for me by pure luck. Until it broke, and my unreferenced commit suddenly looked referenced again. Fixed.
2005-04-10Oops, the actual 'printf' for missing objects was missing.Libravatar Linus Torvalds1-0/+1
Which made fsck very quiet about objects it hadn't found. So add it. We'll need to make things like these optional, because it's perfectly ok to have partial history if you don't want it, and don't want to go backwards. But for development, it's best to always complain about missing sha1 object files that are referenced from somewhere else.
2005-04-10Add connectivity tracking to fsck.Libravatar Linus Torvalds1-4/+100
This shows that I've lost track of one commit already. Most likely because I forgot to update the .dircache/HEAD file when doing a commit, so that the next commit referenced not the top-of-tree, but the one older commit. Having dangling commits is fine (in fact, you should always have at least _one_ dangling commit in the top-of-tree). But it's good to know about them.
2005-04-09Make fsck-cache warn about old-style tree objects that have fullLibravatar Linus Torvalds1-0/+9
pathnames in them. We're migrating away from that. This will cause tons of warnings for the current "sparse" archive, but hell, better now than later.
2005-04-09Teach "fsck" and "read-tree" about recursive tree-nodes.Libravatar Linus Torvalds1-2/+3
This is totally untested, since we can't actually _write_ things that way yet, but I'll get to that next, I hope. That should fix the huge wasted space for kernel-sized tree objects.
2005-04-09Make "fsck-cache" print out all the root commits it finds.Libravatar Linus Torvalds1-0/+5
Once I do the reference tracking, I'll also make it print out all the HEAD commits it finds, which is even more interesting.
2005-04-09Fix missing return values and some error tests for empty index filesLibravatar Linus Torvalds1-0/+2
Patches from Dave Jones and Ingo Molnar, but since I don't have any infrastructure in place to use the old patch applicator scripts I am trying to build up, I ended up fixing the thing by hand instead. Credit where credit is due, though. Nice to see that people are taking a look at the project even in this early stage.
2005-04-08Make fsck-cache start parsing the object types, and checking theirLibravatar Linus Torvalds1-11/+42
internal format. This doesn't yet check the reachability information, but we're getting there.. Slowly.
2005-04-08Add first cut at "fsck-cache" that validates the SHA1 object store.Libravatar Linus Torvalds1-0/+106
It doesn't complain about mine. But it also doesn't yet check for inter-object reachability etc.