Skip to content

Commit

Permalink
internal/core/adt: consider closed status for equality
Browse files Browse the repository at this point in the history
Change-Id: Ie7c76352a875f295808841550cdd4b79c75f73c4
Reviewed-on: https://cue-review.googlesource.com/c/cue/+/8102
Reviewed-by: CUE cueckoo <cueckoo@gmail.com>
Reviewed-by: Marcel van Lohuizen <mpvl@golang.org>
  • Loading branch information
mpvl committed Jan 9, 2021
1 parent d4c600f commit b619e0c
Show file tree
Hide file tree
Showing 6 changed files with 36 additions and 29 deletions.
5 changes: 3 additions & 2 deletions cue/testdata/comprehensions/issue507.txtar
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,9 @@ bar: [
]
-- out/eval --
(struct){
somelist: (#list){
}
somelist: (list){ |(*(#list){
}, (list){
}) }
foo: (#list){
}
otherlist: (#list){
Expand Down
5 changes: 3 additions & 2 deletions cue/testdata/fulleval/027_len_of_incomplete_types.txtar
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,9 @@ v10: 0
<0>{args: [], v1: 0, v2: 0, v3: 0, v4: 1, v5: len ((<1>{a: 3} | <2>{a: 4})), v6: len (('sf' | 'dd')), v7: 2, v8: len (([2] | [1,2])), v9: 4, v10: 0}
-- out/eval --
(struct){
args: (#list){
}
args: (list){ |(*(#list){
}, (list){
}) }
v1: (int){ 0 }
v2: (int){ 0 }
v3: (int){ 0 }
Expand Down
5 changes: 3 additions & 2 deletions cue/testdata/fulleval/053_issue312.txtar
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,6 @@ for x in [1] *close({}) | {
-- out/legacy-debug --
<0>{ <1>for _, x in [1] yield <2>{}, (*close (<3>{}) | <4>{[]: <5>(_: string)->null, })}
-- out/eval --
(#struct){
}
(struct){ |(*(#struct){
}, (struct){
}) }
2 changes: 1 addition & 1 deletion doc/tutorial/kubernetes/manual/services/cloud.cue
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ deployment: [Name=_]: _base & {
port: [string]: int

arg: [string]: string
args: [ for k, v in arg { "-\(k)=\(v)" } ] | [...string]
args: *[ for k, v in arg {"-\(k)=\(v)"}] | [...string]

// Environment variables
env: [string]: string
Expand Down
44 changes: 22 additions & 22 deletions doc/tutorial/kubernetes/testdata/manual.out
Original file line number Diff line number Diff line change
Expand Up @@ -159,7 +159,7 @@ deployment: {
etcd: "etcd:2379"
"event-server": "events:7788"
}
args: ["-etcd=etcd:2379", "-event-server=events:7788"] | []
args: ["-etcd=etcd:2379", "-event-server=events:7788"]
env: {}
label: {
app: "breaddispatcher"
Expand Down Expand Up @@ -255,7 +255,7 @@ kubernetes: {
containers: [{
name: "breaddispatcher"
image: "gcr.io/myproj/breaddispatcher:v0.3.24"
args: ["-etcd=etcd:2379", "-event-server=events:7788"] | []
args: ["-etcd=etcd:2379", "-event-server=events:7788"]
ports: [{
name: "http"
containerPort: 7080
Expand Down Expand Up @@ -537,7 +537,7 @@ deployment: {
}
}
port: {}
args: ["-http=:8080", "-etcd=etcd:2379"] | []
args: ["-http=:8080", "-etcd=etcd:2379"]
env: {}
label: {
app: "valeter"
Expand Down Expand Up @@ -633,7 +633,7 @@ kubernetes: {
containers: [{
name: "valeter"
image: "gcr.io/myproj/valeter:v0.0.4"
args: ["-http=:8080", "-etcd=etcd:2379"] | []
args: ["-http=:8080", "-etcd=etcd:2379"]
ports: [{
name: "http"
containerPort: 8080
Expand Down Expand Up @@ -790,7 +790,7 @@ deployment: {
http: ":8080"
etcd: "etcd:2379"
}
args: ["-http=:8080", "-etcd=etcd:2379"] | []
args: ["-http=:8080", "-etcd=etcd:2379"]
env: {}
label: {
app: "waterdispatcher"
Expand Down Expand Up @@ -886,7 +886,7 @@ kubernetes: {
containers: [{
name: "waterdispatcher"
image: "gcr.io/myproj/waterdispatcher:v0.0.48"
args: ["-http=:8080", "-etcd=etcd:2379"] | []
args: ["-http=:8080", "-etcd=etcd:2379"]
ports: [{
name: "http"
containerPort: 7080
Expand Down Expand Up @@ -1130,7 +1130,7 @@ deployment: {
}
}
port: {}
args: ["-name=$(NAME)", "-data-dir=/data/etcd3", "-initial-advertise-peer-urls=http://$(IP):2380", "-listen-peer-urls=http://$(IP):2380", "-listen-client-urls=http://$(IP):2379,http://127.0.0.1:2379", "-advertise-client-urls=http://$(IP):2379", "-discovery=https://discovery.etcd.io/xxxxxx"] | []
args: ["-name=$(NAME)", "-data-dir=/data/etcd3", "-initial-advertise-peer-urls=http://$(IP):2380", "-listen-peer-urls=http://$(IP):2380", "-listen-client-urls=http://$(IP):2379,http://127.0.0.1:2379", "-advertise-client-urls=http://$(IP):2379", "-discovery=https://discovery.etcd.io/xxxxxx"]
label: {
app: "etcd"
domain: "prod"
Expand Down Expand Up @@ -1245,7 +1245,7 @@ kubernetes: {
containers: [{
name: "etcd"
image: "quay.io/coreos/etcd:v3.3.10"
args: ["-name=$(NAME)", "-data-dir=/data/etcd3", "-initial-advertise-peer-urls=http://$(IP):2380", "-listen-peer-urls=http://$(IP):2380", "-listen-client-urls=http://$(IP):2379,http://127.0.0.1:2379", "-advertise-client-urls=http://$(IP):2379", "-discovery=https://discovery.etcd.io/xxxxxx"] | []
args: ["-name=$(NAME)", "-data-dir=/data/etcd3", "-initial-advertise-peer-urls=http://$(IP):2380", "-listen-peer-urls=http://$(IP):2380", "-listen-client-urls=http://$(IP):2379,http://127.0.0.1:2379", "-advertise-client-urls=http://$(IP):2379", "-discovery=https://discovery.etcd.io/xxxxxx"]
command: ["/usr/local/bin/etcd"]
volumeMounts: [{
name: "etcd3"
Expand Down Expand Up @@ -1329,7 +1329,7 @@ deployment: {
grpc: 7788
}
}
args: ["-cert=/etc/ssl/server.pem", "-key=/etc/ssl/server.key", "-grpc=:7788"] | []
args: ["-cert=/etc/ssl/server.pem", "-key=/etc/ssl/server.key", "-grpc=:7788"]
env: {}
volume: {
"secret-volume": {
Expand Down Expand Up @@ -1454,7 +1454,7 @@ kubernetes: {
containers: [{
name: "events"
image: "gcr.io/myproj/events:v0.1.31"
args: ["-cert=/etc/ssl/server.pem", "-key=/etc/ssl/server.key", "-grpc=:7788"] | []
args: ["-cert=/etc/ssl/server.pem", "-key=/etc/ssl/server.key", "-grpc=:7788"]
volumeMounts: [{
name: v.name
mountPath: v.mountPath
Expand Down Expand Up @@ -1986,7 +1986,7 @@ deployment: {
ca: "/etc/certs/servfx.ca"
"ssh-tunnel-key": "/sslcerts/tunnel-private.pem"
}
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-key=/etc/certs/client.key", "-cert=/etc/certs/client.pem", "-ca=/etc/certs/servfx.ca", "-ssh-tunnel-key=/sslcerts/tunnel-private.pem"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-key=/etc/certs/client.key", "-cert=/etc/certs/client.pem", "-ca=/etc/certs/servfx.ca", "-ssh-tunnel-key=/sslcerts/tunnel-private.pem"]
env: {}
volume: {
"caller-disk": {
Expand Down Expand Up @@ -2130,7 +2130,7 @@ kubernetes: {
containers: [{
name: "caller"
image: "gcr.io/myproj/caller:v0.20.14"
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-key=/etc/certs/client.key", "-cert=/etc/certs/client.pem", "-ca=/etc/certs/servfx.ca", "-ssh-tunnel-key=/sslcerts/tunnel-private.pem"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-key=/etc/certs/client.key", "-cert=/etc/certs/client.pem", "-ca=/etc/certs/servfx.ca", "-ssh-tunnel-key=/sslcerts/tunnel-private.pem"]
livenessProbe: {
httpGet: {
path: "/debug/health"
Expand Down Expand Up @@ -2207,7 +2207,7 @@ deployment: {
"event-server": "events:7788"
"ssh-tunnel-key": "/etc/certs/tunnel-private.pem"
}
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"]
env: {}
volume: {
"secret-ssh-key": {
Expand Down Expand Up @@ -2351,7 +2351,7 @@ kubernetes: {
containers: [{
name: "dishwasher"
image: "gcr.io/myproj/dishwasher:v0.2.13"
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"]
livenessProbe: {
httpGet: {
path: "/debug/health"
Expand Down Expand Up @@ -2428,7 +2428,7 @@ deployment: {
"event-server": "events:7788"
"ssh-tunnel-key": "/etc/certs/tunnel-private.pem"
}
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"]
env: {}
volume: {
"expiditer-disk": {
Expand Down Expand Up @@ -2560,7 +2560,7 @@ kubernetes: {
containers: [{
name: "expiditer"
image: "gcr.io/myproj/expiditer:v0.5.34"
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem"]
livenessProbe: {
httpGet: {
path: "/debug/health"
Expand Down Expand Up @@ -2625,7 +2625,7 @@ deployment: {
logdir: "/logs"
"event-server": "events:7788"
}
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788"]
env: {}
volume: {
"secret-headchef": {
Expand Down Expand Up @@ -2757,7 +2757,7 @@ kubernetes: {
containers: [{
name: "headchef"
image: "gcr.io/myproj/headchef:v0.2.16"
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788"]
livenessProbe: {
httpGet: {
path: "/debug/health"
Expand Down Expand Up @@ -2826,7 +2826,7 @@ deployment: {
"reconnect-delay": "1h"
"-recovery-overlap": "100000"
}
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-name=linecook", "-etcd=etcd:2379", "-reconnect-delay=1h", "--recovery-overlap=100000"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-name=linecook", "-etcd=etcd:2379", "-reconnect-delay=1h", "--recovery-overlap=100000"]
env: {}
volume: {
"secret-linecook": {
Expand Down Expand Up @@ -2958,7 +2958,7 @@ kubernetes: {
containers: [{
name: "linecook"
image: "gcr.io/myproj/linecook:v0.1.42"
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-name=linecook", "-etcd=etcd:2379", "-reconnect-delay=1h", "--recovery-overlap=100000"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-name=linecook", "-etcd=etcd:2379", "-reconnect-delay=1h", "--recovery-overlap=100000"]
livenessProbe: {
httpGet: {
path: "/debug/health"
Expand Down Expand Up @@ -3027,7 +3027,7 @@ deployment: {
etcd: "etcd:2379"
"recovery-overlap": "10000"
}
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem", "-reconnect-delay=1m", "-etcd=etcd:2379", "-recovery-overlap=10000"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem", "-reconnect-delay=1m", "-etcd=etcd:2379", "-recovery-overlap=10000"]
env: {}
volume: {
"secret-pastrychef": {
Expand Down Expand Up @@ -3159,7 +3159,7 @@ kubernetes: {
containers: [{
name: "pastrychef"
image: "gcr.io/myproj/pastrychef:v0.1.15"
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem", "-reconnect-delay=1m", "-etcd=etcd:2379", "-recovery-overlap=10000"] | []
args: ["-env=prod", "-logdir=/logs", "-event-server=events:7788", "-ssh-tunnel-key=/etc/certs/tunnel-private.pem", "-reconnect-delay=1m", "-etcd=etcd:2379", "-recovery-overlap=10000"]
livenessProbe: {
httpGet: {
path: "/debug/health"
Expand Down
4 changes: 4 additions & 0 deletions internal/core/adt/equality.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,10 @@ func equalVertex(ctx *OpContext, x *Vertex, v Value) bool {
return false
}

if x.IsClosed(ctx) != y.IsClosed(ctx) {
return false
}

loop1:
for _, a := range x.Arcs {
for _, b := range y.Arcs {
Expand Down

0 comments on commit b619e0c

Please sign in to comment.