Browse Source

Merge pull request #18263 from jdconrad/mapfix

Fix bracket shortcuts
Jack Conradson 9 years ago
parent
commit
30b5b4fc83

+ 1 - 1
modules/lang-painless/src/main/java/org/elasticsearch/painless/Analyzer.java

@@ -102,7 +102,7 @@ class Analyzer extends PainlessParserBaseVisitor<Void> {
         metadata.scorerValueSlot = utility.addVariable(null, "#scorer", definition.objectType).slot;
         metadata.scorerValueSlot = utility.addVariable(null, "#scorer", definition.objectType).slot;
         // doc parameter passed to the script.
         // doc parameter passed to the script.
         // TODO: currently working as a def type, should be smapType...
         // TODO: currently working as a def type, should be smapType...
-        metadata.docValueSlot = utility.addVariable(null, "doc", definition.defType).slot;
+        metadata.docValueSlot = utility.addVariable(null, "doc", definition.smapType).slot;
         //
         //
         // reserved words implemented as local variables
         // reserved words implemented as local variables
         //
         //

+ 9 - 9
modules/lang-painless/src/main/java/org/elasticsearch/painless/AnalyzerExternal.java

@@ -238,14 +238,6 @@ class AnalyzerExternal {
                 definition.getType(parentemd.current.struct, parentemd.current.type.getDimensions() - 1);
                 definition.getType(parentemd.current.struct, parentemd.current.type.getDimensions() - 1);
             analyzeLoadStoreExternal(ctx);
             analyzeLoadStoreExternal(ctx);
             parentemd.current = braceenmd.type;
             parentemd.current = braceenmd.type;
-
-            if (dotctx != null) {
-                metadata.createExtNodeMetadata(parent, dotctx);
-                analyzer.visit(dotctx);
-            } else if (bracectx != null) {
-                metadata.createExtNodeMetadata(parent, bracectx);
-                analyzer.visit(bracectx);
-            }
         } else {
         } else {
             final boolean store = braceenmd.last && parentemd.storeExpr != null;
             final boolean store = braceenmd.last && parentemd.storeExpr != null;
             final boolean get = parentemd.read || parentemd.token > 0 || !braceenmd.last;
             final boolean get = parentemd.read || parentemd.token > 0 || !braceenmd.last;
@@ -319,6 +311,14 @@ class AnalyzerExternal {
             throw new IllegalArgumentException(AnalyzerUtility.error(ctx) +
             throw new IllegalArgumentException(AnalyzerUtility.error(ctx) +
                 "Attempting to address a non-array type [" + parentemd.current.name + "] as an array.");
                 "Attempting to address a non-array type [" + parentemd.current.name + "] as an array.");
         }
         }
+
+        if (dotctx != null) {
+            metadata.createExtNodeMetadata(parent, dotctx);
+            analyzer.visit(dotctx);
+        } else if (bracectx != null) {
+            metadata.createExtNodeMetadata(parent, bracectx);
+            analyzer.visit(bracectx);
+        }
     }
     }
 
 
     void processExtdot(final ExtdotContext ctx) {
     void processExtdot(final ExtdotContext ctx) {
@@ -449,7 +449,7 @@ class AnalyzerExternal {
             }
             }
 
 
             // special cases: reserved words
             // special cases: reserved words
-            if ("_score".equals(id) || "doc".equals(id)) {
+            if (varenmd.last && ("_score".equals(id) || "doc".equals(id))) {
                 // read-only: don't allow stores
                 // read-only: don't allow stores
                 if (parentemd.storeExpr != null) {
                 if (parentemd.storeExpr != null) {
                     throw new IllegalArgumentException(AnalyzerUtility.error(ctx) + "Variable [" + id + "] is read-only.");
                     throw new IllegalArgumentException(AnalyzerUtility.error(ctx) + "Variable [" + id + "] is read-only.");

+ 19 - 27
modules/lang-painless/src/main/java/org/elasticsearch/painless/WriterExternal.java

@@ -306,18 +306,14 @@ class WriterExternal {
             final boolean cat = utility.containsStrings(parentemd.storeExpr);
             final boolean cat = utility.containsStrings(parentemd.storeExpr);
 
 
             if (cat) {
             if (cat) {
-                if (field || name || shortcut) {
-                    execute.dupX1();
-                } else if (array) {
-                    execute.dup2X1();
+                if (maplist && constant != null) {
+                    utility.writeConstant(source, constant);
                 }
                 }
 
 
-                if (maplist) {
-                    if (constant != null) {
-                        utility.writeConstant(source, constant);
-                    }
-
-                    execute.dupX2();
+                if (field || name || (shortcut && !maplist)) {
+                    execute.dupX1();
+                } else if (array || maplist) {
+                    execute.dup2X1();
                 }
                 }
 
 
                 writeLoadStoreInstruction(source, false, variable, field, name, array, shortcut);
                 writeLoadStoreInstruction(source, false, variable, field, name, array, shortcut);
@@ -340,18 +336,14 @@ class WriterExternal {
             } else if (parentemd.token > 0) {
             } else if (parentemd.token > 0) {
                 final int token = parentemd.token;
                 final int token = parentemd.token;
 
 
-                if (field || name || shortcut) {
-                    execute.dup();
-                } else if (array) {
-                    execute.dup2();
+                if (maplist && constant != null) {
+                    utility.writeConstant(source, constant);
                 }
                 }
 
 
-                if (maplist) {
-                    if (constant != null) {
-                        utility.writeConstant(source, constant);
-                    }
-
-                    execute.dupX1();
+                if (field || name || (shortcut && !maplist)) {
+                    execute.dup();
+                } else if (array || maplist) {
+                    execute.dup2();
                 }
                 }
 
 
                 writeLoadStoreInstruction(source, false, variable, field, name, array, shortcut);
                 writeLoadStoreInstruction(source, false, variable, field, name, array, shortcut);
@@ -467,10 +459,10 @@ class WriterExternal {
 
 
     private void writeLoadStoreField(final ParserRuleContext source, final boolean store, final String name) {
     private void writeLoadStoreField(final ParserRuleContext source, final boolean store, final String name) {
         if (store) {
         if (store) {
-            execute.visitInvokeDynamicInsn(name, WriterConstants.DEF_DYNAMIC_STORE_FIELD_DESC, 
+            execute.visitInvokeDynamicInsn(name, WriterConstants.DEF_DYNAMIC_STORE_FIELD_DESC,
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.STORE });
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.STORE });
         } else {
         } else {
-            execute.visitInvokeDynamicInsn(name, WriterConstants.DEF_DYNAMIC_LOAD_FIELD_DESC, 
+            execute.visitInvokeDynamicInsn(name, WriterConstants.DEF_DYNAMIC_LOAD_FIELD_DESC,
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.LOAD });
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.LOAD });
         }
         }
     }
     }
@@ -482,10 +474,10 @@ class WriterExternal {
 
 
         if (type.sort == Sort.DEF) {
         if (type.sort == Sort.DEF) {
             if (store) {
             if (store) {
-                execute.visitInvokeDynamicInsn("arrayStore", WriterConstants.DEF_DYNAMIC_ARRAY_STORE_DESC, 
+                execute.visitInvokeDynamicInsn("arrayStore", WriterConstants.DEF_DYNAMIC_ARRAY_STORE_DESC,
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.ARRAY_STORE });
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.ARRAY_STORE });
             } else {
             } else {
-                execute.visitInvokeDynamicInsn("arrayLoad", WriterConstants.DEF_DYNAMIC_ARRAY_LOAD_DESC, 
+                execute.visitInvokeDynamicInsn("arrayLoad", WriterConstants.DEF_DYNAMIC_ARRAY_LOAD_DESC,
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.ARRAY_LOAD });
                                            WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.ARRAY_LOAD });
             }
             }
         } else {
         } else {
@@ -705,11 +697,11 @@ class WriterExternal {
             writeDynamicCallExternal(source);
             writeDynamicCallExternal(source);
         }
         }
     }
     }
-    
+
     private void writeDynamicCallExternal(final ExtcallContext source) {
     private void writeDynamicCallExternal(final ExtcallContext source) {
         final ExtNodeMetadata sourceenmd = metadata.getExtNodeMetadata(source);
         final ExtNodeMetadata sourceenmd = metadata.getExtNodeMetadata(source);
         final List<ExpressionContext> arguments = source.arguments().expression();
         final List<ExpressionContext> arguments = source.arguments().expression();
-        
+
         StringBuilder signature = new StringBuilder();
         StringBuilder signature = new StringBuilder();
         signature.append('(');
         signature.append('(');
         // first parameter is the receiver, we never know its type: always Object
         // first parameter is the receiver, we never know its type: always Object
@@ -726,7 +718,7 @@ class WriterExternal {
         signature.append(')');
         signature.append(')');
         // return value: currently always Object. making this better may be tricky...
         // return value: currently always Object. making this better may be tricky...
         signature.append(WriterConstants.OBJECT_TYPE.getDescriptor());
         signature.append(WriterConstants.OBJECT_TYPE.getDescriptor());
-        execute.visitInvokeDynamicInsn((String)sourceenmd.target, signature.toString(), 
+        execute.visitInvokeDynamicInsn((String)sourceenmd.target, signature.toString(),
                                        WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.METHOD_CALL });
                                        WriterConstants.DEF_BOOTSTRAP_HANDLE, new Object[] { DynamicCallSite.METHOD_CALL });
     }
     }
 }
 }

