[hacktree] Store objects with an extension so we know whether they're files or metadata



commit 0b851a743e1d09604de47a99a59c83dde59e588d
Author: Colin Walters <walters verbum org>
Date:   Fri Oct 14 22:30:18 2011 -0400

    Store objects with an extension so we know whether they're files or metadata

 src/ht-builtin-fsck.c           |   17 +++++++--
 src/libhacktree/hacktree-core.h |    5 +++
 src/libhacktree/hacktree-repo.c |   68 ++++++++++++++++++++++++++++----------
 3 files changed, 68 insertions(+), 22 deletions(-)
---
diff --git a/src/ht-builtin-fsck.c b/src/ht-builtin-fsck.c
index abf6ecb..3672524 100644
--- a/src/ht-builtin-fsck.c
+++ b/src/ht-builtin-fsck.c
@@ -49,9 +49,11 @@ object_iter_callback (HacktreeRepo  *repo,
   struct stat stbuf;
   GChecksum *checksum = NULL;
   GError *error = NULL;
-  char *dirname;
-  char *checksum_prefix;
-  char *checksum_string;
+  char *dirname = NULL;
+  char *checksum_prefix = NULL;
+  char *checksum_string = NULL;
+  char *filename_checksum = NULL;
+  char *dot;
 
   dirname = g_path_get_dirname (path);
   checksum_prefix = g_path_get_basename (dirname);
@@ -63,7 +65,12 @@ object_iter_callback (HacktreeRepo  *repo,
   if (!hacktree_stat_and_checksum_file (-1, path, &checksum, &stbuf, &error))
     goto out;
 
-  checksum_string = g_strconcat (checksum_prefix, g_file_info_get_name (file_info), NULL);
+  filename_checksum = g_strdup (g_file_info_get_name (file_info));
+  dot = strrchr (filename_checksum, '.');
+  g_assert (dot != NULL);
+  *dot = '\0';
+
+  checksum_string = g_strconcat (checksum_prefix, filename_checksum, NULL);
 
   if (strcmp (checksum_string, g_checksum_get_string (checksum)) != 0)
     {
@@ -78,6 +85,8 @@ object_iter_callback (HacktreeRepo  *repo,
     g_checksum_free (checksum);
   g_free (dirname);
   g_free (checksum_prefix);
+  g_free (checksum_string);
+  g_free (filename_checksum);
   if (error != NULL)
     {
       g_printerr ("%s\n", error->message);
diff --git a/src/libhacktree/hacktree-core.h b/src/libhacktree/hacktree-core.h
index b5ed901..5102039 100644
--- a/src/libhacktree/hacktree-core.h
+++ b/src/libhacktree/hacktree-core.h
@@ -29,6 +29,11 @@ G_BEGIN_DECLS
 #define HACKTREE_EMPTY_STRING_SHA256 "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855";
 
 typedef enum {
+  HACKTREE_OBJECT_TYPE_FILE = 1,
+  HACKTREE_OBJECT_TYPE_META = 2,
+} HacktreeObjectType;
+
+typedef enum {
   HACKTREE_SERIALIZED_TREE_VARIANT = 1,
   HACKTREE_SERIALIZED_COMMIT_VARIANT = 2,
   HACKTREE_SERIALIZED_DIRMETA_VARIANT = 3
diff --git a/src/libhacktree/hacktree-repo.c b/src/libhacktree/hacktree-repo.c
index 6c0bbf6..e7b07b7 100644
--- a/src/libhacktree/hacktree-repo.c
+++ b/src/libhacktree/hacktree-repo.c
@@ -28,12 +28,14 @@
 
 static gboolean
 link_one_file (HacktreeRepo *self, const char *path,
+               HacktreeObjectType type,
                gboolean ignore_exists, gboolean force,
                GChecksum **out_checksum,
                GError **error);
 static char *
-get_object_path_for_checksum (HacktreeRepo  *self,
-                              const char    *checksum);
+get_object_path (HacktreeRepo  *self,
+                 const char    *checksum,
+                 HacktreeObjectType type);
 
 enum {
   PROP_0,
@@ -258,7 +260,8 @@ import_gvariant_object (HacktreeRepo  *self,
                               NULL, error))
     goto out;
 
-  if (!link_one_file (self, tmp_name, TRUE, FALSE, out_checksum, error))
+  if (!link_one_file (self, tmp_name, HACKTREE_OBJECT_TYPE_META, 
+                      TRUE, FALSE, out_checksum, error))
     goto out;
   
   ret = TRUE;
@@ -289,7 +292,7 @@ load_gvariant_object_unknown (HacktreeRepo  *self,
   char *path = NULL;
   guint32 ret_type;
 
-  path = get_object_path_for_checksum (self, sha256);
+  path = get_object_path (self, sha256, HACKTREE_OBJECT_TYPE_META);
   
   mfile = g_mapped_file_new (priv->index_path, FALSE, error);
   if (mfile == NULL)
@@ -429,15 +432,31 @@ import_directory_meta (HacktreeRepo  *self,
 }
 
 static char *
-get_object_path_for_checksum (HacktreeRepo  *self,
-                              const char    *checksum)
+get_object_path (HacktreeRepo  *self,
+                 const char    *checksum,
+                 HacktreeObjectType type)
 {
   HacktreeRepoPrivate *priv = GET_PRIVATE (self);
   char *checksum_prefix;
+  char *base_path;
   char *ret;
+  const char *type_string;
 
   checksum_prefix = g_strndup (checksum, 2);
-  ret = g_build_filename (priv->objects_path, checksum_prefix, checksum + 2, NULL);
+  base_path = g_build_filename (priv->objects_path, checksum_prefix, checksum + 2, NULL);
+  switch (type)
+    {
+    case HACKTREE_OBJECT_TYPE_FILE:
+      type_string = ".file";
+      break;
+    case HACKTREE_OBJECT_TYPE_META:
+      type_string = ".meta";
+      break;
+    default:
+      g_assert_not_reached ();
+    }
+  ret = g_strconcat (base_path, type_string, NULL);
+  g_free (base_path);
   g_free (checksum_prefix);
  
   return ret;
@@ -446,12 +465,13 @@ get_object_path_for_checksum (HacktreeRepo  *self,
 static char *
 prepare_dir_for_checksum_get_object_path (HacktreeRepo *self,
                                           GChecksum    *checksum,
+                                          HacktreeObjectType type,
                                           GError      **error)
 {
   char *checksum_dir = NULL;
   char *object_path = NULL;
 
-  object_path = get_object_path_for_checksum (self, g_checksum_get_string (checksum));
+  object_path = get_object_path (self, g_checksum_get_string (checksum), type);
   checksum_dir = g_path_get_dirname (object_path);
 
   if (!ht_util_ensure_directory (checksum_dir, FALSE, error))
@@ -463,7 +483,7 @@ prepare_dir_for_checksum_get_object_path (HacktreeRepo *self,
 }
 
 static gboolean
-link_one_file (HacktreeRepo *self, const char *path,
+link_one_file (HacktreeRepo *self, const char *path, HacktreeObjectType type,
                gboolean ignore_exists, gboolean force,
                GChecksum **out_checksum,
                GError **error)
@@ -492,7 +512,7 @@ link_one_file (HacktreeRepo *self, const char *path,
 
   if (!hacktree_stat_and_checksum_file (dirfd (src_dir), path, &id, &stbuf, error))
     goto out;
-  dest_path = prepare_dir_for_checksum_get_object_path (self, id, error);
+  dest_path = prepare_dir_for_checksum_get_object_path (self, id, type, error);
   if (!dest_path)
     goto out;
 
@@ -563,7 +583,8 @@ hacktree_repo_link_file (HacktreeRepo *self,
 
   g_return_val_if_fail (priv->inited, FALSE);
 
-  if (!link_one_file (self, path, ignore_exists, force, &checksum, error))
+  if (!link_one_file (self, path, HACKTREE_OBJECT_TYPE_FILE,
+                      ignore_exists, force, &checksum, error))
     return FALSE;
   g_checksum_free (checksum);
   return TRUE;
@@ -1001,7 +1022,8 @@ add_one_file_to_tree_and_import (HacktreeRepo   *self,
   
   g_assert (tree != NULL);
 
-  if (!link_one_file (self, abspath, TRUE, FALSE, &checksum, error))
+  if (!link_one_file (self, abspath, HACKTREE_OBJECT_TYPE_FILE,
+                      TRUE, FALSE, &checksum, error))
     goto out;
 
   g_hash_table_replace (tree->files, g_strdup (basename),
@@ -1241,12 +1263,22 @@ iter_object_dir (HacktreeRepo   *self,
       name = g_file_info_get_attribute_byte_string (file_info, "standard::name"); 
       type = g_file_info_get_attribute_uint32 (file_info, "standard::type");
       
-      /* 64 - 2 */
-      if (strlen (name) == 62 && type != G_FILE_TYPE_DIRECTORY)
+      if (type != G_FILE_TYPE_DIRECTORY
+          && (g_str_has_suffix (name, ".meta")
+              || g_str_has_suffix (name, ".file")))
         {
-          char *path = g_build_filename (dirpath, name, NULL);
-          callback (self, path, file_info, user_data);
-          g_free (path);
+          char *dot;
+          char *path;
+          
+          dot = strrchr (name, '.');
+          g_assert (dot);
+          
+          if ((dot - name) == 62)
+            {
+              path = g_build_filename (dirpath, name, NULL);
+              callback (self, path, file_info, user_data);
+              g_free (path);
+            }
         }
 
       g_object_unref (file_info);
@@ -1281,7 +1313,7 @@ hacktree_repo_iter_objects (HacktreeRepo  *self,
   g_return_val_if_fail (priv->inited, FALSE);
 
   objectdir = g_file_new_for_path (priv->objects_path);
-  enumerator = g_file_enumerate_children (objectdir, "standard::*,unix::*", 
+  enumerator = g_file_enumerate_children (objectdir, "standard::name,standard::type,unix::*", 
                                           G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS,
                                           NULL, 
                                           error);



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]