X-Git-Url: http://git.tuebingen.mpg.de/?p=adu.git;a=blobdiff_plain;f=create.c;h=2925d570d862b150b5786531c6a5dce51f5cb0e5;hp=47c715568d5e41e0f051eaf9530f920dcc167753;hb=c7d5ddb6906ab8a18181fee29ac78d604db5fdb9;hpb=89630c6c71b9f3202e5212d35877d6f907c6da44 diff --git a/create.c b/create.c index 47c7155..2925d57 100644 --- a/create.c +++ b/create.c @@ -4,51 +4,21 @@ * Licensed under the GPL v2. For licencing details see COPYING. */ -/** \file create.c The create mode of adu. */ +/** \file create.c \brief The create mode of adu. */ #include /* readdir() */ +#include "format.h" #include "adu.h" #include "gcc-compat.h" #include "cmdline.h" #include "fd.h" #include "string.h" #include "error.h" -#include "portable_io.h" +#include "user.h" /* Id of the device containing the base dir. */ static dev_t device_id; -static int write_uid(struct user_info *ui, void *data) -{ - char **p = data; - - write_u32(*p, ui->uid); - *p += sizeof(uint32_t); - return 1; -} - -static int write_uid_list(void) -{ - char *buf, *p, *filename; - uint32_t count = 0; - struct user_info *ui; - size_t size = num_uids * sizeof(uint32_t); - int ret; - - if (!num_uids) - return 0; - buf = p = adu_malloc(size); - ret = for_each_admissible_user(write_uid, &p); - if (ret < 0) - goto out; - filename = get_uid_list_name(); - ret = adu_write_file(filename, buf, size); - free(filename); -out: - free(buf); - return ret; -} - static int add_directory(char *dirname, uint64_t *dir_num, uint64_t *parent_dir_num, uint64_t *dir_size, uint64_t *dir_files) { @@ -88,9 +58,7 @@ static int update_user_row(struct osl_table *t, uint64_t dir_num, objects[UT_BYTES].size = sizeof(*add); objects[UT_FILES].data = &num_files; objects[UT_FILES].size = sizeof(num_files); - INFO_LOG("######################### ret: %d\n", ret); ret = osl(osl_add_row(t, objects)); - INFO_LOG("######################### ret: %d\n", ret); return ret; } else { /* add size and increment file count */ uint64_t num; @@ -163,11 +131,9 @@ static int scan_dir(char *dirname, uint64_t *parent_dir_num) dir_size += size; dir_files++; uid = s.st_uid; - ret = search_uid(uid, CREATE_USER_TABLE | OPEN_USER_TABLE, &ui); + ret = create_user_table(conf.database_dir_arg, uid, &ui); if (ret < 0) goto out; - ui->bytes += size; - ui->files++; ret = update_user_row(ui->table, this_dir_num, &size); if (ret < 0) goto out; @@ -183,7 +149,12 @@ out: return ret; } -int com_create() +/** + * The main function of the create mode. + * + * \return Standard. + */ +int com_create(void) { uint64_t zero = 0ULL; int ret; @@ -202,8 +173,7 @@ int com_create() ret = scan_dir(conf.base_dir_arg, &zero); if (ret < 0) goto out; - ret = write_uid_list(); + ret = write_uid_file(conf.database_dir_arg); out: - close_all_tables(); return ret; }