return 1;
}
-t_LstArticulos *art_cargar(const char *filename, int tipo)
+t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque)
{
xmlDocPtr document;
xmlNode *node, *inicio;
- int cant, error = 0, i;
+ int error = 0, i;
EMUFS_REG_SIZE size;
t_LstArticulos *tmp;
lst_articulos = NULL;
- EMUFS_REG_ID id;
+ EMUFS_REG_ID id, *indices, indices_cant;
tmp = (t_LstArticulos *)malloc(sizeof(t_LstArticulos));
if (tmp == NULL) return NULL;
node = node->next;
}
- tmp->fp = emufs_crear("articulos", tipo-1, sizeof(t_Articulo)*40+128, sizeof(t_Articulo));
+ tmp->fp = emufs_crear("articulos", tipo-1, tam_bloque, sizeof(t_Articulo));
for (node=inicio ; node ; node = node->next) {
if (node->type == XML_ELEMENT_NODE) {
if (strcmp(node->name, "ARTICULO") == 0) {
t_Articulo art;
void *save;
+ memset(&art, '*', sizeof(t_Articulo));
art.numero = atoi(xmlGetProp(node, "NroArtículo"));
- strncpy(art.desc, xmlGetProp(node, "Descripción"), 50);
- strncpy(art.presentacion, xmlGetProp(node, "Presentación"), 30);
- strncpy(art.existencia, xmlGetProp(node, "Existencia"), 8);
+ strcpy(art.desc, xmlGetProp(node, "Descripción"));
+ strcpy(art.presentacion, xmlGetProp(node, "Presentación"));
+ strcpy(art.existencia, xmlGetProp(node, "Existencia"));
/*strncpy(tmp->array[cant].ubicacion, xmlGetProp(node, "Ubicacion"), 30);*/
- strncpy(art.pvu, xmlGetProp(node, "PVU"), 8);
- strncpy(art.emin, xmlGetProp(node, "Emín"), 8);
+ strcpy(art.pvu, xmlGetProp(node, "PVU"));
+ strcpy(art.emin, xmlGetProp(node, "Emín"));
/* Ya leido el articulo ahora paso a guardarlo en el archivo y agregarlo a la lista */
save = procesar_guardar_articulo(&art, &size, lst_articulos);
if (save != NULL) {
} else {
tmp->fp = emufs_abrir("articulos");
/* Ahora trato de recuperar la info */
- cant = emufs_idx_get_count(tmp->fp);
- for(i=0; i<cant; i++) {
+ indices = emufs_idx_get(tmp->fp, &indices_cant);
+ for(i=0; i<indices_cant; i++) {
t_Articulo art;
void *save;
- id = emufs_idx_get_id_at(tmp->fp, i);
/* Leo el registro */
- save = tmp->fp->leer_registro(tmp->fp, id, &size, &error);
+ save = tmp->fp->leer_registro(tmp->fp, indices[i], &size, &error);
if (procesar_leer_articulo(&art, save, size, tmp) == 1) {
- agregar_nodo_articulo(tmp, crear_nodo_articulo(id, art.numero));
+ agregar_nodo_articulo(tmp, crear_nodo_articulo(indices[i], art.numero));
free(save);
}
}
+ free(indices);
}
return tmp;
/* Lleno el lugar no ocupado de los strings con *, para que el ver
* registro se vea bien
*/
- i[0] = sizeof(unsigned int);
- i[1] = sizeof(char)*(strlen(src->desc)+1);
- i[2] = sizeof(char)*(strlen(src->presentacion)+1);
- i[3] = sizeof(char)*(strlen(src->existencia)+1);
-/* i[4] = sizeof(char)*(strlen(src->ubicacion)+1); */
- i[4] = sizeof(char)*(strlen(src->pvu)+1);
- i[5] = sizeof(char)*(strlen(src->emin)+1);
tmp = (char *)malloc(sizeof(t_Articulo));
- if (tmp == NULL) return NULL;
- memcpy(tmp, from, i[0]);
- memcpy(tmp+i[0], from+i[0], i[1]); memset(tmp+i[0]+i[1], '*', 51-i[1]);
- memcpy(tmp+i[0]+51, from+i[0]+51, i[2]); memset(tmp+i[0]+51+i[2], '*', 31-i[2]);
- memcpy(tmp+i[0]+82, from+i[0]+82, i[3]); memset(tmp+i[0]+82+i[3], '*', 9-i[3]);
- memcpy(tmp+i[0]+91, from+i[0]+91, i[4]); memset(tmp+i[0]+91+i[4], '*', 9-i[4]);
- memcpy(tmp+i[0]+100, from+i[0]+100, i[5]); memset(tmp+i[0]+100+i[5], '*', 9-i[5]);
-
+ memcpy(tmp, from, sizeof(t_Articulo));
(*size) = sizeof(t_Articulo);
}
return tmp;