shithub: hugo

Download patch

ref: 55d0b89417651eba3ae51c96bd9de9e0daa0399e
parent: aee2b06780858c12d8cb04c7b1ba592543410aa9
author: Cameron Moore <[email protected]>
date: Thu Jul 27 13:23:49 EDT 2017

tpl/collections: Fix intersect on []interface{} handling

Fixes #3718

--- a/tpl/collections/where.go
+++ b/tpl/collections/where.go
@@ -53,6 +53,7 @@
 	if !v.IsValid() {
 		vIsNil = true
 	}
+
 	mv, mvIsNil := indirect(mv)
 	if !mv.IsValid() {
 		mvIsNil = true
@@ -115,7 +116,7 @@
 			return false, nil
 		}
 
-		if v.Kind() != reflect.Interface && mv.Type().Elem().Kind() != reflect.Interface && mv.Type().Elem() != v.Type() {
+		if v.Kind() != reflect.Interface && mv.Type().Elem().Kind() != reflect.Interface && mv.Type().Elem() != v.Type() && v.Kind() != reflect.Array && v.Kind() != reflect.Slice {
 			return false, nil
 		}
 		switch v.Kind() {
@@ -144,6 +145,9 @@
 					ima = append(ima, toTimeUnix(mv.Index(i)))
 				}
 			}
+		case reflect.Array, reflect.Slice:
+			slv = v.Interface()
+			slmv = mv.Interface()
 		}
 	}
 
--- a/tpl/collections/where_test.go
+++ b/tpl/collections/where_test.go
@@ -536,6 +536,12 @@
 		{reflect.ValueOf(true), reflect.ValueOf(false), ">", expect{false, false}},
 		{reflect.ValueOf(123), reflect.ValueOf([]int{}), "in", expect{false, false}},
 		{reflect.ValueOf(123), reflect.ValueOf(123), "op", expect{false, true}},
+
+		// Issue #3718
+		{reflect.ValueOf([]interface{}{"a"}), reflect.ValueOf([]string{"a", "b"}), "intersect", expect{true, false}},
+		{reflect.ValueOf([]string{"a"}), reflect.ValueOf([]interface{}{"a", "b"}), "intersect", expect{true, false}},
+		{reflect.ValueOf([]interface{}{1, 2}), reflect.ValueOf([]int{1}), "intersect", expect{true, false}},
+		{reflect.ValueOf([]int{1}), reflect.ValueOf([]interface{}{1, 2}), "intersect", expect{true, false}},
 	} {
 		result, err := ns.checkCondition(test.value, test.match, test.op)
 		if test.expect.isError {