[ 
https://issues.apache.org/jira/browse/TINKERPOP-2234?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=18022534#comment-18022534
 ] 

ASF GitHub Bot commented on TINKERPOP-2234:
-------------------------------------------

spmallette commented on code in PR #3211:
URL: https://github.com/apache/tinkerpop/pull/3211#discussion_r2376885126


##########
gremlin-core/src/main/java/org/apache/tinkerpop/gremlin/process/traversal/Type.java:
##########
@@ -0,0 +1,123 @@
+/*
+ * 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.tinkerpop.gremlin.process.traversal;
+
+import java.util.Map;
+import java.util.Optional;
+import java.util.concurrent.ConcurrentHashMap;
+
+/**
+ * {@code Type} is a {@code BiPredicate} that determines whether the first 
argument is a type of the second argument.
+ *
+ */
+public enum Type implements PBiPredicate<Object, Object> {

Review Comment:
   I think [my 
comment](https://github.com/apache/tinkerpop/pull/3207/files#r2352474590) still 
stands from the proposal. I still think `Type` should be better constrained by 
that `<Object, Object>` and that `<Object, Class<?>>` is more agreeable. Doing 
so would also get rid of the catch-all `else { return false }` and that check 
for `GType.NULL`:
   
   ```java
       typeOf {
           @Override
           public boolean test(final Object first, final Class<?> second) {
               if (first == null) return false;
               return secondClass.isAssignableFrom(first.getClass());
           }
   
       };
   ```
   
   This way, it can never be called other than how it is intended. In `P` you 
already have the types constrained to multiple `typeOf` overloads. Why expand 
them back to the `Type` enum when you can just coerce them each to `Class<?>` 
by moving that logic I removed above back to those specific `P` overloads?
   
   Also, you'd catch `GlobalTypeCache` failures at traversal construction time 
with that logic in `P` rather than at runtime which seems more advantageous to 
me. 
   
   Do we lose something by getting more strict with the types for the `Type` 
enum?
   
   As a separate point, are we making a mistake using `Type` for the name of 
this enum? We have `Type` and `GType` and at some point in the future we will 
have a schema. "Type" is such a great word to save for when we really need it. 
We currently have `Contains`, `Compare` , and the unfortunately named `Text`. 
The first two are verbs which actively define what `P` is doing - containing or 
comparing.  Maybe there's a verb form that would be better than `Type`?  Maybe 
we call the enum `InstanceOf` rather than `Type`- that's pretty normal and 
understood?
   
   





> Introduce Type Predicate
> ------------------------
>
>                 Key: TINKERPOP-2234
>                 URL: https://issues.apache.org/jira/browse/TINKERPOP-2234
>             Project: TinkerPop
>          Issue Type: Improvement
>          Components: process
>    Affects Versions: 3.4.2
>            Reporter: Stephen Mallette
>            Priority: Major
>
> Provide for a {{typeOf()}} predicate that allows for testing the type of an 
> object which would enable neat things like:
> {code}
> g.V().outE().has('weight',gt(0.1)).inV().path().unfold().is(typeOf(VERTEX))
> {code}
> See the linked DISCUSS thread for more information.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to