1<?xml version="1.0" encoding="utf-8" ?> 2<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 3<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 4<head> 5<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 6<meta name="generator" content="Docutils 0.14: http://docutils.sourceforge.net/" /> 7<title>Boost Pointer Container Library</title> 8<style type="text/css"> 9 10/* 11:Author: David Goodger (goodger@python.org) 12:Id: $Id: html4css1.css 7952 2016-07-26 18:15:59Z milde $ 13:Copyright: This stylesheet has been placed in the public domain. 14 15Default cascading style sheet for the HTML output of Docutils. 16 17See http://docutils.sf.net/docs/howto/html-stylesheets.html for how to 18customize this style sheet. 19*/ 20 21/* used to remove borders from tables and images */ 22.borderless, table.borderless td, table.borderless th { 23 border: 0 } 24 25table.borderless td, table.borderless th { 26 /* Override padding for "table.docutils td" with "! important". 27 The right padding separates the table cells. */ 28 padding: 0 0.5em 0 0 ! important } 29 30.first { 31 /* Override more specific margin styles with "! important". */ 32 margin-top: 0 ! important } 33 34.last, .with-subtitle { 35 margin-bottom: 0 ! important } 36 37.hidden { 38 display: none } 39 40.subscript { 41 vertical-align: sub; 42 font-size: smaller } 43 44.superscript { 45 vertical-align: super; 46 font-size: smaller } 47 48a.toc-backref { 49 text-decoration: none ; 50 color: black } 51 52blockquote.epigraph { 53 margin: 2em 5em ; } 54 55dl.docutils dd { 56 margin-bottom: 0.5em } 57 58object[type="image/svg+xml"], object[type="application/x-shockwave-flash"] { 59 overflow: hidden; 60} 61 62/* Uncomment (and remove this text!) to get bold-faced definition list terms 63dl.docutils dt { 64 font-weight: bold } 65*/ 66 67div.abstract { 68 margin: 2em 5em } 69 70div.abstract p.topic-title { 71 font-weight: bold ; 72 text-align: center } 73 74div.admonition, div.attention, div.caution, div.danger, div.error, 75div.hint, div.important, div.note, div.tip, div.warning { 76 margin: 2em ; 77 border: medium outset ; 78 padding: 1em } 79 80div.admonition p.admonition-title, div.hint p.admonition-title, 81div.important p.admonition-title, div.note p.admonition-title, 82div.tip p.admonition-title { 83 font-weight: bold ; 84 font-family: sans-serif } 85 86div.attention p.admonition-title, div.caution p.admonition-title, 87div.danger p.admonition-title, div.error p.admonition-title, 88div.warning p.admonition-title, .code .error { 89 color: red ; 90 font-weight: bold ; 91 font-family: sans-serif } 92 93/* Uncomment (and remove this text!) to get reduced vertical space in 94 compound paragraphs. 95div.compound .compound-first, div.compound .compound-middle { 96 margin-bottom: 0.5em } 97 98div.compound .compound-last, div.compound .compound-middle { 99 margin-top: 0.5em } 100*/ 101 102div.dedication { 103 margin: 2em 5em ; 104 text-align: center ; 105 font-style: italic } 106 107div.dedication p.topic-title { 108 font-weight: bold ; 109 font-style: normal } 110 111div.figure { 112 margin-left: 2em ; 113 margin-right: 2em } 114 115div.footer, div.header { 116 clear: both; 117 font-size: smaller } 118 119div.line-block { 120 display: block ; 121 margin-top: 1em ; 122 margin-bottom: 1em } 123 124div.line-block div.line-block { 125 margin-top: 0 ; 126 margin-bottom: 0 ; 127 margin-left: 1.5em } 128 129div.sidebar { 130 margin: 0 0 0.5em 1em ; 131 border: medium outset ; 132 padding: 1em ; 133 background-color: #ffffee ; 134 width: 40% ; 135 float: right ; 136 clear: right } 137 138div.sidebar p.rubric { 139 font-family: sans-serif ; 140 font-size: medium } 141 142div.system-messages { 143 margin: 5em } 144 145div.system-messages h1 { 146 color: red } 147 148div.system-message { 149 border: medium outset ; 150 padding: 1em } 151 152div.system-message p.system-message-title { 153 color: red ; 154 font-weight: bold } 155 156div.topic { 157 margin: 2em } 158 159h1.section-subtitle, h2.section-subtitle, h3.section-subtitle, 160h4.section-subtitle, h5.section-subtitle, h6.section-subtitle { 161 margin-top: 0.4em } 162 163h1.title { 164 text-align: center } 165 166h2.subtitle { 167 text-align: center } 168 169hr.docutils { 170 width: 75% } 171 172img.align-left, .figure.align-left, object.align-left, table.align-left { 173 clear: left ; 174 float: left ; 175 margin-right: 1em } 176 177img.align-right, .figure.align-right, object.align-right, table.align-right { 178 clear: right ; 179 float: right ; 180 margin-left: 1em } 181 182img.align-center, .figure.align-center, object.align-center { 183 display: block; 184 margin-left: auto; 185 margin-right: auto; 186} 187 188table.align-center { 189 margin-left: auto; 190 margin-right: auto; 191} 192 193.align-left { 194 text-align: left } 195 196.align-center { 197 clear: both ; 198 text-align: center } 199 200.align-right { 201 text-align: right } 202 203/* reset inner alignment in figures */ 204div.align-right { 205 text-align: inherit } 206 207/* div.align-center * { */ 208/* text-align: left } */ 209 210.align-top { 211 vertical-align: top } 212 213.align-middle { 214 vertical-align: middle } 215 216.align-bottom { 217 vertical-align: bottom } 218 219ol.simple, ul.simple { 220 margin-bottom: 1em } 221 222ol.arabic { 223 list-style: decimal } 224 225ol.loweralpha { 226 list-style: lower-alpha } 227 228ol.upperalpha { 229 list-style: upper-alpha } 230 231ol.lowerroman { 232 list-style: lower-roman } 233 234ol.upperroman { 235 list-style: upper-roman } 236 237p.attribution { 238 text-align: right ; 239 margin-left: 50% } 240 241p.caption { 242 font-style: italic } 243 244p.credits { 245 font-style: italic ; 246 font-size: smaller } 247 248p.label { 249 white-space: nowrap } 250 251p.rubric { 252 font-weight: bold ; 253 font-size: larger ; 254 color: maroon ; 255 text-align: center } 256 257p.sidebar-title { 258 font-family: sans-serif ; 259 font-weight: bold ; 260 font-size: larger } 261 262p.sidebar-subtitle { 263 font-family: sans-serif ; 264 font-weight: bold } 265 266p.topic-title { 267 font-weight: bold } 268 269pre.address { 270 margin-bottom: 0 ; 271 margin-top: 0 ; 272 font: inherit } 273 274pre.literal-block, pre.doctest-block, pre.math, pre.code { 275 margin-left: 2em ; 276 margin-right: 2em } 277 278pre.code .ln { color: grey; } /* line numbers */ 279pre.code, code { background-color: #eeeeee } 280pre.code .comment, code .comment { color: #5C6576 } 281pre.code .keyword, code .keyword { color: #3B0D06; font-weight: bold } 282pre.code .literal.string, code .literal.string { color: #0C5404 } 283pre.code .name.builtin, code .name.builtin { color: #352B84 } 284pre.code .deleted, code .deleted { background-color: #DEB0A1} 285pre.code .inserted, code .inserted { background-color: #A3D289} 286 287span.classifier { 288 font-family: sans-serif ; 289 font-style: oblique } 290 291span.classifier-delimiter { 292 font-family: sans-serif ; 293 font-weight: bold } 294 295span.interpreted { 296 font-family: sans-serif } 297 298span.option { 299 white-space: nowrap } 300 301span.pre { 302 white-space: pre } 303 304span.problematic { 305 color: red } 306 307span.section-subtitle { 308 /* font-size relative to parent (h1..h6 element) */ 309 font-size: 80% } 310 311table.citation { 312 border-left: solid 1px gray; 313 margin-left: 1px } 314 315table.docinfo { 316 margin: 2em 4em } 317 318table.docutils { 319 margin-top: 0.5em ; 320 margin-bottom: 0.5em } 321 322table.footnote { 323 border-left: solid 1px black; 324 margin-left: 1px } 325 326table.docutils td, table.docutils th, 327table.docinfo td, table.docinfo th { 328 padding-left: 0.5em ; 329 padding-right: 0.5em ; 330 vertical-align: top } 331 332table.docutils th.field-name, table.docinfo th.docinfo-name { 333 font-weight: bold ; 334 text-align: left ; 335 white-space: nowrap ; 336 padding-left: 0 } 337 338/* "booktabs" style (no vertical lines) */ 339table.docutils.booktabs { 340 border: 0px; 341 border-top: 2px solid; 342 border-bottom: 2px solid; 343 border-collapse: collapse; 344} 345table.docutils.booktabs * { 346 border: 0px; 347} 348table.docutils.booktabs th { 349 border-bottom: thin solid; 350 text-align: left; 351} 352 353h1 tt.docutils, h2 tt.docutils, h3 tt.docutils, 354h4 tt.docutils, h5 tt.docutils, h6 tt.docutils { 355 font-size: 100% } 356 357ul.auto-toc { 358 list-style-type: none } 359 360</style> 361</head> 362<body> 363<div class="document" id="boost-pointer-container-library"> 364<h1 class="title"><img alt="Boost" src="boost.png" /> Pointer Container Library</h1> 365 366<div class="section" id="class-ptr-sequence-adapter"> 367<h1>Class <tt class="docutils literal">ptr_sequence_adapter</tt></h1> 368<p>This section describes all the common operations for all the pointer 369sequences:</p> 370<ul class="simple"> 371<li><a class="reference external" href="ptr_vector.html">ptr_vector</a></li> 372<li><a class="reference external" href="ptr_list.html">ptr_list</a></li> 373<li><a class="reference external" href="ptr_deque.html">ptr_deque</a></li> 374</ul> 375<p>The <tt class="docutils literal">ptr_sequence_adapter</tt> is also a concrete class that you can use to create custom pointer 376containers from.</p> 377<p><strong>Hierarchy:</strong></p> 378<ul class="simple"> 379<li><a class="reference external" href="reversible_ptr_container.html">reversible_ptr_container</a><ul> 380<li><tt class="docutils literal">ptr_sequence_adapter</tt><ul> 381<li><a class="reference external" href="ptr_vector.html">ptr_vector</a></li> 382<li><a class="reference external" href="ptr_list.html">ptr_list</a></li> 383<li><a class="reference external" href="ptr_deque.html">ptr_deque</a></li> 384<li><a class="reference external" href="ptr_array.html">ptr_array</a></li> 385</ul> 386</li> 387</ul> 388</li> 389</ul> 390<p><strong>Navigate:</strong></p> 391<ul class="simple"> 392<li><a class="reference external" href="ptr_container.html">home</a></li> 393<li><a class="reference external" href="reference.html">reference</a></li> 394</ul> 395<p><strong>Synopsis:</strong></p> 396<pre class="literal-block"> 397namespace boost 398{ 399 400 template 401 < 402 class T, 403 class VoidPtrSeq, 404 class CloneAllocator = heap_clone_allocator 405 > 406 class ptr_sequence_adapter 407 { 408 public: // <a class="reference internal" href="#construct-copy-destroy">construct/copy/destroy</a> 409 template< class InputIterator > 410 assign( InputIterator first, InputIterator last ); 411 template< class InputRange > 412 assign( const InputRange& e ); 413 414 public: // <a class="reference internal" href="#element-access">element access</a> 415 T& front(); 416 const T& front() const; 417 T& back(); 418 const T& back() const; 419 420 public: // <a class="reference internal" href="#modifiers">modifiers</a> 421 void push_back( T* x ); 422 template< class U > 423 void push_back( <a class="reference external" href="compatible_smart_ptr.html"><em>compatible-smart-ptr</em></a><U> x ); 424 auto_type pop_back(); 425 iterator insert( iterator position, T* x ); 426 template< class U > 427 iterator insert( iterator position, <a class="reference external" href="compatible_smart_ptr.html"><em>compatible-smart-ptr</em></a><U> x ); 428 template< class InputIterator > 429 void insert( iterator position, InputIterator first, InputIterator last ); 430 template< class InputRange > 431 void insert( iterator position, const InputRange& r ); 432 iterator erase( iterator position ); 433 iterator erase( iterator first, iterator last ); 434 template< class Range > 435 iterator erase( const Range& r ); 436 void resize( size_type size ); 437 void resize( size_type size, T* to_clone ); 438 439 public: // <a class="reference internal" href="#pointer-container-requirements">pointer container requirements</a> 440 template< class PtrSequence > 441 void transfer( iterator before, typename PtrSequence::iterator object, 442 PtrSequence& from ); 443 template< class PtrSequence > 444 void transfer( iterator before, typename PtrSequence::iterator first, typename PtrSequence::iterator last, 445 PtrSequence& from ); 446 void template< class PtrSequence, class Range > 447 void transfer( iterator before, const Range& r, PtrSequence& from ); 448 template< class PtrSequence > 449 void transfer( iterator before, PtrSequence& from ); 450 451 public: // <a class="reference internal" href="#algorithms">algorithms</a> 452 453 void sort(); 454 void sort( iterator first, iterator last ); 455 template< class Compare > 456 void sort( Compare comp ); 457 template< class Compare > 458 void sort( iterator begin, iterator end, Compare comp ); 459 460 void unique(); 461 void unique( iterator first, iterator last ); 462 template< class Compare > 463 void unique( Compare comp ); 464 template< class Compare > 465 void unique( iterator begin, iterator end, Compare comp ); 466 467 template< class Pred > 468 void erase_if( Pred pred ); 469 template< class Pred > 470 void erase_if( iterator begin, iterator end, Pred pred ); 471 472 void merge( ptr_sequence_adapter& r ); 473 template< class Compare > 474 void merge( ptr_sequence_adapter& r, Compare comp ); 475 void merge( iterator first, iterator last, ptr_sequence_adapter& from ); 476 template< class Compare > 477 void merge( iterator first, iterator last, ptr_sequence_adapter& from, Compare comp ); 478 479 public: // <a class="reference external" href="ptr_list.html">ptr_list interface</a> 480 481 public: // <a class="reference external" href="ptr_vector.html">ptr_vector interface</a> 482 483 public: // <a class="reference external" href="ptr_deque.html">ptr_deque interface</a> 484 485 }; // class 'ptr_sequence_adapter' 486 487} // namespace 'boost' 488</pre> 489</div> 490<div class="section" id="semantics"> 491<h1>Semantics</h1> 492<div class="section" id="semantics-construct-copy-destroy"> 493<span id="construct-copy-destroy"></span><h2>Semantics: construct/copy/destroy</h2> 494<ul> 495<li><p class="first"><tt class="docutils literal">template< class InputIterator > 496void assign( InputIterator first, InputIterator last );</tt></p> 497<blockquote> 498<ul class="simple"> 499<li>Requirements: <tt class="docutils literal">(first,last]</tt> is a valid range</li> 500<li>Effects: <tt class="docutils literal"><span class="pre">clear();</span> insert( first, last );</tt></li> 501<li>Postconditions: <tt class="docutils literal">size() == <span class="pre">std::distance(</span> first, last );</tt></li> 502<li>Exception safety: strong guarantee</li> 503</ul> 504</blockquote> 505</li> 506<li><p class="first"><tt class="docutils literal">template< class InputRange > 507void assign( const InputRange& r );</tt></p> 508<blockquote> 509<ul class="simple"> 510<li>Effects: <tt class="docutils literal">assign( <span class="pre">boost::begin(r),</span> <span class="pre">boost::end(r)</span> );</tt></li> 511</ul> 512</blockquote> 513</li> 514</ul> 515<!-- - ``assign( size_type n, const T& u )`` 516 517- Effects: ``clear(); insert( begin(), n, u );`` 518 519- Postconditions: ``size() == n`` 520 521- Exception safety: Strong guarantee --> 522<!-- void resize( size_type sz, const T& x ); 523Effects: 524 525if ( sz > size() ) 526 insert( end(), sz-size(), x ); 527 else if ( sz < size() ) 528 erase( begin()+sz, end() ); 529 else 530 ; //do nothing 531 532Postconditions: size() == sz 533 534Exception safety: Strong guarantee --> 535</div> 536<div class="section" id="semantics-element-access"> 537<span id="element-access"></span><h2>Semantics: element access</h2> 538<ul> 539<li><p class="first"><tt class="docutils literal">T& <span class="pre">front();</span></tt></p> 540<blockquote> 541<ul class="simple"> 542<li>Requirements: <tt class="docutils literal">not <span class="pre">empty();</span></tt></li> 543<li>Effects: <tt class="docutils literal">return <span class="pre">*begin();</span></tt></li> 544</ul> 545</blockquote> 546</li> 547<li><p class="first"><tt class="docutils literal">const T& front() const;</tt></p> 548<blockquote> 549<ul class="simple"> 550<li>Requirements: <tt class="docutils literal">not <span class="pre">empty();</span></tt></li> 551<li>Effects: <tt class="docutils literal">return <span class="pre">*begin();</span></tt></li> 552</ul> 553</blockquote> 554</li> 555<li><p class="first"><tt class="docutils literal">T& <span class="pre">back();</span></tt></p> 556<blockquote> 557<ul class="simple"> 558<li>Requirements: <tt class="docutils literal">not <span class="pre">empty();</span></tt></li> 559<li>Effects: <tt class="docutils literal">return <span class="pre">*--end();</span></tt></li> 560</ul> 561</blockquote> 562</li> 563<li><p class="first"><tt class="docutils literal">const T& back() const;</tt></p> 564<blockquote> 565<ul class="simple"> 566<li>Requirements: <tt class="docutils literal">not <span class="pre">empty();</span></tt></li> 567<li>Effects: <tt class="docutils literal">return <span class="pre">*--end();</span></tt></li> 568</ul> 569</blockquote> 570</li> 571</ul> 572</div> 573<div class="section" id="semantics-modifiers"> 574<span id="modifiers"></span><h2>Semantics: modifiers</h2> 575<ul> 576<li><p class="first"><tt class="docutils literal">void push_back( T* x );</tt></p> 577<blockquote> 578<ul class="simple"> 579<li>Requirements: <tt class="docutils literal">x != 0</tt></li> 580<li>Effects: Inserts the pointer into container and takes ownership of it</li> 581<li>Throws: <tt class="docutils literal">bad_pointer</tt> if <tt class="docutils literal">x == 0</tt></li> 582<li>Exception safety: Strong guarantee</li> 583</ul> 584</blockquote> 585</li> 586<li><p class="first"><tt class="docutils literal">template< class U > void push_back( <span class="pre"><a class="reference external" href="compatible_smart_ptr.html"><em>compatible-smart-ptr</em></a><U></span> x );</tt></p> 587<blockquote> 588<ul class="simple"> 589<li>Effects: <tt class="docutils literal">push_back( x.release() );</tt></li> 590</ul> 591</blockquote> 592</li> 593</ul> 594<!-- - ``void push_back( const T& x );`` 595 596- Effects: ``push_back( CloneAllocator::clone( x ) );`` 597 598- Exception safety: Strong guarantee --> 599<ul> 600<li><p class="first"><tt class="docutils literal">auto_type <span class="pre">pop_back();</span></tt></p> 601<blockquote> 602<ul class="simple"> 603<li>Requirements:<tt class="docutils literal">not empty()</tt></li> 604<li>Effects: Removes the last element in the container</li> 605<li>Postconditions: <tt class="docutils literal">size()</tt> is one less</li> 606<li>Throws: <tt class="docutils literal">bad_ptr_container_operation</tt> if <tt class="docutils literal">empty() == true</tt></li> 607<li>Exception safety: Strong guarantee</li> 608</ul> 609</blockquote> 610</li> 611<li><p class="first"><tt class="docutils literal">iterator insert( iterator position, T* x );</tt></p> 612<blockquote> 613<ul class="simple"> 614<li>Requirements: <tt class="docutils literal">position</tt> is a valid iterator from the container and 615<tt class="docutils literal">x != 0</tt></li> 616<li>Effects: Inserts <tt class="docutils literal">x</tt> before <tt class="docutils literal">position</tt> and returns an iterator pointing to it</li> 617<li>Throws: <tt class="docutils literal">bad_pointer</tt> if <tt class="docutils literal">x == 0</tt></li> 618<li>Exception safety: Strong guarantee</li> 619</ul> 620</blockquote> 621</li> 622<li><p class="first"><tt class="docutils literal">template< class U > iterator insert( iterator position, <span class="pre"><a class="reference external" href="compatible_smart_ptr.html"><em>compatible-smart-ptr</em></a><U></span> x );</tt></p> 623<blockquote> 624<ul class="simple"> 625<li>Effects: <tt class="docutils literal">return insert( position, x.release() );</tt></li> 626</ul> 627</blockquote> 628</li> 629</ul> 630<!-- - ``iterator insert( iterator position, const T& x );`` 631 632- Requirements: ``position`` is a valid iterator from the container 633 634- Effects: ``return insert( position, CloneAllocator::clone( x ) );`` 635 636- Exception safety: Strong guarantee 637 638- ``void insert( iterator position, size_type n, const T& x );`` 639 640- Requirements: ``position`` is a valid iterator from the container 641 642- Effects: Inserts ``n`` clones of ``x`` before position into the container 643 644- Exception safety: Strong guarantee --> 645<ul> 646<li><p class="first"><tt class="docutils literal">template< class InputIterator > 647void insert( iterator position, InputIterator first, InputIterator last );</tt></p> 648<blockquote> 649<ul class="simple"> 650<li>Requirements: <tt class="docutils literal">position</tt> is a valid iterator from the container</li> 651<li>Effects: Inserts a cloned range before <tt class="docutils literal">position</tt></li> 652<li>Exception safety: Strong guarantee</li> 653</ul> 654</blockquote> 655</li> 656<li><p class="first"><tt class="docutils literal">template< class InputRange > 657void insert( iterator position, const InputRange& r );</tt></p> 658<blockquote> 659<ul class="simple"> 660<li>Effects: <tt class="docutils literal">insert( position, <span class="pre">boost::begin(r),</span> <span class="pre">boost::end(r)</span> );</tt></li> 661</ul> 662</blockquote> 663</li> 664<li><p class="first"><tt class="docutils literal">iterator erase( iterator position );</tt></p> 665<blockquote> 666<ul class="simple"> 667<li>Requirements: <tt class="docutils literal">position</tt> is a valid iterator from the container</li> 668<li>Effects: Removes the element defined by <tt class="docutils literal">position</tt> and returns an iterator to the following element</li> 669<li>Throws: Nothing</li> 670</ul> 671</blockquote> 672</li> 673<li><p class="first"><tt class="docutils literal">iterator erase( iterator first, iterator last );</tt></p> 674<blockquote> 675<ul class="simple"> 676<li>Requirements: <tt class="docutils literal">[first,last)</tt> is a valid range</li> 677<li>Effects: Removes the range of element defined by <tt class="docutils literal">[first,last)</tt> and returns an iterator to the following element</li> 678<li>Throws: Nothing</li> 679</ul> 680</blockquote> 681</li> 682<li><p class="first"><tt class="docutils literal">template< class Range > 683void erase( const Range& r );</tt></p> 684<blockquote> 685<ul class="simple"> 686<li>Effects: <tt class="docutils literal">erase( <span class="pre">boost::begin(r),</span> <span class="pre">boost::end(r)</span> );</tt></li> 687</ul> 688</blockquote> 689</li> 690<li><p class="first"><tt class="docutils literal">void resize( size_type size );</tt></p> 691<blockquote> 692<ul class="simple"> 693<li>Effects: Resizes the container. If elements are erased, it happens from the back. If elements are inserted, it happens at the back.</li> 694<li>Requirements: <tt class="docutils literal">T</tt> is default constructible</li> 695<li>Postcondition: <tt class="docutils literal">size() == size;</tt></li> 696<li>Exception safety: Basic guarantee under expansion; nothrow guarantee otherwise</li> 697</ul> 698</blockquote> 699</li> 700<li><p class="first"><tt class="docutils literal">void resize( size_type size, T* to_clone );</tt></p> 701<blockquote> 702<ul class="simple"> 703<li>Effects: Resizes the container. If elements are erased, it happens from the back. If elements are inserted, clones of <tt class="docutils literal">*to_clone</tt> are inserted at the back.</li> 704<li>Postcondition: <tt class="docutils literal">size() == size;</tt></li> 705<li>Exception safety: Basic guarantee under expansion; nothrow guarantee otherwise</li> 706<li>Remarks: <tt class="docutils literal">to_clone == 0</tt> is valid if the container supports nulls. The container does not take ownership of <tt class="docutils literal">to_clone</tt>.</li> 707</ul> 708</blockquote> 709</li> 710</ul> 711</div> 712<div class="section" id="semantics-pointer-container-requirements"> 713<span id="pointer-container-requirements"></span><h2>Semantics: pointer container requirements</h2> 714<p>You can use <tt class="docutils literal">transfer()</tt> to move elements between two containers of the same type. Furthermore, 715you can also move elements from a container of type <tt class="docutils literal">T</tt> to a container of type <tt class="docutils literal">U</tt> as long as 716<tt class="docutils literal"><span class="pre">T::value_type</span></tt> is convertible to <tt class="docutils literal"><span class="pre">U::value_type</span></tt>. An example would be transferring from <tt class="docutils literal"><span class="pre">boost::ptr_vector<Derived></span></tt> 717to <tt class="docutils literal"><span class="pre">boost::ptr_deque<Base></span></tt>.</p> 718<p>(<strong>Remark:</strong> <em>When moving elements between two different containers, it is your responsibility to make sure the allocators are compatible.</em> 719<em>The special latitude of being able to transfer between two different containers is only available for Sequences and not for Associative Containers.</em>)</p> 720<!-- --> 721<ul> 722<li><p class="first"><tt class="docutils literal">template< class PtrSequence > void transfer( iterator before, typename <span class="pre">PtrSequence::iterator</span> object, PtrSequence& from );</tt></p> 723<blockquote> 724<ul class="simple"> 725<li>Effects: Inserts the object defined by <tt class="docutils literal">object</tt> into the container and remove it from <tt class="docutils literal">from</tt>. 726Insertion takes place before <tt class="docutils literal">before</tt>.</li> 727<li>Postconditions: If <tt class="docutils literal">from.empty()</tt>, nothing happens. Otherwise 728<tt class="docutils literal">size()</tt> is one more, <tt class="docutils literal">from.size()</tt> is one less.</li> 729<li>Exception safety: Strong guarantee</li> 730</ul> 731</blockquote> 732</li> 733<li><p class="first"><tt class="docutils literal">template< class PtrSequence > void transfer( iterator before, typename <span class="pre">PtrSequence::iterator</span> first, typename <span class="pre">PtrSequence::iterator</span> last, PtrSequence& from );</tt></p> 734<blockquote> 735<ul class="simple"> 736<li>Requirements: <tt class="docutils literal">from.size() >= <span class="pre">std::distance(first,last)</span></tt></li> 737<li>Effects: Inserts the objects defined by the range <tt class="docutils literal">[first,last)</tt> into the container and remove it from <tt class="docutils literal">from</tt>. 738Insertion takes place before <tt class="docutils literal">before</tt>.</li> 739<li>Postconditions: If <tt class="docutils literal">from.empty()</tt>, nothing happens. Otherwise, 740let <tt class="docutils literal">N == <span class="pre">std::distance(first,last);</span></tt> then <tt class="docutils literal">size()</tt> is <tt class="docutils literal">N</tt> more, <tt class="docutils literal">from.size()</tt> is <tt class="docutils literal">N</tt> less.</li> 741<li>Exception safety: Strong guarantee</li> 742<li>Complexity: Linear or better</li> 743</ul> 744</blockquote> 745</li> 746<li><p class="first"><tt class="docutils literal">void template< class PtrSequence, class Range > void transfer( iterator before, const Range& r, PtrSequence& from );</tt></p> 747<blockquote> 748<ul class="simple"> 749<li>Effects: <tt class="docutils literal">transfer(before, <span class="pre">boost::begin(r),</span> <span class="pre">boost::end(r),</span> from);</tt></li> 750</ul> 751</blockquote> 752</li> 753<li><p class="first"><tt class="docutils literal">template< class PtrSequence> void transfer( iterator before, PtrSequence& from );</tt></p> 754<blockquote> 755<ul class="simple"> 756<li>Effects: <tt class="docutils literal">transfer(before, from, from);</tt></li> 757</ul> 758</blockquote> 759</li> 760</ul> 761</div> 762<div class="section" id="semantics-algorithms"> 763<span id="algorithms"></span><h2>Semantics: algorithms</h2> 764<p>The general requirement for these algorithms is that the container <em>does not 765contain any nulls</em>.</p> 766<ul> 767<li><p class="first"><tt class="docutils literal">void <span class="pre">sort();</span></tt></p> 768</li> 769<li><p class="first"><tt class="docutils literal">void sort( iterator first, iterator last );</tt></p> 770</li> 771<li><p class="first"><tt class="docutils literal">template< class Compare > void sort( Compare comp );</tt></p> 772</li> 773<li><p class="first"><tt class="docutils literal">template< class Compare > void sort( iterator begin, iterator end, Compare comp );</tt></p> 774<blockquote> 775<ul class="simple"> 776<li>Requirements: (versions without <tt class="docutils literal">Compare</tt>) <tt class="docutils literal">bool operator<( const T&, const T& )</tt> is defined</li> 777<li>Requirements: (<tt class="docutils literal">Compare</tt> versions) <tt class="docutils literal">Compare</tt> must take <tt class="docutils literal">const T&</tt> arguments</li> 778<li>Effects: sorts the entire container or the specified range</li> 779<li>Exception safety: nothrow guarantee (the behavior is undefined if the comparison operator throws)</li> 780<li>Remarks: The versions of <tt class="docutils literal">sort()</tt> that take two iterators are not available for <tt class="docutils literal">ptr_list</tt></li> 781</ul> 782</blockquote> 783</li> 784<li><p class="first"><tt class="docutils literal">void <span class="pre">unique();</span></tt></p> 785</li> 786<li><p class="first"><tt class="docutils literal">void unique( iterator first, iterator last );</tt></p> 787</li> 788<li><p class="first"><tt class="docutils literal">template< class Compare > void unique( Compare comp );</tt></p> 789</li> 790<li><p class="first"><tt class="docutils literal">template< class Compare > void unique( iterator begin, iterator end, Compare comp );</tt></p> 791<blockquote> 792<ul class="simple"> 793<li>Requirements: (versions without <tt class="docutils literal">Compare</tt>) <tt class="docutils literal">bool <span class="pre">operator==(</span> const T&, const T& )</tt> is defined</li> 794<li>Requirements: (<tt class="docutils literal">Compare</tt> versions) <tt class="docutils literal">Compare</tt> must take <tt class="docutils literal">const T&</tt> arguments</li> 795<li>Effects: removes adjacent and equal objects from the entire container or the specified range</li> 796<li>Exception safety: nothrow guarantee (the behavior is undefined if the comparison operator throws)</li> 797</ul> 798</blockquote> 799</li> 800<li><p class="first"><tt class="docutils literal">template< class Pred > void erase_if( Pred pred );</tt></p> 801</li> 802<li><p class="first"><tt class="docutils literal">template< class Pred > void erase_if( iterator begin, iterator end, Pred pred );</tt></p> 803<blockquote> 804<ul class="simple"> 805<li>Requirements: <tt class="docutils literal">Pred</tt> must take an <tt class="docutils literal">const T&</tt> argument</li> 806<li>Effects: removes all elements <tt class="docutils literal">t</tt> for which <tt class="docutils literal">pred(t)</tt> returns <tt class="docutils literal">true</tt> from the entire container or the specified range</li> 807<li>Exception safety: nothrow guarantee (the behavior is undefined if the comparison operator throws)</li> 808</ul> 809</blockquote> 810</li> 811<li><p class="first"><tt class="docutils literal">void merge( ptr_sequence_adapter& r );</tt></p> 812</li> 813<li><p class="first"><tt class="docutils literal">template< class Compare > void merge( ptr_sequence_adapter& r, Compare comp );</tt></p> 814</li> 815<li><p class="first"><tt class="docutils literal">void merge( iterator first, iterator last, ptr_sequence_adapter& from );</tt></p> 816</li> 817<li><p class="first"><tt class="docutils literal">template< class Compare > void merge( iterator first, iterator last, ptr_sequence_adapter& from, Compare comp );</tt></p> 818<blockquote> 819<ul class="simple"> 820<li>Requirements: (<tt class="docutils literal">Compare</tt> versions) <tt class="docutils literal">Compare</tt> must take <tt class="docutils literal">const T&</tt> arguments</li> 821<li>Requirements: both sequences are sorted wrt. the same predicate</li> 822<li>Effects: transfers the entire container or the specified sequence to the container while 823ensuring the new sequence is also sorted</li> 824<li>Postconditions: (Container versions) <tt class="docutils literal">r.empty()</tt></li> 825<li>Exception safety: nothrow guarantee (the behavior is undefined if the comparison operator throws)</li> 826</ul> 827</blockquote> 828</li> 829</ul> 830<hr><table class="docutils field-list" frame="void" rules="none"> 831<col class="field-name" /> 832<col class="field-body" /> 833<tbody valign="top"> 834<tr class="field"><th class="field-name">Copyright:</th><td class="field-body">Thorsten Ottosen 2004-2006. Use, modification and distribution is subject to the Boost Software License, Version 1.0 (see <a class="reference external" href="http://www.boost.org/LICENSE_1_0.txt">LICENSE_1_0.txt</a>).</td> 835</tr> 836</tbody> 837</table> 838</div> 839</div> 840</div> 841</body> 842</html> 843