diff options
| author | Brian S. O'Neill <bronee@gmail.com> | 2011-10-03 21:56:28 +0000 | 
|---|---|---|
| committer | Brian S. O'Neill <bronee@gmail.com> | 2011-10-03 21:56:28 +0000 | 
| commit | 35783466fcf6f964be62bf65eed06ab2b647d7ba (patch) | |
| tree | f2889e536b5305eb00170f040a1a4530ba45121c /src | |
| parent | 6b128f6b4bafe78400e96759f109da22a647103c (diff) | |
Automatically update layout generation for deserialized layouts.
Diffstat (limited to 'src')
| -rw-r--r-- | src/main/java/com/amazon/carbonado/layout/LayoutFactory.java | 58 | 
1 files changed, 31 insertions, 27 deletions
| diff --git a/src/main/java/com/amazon/carbonado/layout/LayoutFactory.java b/src/main/java/com/amazon/carbonado/layout/LayoutFactory.java index 67d4348..71d1ec5 100644 --- a/src/main/java/com/amazon/carbonado/layout/LayoutFactory.java +++ b/src/main/java/com/amazon/carbonado/layout/LayoutFactory.java @@ -269,27 +269,12 @@ public class LayoutFactory implements LayoutCapability {                      // exception, which prevents the mistake from persisting.
                      assert(newLayout != null);
 -                    int generation = 0;
 -
 -                    Cursor<StoredLayout> cursor = mLayoutStorage
 -                        .query("storableTypeName = ?")
 -                        .with(info.getStorableType().getName())
 -                        .orderBy("-generation")
 -                        .fetch();
 -
 -                    boolean newGen;
 -                    try {
 -                        if (newGen = cursor.hasNext()) {
 -                            generation = cursor.next().getGeneration() + 1;
 -                        }
 -                    } finally {
 -                        cursor.close();
 -                    }
 +                    int generation = nextGeneration(info.getStorableType().getName());
                      newLayout.insert(readOnly, generation);
                      layout = newLayout;
 -                    if (newGen) {
 +                    if (generation == 0) {
                          LogFactory.getLog(getClass())
                              .debug("New schema layout inserted: " + layout);
                      }
 @@ -368,6 +353,7 @@ public class LayoutFactory implements LayoutCapability {          Transaction txn = mRepository.enterTransaction();
          try {
              txn.setForUpdate(true);
 +
              StoredLayout storedLayout = mLayoutStorage.prepare();
              storedLayout.readFrom(in);
              try {
 @@ -375,17 +361,20 @@ public class LayoutFactory implements LayoutCapability {              } catch (UniqueConstraintException e) {
                  StoredLayout existing = mLayoutStorage.prepare();
                  storedLayout.copyPrimaryKeyProperties(existing);
 -                if (!existing.tryLoad()) {
 -                    throw e;
 -                }
 -                // Only check subset of primary and alternate keys. The check
 -                // of layout properties is more important.
 -                if (!(existing.getLayoutID() == storedLayout.getLayoutID() &&
 -                      existing.getStorableTypeName().equals(storedLayout.getStorableTypeName())))
 -                {
 -                    throw e;
 +                if (existing.tryLoad()) {
 +                    // Only check subset of primary and alternate keys. The check
 +                    // of layout properties is more important.
 +                    if (!existing.getStorableTypeName().equals(storedLayout.getStorableTypeName()))
 +                    {
 +                        throw e;
 +                    }
 +                    storedLayout = existing;
 +                } else {
 +                    // Assume alternate key constraint, so increment the generation.
 +                    storedLayout.setGeneration
 +                        (nextGeneration(storedLayout.getStorableTypeName()));
 +                    storedLayout.insert();
                  }
 -                storedLayout = existing;
              }
              int op;
 @@ -424,6 +413,21 @@ public class LayoutFactory implements LayoutCapability {          mReconstructed.put(reconstructed, layout);
      }
 +    private int nextGeneration(String typeName) throws FetchException {
 +        Cursor<StoredLayout> cursor = mLayoutStorage
 +            .query("storableTypeName = ?").with(typeName).orderBy("-generation").fetch();
 +
 +        try {
 +            if (cursor.hasNext()) {
 +                return cursor.next().getGeneration() + 1;
 +            }
 +        } finally {
 +            cursor.close();
 +        }
 +
 +        return 0;
 +    }
 +
      /**
       * Creates a long hash code that attempts to mix in all relevant layout
       * elements.
 | 
