Loading of favorites from resource file added.

This commit is contained in:
Martin Dvorak 2014-03-29 13:19:15 +01:00
parent 0f32fe0c65
commit 105d66c75d
2 changed files with 62 additions and 43 deletions

View file

@ -19,22 +19,12 @@ void favorites_init(FavoriteItems *favorites)
{
favorites->items=NULL;
favorites->count=0;
favorites->loaded=false;
}
void favorites_load(FavoriteItems *favorites)
void favorites_get(FavoriteItems *favorites)
{
// TODO fake initialization instead of .hhrc load
favorites->count=2;
favorites->items=malloc(sizeof(char *)*favorites->count);
favorites->items[0]=malloc(2);
strcpy(favorites->items[0],"a");
favorites->items[1]=malloc(2);
strcpy(favorites->items[1],"b");
lazy loading (boolean indicator to FavoriteItems)
// TODO load from file
if(!favorites->loaded) {
char *home = getenv(ENV_VAR_HOME);
char *fileName=(char*)malloc(strlen(home)+1+strlen(FILE_HH_RC)+1);
strcpy(fileName,home);
@ -55,21 +45,49 @@ void favorites_load(FavoriteItems *favorites)
}
fclose(input_file);
file_contents[input_file_size] = 0;
} else {
fprintf(stderr,"\nHistory file not found: %s\n",fileName);
if(file_contents && strlen(file_contents)) {
favorites->count = 0;
char *p=strchr(file_contents,'\n');
while (p!=NULL) {
favorites->count++;
p=strchr(p+1,'\n');
}
if(file_contents) {
split & process & initilize favorites
favorites->items = malloc(sizeof(char*) * favorites->count);
int i = 0;
char *pb=file_contents, *pe;
pe=strchr(file_contents, '\n');
while(pe!=NULL) {
favorites->items[i]=pb;
*pe=0;
favorites->items[i]=strdup(pb);
pb=pe+1;
pe=strchr(pb, '\n');
i++;
}
free(file_contents);
}
} else {
// favorites file not found > favorites don't exist yet
favorites->loaded=true;
return;
}
}
}
void favorites_add(FavoriteItems *favorites, char *newFavorite)
{
if(favorites->count) {
favorites->items=realloc(favorites->items, sizeof(char *) * ++favorites->count);
favorites->items[favorites->count-1]=newFavorite;
favorites->items[favorites->count-1]=strdup(newFavorite);
favorites_choose(favorites, newFavorite);
} else {
favorites->items=malloc(sizeof(char*));
favorites->items[0]=strdup(newFavorite);
favorites->count=1;
}
favorites_save(favorites);
}
@ -96,15 +114,16 @@ void favorites_choose(FavoriteItems *favorites, char *choice)
void favorites_remove(FavoriteItems *favorites, char *almostDead)
{
// TODO: keept slot you have, just change count
// TODO: keep slot you have, just change count
favorites_save(favorites);
}
void favorites_save(FavoriteItems *favorites)
{
create/update history file
if(favorites->count) {
// TODO shrink file and rewrite it (can be shorter)
}
}
void favorites_destroy(FavoriteItems *favorites)

View file

@ -15,19 +15,19 @@
#define ENV_VAR_USER "USER"
#define ENV_VAR_HOME "HOME"
#define FILE_HH_RC ".hhrc"
#define FILE_HH_RC ".hh_favorites"
typedef struct {
char **items;
unsigned count;
bool loaded;
} FavoriteItems;
void favorites_init(FavoriteItems *favorites);
void favorites_load(FavoriteItems *favorites);
void favorites_get(FavoriteItems *favorites);
void favorites_add(FavoriteItems *favorites, char *favorite);
void favorites_choose(FavoriteItems *favorites, char *choice);
void favorites_remove(FavoriteItems *favorites, char *almostDead);
void favorites_save(FavoriteItems *favorites);
void favorites_destroy(FavoriteItems *favorites);
#endif