Revision: 9121
Author: [email protected]
Date: Tue Oct 19 17:35:25 2010
Log: Prevent non-null null types from appearing.

Contradiction in terms, and makes the compiler blow up.

http://gwt-code-reviews.appspot.com/1028801/show

Review by: [email protected]
http://code.google.com/p/google-web-toolkit/source/detail?r=9121

Modified:
 /trunk/dev/core/src/com/google/gwt/dev/jjs/ast/JNonNullType.java
 /trunk/dev/core/src/com/google/gwt/dev/jjs/ast/JProgram.java

=======================================
--- /trunk/dev/core/src/com/google/gwt/dev/jjs/ast/JNonNullType.java Thu Aug 19 13:25:39 2010 +++ /trunk/dev/core/src/com/google/gwt/dev/jjs/ast/JNonNullType.java Tue Oct 19 14:23:16 2010
@@ -25,7 +25,7 @@

   JNonNullType(JReferenceType ref) {
     super(ref.getSourceInfo(), ref.getName());
-    assert ref.canBeNull();
+    assert !(ref instanceof JNullType);
     this.ref = ref;
   }

=======================================
--- /trunk/dev/core/src/com/google/gwt/dev/jjs/ast/JProgram.java Mon Aug 30 04:31:11 2010 +++ /trunk/dev/core/src/com/google/gwt/dev/jjs/ast/JProgram.java Tue Oct 19 14:23:16 2010
@@ -765,21 +765,18 @@
   }

   public JsonObject getCastableTypeMap(JReferenceType referenceType) {
-
     // ensure jsonCastableTypeMaps has been initialized
     // it might not have been if the CastNormalizer has not been run
     if (castableTypeMaps == null) {
       initTypeInfo(null);
     }
-
     JsonObject returnMap = castableTypeMaps.get(referenceType);
     if (returnMap == null) {
       // add a new empty map
       returnMap = new JsonObject(createSourceInfoSynthetic(JProgram.class,
- "empty map"), getJavaScriptObject());
+          "empty map"), getJavaScriptObject());
       castableTypeMaps.put(referenceType, returnMap);
     }
-
     return returnMap;
   }

@@ -1158,12 +1155,10 @@
   public JPrimitiveType getTypeVoid() {
     return JPrimitiveType.VOID;
   }
-
+
   public void initTypeInfo(
- IdentityHashMap<JReferenceType,JsonObject> instantiatedTypeCastableTypeMaps) {
-
+ IdentityHashMap<JReferenceType, JsonObject> instantiatedTypeCastableTypeMaps) {
     castableTypeMaps = instantiatedTypeCastableTypeMaps;
-
     if (castableTypeMaps == null || castableTypeMaps.size() == 0) {
       castableTypeMaps = new IdentityHashMap<JReferenceType, JsonObject>();
     }
@@ -1240,6 +1235,10 @@
     if (type1 == type2) {
       return type1;
     }
+
+    if (type1 instanceof JNullType || type2 instanceof JNullType) {
+      return JNullType.INSTANCE;
+    }

     if (type1 instanceof JNonNullType != type2 instanceof JNonNullType) {
       // If either is non-nullable, the result should be non-nullable.

--
http://groups.google.com/group/Google-Web-Toolkit-Contributors

Reply via email to