2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								<?xml version="1.0" encoding="utf-8" ?>  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< html  xmlns = "http://www.w3.org/1999/xhtml"  xml:lang = "en"  lang = "en" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< head >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< meta  http-equiv = "Content-Type"  content = "text/html; charset=utf-8"  / >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< meta  name = "generator"  content = "Docutils 0.3.1: http://docutils.sourceforge.net/"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< title > New Iterator Concepts< / title >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< meta  name = "author"  content = "David Abrahams, Jeremy Siek, Thomas Witt"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< meta  name = "organization"  content = "Boost Consulting, Indiana University Open Systems Lab, University of Hanover Institute for Transport Railway Operation and Construction"  / >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 14:44:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< meta  name = "date"  content = "2003-12-02"  / >  
						 
					
						
							
								
									
										
										
										
											2003-09-14 02:17:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< meta  name = "copyright"  content = "Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003. All rights reserved"  / >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< style  type = "text/css" > < ! - -  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:Author: David Goodger
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:Contact: goodger@users.sourceforge.net
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:date: $Date$
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:version: $Revision$
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								:copyright: This stylesheet has been placed in the public domain.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Default cascading style sheet for the HTML output of Docutils.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								.first {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-top: 0 }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								.last {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-bottom: 0 }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a.toc-backref {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text-decoration: none ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  color: black }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dd {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-bottom: 0.5em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.abstract {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin: 2em 5em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.abstract p.topic-title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text-align: center }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.attention, div.caution, div.danger, div.error, div.hint,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.important, div.note, div.tip, div.warning {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin: 2em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  border: medium outset ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  padding: 1em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.attention p.admonition-title, div.caution p.admonition-title,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.danger p.admonition-title, div.error p.admonition-title,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.warning p.admonition-title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  color: red ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: sans-serif }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.hint p.admonition-title, div.important p.admonition-title,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.note p.admonition-title, div.tip p.admonition-title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: sans-serif }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.dedication {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin: 2em 5em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text-align: center ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-style: italic }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.dedication p.topic-title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-style: normal }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.figure {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-left: 2em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.footer, div.header {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-size: smaller }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.system-messages {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin: 5em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.system-messages h1 {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  color: red }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.system-message {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  border: medium outset ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  padding: 1em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.system-message p.system-message-title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  color: red ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								div.topic {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin: 2em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								h1.title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text-align: center }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								h2.subtitle {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text-align: center }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								hr {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  width: 75% }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ol.simple, ul.simple {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-bottom: 1em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ol.arabic {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  list-style: decimal }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ol.loweralpha {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  list-style: lower-alpha }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ol.upperalpha {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  list-style: upper-alpha }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ol.lowerroman {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  list-style: lower-roman }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ol.upperroman {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  list-style: upper-roman }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								p.caption {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-style: italic }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								p.credits {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-style: italic ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-size: smaller }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								p.label {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  white-space: nowrap }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								p.topic-title {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pre.address {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-bottom: 0 ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-top: 0 ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: serif ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-size: 100% }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pre.line-block {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: serif ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-size: 100% }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pre.literal-block, pre.doctest-block {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-left: 2em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-right: 2em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  background-color: #eeeeee }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								span.classifier {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: sans-serif ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-style: oblique }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								span.classifier-delimiter {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: sans-serif ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								span.interpreted {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-family: sans-serif }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								span.option-argument {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-style: italic }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								span.pre {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  white-space: pre }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								span.problematic {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  color: red }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								table {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-top: 0.5em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin-bottom: 0.5em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								table.citation {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  border-left: solid thin gray ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  padding-left: 0.5ex }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								table.docinfo {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  margin: 2em 4em }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								table.footnote {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  border-left: solid thin black ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  padding-left: 0.5ex }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								td, th {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  padding-left: 0.5em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  padding-right: 0.5em ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  vertical-align: top }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								th.docinfo-name, th.field-name {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-weight: bold ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text-align: left ;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  white-space: nowrap }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								h1 tt, h2 tt, h3 tt, h4 tt, h5 tt, h6 tt {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  font-size: 100% }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								tt {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  background-color: #eeeeee }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ul.auto-toc {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  list-style-type: none }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-->< / style > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / head >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< body >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "document"  id = "new-iterator-concepts" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< h1  class = "title" > New Iterator Concepts< / h1 >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< table  class = "docinfo"  frame = "void"  rules = "none" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  class = "docinfo-name"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  class = "docinfo-content"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  class = "docinfo-name" > Author:< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > David Abrahams, Jeremy Siek, Thomas Witt< / td > < / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  class = "docinfo-name" > Contact:< / th >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < a  class = "first reference"  href = "mailto:dave@boost-consulting.com" > dave@ boost-consulting.com< / a > , < a  class = "reference"  href = "mailto:jsiek@osl.iu.edu" > jsiek@ osl.iu.edu< / a > , < a  class = "last reference"  href = "mailto:witt@acm.org" > witt@ acm.org< / a > < / td > < / tr >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< tr > < th  class = "docinfo-name" > Organization:< / th >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < a  class = "first reference"  href = "http://www.boost-consulting.com" > Boost Consulting< / a > , Indiana University < a  class = "reference"  href = "http://www.osl.iu.edu" > Open 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Systems Lab< / a > , University of Hanover < a  class = "last reference"  href = "http://www.ive.uni-hannover.de" > Institute for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Transport Railway Operation and Construction< / a > < / td > < / tr > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< tr > < th  class = "docinfo-name" > Date:< / th >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 14:44:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > 2003-12-02< / td > < / tr >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tr  class = "field" > < th  class = "docinfo-name" > Number:< / th > < td  class = "field-body" > This is a revised version of < a  class = "reference"  href = "http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1550.html" > n1550< / a > =03-0133, which was 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								accepted for Technical Report 1 by the C++ standard
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								committee's library working group. This proposal is a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								revision of paper < a  class = "reference"  href = "http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2001/n1297.html" > n1297< / a > , < a  class = "reference"  href = "http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1477.html" > n1477< / a > , and < a  class = "reference"  href = "http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1531.html" > n1531< / a > .< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  class = "docinfo-name" > Copyright:< / th >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > Copyright David Abrahams, Jeremy Siek, and Thomas Witt 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2003. All rights reserved< / td > < / tr > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  Version 1.25 of this ReStructuredText document is the same as
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								n1550_, the paper accepted by the LWG. -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< table  class = "field-list"  frame = "void"  rules = "none" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  class = "field-name"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  class = "field-body"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr  class = "field" > < th  class = "field-name" > Abstract:< / th > < td  class = "field-body" > We propose a new system of iterator concepts that treat 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								access and positioning independently. This allows the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								concepts to more closely match the requirements
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								of algorithms and provides better categorizations
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								of iterators that are used in practice.< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "contents topic"  id = "table-of-contents" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p  class = "topic-title" > < a  name = "table-of-contents" > Table of Contents< / a > < / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< ul  class = "simple" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#motivation"  id = "id1"  name = "id1" > Motivation< / a > < / li >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#impact-on-the-standard"  id = "id2"  name = "id2" > Impact on the Standard< / a > < ul >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#possible-but-not-proposed-changes-to-the-working-paper"  id = "id3"  name = "id3" > Possible (but not proposed) Changes to the Working Paper< / a > < ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#changes-to-algorithm-requirements"  id = "id4"  name = "id4" > Changes to Algorithm Requirements< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#deprecations"  id = "id5"  name = "id5" > Deprecations< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#vector-bool"  id = "id6"  name = "id6" > < tt  class = "literal" > < span  class = "pre" > vector< bool> < / span > < / tt > < / a > < / li >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / li >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#design"  id = "id7"  name = "id7" > Design< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#proposed-text"  id = "id8"  name = "id8" > Proposed Text< / a > < ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#addition-to-lib-iterator-requirements"  id = "id9"  name = "id9" > Addition to [lib.iterator.requirements]< / a > < ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#iterator-value-access-concepts-lib-iterator-value-access"  id = "id10"  name = "id10" > Iterator Value Access Concepts [lib.iterator.value.access]< / a > < ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#readable-iterators-lib-readable-iterators"  id = "id11"  name = "id11" > Readable Iterators [lib.readable.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#writable-iterators-lib-writable-iterators"  id = "id12"  name = "id12" > Writable Iterators [lib.writable.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#swappable-iterators-lib-swappable-iterators"  id = "id13"  name = "id13" > Swappable Iterators [lib.swappable.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#lvalue-iterators-lib-lvalue-iterators"  id = "id14"  name = "id14" > Lvalue Iterators [lib.lvalue.iterators]< / a > < / li >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / li >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#iterator-traversal-concepts-lib-iterator-traversal"  id = "id15"  name = "id15" > Iterator Traversal Concepts [lib.iterator.traversal]< / a > < ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#incrementable-iterators-lib-incrementable-iterators"  id = "id16"  name = "id16" > Incrementable Iterators [lib.incrementable.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#single-pass-iterators-lib-single-pass-iterators"  id = "id17"  name = "id17" > Single Pass Iterators [lib.single.pass.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#forward-traversal-iterators-lib-forward-traversal-iterators"  id = "id18"  name = "id18" > Forward Traversal Iterators [lib.forward.traversal.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#bidirectional-traversal-iterators-lib-bidirectional-traversal-iterators"  id = "id19"  name = "id19" > Bidirectional Traversal Iterators [lib.bidirectional.traversal.iterators]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#random-access-traversal-iterators-lib-random-access-traversal-iterators"  id = "id20"  name = "id20" > Random Access Traversal Iterators [lib.random.access.traversal.iterators]< / a > < / li >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / li >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#addition-to-lib-iterator-synopsis"  id = "id21"  name = "id21" > Addition to [lib.iterator.synopsis]< / a > < / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#addition-to-lib-iterator-traits"  id = "id22"  name = "id22" > Addition to [lib.iterator.traits]< / a > < / li >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / li >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > < a  class = "reference"  href = "#footnotes"  id = "id23"  name = "id23" > Footnotes< / a > < / li >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "motivation" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< h1 > < a  class = "toc-backref"  href = "#id1"  name = "motivation" > Motivation< / a > < / h1 >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > The standard iterator categories and requirements are flawed because 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								they use a single hierarchy of concepts to address two orthogonal
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								issues: < em > iterator traversal< / em >  and < em > value access< / em > . As a result, many
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								algorithms with requirements expressed in terms of the iterator
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								categories are too strict. Also, many real-world iterators can not be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								accurately categorized.  A proxy-based iterator with random-access
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								traversal, for example, may only legally have a category of " input
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterator" , so generic algorithms are unable to take advantage of its
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								random-access capabilities.  The current iterator concept hierarchy is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								geared towards iterator traversal (hence the category names), while
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requirements that address value access sneak in at various places. The
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								following table gives a summary of the current value access
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requirements in the iterator categories.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "31%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "69%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "2" > Value Access Requirements in Existing Iterator Categories< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > Output Iterator< / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > *i< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > a< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > Input Iterator< / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > *i< / span > < / tt >  is convertible to < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > Forward Iterator< / td >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > *i< / span > < / tt >  is < tt  class = "literal" > < span  class = "pre" > T& < / span > < / tt >  (or < tt  class = "literal" > < span  class = "pre" > const< / span >  < span  class = "pre" > T& < / span > < / tt >  once < a  class = "reference"  href = "http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#200" > issue 200< / a >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is resolved)< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > Random Access Iterator< / td >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > i[n]< / span > < / tt >  is convertible to < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt >  (also < tt  class = "literal" > < span  class = "pre" > i[n]< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > t< / span > < / tt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is required for mutable iterators once < a  class = "reference"  href = "http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#299" > issue 299< / a > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								is resolved)< / td > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Because iterator traversal and value access are mixed together in a 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								single hierarchy, many useful iterators can not be appropriately
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								categorized. For example, < tt  class = "literal" > < span  class = "pre" > vector< bool> ::iterator< / span > < / tt >  is almost a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								random access iterator, but the return type is not < tt  class = "literal" > < span  class = "pre" > bool& < / span > < / tt >  (see
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< a  class = "reference"  href = "http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#96" > issue 96< / a >  and Herb Sutter's paper J16/99-0008 = WG21 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								N1185). Therefore, the iterators of < tt  class = "literal" > < span  class = "pre" > vector< bool> < / span > < / tt >  only meet the
							 
						 
					
						
							
								
									
										
										
										
											2003-09-21 00:30:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								requirements of input iterator and output iterator.  This is so
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								nonintuitive that the C++ standard contradicts itself on this point.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In paragraph 23.2.4/1 it says that a < tt  class = "literal" > < span  class = "pre" > vector< / span > < / tt >  is a sequence that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								supports random access iterators.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > Another difficult-to-categorize iterator is the transform iterator, an 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								adaptor which applies a unary function object to the dereferenced
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								value of the some underlying iterator (see < a  class = "reference"  href = "http://www.boost.org/libs/utility/transform_iterator.htm" > transform_iterator< / a > ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For unary functions such as < tt  class = "literal" > < span  class = "pre" > times< / span > < / tt > , the return type of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > operator*< / span > < / tt >  clearly needs to be the < tt  class = "literal" > < span  class = "pre" > result_type< / span > < / tt >  of the function 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								object, which is typically not a reference.  Because random access
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterators are required to return lvalues from < tt  class = "literal" > < span  class = "pre" > operator*< / span > < / tt > , if you
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								wrap < tt  class = "literal" > < span  class = "pre" > int*< / span > < / tt >  with a transform iterator, you do not get a random
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								access iterator as might be expected, but an input iterator.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > A third example is found in the vertex and edge iterators of the 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< a  class = "reference"  href = "http://www.boost.org/libs/graph/doc/table_of_contents.html" > Boost Graph Library< / a > . These iterators return vertex and edge 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								descriptors, which are lightweight handles created on-the-fly. They
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								must be returned by-value. As a result, their current standard
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterator category is < tt  class = "literal" > < span  class = "pre" > input_iterator_tag< / span > < / tt > , which means that,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								strictly speaking, you could not use these iterators with algorithms
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								like < tt  class = "literal" > < span  class = "pre" > min_element()< / span > < / tt > . As a temporary solution, the concept
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< a  class = "reference"  href = "http://www.boost.org/libs/utility/MultiPassInputIterator.html" > Multi-Pass Input Iterator< / a >  was introduced to describe the vertex and 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								edge descriptors, but as the design notes for the concept suggest, a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								better solution is needed.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > In short, there are many useful iterators that do not fit into the 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								current standard iterator categories. As a result, the following bad
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								things happen:< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< ul  class = "simple" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Iterators are often mis-categorized.< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Algorithm requirements are more strict than necessary, because they 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cannot separate the need for random access or bidirectional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								traversal from the need for a true reference return type.< / li > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "impact-on-the-standard" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< h1 > < a  class = "toc-backref"  href = "#id2"  name = "impact-on-the-standard" > Impact on the Standard< / a > < / h1 >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > This proposal for TR1 is a pure extension. Further, the new iterator 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								concepts are backward-compatible with the old iterator requirements,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and old iterators are forward-compatible with the new iterator
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								concepts. That is to say, iterators that satisfy the old requirements
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								also satisfy appropriate concepts in the new system, and iterators
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								modeling the new concepts will automatically satisfy the appropriate
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								old requirements.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								<!--  I think we need to say something about the resolution to allow
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								convertibility to any of the old-style tags as a TR issue (hope it
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								made it). -DWA -->
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								<!--  Hmm, not sure I understand. Are you talking about whether a
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								standards conforming input iterator is allowed to have
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a tag that is not input_iterator_tag but that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is convertible to input_iterator_tag? -JGS -->
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > Note that as currently specified, < tt  class = "literal" > < span  class = "pre" > istreambuf_iterator< / span > < / tt >  doesn't 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								meet the Readable Iterator requirements because its < tt  class = "literal" > < span  class = "pre" > value_type< / span > < / tt > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is not convertible to its < tt  class = "literal" > < span  class = "pre" > reference< / span > < / tt >  type.  We believe this to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								be a defect in the standard; it should be fixed by changing its
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > reference< / span > < / tt >  type from < tt  class = "literal" > < span  class = "pre" > value_type& < / span > < / tt >  to < tt  class = "literal" > < span  class = "pre" > value_type< / span >  < span  class = "pre" > const& < / span > < / tt > .< / p >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = "section"  id = "possible-but-not-proposed-changes-to-the-working-paper" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h2 > < a  class = "toc-backref"  href = "#id3"  name = "possible-but-not-proposed-changes-to-the-working-paper" > Possible (but not proposed) Changes to the Working Paper< / a > < / h2 >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > The extensions in this paper suggest several changes we might make 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to the working paper for the next standard.  These changes are not
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a formal part of this proposal for TR1.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "changes-to-algorithm-requirements" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h3 > < a  class = "toc-backref"  href = "#id4"  name = "changes-to-algorithm-requirements" > Changes to Algorithm Requirements< / a > < / h3 >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > The algorithms in the standard library could benefit from the new 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterator concepts because the new concepts provide a more accurate way
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to express their type requirements. The result is algorithms that are
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								usable in more situations and have fewer type requirements.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > For the next working paper (but not for TR1), the committee should 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								consider the following changes to the type requirements of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								algorithms.  These changes are phrased as phrased as textual
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								substitutions, listing the algorithms to which each textual
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								substitution applies.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > Forward Iterator ->  Forward Traversal Iterator and Readable Iterator< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > find_end,< / span >  < span  class = "pre" > adjacent_find,< / span >  < span  class = "pre" > search,< / span >  < span  class = "pre" > search_n,< / span >  < span  class = "pre" > rotate_copy,< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > lower_bound,< / span >  < span  class = "pre" > upper_bound,< / span >  < span  class = "pre" > equal_range,< / span >  < span  class = "pre" > binary_search,< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > min_element,< / span >  < span  class = "pre" > max_element< / span > < / tt > < / blockquote >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:45:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > Forward Iterator (1) ->  Single Pass Iterator and Readable Iterator, 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Forward Iterator (2) ->  Forward Traversal Iterator and Readable Iterator< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > find_first_of< / span > < / tt > < / blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Forward Iterator ->  Readable Iterator and Writable Iterator< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > iter_swap< / span > < / tt > < / blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Forward Iterator ->  Single Pass Iterator and Writable Iterator< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > fill,< / span >  < span  class = "pre" > generate< / span > < / tt > < / blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Forward Iterator ->  Forward Traversal Iterator and Swappable Iterator< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > rotate< / span > < / tt > < / blockquote >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:45:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > Forward Iterator (1) ->  Swappable Iterator and Single Pass Iterator, 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Forward Iterator (2) ->  Swappable Iterator and  Incrementable Iterator< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > swap_ranges< / span > < / tt > < / blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Forward Iterator ->  Forward Traversal Iterator and Readable Iterator and Writable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > remove,< / span >  < span  class = "pre" > remove_if,< / span >  < span  class = "pre" > unique< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Forward Iterator ->  Single Pass Iterator and Readable Iterator and Writable Iterator< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > replace,< / span >  < span  class = "pre" > replace_if< / span > < / tt > < / blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Bidirectional Iterator ->  Bidirectional Traversal Iterator and Swappable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > reverse< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Bidirectional Iterator ->  Bidirectional Traversal Iterator and Readable and Swappable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > partition< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Bidirectional Iterator (1) ->  Bidirectional Traversal Iterator and Readable Iterator,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Bidirectional Iterator (2) ->  Bidirectional Traversal Iterator and Writable Iterator< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > copy_backwards< / span > < / tt > < / blockquote >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Bidirectional Iterator ->  Bidirectional Traversal Iterator and Swappable Iterator and Readable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > next_permutation,< / span >  < span  class = "pre" > prev_permutation< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Bidirectional Iterator ->  Bidirectional Traversal Iterator and Readable Iterator and Writable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > stable_partition,< / span >  < span  class = "pre" > inplace_merge< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Bidirectional Iterator ->  Bidirectional Traversal Iterator and Readable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > reverse_copy< / span > < / tt > < / dd >  
						 
					
						
							
								
									
										
										
										
											2003-09-21 00:30:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< dt > Random Access Iterator ->  Random Access Traversal Iterator and Readable and Writable Iterator< / dt >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > random_shuffle,< / span >  < span  class = "pre" > sort,< / span >  < span  class = "pre" > stable_sort,< / span >  < span  class = "pre" > partial_sort,< / span >  < span  class = "pre" > nth_element,< / span >  < span  class = "pre" > push_heap,< / span >  < span  class = "pre" > pop_heap< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > make_heap,< / span >  < span  class = "pre" > sort_heap< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > Input Iterator (2) ->  Incrementable Iterator and Readable Iterator< / dt >  
						 
					
						
							
								
									
										
										
										
											2003-09-21 00:30:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > equal,< / span >  < span  class = "pre" > mismatch< / span > < / tt > < / dd >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< dt > Input Iterator (2) ->  Incrementable Iterator and Readable Iterator< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > < tt  class = "literal" > < span  class = "pre" > transform< / span > < / tt > < / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = "section"  id = "deprecations" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h3 > < a  class = "toc-backref"  href = "#id5"  name = "deprecations" > Deprecations< / a > < / h3 >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > For the next working paper (but not for TR1), the committee should 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								consider deprecating the old iterator tags, and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								std::iterator_traits, since it will be superceded by individual
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								traits metafunctions.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "vector-bool" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h3 > < a  class = "toc-backref"  href = "#id6"  name = "vector-bool" > < tt  class = "literal" > < span  class = "pre" > vector< bool> < / span > < / tt > < / a > < / h3 >  
						 
					
						
							
								
									
										
										
										
											2003-10-30 21:11:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > For the next working paper (but not for TR1), the committee should 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								consider reclassifying < tt  class = "literal" > < span  class = "pre" > vector< bool> ::iterator< / span > < / tt >  as a Random
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Access Traversal Iterator and Readable Iterator and Writable
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Iterator.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "design" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h1 > < a  class = "toc-backref"  href = "#id7"  name = "design" > Design< / a > < / h1 >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 16:04:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > The iterator requirements are to be separated into two groups. One set 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								of concepts handles the syntax and semantics of value access:< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< ul  class = "simple" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Readable Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Writable Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Swappable Iterator< / li >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 13:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< li > Lvalue Iterator< / li >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > The access concepts describe requirements related to < tt  class = "literal" > < span  class = "pre" > operator*< / span > < / tt >  and 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > operator-> < / span > < / tt > , including the < tt  class = "literal" > < span  class = "pre" > value_type< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > reference< / span > < / tt > , and 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > pointer< / span > < / tt >  associated types.< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > The other set of concepts handles traversal:< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< ul  class = "simple" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Incrementable Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Single Pass Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Forward Traversal Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Bidirectional Traversal Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< li > Random Access Traversal Iterator< / li >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / ul >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > The refinement relationships for the traversal concepts are in the 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								following diagram.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > < img  alt = "traversal.png"  src = "traversal.png"  / > < / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > In addition to the iterator movement operators, such as 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > operator++< / span > < / tt > , the traversal concepts also include requirements on 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								position comparison such as < tt  class = "literal" > < span  class = "pre" > operator==< / span > < / tt >  and < tt  class = "literal" > < span  class = "pre" > operator< < / span > < / tt > .  The
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								reason for the fine grain slicing of the concepts into the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Incrementable and Single Pass is to provide concepts that are exact
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								matches with the original input and output iterator requirements.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > The relationship between the new iterator concepts and the old are 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								given in the following diagram.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > < img  alt = "oldeqnew.png"  src = "oldeqnew.png"  / > < / p >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:45:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > Like the old iterator requirements, we provide tags for purposes of 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dispatching based on the traversal concepts.  The tags are related via
							 
						 
					
						
							
								
									
										
										
										
											2003-09-21 00:30:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								inheritance so that a tag is convertible to another tag if the concept
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								associated with the first tag is a refinement of the second tag.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Our design reuses < tt  class = "literal" > < span  class = "pre" > iterator_traits< Iter> ::iterator_category< / span > < / tt >  to 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								indicate an iterator's traversal capability.  To specify
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								capabilities not captured by any old-style iterator category, an
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterator designer can use an < tt  class = "literal" > < span  class = "pre" > iterator_category< / span > < / tt >  type that is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								convertible to both the the most-derived old iterator category tag
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								which fits, and the appropriate new iterator traversal tag.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								<!--  dwa2003/1/2: Note that we are not *requiring* convertibility to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a new-style traversal tag in order to meet new concepts.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Old-style iterators still fit, after all. -->
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > We do not provide tags for the purposes of dispatching based on the 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								access concepts, in part because we could not find a way to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								automatically infer the right access tags for old-style iterators.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								An iterator's writability may be dependent on the assignability of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								its < tt  class = "literal" > < span  class = "pre" > value_type< / span > < / tt >  and there's no known way to detect whether an
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								arbitrary type is assignable.  Fortunately, the need for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dispatching based on access capability is not as great as the need
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								for dispatching based on traversal capability.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > A difficult design decision concerned the < tt  class = "literal" > < span  class = "pre" > operator[]< / span > < / tt > . The direct 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								approach for specifying < tt  class = "literal" > < span  class = "pre" > operator[]< / span > < / tt >  would have a return type of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > reference< / span > < / tt > ; the same as < tt  class = "literal" > < span  class = "pre" > operator*< / span > < / tt > . However, going in this 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								direction would mean that an iterator satisfying the old Random Access
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Iterator requirements would not necessarily be a model of Readable or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Writable Lvalue Iterator.  Instead we have chosen a design that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								matches the preferred resolution of < a  class = "reference"  href = "http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#299" > issue 299< / a > : < tt  class = "literal" > < span  class = "pre" > operator[]< / span > < / tt >  is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								only required to return something convertible to the < tt  class = "literal" > < span  class = "pre" > value_type< / span > < / tt > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								(for a Readable Iterator), and is required to support assignment
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > i[n]< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > t< / span > < / tt >  (for a Writable Iterator).< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "proposed-text" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h1 > < a  class = "toc-backref"  href = "#id8"  name = "proposed-text" > Proposed Text< / a > < / h1 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "addition-to-lib-iterator-requirements" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h2 > < a  class = "toc-backref"  href = "#id9"  name = "addition-to-lib-iterator-requirements" > Addition to [lib.iterator.requirements]< / a > < / h2 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "iterator-value-access-concepts-lib-iterator-value-access" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h3 > < a  class = "toc-backref"  href = "#id10"  name = "iterator-value-access-concepts-lib-iterator-value-access" > Iterator Value Access Concepts [lib.iterator.value.access]< / a > < / h3 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > In the tables below, < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  is an iterator type, < tt  class = "literal" > < span  class = "pre" > a< / span > < / tt >  is a constant 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								object of type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > R< / span > < / tt >  is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > std::iterator_traits< X> ::reference< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt >  is 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > std::iterator_traits< X> ::value_type< / span > < / tt > , and < tt  class = "literal" > < span  class = "pre" > v< / span > < / tt >  is a constant 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								object of type < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > .< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< a  class = "target"  id = "readable-iterator"  name = "readable-iterator" > < / a > < div  class = "section"  id = "readable-iterators-lib-readable-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id11"  name = "readable-iterators-lib-readable-iterators" > Readable Iterators [lib.readable.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Readable Iterator< / em >  concept 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								for the value type < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt >  if the following expressions are valid and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								respect the stated semantics. < tt  class = "literal" > < span  class = "pre" > U< / span > < / tt >  is the type of any specified
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								member of type < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > .< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "42%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "29%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "30%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Readable Iterator Requirements (in addition to CopyConstructible)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< th > Note/Precondition< / th >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::value_type< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > Any non-reference, 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								non-cv-qualified type< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::reference< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > R< / span > < / tt > , Convertible to 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > *a< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > Convertible to < tt  class = "literal" > < span  class = "pre" > R< / span > < / tt > , 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Convertible to < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > < / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > pre: < tt  class = "literal" > < span  class = "pre" > a< / span > < / tt >  is 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dereferenceable. If < tt  class = "literal" > < span  class = "pre" > a< / span > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > ==< / span >  < span  class = "pre" > b< / span > < / tt >  then < tt  class = "literal" > < span  class = "pre" > *a< / span > < / tt >  is 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								equivalent to < tt  class = "literal" > < span  class = "pre" > *b< / span > < / tt > < / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > static_cast< T> (< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > static_cast< R> (*a)< / span >  < span  class = "pre" > )< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > equivalent to 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > static_cast< T> (*a)< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a-> m< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > U& < / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > pre: < tt  class = "literal" > < span  class = "pre" > (*a).m< / span > < / tt >  is 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								well-defined.  Equivalent
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to < tt  class = "literal" > < span  class = "pre" > (*a).m< / span > < / tt > < / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  TR1: the originally - proposed requirement that typeof(*a) == R
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								was too restrictive.  Now we just require that it's
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								convertible to R and that accessing a T through that conversion
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is equivalent to accessing a T directly. -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< a  class = "target"  id = "writable-iterator"  name = "writable-iterator" > < / a > < / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "writable-iterators-lib-writable-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id12"  name = "writable-iterators-lib-writable-iterators" > Writable Iterators [lib.writable.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Writable Iterator< / em >  concept 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if the following expressions are valid and respect the stated
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 14:44:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								semantics.  Writable Iterators have an associated < em > set of value types< / em > .< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-09-14 02:17:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "37%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "21%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-09-14 02:17:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "42%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Writable Iterator Requirements (in addition to CopyConstructible)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Precondition< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > *a< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > o< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > pre: The type of < tt  class = "literal" > < span  class = "pre" > o< / span > < / tt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is in the set of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								value types of < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > < / td > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "swappable-iterators-lib-swappable-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id13"  name = "swappable-iterators-lib-swappable-iterators" > Swappable Iterators [lib.swappable.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Swappable Iterator< / em >  concept 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if the following expressions are valid and respect the stated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								semantics.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "37%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "19%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "43%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Swappable Iterator Requirements (in addition to CopyConstructible)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Postcondition< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > iter_swap(a,< / span >  < span  class = "pre" > b)< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > void< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > the pointed to values are 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								exchanged< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dt > [< em > Note:< / em >  An iterator that is a model of the < em > Readable< / em >  and < em > Writable Iterator< / em >  concepts< / dt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< dd > is also a model of < em > Swappable Iterator< / em > .  < em > --end note< / em > ]< / dd >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / dl >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 13:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = "section"  id = "lvalue-iterators-lib-lvalue-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id14"  name = "lvalue-iterators-lib-lvalue-iterators" > Lvalue Iterators [lib.lvalue.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 13:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > The < em > Lvalue Iterator< / em >  concept adds the requirement that the 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > reference< / span > < / tt >  type be a reference to the value type of the iterator.< / p >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "42%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "14%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "44%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 13:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Lvalue Iterator Requirements< / th >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Assertion< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::reference< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > T& < / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt >  is < em > cv< / em >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::value_type< / span > < / tt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								where < em > cv< / em >  is an optional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cv-qualification< / td > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "iterator-traversal-concepts-lib-iterator-traversal" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h3 > < a  class = "toc-backref"  href = "#id15"  name = "iterator-traversal-concepts-lib-iterator-traversal" > Iterator Traversal Concepts [lib.iterator.traversal]< / a > < / h3 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > In the tables below, < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  is an iterator type, < tt  class = "literal" > < span  class = "pre" > a< / span > < / tt >  and < tt  class = "literal" > < span  class = "pre" > b< / span > < / tt >  are 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								constant objects of type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > r< / span > < / tt >  and < tt  class = "literal" > < span  class = "pre" > s< / span > < / tt >  are mutable objects of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt >  is < tt  class = "literal" > < span  class = "pre" > std::iterator_traits< X> ::value_type< / span > < / tt > , and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > v< / span > < / tt >  is a constant object of type < tt  class = "literal" > < span  class = "pre" > T< / span > < / tt > .< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "incrementable-iterators-lib-incrementable-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id16"  name = "incrementable-iterators-lib-incrementable-iterators" > Incrementable Iterators [lib.incrementable.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Incrementable Iterator< / em >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								concept if the following expressions are valid and respect the stated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								semantics.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "39%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "37%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "24%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Incrementable Iterator Requirements (in addition to Assignable, Copy Constructible)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Assertion/Semantics< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > ++r< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > & r< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > & ++r< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > r++< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < pre  class = "first last literal-block" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   X tmp = r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   ++r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   return tmp;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / pre >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > traversal_category< X> ::type< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > Convertible to 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > incrementable_traversal_tag< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  TR1: incrementable_iterator_tag changed to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								incrementable_traversal_tag for consistency. -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "single-pass-iterators-lib-single-pass-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id17"  name = "single-pass-iterators-lib-single-pass-iterators" > Single Pass Iterators [lib.single.pass.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Single Pass Iterator< / em >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								concept if the following expressions are valid and respect the stated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								semantics.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "36%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< col  width = "33%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "31%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Single Pass Iterator Requirements (in addition to Incrementable Iterator and Equality 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Comparable)< / th > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< th > Assertion/Semantics / 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Pre-/Post-condition< / th > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > ++r< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > pre: < tt  class = "literal" > < span  class = "pre" > r< / span > < / tt >  is 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dereferenceable; post:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > r< / span > < / tt >  is dereferenceable or 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > r< / span > < / tt >  is past-the-end< / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > b< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > bool< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > ==< / span > < / tt >  is an equivalence 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								relation over its domain< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > !=< / span >  < span  class = "pre" > b< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > bool< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > !(a< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > b)< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > traversal_category< X> ::type< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > Convertible to 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > single_pass_traversal_tag< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  TR1: single_pass_iterator_tag changed to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								single_pass_traversal_tag for consistency -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "forward-traversal-iterators-lib-forward-traversal-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id18"  name = "forward-traversal-iterators-lib-forward-traversal-iterators" > Forward Traversal Iterators [lib.forward.traversal.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Forward Traversal Iterator< / em >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								concept if the following expressions are valid and respect the stated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								semantics.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "44%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< col  width = "39%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "17%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Forward Traversal Iterator Requirements (in addition to Single Pass Iterator)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Assertion/Note< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > X< / span >  < span  class = "pre" > u;< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > note: < tt  class = "literal" > < span  class = "pre" > u< / span > < / tt >  may 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								have a singular
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								value.< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > ++r< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > r< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > s< / span > < / tt >  and 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > r< / span > < / tt >  is 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dereferenceable
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								implies < tt  class = "literal" > < span  class = "pre" > ++r< / span > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > ==< / span >  < span  class = "pre" > ++s.< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::difference_type< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > A signed integral type representing 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the distance between iterators< / td > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > traversal_category< X> ::type< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > Convertible to 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > forward_traversal_tag< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  TR1: forward_traversal_iterator_tag changed to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								forward_traversal_tag for consistency -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "bidirectional-traversal-iterators-lib-bidirectional-traversal-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id19"  name = "bidirectional-traversal-iterators-lib-bidirectional-traversal-iterators" > Bidirectional Traversal Iterators [lib.bidirectional.traversal.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Bidirectional Traversal 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Iterator< / em >  concept if the following expressions are valid and respect
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the stated semantics.< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "35%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "44%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "21%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "3" > Bidirectional Traversal Iterator Requirements (in addition to Forward Traversal Iterator)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< th > Assertion/Semantics / 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Pre-/Post-condition< / th > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > --r< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > pre: there exists 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > s< / span > < / tt >  such that < tt  class = "literal" > < span  class = "pre" > r< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > ==< / span >  < span  class = "pre" > ++s< / span > < / tt > .  post: 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > s< / span > < / tt >  is 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dereferenceable.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > --(++r)< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > r< / span > < / tt > . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > --r< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > --s< / span > < / tt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								implies < tt  class = "literal" > < span  class = "pre" > r< / span >  < span  class = "pre" > ==< / span > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > s< / span > < / tt > . < tt  class = "literal" > < span  class = "pre" > & r< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > & --r< / span > < / tt > .< / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > r--< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > const< / span >  < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < pre  class = "first last literal-block" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  X tmp = r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  --r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return tmp;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / pre >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > traversal_category< X> ::type< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > Convertible to 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > bidirectional_traversal_tag< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  TR1: bidirectional_traversal_iterator_tag changed to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bidirectional_traversal_tag for consistency -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "random-access-traversal-iterators-lib-random-access-traversal-iterators" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h4 > < a  class = "toc-backref"  href = "#id20"  name = "random-access-traversal-iterators-lib-random-access-traversal-iterators" > Random Access Traversal Iterators [lib.random.access.traversal.iterators]< / a > < / h4 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< p > A class or built-in type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt >  models the < em > Random Access Traversal 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Iterator< / em >  concept if the following expressions are valid and respect
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the stated semantics.  In the table below, < tt  class = "literal" > < span  class = "pre" > Distance< / span > < / tt >  is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::difference_type< / span > < / tt >  and < tt  class = "literal" > < span  class = "pre" > n< / span > < / tt >  represents a 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								constant object of type < tt  class = "literal" > < span  class = "pre" > Distance< / span > < / tt > .< / p > 
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< table  border  class = "table" >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< colgroup >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "31%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "35%"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< col  width = "18%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< col  width = "16%"  / >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / colgroup >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< thead  valign = "bottom" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th  colspan = "4" > Random Access Traversal Iterator Requirements (in addition to Bidirectional Traversal Iterator)< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < th > Expression< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Return Type< / th >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< th > Operational Semantics< / th >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< th > Assertion/ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Precondition< / th > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / thead >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tbody  valign = "top" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > r< / span >  < span  class = "pre" > +=< / span >  < span  class = "pre" > n< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < pre  class = "first last literal-block" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  Distance m = n;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  if (m > = 0)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    while (m--)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      ++r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  else
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    while (m++)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      --r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  return r;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / pre >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > +< / span >  < span  class = "pre" > n< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > n< / span >  < span  class = "pre" > +< / span >  < span  class = "pre" > a< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > {< / span >  < span  class = "pre" > X< / span >  < span  class = "pre" > tmp< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > a;< / span >  < span  class = "pre" > return< / span >  < span  class = "pre" > tmp< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > +=< / span >  < span  class = "pre" > n;< / span >  < span  class = "pre" > }< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > r< / span >  < span  class = "pre" > -=< / span >  < span  class = "pre" > n< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X& < / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > return< / span >  < span  class = "pre" > r< / span >  < span  class = "pre" > +=< / span >  < span  class = "pre" > -n< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > -< / span >  < span  class = "pre" > n< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > {< / span >  < span  class = "pre" > X< / span >  < span  class = "pre" > tmp< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > a;< / span >  < span  class = "pre" > return< / span >  < span  class = "pre" > tmp< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > -=< / span >  < span  class = "pre" > n;< / span >  < span  class = "pre" > }< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > b< / span >  < span  class = "pre" > -< / span >  < span  class = "pre" > a< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > Distance< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > < < / span >  < span  class = "pre" > b< / span >  < span  class = "pre" > ?< / span >    < span  class = "pre" > distance(a,b)< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > :< / span >  < span  class = "pre" > -distance(b,a)< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > pre: there exists a 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								value < tt  class = "literal" > < span  class = "pre" > n< / span > < / tt >  of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > Distance< / span > < / tt >  such that 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > +< / span >  < span  class = "pre" > n< / span >  < span  class = "pre" > ==< / span >  < span  class = "pre" > b< / span > < / tt > .  < tt  class = "literal" > < span  class = "pre" > b< / span >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< span  class = "pre" > ==< / span >  < span  class = "pre" > a< / span >  < span  class = "pre" > +< / span >  < span  class = "pre" > (b< / span >  < span  class = "pre" > -< / span >  < span  class = "pre" > a)< / span > < / tt > .< / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a[n]< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to T< / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > *(a< / span >  < span  class = "pre" > +< / span >  < span  class = "pre" > n)< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > pre: a is a < a  class = "reference"  href = "#readable-iterator" > readable 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterator< / a > < / td > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a[n]< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > v< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to T< / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > *(a< / span >  < span  class = "pre" > +< / span >  < span  class = "pre" > n)< / span >  < span  class = "pre" > =< / span >  < span  class = "pre" > v< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > pre: a is a < a  class = "reference"  href = "#writable-iterator" > writable 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								iterator< / a > < / td > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > < < / span >  < span  class = "pre" > b< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > bool< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > b< / span >  < span  class = "pre" > -< / span >  < span  class = "pre" > a< / span >  < span  class = "pre" > > < / span >  < span  class = "pre" > 0< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > < < / span > < / tt >  is a total 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ordering relation< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > > < / span >  < span  class = "pre" > b< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > bool< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > b< / span >  < span  class = "pre" > < < / span >  < span  class = "pre" > a< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-09-22 15:10:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > > < / span > < / tt >  is a total 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ordering relation< / td > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > > =< / span >  < span  class = "pre" > b< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > bool< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > !(a< / span >  < span  class = "pre" > < < / span >  < span  class = "pre" > b)< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > a< / span >  < span  class = "pre" > < =< / span >  < span  class = "pre" > b< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > convertible to < tt  class = "literal" > < span  class = "pre" > bool< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > < tt  class = "literal" > < span  class = "pre" > !(a< / span >  < span  class = "pre" > > < / span >  < span  class = "pre" > b)< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tr > < td > < tt  class = "literal" > < span  class = "pre" > traversal_category< X> ::type< / span > < / tt > < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td > Convertible to 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > random_access_traversal_tag< / span > < / tt > < / td >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< td >   < / td >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tr >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / tbody >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / table >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  TR1: random_access_traversal_iterator_tag changed to
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								random_access_traversal_tag for consistency -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "addition-to-lib-iterator-synopsis" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h2 > < a  class = "toc-backref"  href = "#id21"  name = "addition-to-lib-iterator-synopsis" > Addition to [lib.iterator.synopsis]< / a > < / h2 >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< pre  class = "literal-block" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// lib.iterator.traits, traits and tags
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								template < class Iterator>  struct is_readable_iterator;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								template < class Iterator>  struct iterator_traversal;
							 
						 
					
						
							
								
									
										
										
										
											2003-09-22 13:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								struct incrementable_traversal_tag { };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								struct single_pass_traversal_tag : incrementable_traversal_tag { };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								struct forward_traversal_tag : single_pass_traversal_tag { };
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								struct bidirectional_traversal_tag : forward_traversal_tag { };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								struct random_access_traversal_tag : bidirectional_traversal_tag { };
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / pre >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "addition-to-lib-iterator-traits" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h2 > < a  class = "toc-backref"  href = "#id22"  name = "addition-to-lib-iterator-traits" > Addition to [lib.iterator.traits]< / a > < / h2 >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > The < tt  class = "literal" > < span  class = "pre" > is_readable_iterator< / span > < / tt >  and < tt  class = "literal" > < span  class = "pre" > iterator_traversal< / span > < / tt >  class 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								templates satisfy the < a  class = "reference"  href = "http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1519.htm" > UnaryTypeTrait< / a >  requirements.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > Given an iterator type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > is_readable_iterator< X> ::value< / span > < / tt >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								yields < tt  class = "literal" > < span  class = "pre" > true< / span > < / tt >  if, for an object < tt  class = "literal" > < span  class = "pre" > a< / span > < / tt >  of type < tt  class = "literal" > < span  class = "pre" > X< / span > < / tt > , < tt  class = "literal" > < span  class = "pre" > *a< / span > < / tt >  is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								convertible to < tt  class = "literal" > < span  class = "pre" > iterator_traits< X> ::value_type< / span > < / tt > , and < tt  class = "literal" > < span  class = "pre" > false< / span > < / tt > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								otherwise.< / p > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< p > < tt  class = "literal" > < span  class = "pre" > iterator_traversal< X> ::value_type< / span > < / tt >  is defined to be:< / p >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< pre  class = "literal-block" >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								traversal-category(X) =
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    cat = iterator_traits< X> ::iterator_category;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if (cat is convertible to incrementable_traversal_tag)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return cat;
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    else if (cat is convertible to random_access_iterator_tag)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return random_access_traversal_tag;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else if (cat is convertible to bidirectional_iterator_tag)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return bidirectional_traversal_tag;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else if (cat is convertible to forward_iterator_tag)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return forward_traversal_tag;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else if (cat is convertible to input_iterator_tag)
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return single_pass_traversal_tag;
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    else if (cat is convertible to output_iterator_tag)
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return incrementable_traversal_tag;
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    else
							 
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        < em > the program is ill-formed< / em > 
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / pre >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "section"  id = "footnotes" >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 03:12:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< h1 > < a  class = "toc-backref"  href = "#id23"  name = "footnotes" > Footnotes< / a > < / h1 >  
						 
					
						
							
								
									
										
										
										
											2003-11-24 05:02:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p > The UnaryTypeTrait concept is defined in < a  class = "reference"  href = "http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1519.htm" > n1519< / a > ; the LWG added the 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requirement that specializations are derived from their nested
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< tt  class = "literal" > < span  class = "pre" > ::type< / span > < / tt > .< / p >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								<!--  LocalWords:  Abrahams Siek Witt const bool Sutter's WG int UL LI href Lvalue
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								LocalWords:  ReadableIterator WritableIterator SwappableIterator cv pre iter
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								LocalWords:  ConstantLvalueIterator MutableLvalueIterator CopyConstructible TR
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								LocalWords:  ForwardTraversalIterator BidirectionalTraversalIterator lvalue
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								LocalWords:  RandomAccessTraversalIterator dereferenceable Incrementable tmp
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								LocalWords:  incrementable xxx min prev inplace png oldeqnew AccessTag struct
							 
						 
					
						
							
								
									
										
										
										
											2003-09-22 16:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								LocalWords:  TraversalTag typename lvalues DWA Hmm JGS mis enum -->
							 
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< hr  class = "footer"  / >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< div  class = "footer" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< a  class = "reference"  href = "new-iter-concepts.rst" > View document source< / a > . 
						 
					
						
							
								
									
										
										
										
											2003-12-02 14:44:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Generated on: 2003-12-02 14:41 UTC.
							 
						 
					
						
							
								
									
										
										
										
											2003-12-02 13:10:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Generated by < a  class = "reference"  href = "http://docutils.sourceforge.net/" > Docutils< / a >  from < a  class = "reference"  href = "http://docutils.sourceforge.net/rst.html" > reStructuredText< / a >  source.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
									
										
										
										
											2003-07-13 22:47:15 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / body >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / html >