-static void repository_extract_r (int cmd, char *rep)
-{
- struct dir_entry *e;
- int i;
- struct stat fs;
- size_t rep_len = strlen (rep);
-
- e = dir_open (rep);
- if (!e)
- return;
- if (rep[rep_len-1] != '/')
- rep[rep_len] = '/';
- else
- --rep_len;
- for (i=0; e[i].name; i++)
- {
- if (!strcmp (e[i].name, ".") || !strcmp (e[i].name, ".."))
- continue;
- strcpy (rep +rep_len+1, e[i].name);
- stat (rep, &fs);
- switch (fs.st_mode & S_IFMT)
- {
- case S_IFREG:
- file_extract (cmd, &fs, rep, rep);
- break;
- case S_IFDIR:
- repository_extract_r (cmd, rep);
- break;
- }
- }
- dir_free (&e);
-}
-
-void repository_update_r (int cmd, char *dst, char *src);
-
-void repository_add_tree (int cmd, char *dst, char *src)
-{
- mkdir (dst, 0755);
- repository_update_r (cmd, dst, src);
-}
-
-void repository_del_tree (int cmd, char *dst, char *src)
-{
- log (LOG_DEBUG, "rmdir of %s", dst);
-}
-
-void repository_update_r (int cmd, char *dst, char *src)
-{
- struct dir_entry *e_dst, *e_src;
- int i_dst = 0, i_src = 0;
- struct stat fs_dst, fs_src;
- size_t dst_len = strlen (dst);
- size_t src_len = strlen (src);
-
- e_dst = dir_open (dst);
- e_src = dir_open (src);
-
- if (!e_dst && !e_src)
- return;
- if (!e_dst)
- repository_add_tree (cmd, dst, src);
- else if (!e_src)
- repository_del_tree (cmd, dst, src);
-
- dir_sort (e_src);
- dir_sort (e_dst);
-
- if (src[src_len-1] != '/')
- src[src_len] = '/';
- else
- --src_len;
- if (dst[dst_len-1] != '/')
- dst[dst_len] = '/';
- else
- --dst_len;
- while (e_dst[i_dst].name || e_src[i_src].name)
- {
- int sd;
-
- if (e_dst[i_dst].name && e_src[i_src].name)
- sd = strcmp (e_dst[i_dst].name, e_src[i_src].name);
- else if (e_src[i_src].name)
- sd = 1;
- else
- sd = -1;
-
- if (sd == 0)
- {
- strcpy (dst +dst_len+1, e_dst[i_dst].name);
- strcpy (src +src_len+1, e_src[i_src].name);
-
- /* check type, date, length */
-
- if (strcmp (e_dst[i_dst].name, ".") &&
- strcmp (e_dst[i_dst].name, ".."))
- {
- stat (dst, &fs_dst);
- stat (src, &fs_src);
-
- switch (fs_dst.st_mode & S_IFMT)
- {
- case S_IFREG:
- if (fs_src.st_mtime != fs_dst.st_mtime)
- {
- file_extract ('d', &fs_dst, dst, dst);
- file_extract ('a', &fs_src, src, dst);
- }
- break;
- case S_IFDIR:
- repository_update_r (cmd, dst, src);
- break;
- }
- }
- i_src++;
- i_dst++;
- }
- else if (sd > 0)
- {
- strcpy (dst +dst_len+1, e_src[i_src].name);
- strcpy (src +src_len+1, e_src[i_src].name);
-
- stat (src, &fs_src);
- switch (fs_src.st_mode & S_IFMT)
- {
- case S_IFREG:
- file_extract ('a', &fs_src, src, dst);
- break;
- case S_IFDIR:
- repository_add_tree (cmd, dst, src);
- break;
- }
- i_src++;
- }
- else
- {
- strcpy (dst +dst_len+1, e_dst[i_dst].name);
- strcpy (src +src_len+1, e_dst[i_dst].name);
-
- stat (dst, &fs_dst);
- switch (fs_dst.st_mode & S_IFMT)
- {
- case S_IFREG:
- file_extract ('d', &fs_dst, dst, dst);
- break;
- case S_IFDIR:
- repository_del_tree (cmd, dst, src);
- break;
- }
- i_dst++;
- }
- }
- dir_free (&e_dst);
- dir_free (&e_src);
-}
-
-void repository_traverse (int cmd, const char *rep)
-{
- char rep_tmp1[2048];
- char rep_tmp2[2048];
-
- strcpy (rep_tmp1, rep);
- if (base_path)
- {
- strcpy (rep_tmp2, base_path);
- repository_update_r (cmd, rep_tmp2, rep_tmp1);
- }
- else
- repository_extract_r (cmd, rep_tmp1);
-}
-
-