diff options
author | Ludovic Pouzenc <ludovic@pouzenc.fr> | 2011-02-18 17:06:00 +0000 |
---|---|---|
committer | Ludovic Pouzenc <ludovic@pouzenc.fr> | 2011-02-18 17:06:00 +0000 |
commit | 78725557a028004d6e03a6ce82856eae282a1a8f (patch) | |
tree | 784e507f65b4e9984e952e76a4e66ad228d9f261 /src/slices.c | |
parent | 4dc52777eb3e950f8758037f3e10f1b7e55957ba (diff) | |
download | 2011-ddhardrescue-78725557a028004d6e03a6ce82856eae282a1a8f.tar.gz 2011-ddhardrescue-78725557a028004d6e03a6ce82856eae282a1a8f.tar.bz2 2011-ddhardrescue-78725557a028004d6e03a6ce82856eae282a1a8f.zip |
Iport initial du projet. Compile presque, reste beaucoup de fonctions utilisataires pour les slices à coder (notamment slicesDump()) et manque une gestion multi-thread pour aficher pendant le recovery.
git-svn-id: file:///var/svn/2011-ddhardrescue/trunk@2 d3078510-dda0-49f1-841c-895ef4b7ec81
Diffstat (limited to 'src/slices.c')
-rwxr-xr-x | src/slices.c | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/src/slices.c b/src/slices.c new file mode 100755 index 0000000..edae571 --- /dev/null +++ b/src/slices.c @@ -0,0 +1,53 @@ +#include <string.h> +#include "slices.h" + +slice_t *sliceNew(address_t begin, address_t end, sliceStatus_t status, slice_t *next) { + slice_t *s = malloc(1*sizeof(slice_t)); + if (s!=NULL) { + s->begin=begin; + s->end=end; + s->status=status; + s->next=next; + } + + return s; +} + +int sliceSplit(slice_t *slice, address_t splitAt, sliceStatus_t statusBefore, sliceStatus_t statusAt, sliceStatus_t statusAfter) { + return 1; +} + +slices_t *slicesNew() { + slices_t *ss = malloc(1*sizeof(slices_t)); + if (ss!=NULL) { + ss->count=0; + ss->first=NULL; + ss->last=NULL; + } + + return ss; +} + +void slicesAppend(slices_t *slices, slice_t *slice) { + +} + +slice_t *slicesFindLargest(slices_t *slices, sliceStatus_t status) { + return NULL; +} + +char *slicesDump(slices_t *slices, int charCount, address_t begin, address_t end) { + slice_t *curr = slices->first; + address_t sb,se, blockSize=(end-begin)/(charCount+1); + char *dump=malloc(1*charCount+1); + memset(dump, ' ', charCount); + + while (curr != NULL) { + sb=curr->begin; + // TODO : boucle pour dessiner les caractères correspondant selon le type de zone. Attention aux cas ou 1 caractère contient la frontière de plusieurs zones (ne pas toujours écraser avec la dernière valeur) + + curr=curr->next; + } + + return dump; +} |