This is an automated email from the ASF dual-hosted git repository.

ahuber pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/causeway.git


The following commit(s) were added to refs/heads/master by this push:
     new 96381c2ae6 CAUSEWAY-3508: converts IdStringifierForDnSCOID to a 
ValueSemanticsProvider
96381c2ae6 is described below

commit 96381c2ae649e44a89315b4e19030690492103df
Author: Andi Huber <[email protected]>
AuthorDate: Thu Jun 29 07:42:59 2023 +0200

    CAUSEWAY-3508: converts IdStringifierForDnSCOID to a
    ValueSemanticsProvider
---
 .../CausewayModulePersistenceJdoDatanucleus.java   |  6 +--
 .../idstringifers/IdStringifierForDnSCOID.java     | 31 ------------
 .../metamodel/facets/entity/JdoEntityFacet.java    |  8 +--
 .../valuetypes/DnScoidValueSemantics.java          | 57 ++++++++++++++++++++++
 4 files changed, 64 insertions(+), 38 deletions(-)

diff --git 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/CausewayModulePersistenceJdoDatanucleus.java
 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/CausewayModulePersistenceJdoDatanucleus.java
index d376c0551e..5f1bd3f004 100644
--- 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/CausewayModulePersistenceJdoDatanucleus.java
+++ 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/CausewayModulePersistenceJdoDatanucleus.java
@@ -25,8 +25,6 @@ import javax.jdo.JDOException;
 import javax.jdo.PersistenceManagerFactory;
 import javax.sql.DataSource;
 
-import 
org.apache.causeway.persistence.jdo.datanucleus.idstringifers.IdStringifierForDnSCOID;
-
 import org.datanucleus.api.jdo.JDOPersistenceManagerFactory;
 import org.datanucleus.metadata.PersistenceUnitMetaData;
 import org.springframework.beans.factory.annotation.Qualifier;
@@ -57,6 +55,7 @@ import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnDatastoreUni
 import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnIntIdValueSemantics;
 import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnLongIdValueSemantics;
 import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnObjectIdValueSemantics;
+import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnScoidValueSemantics;
 import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnShortIdValueSemantics;
 import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.DnStringIdValueSemantics;
 import 
org.apache.causeway.persistence.jdo.datanucleus.valuetypes.JdoByteIdentityValueSemantics;
@@ -106,8 +105,7 @@ import lombok.extern.log4j.Log4j2;
     DnCharIdValueSemantics.class,
     DnStringIdValueSemantics.class,
     DnObjectIdValueSemantics.class,
-
-    IdStringifierForDnSCOID.class,
+    DnScoidValueSemantics.class, // in support of 
@PersistenceCapable(identityType=IdentityType.NONDURABLE)
 
     // @Service's
     JdoSupportServiceDefault.class,
diff --git 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/idstringifers/IdStringifierForDnSCOID.java
 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/idstringifers/IdStringifierForDnSCOID.java
deleted file mode 100644
index c50abf994e..0000000000
--- 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/idstringifers/IdStringifierForDnSCOID.java
+++ /dev/null
@@ -1,31 +0,0 @@
-package org.apache.causeway.persistence.jdo.datanucleus.idstringifers;
-
-import javax.annotation.Priority;
-
-import org.apache.causeway.applib.annotation.PriorityPrecedence;
-import org.apache.causeway.applib.services.bookmark.IdStringifier;
-import org.datanucleus.identity.SCOID;
-
-import org.springframework.stereotype.Component;
-
-import lombok.NonNull;
-
-@Component
-@Priority(PriorityPrecedence.LATE + 100) // after the implementations of 
DatastoreId; for a custom impl.
-public class IdStringifierForDnSCOID implements IdStringifier<SCOID> {
-
-    @Override
-    public Class<SCOID> getCorrespondingClass() {
-        return SCOID.class;
-    }
-
-    @Override
-    public String enstring(@NonNull SCOID value) {
-        return value.getSCOClass();
-    }
-
-    @Override
-    public SCOID destring(@NonNull Class<?> targetEntityClass, @NonNull String 
stringified) {
-        return new SCOID(stringified);
-    }
-}
diff --git 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/metamodel/facets/entity/JdoEntityFacet.java
 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/metamodel/facets/entity/JdoEntityFacet.java
