<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Fri, Dec 12, 2014 at 3:22 PM, Andrew Barnert <span dir="ltr"><<a href="mailto:abarnert@yahoo.com" target="_blank">abarnert@yahoo.com</a>></span> wrote:<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="auto"><span class=""><blockquote type="cite"><div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div>1) It's not clear what is meant by an "iterator" -- when we use the term is seems like we are talking about a type, when we are really talking about "anything that conforms to the iterator protocol", so I'm going to introduce a new term: TIIP (Type Implementing the Iterator Protocol) -- maybe that's too cute, but role with it for now.</div></div></div></div></div></blockquote><div><br></div></span><div>When you're writing actual code, you can test this with isinstance(collections.abc.Iterator). Of course ABCs don't _perfectly_ cover their related protocols (in this case, if you create a type that has __iter__ and __next__ but __iter__ doesn't return self--or, of course, if you just register some random type with Iterator explicitly--you've created a subclass of Iterator that isn't a subtype of the iterator protocol). But I think it still makes sense to use Iterator as shorthand for "type that subclasses Iterator" with the implied "is an actual subtype of the semantic type intended by the Iterator class".</div></div></blockquote><div><br></div><div>this issue here is that inteh PEP, and in this list, it seems "iterator" was used to describe classes with __init__ and __next__ methods, AS APPOSED to the things returned from functions with a yield in them...</div><div><br></div><div>and:</div><div><br></div><div><div>In [12]: g = (i for i in range(10))</div><div><br></div><div>In [13]: isinstance(it, collections.abc.Iterator)</div><div>Out[13]: True</div></div><div><br></div><div>and </div><div><br></div><div><div>In [15]: def gf():</div><div> ....: yield 1</div><div> ....: yield 2</div><div><br></div><div>In [16]: gen = gf()</div><div><br></div><div>In [17]: isinstance(gen, collections.abc.Iterator)</div><div>Out[17]: True</div></div><div><br></div><div>So generators ARE iterators, but his definition and yet the contrast was being made....</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="auto"><div>This kind of shorthand is used regularly in discussing types in every OO language, not just Python.</div></div></blockquote><div><br></div><div>sure, but Python is dynamically types, so "conforms to a protocol" not at all teh same is "isinstance", even though ABCS have made this closer...</div><div> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="auto"><div>In Python, the term "Iterator" is just as consistent and meaningful as in all these other languages. The fact that some people confuse iterables and iterators isn't a reason to abandon this simplicity.</div></div></blockquote><div><br></div><div>actually, the confusion between iterables and iterators want the issue I as trying to address -- but the confusion with a sentence like</div><div><br></div><div>"<span style="color:rgb(51,51,51);font-size:12px;line-height:19.6000003814697px;white-space:pre-wrap">Under this proposal, generators and iterators would be distinct, but </span><span style="color:rgb(51,51,51);font-size:12px;line-height:19.6000003814697px;white-space:pre-wrap">related, concepts</span>"</div><div><br></div><div>That has been removed from the PEP -- I think it's more clean now in any case.</div><div><br></div><div>But yes, I could have written all that and stuck with plain old "iterator" instead of making up "TIIP"</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="auto"><div> Especially since it doesn't even help to solve the problem--as we've just seen in this very message I'm replying to, it's just as easy for someone to mistakenly use TIIP to describe "range" as it is for them to mistakenly use "Iterator".</div></div></blockquote><div><br></div><div>My bad -- typing too fast! And this was never about the itterable vs iterator distinction anyway.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="auto"><div> (In fact, it's arguably worse, because what would you call an Iterable under the same naming scheme but Type Implementing Iterable Protocol, or TIIP?)</div></div></blockquote><div><br></div><div>I was not trying to mingle iterable and iterator -- really I wan't :-)</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="auto"><div></div><div>The things we need to be clear about here are the things that _dont't_ have an official name. In particular, the thing that's built from calling a generator function or evaluating a generator expression and used by the generator.</div></div></blockquote><div><br></div><div>now I am confused:</div><div><br></div><div><div>In [18]: g = ( i for i in range(10) )</div><div><br></div><div>In [19]: type(g)</div><div>Out[19]: generator</div></div><div><br></div><div>how is that not a "generator"?</div><div><br></div><div>-Chris</div><div><br></div></div>-- <br><div class="gmail_signature"><br>Christopher Barker, Ph.D.<br>Oceanographer<br><br>Emergency Response Division<br>NOAA/NOS/OR&R (206) 526-6959 voice<br>7600 Sand Point Way NE (206) 526-6329 fax<br>Seattle, WA 98115 (206) 526-6317 main reception<br><br><a href="mailto:Chris.Barker@noaa.gov" target="_blank">Chris.Barker@noaa.gov</a></div>
</div></div>