X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/78ff3129342b5ae75673aac710820805fe5e3f41..32e8d7768f2eea899ca5166f75c2c55a672d7f79:/emufs/indices.c?ds=sidebyside diff --git a/emufs/indices.c b/emufs/indices.c index c7235d9..1728d19 100644 --- a/emufs/indices.c +++ b/emufs/indices.c @@ -100,6 +100,7 @@ CLAVE emufs_indice_generar_clave_desde_valor(INDICE *idx, char *data) { int error; CLAVE k; + char salvar[100]; if (idx == NULL) PERR("NULL INDEX!"); switch (idx->tipo_dato) { @@ -114,13 +115,14 @@ CLAVE emufs_indice_generar_clave_desde_valor(INDICE *idx, char *data) * Ver de borrarla despues de usarla */ error = 0; - PERR("VOY A GRABAR TEXTO EN ARCHIVO"); + /* Le agrego un * para diferenciarla, porque no la tengo abreviada! */ + /* Hack feo :-D */ + sprintf(salvar, "*%s", data); k.i_clave = idx->emu_string->grabar_registro(idx->emu_string, - data, - strlen(data)+1, + salvar, + strlen(salvar)+1, &error ); - fprintf(stderr, "GENERE CLAVE CON (%s) y estoy en ID=%d\n", data, k.i_clave); } return k; @@ -154,7 +156,7 @@ int emufs_indice_es_menor(INDICE *idx, CLAVE c1, CLAVE c2) { char *sc1, *sc2; /* Si es IDX_STRING aca pongo los strings leidos */ EMUFS_REG_SIZE dummy; /* No me interesa el tamaño del string aca! */ - int error=0; + int error=0, a, b; switch (idx->tipo_dato) { case IDX_FLOAT: @@ -164,7 +166,11 @@ int emufs_indice_es_menor(INDICE *idx, CLAVE c1, CLAVE c2) case IDX_STRING: sc1 = idx->emu_string->leer_registro(idx->emu_string, c1, &dummy, &error); sc2 = idx->emu_string->leer_registro(idx->emu_string, c2, &dummy, &error); - error = (strcmp(sc1, sc2) < 0); + /* Salteo el caracter que indica si la clave en temporal */ + a = b = 0; + if (*sc1 == '*') a = 1; + if (*sc2 == '*') b = 1; + error = (strcmp(sc1+a, sc2+b) < 0); free(sc1); free(sc2); return error; @@ -176,7 +182,7 @@ int emufs_indice_es_igual(INDICE *idx, CLAVE c1, CLAVE c2) { char *sc1, *sc2; /* Si es IDX_STRING aca pongo los strings leidos */ EMUFS_REG_SIZE dummy; /* No me interesa el tamaño del string aca! */ - int error; + int error, a, b; switch (idx->tipo_dato) { case IDX_FLOAT: @@ -188,9 +194,13 @@ int emufs_indice_es_igual(INDICE *idx, CLAVE c1, CLAVE c2) sc1 = idx->emu_string->leer_registro(idx->emu_string, c1, &dummy, &error); error = 0; sc2 = idx->emu_string->leer_registro(idx->emu_string, c2, &dummy, &error); - error = (strcmp(sc1, sc2) == 0); - if (sc1) free(sc1); - if (sc2) free(sc2); + /* Salteo el caracter que indica si la clave en temporal */ + a = b = 0; + if (*sc1 == '*') a=1; + if (*sc2 == '*') b=1; + error = (strcmp(sc1+a, sc2+b) == 0); + free(sc1); + free(sc2); return error; } return 0;