+ 4 - 4
modules/lang-painless/src/test/java/org/elasticsearch/painless/NeedsScoreTests.java

@@ -42,22 +42,22 @@ public class NeedsScoreTests extends ESSingleNodeTestCase {
         SearchLookup lookup = new SearchLookup(index.mapperService(), index.fieldData(), null);
         SearchLookup lookup = new SearchLookup(index.mapperService(), index.fieldData(), null);
 
 
         Object compiled = service.compile("1.2", Collections.emptyMap());
         Object compiled = service.compile("1.2", Collections.emptyMap());
-        SearchScript ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled), 
+        SearchScript ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled),
                                          lookup, Collections.<String, Object>emptyMap());
                                          lookup, Collections.<String, Object>emptyMap());
         assertFalse(ss.needsScores());
         assertFalse(ss.needsScores());
 
 
         compiled = service.compile("doc['d'].value", Collections.emptyMap());
         compiled = service.compile("doc['d'].value", Collections.emptyMap());
-        ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled), 
+        ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled),
                             lookup, Collections.<String, Object>emptyMap());
                             lookup, Collections.<String, Object>emptyMap());
         assertFalse(ss.needsScores());
         assertFalse(ss.needsScores());
 
 
         compiled = service.compile("1/_score", Collections.emptyMap());
         compiled = service.compile("1/_score", Collections.emptyMap());
-        ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled), 
+        ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled),
                             lookup, Collections.<String, Object>emptyMap());
                             lookup, Collections.<String, Object>emptyMap());
         assertTrue(ss.needsScores());
         assertTrue(ss.needsScores());
 
 
         compiled = service.compile("doc['d'].value * _score", Collections.emptyMap());
         compiled = service.compile("doc['d'].value * _score", Collections.emptyMap());
-        ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled), 
+        ss = service.search(new CompiledScript(ScriptType.INLINE, "randomName", "painless", compiled),
                             lookup, Collections.<String, Object>emptyMap());
                             lookup, Collections.<String, Object>emptyMap());
         assertTrue(ss.needsScores());
         assertTrue(ss.needsScores());
     }
     }