From 78725557a028004d6e03a6ce82856eae282a1a8f Mon Sep 17 00:00:00 2001 From: Ludovic Pouzenc Date: Fri, 18 Feb 2011 17:06:00 +0000 Subject: 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. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit git-svn-id: file:///var/svn/2011-ddhardrescue/trunk@2 d3078510-dda0-49f1-841c-895ef4b7ec81 --- src/slices.c | 53 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100755 src/slices.c (limited to 'src/slices.c') 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 +#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; +} -- cgit v1.2.3