index a24a169a4c..bb7d638e72 100644
--- 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/metamodel/facets/entity/JdoEntityFacet.java
+++ 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/metamodel/facets/entity/JdoEntityFacet.java
@@ -21,7 +21,6 @@ package 
org.apache.causeway.persistence.jdo.datanucleus.metamodel.facets.entity;
 import java.lang.reflect.Method;
 import java.util.List;
 import java.util.Map;
-import java.util.Objects;
 import java.util.Optional;
 import java.util.concurrent.ConcurrentHashMap;
 import java.util.function.Supplier;
@@ -238,7 +237,10 @@ implements EntityFacet {
             case UNSPECIFIED:
             default:
                 throw new IllegalStateException(String.format(
-                        "JdoEntityFacet has been incorrectly installed on '%s' 
which has an supported identityType of '%s'",
+                        "JdoEntityFacet was installed on '%s', "
+                        + "yet this entity has IdentityType '%s', "
+                        + "which is not supported by the framework's "
+                        + "JDO implementation.",
                         entityClass.getName(), identityType));
         }
     }
@@ -325,7 +327,7 @@ implements EntityFacet {
                 query.getDescription());
     }
 
-    private static boolean hasResultPhrase(javax.jdo.Query<?> namedQuery) {
+    private static boolean hasResultPhrase(final javax.jdo.Query<?> 
namedQuery) {
         if (namedQuery instanceof JDOQuery) {
             JDOQuery<?> jdoQuery = (JDOQuery<?>) namedQuery;
             return jdoQuery.getInternalQuery().getResult() != null;
diff --git 
a/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/valuetypes/DnScoidValueSemantics.java
 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/valuetypes/DnScoidValueSemantics.java
new file mode 100644
index 0000000000..a99e5d5530
--- /dev/null
+++ 
b/persistence/jdo/datanucleus/src/main/java/org/apache/causeway/persistence/jdo/datanucleus/valuetypes/DnScoidValueSemantics.java
@@ -0,0 +1,57 @@
+/*
+ *  Licensed to the Apache Software Foundation (ASF) under one
+ *  or more contributor license agreements.  See the NOTICE file
+ *  distributed with this work for additional information
+ *  regarding copyright ownership.  The ASF licenses this file
+ *  to you under the Apache License, Version 2.0 (the
+ *  "License"); you may not use this file except in compliance
+ *  with the License.  You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing,
+ *  software distributed under the License is distributed on an
+ *  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ *  KIND, either express or implied.  See the License for the
+ *  specific language governing permissions and limitations
+ *  under the License.
+ */
+package org.apache.causeway.persistence.jdo.datanucleus.valuetypes;
+
+import javax.annotation.Priority;
+
+import org.datanucleus.identity.SCOID;
+import org.springframework.stereotype.Component;
+
+import org.apache.causeway.applib.annotation.PriorityPrecedence;
+import 
org.apache.causeway.applib.value.semantics.ValueSemanticsBasedOnIdStringifierEntityAgnostic;
+
+import lombok.NonNull;
+
+/**
+ * Supports {@code @PersistenceCapable(identityType=IdentityType.NONDURABLE)}
+ *
+ * @see SCOID
+ */
+@Component
+@Priority(PriorityPrecedence.LATE + 100) // after the implementations of 
DatastoreId; for a custom impl.
+public class DnScoidValueSemantics
+extends ValueSemanticsBasedOnIdStringifierEntityAgnostic<SCOID> {
+
+    public DnScoidValueSemantics() {
+        super(SCOID.class);
+    }
+
+    // -- ID STRINGIFIER
+
+    @Override
+    public SCOID destring(final @NonNull String stringified) {
+        return new SCOID(stringified);
+    }
+
+    @Override
+    public String enstring(final @NonNull SCOID value) {
+        return value.getSCOClass();
+    }
+
+}

Reply via email to