The object-being sliced in an assignment to a slice is referenced, not
bound.

When a Yield() node is visited, assign to the generator attribute of
the scope, not the visitor.
diff --git a/Lib/compiler/symbols.py b/Lib/compiler/symbols.py
index 946a8b1..bf9a724 100644
--- a/Lib/compiler/symbols.py
+++ b/Lib/compiler/symbols.py
@@ -321,7 +321,7 @@
             self.visit(n, scope, 0)
 
     def visitSlice(self, node, scope, assign=0):
-        self.visit(node.expr, scope, assign)
+        self.visit(node.expr, scope, 0)
         if node.lower:
             self.visit(node.lower, scope, 0)
         if node.upper:
@@ -353,7 +353,7 @@
     # a yield statement signals a generator
 
     def visitYield(self, node, scope):
-        self.generator = 1
+        scope.generator = 1
         self.visit(node.value, scope)
 
 def sort(l):
diff --git a/Tools/compiler/compiler/symbols.py b/Tools/compiler/compiler/symbols.py
index 946a8b1..bf9a724 100644
--- a/Tools/compiler/compiler/symbols.py
+++ b/Tools/compiler/compiler/symbols.py
@@ -321,7 +321,7 @@
             self.visit(n, scope, 0)
 
     def visitSlice(self, node, scope, assign=0):
-        self.visit(node.expr, scope, assign)
+        self.visit(node.expr, scope, 0)
         if node.lower:
             self.visit(node.lower, scope, 0)
         if node.upper:
@@ -353,7 +353,7 @@
     # a yield statement signals a generator
 
     def visitYield(self, node, scope):
-        self.generator = 1
+        scope.generator = 1
         self.visit(node.value, scope)
 
 def sort(l):