stevenzwu commented on code in PR #7517:
URL: https://github.com/apache/iceberg/pull/7517#discussion_r1185469804


##########
api/src/main/java/org/apache/iceberg/util/StructProjection.java:
##########
@@ -189,16 +189,12 @@ public int size() {
 
   @Override
   public <T> T get(int pos, Class<T> javaClass) {
-    if (struct == null) {
-      // Return a null struct when projecting a nested required field from an 
optional struct.
-      // See more details in issue #2738.
-      return null;
-    }
-
     int structPos = positionMap[pos];
-
     if (nestedProjections[pos] != null) {
-      return javaClass.cast(nestedProjections[pos].wrap(struct.get(structPos, 
StructLike.class)));
+      StructLike nestedStruct = struct.get(structPos, StructLike.class);

Review Comment:
   good question. this change avoided the wrapping null at nested level, [which 
is the main reason we added the lines from 
192-196](https://github.com/apache/iceberg/issues/2738) that are removed in 
this PR. 
   
   I guess it can potentially happen if we use `StructProjection` to wrap a 
null `struct` at the root level. If it is a valid scenario, we need to bring 
back line 192-196. If it is not a valid scenario, we should add `Preconditions` 
check in the wrap method.
   ```
     public StructProjection wrap(StructLike newStruct) {
       this.struct = newStruct;
       return this;
     }
   ```



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to