#include <neighb.hh>
Public Types | |
typedef Site_Proxy< void > | category |
typedef neighb_fwd_niter< W > | exact_t |
typedef neighb< W >::site | site |
The associated site type (as a Site_Proxy). | |
typedef neighb< W > | target |
The associated target type. | |
Public Member Functions | |
const neighb< W >::psite & | center () const |
The psite around which this iterator moves. | |
void | center_at (const P &c) |
void | change_target (const neighb< W > &s) |
Change the site set targeted by this iterator. | |
W::psite | compute_p_ () const |
Compute the current psite. | |
void | do_next_ () |
Go to the next point. | |
void | do_start_ () |
Start an iteration. | |
void | invalidate () |
void | invalidate_ () |
Invalidate the iterator. | |
bool | is_valid () const |
bool | is_valid_ () const |
Test the iterator validity. | |
template<typename P > | |
neighb_fwd_niter (const neighb< W > &nbh, const P &c) | |
neighb_fwd_niter () | |
Constructor without argument. | |
void | next () |
Go to the next element. | |
void | next_ () |
Go to the next point. | |
const neighb< W >::psite & | p_hook_ () const |
Hook to the current location. | |
const neighb< W > & | site_set () const |
Give the site set (neighborhood or window) that this iterator browses. | |
void | start () |
void | start_ () |
Start an iteration. | |
const neighb< W >::psite & | subj_ () |
This overriding is very useful: it adds a test to prevent getting an invalid iterator when its center has moved. | |
const neighb< W > *& | target_ () |
Give the target address. It might be 0. | |
const neighb< W >::site & | to_site () const |
Return the site it points to (as a Site_Proxy). | |
neighb_fwd_niter< W > & | update () |
Warning: this method is an advanced tool provided for very special occasions; if you are a regular user, you should never use it! Calling this method forces this relative iterator to synchronize with its center when it has just moved and when the relative iterator still makes sense. | |
Protected Attributes | |
const neighb< W >::psite * | c_ |
A pointer to the center psite around which this iterator moves. | |
W::fwd_qiter | i_ |
const neighb< W > * | s_ |
The target. |
typedef Site_Proxy<void> mln::Site_Proxy< neighb_fwd_niter< W > >::category [inherited] |
Reimplemented from mln::Proxy< neighb_fwd_niter< W > >.
typedef neighb_fwd_niter< W > mln::Object< neighb_fwd_niter< W > >::exact_t [inherited] |
typedef neighb< W > ::site mln::internal::site_iterator_base< neighb< W > , neighb_fwd_niter< W > >::site [inherited] |
The associated site type (as a Site_Proxy).
typedef neighb< W > mln::internal::site_iterator_base< neighb< W > , neighb_fwd_niter< W > >::target [inherited] |
The associated target type.
mln::neighb_fwd_niter< W >::neighb_fwd_niter | ( | ) | [inline] |
Constructor without argument.
mln::neighb_fwd_niter< W >::neighb_fwd_niter | ( | const neighb< W > & | nbh, | |
const P & | c | |||
) | [inline] |
const neighb< W > ::psite& mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::center | ( | ) | const [inherited] |
The psite around which this iterator moves.
void mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::center_at | ( | const P & | c | ) | [inherited] |
Referenced by mln::neighb_fwd_niter< W >::neighb_fwd_niter().
void mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::change_target | ( | const neighb< W > & | s | ) | [inherited] |
Change the site set targeted by this iterator.
Referenced by mln::neighb_fwd_niter< W >::neighb_fwd_niter().
W::psite mln::neighb_fwd_niter< W >::compute_p_ | ( | ) | const [inline] |
Compute the current psite.
void mln::neighb_fwd_niter< W >::do_next_ | ( | ) | [inline] |
Go to the next point.
void mln::neighb_fwd_niter< W >::do_start_ | ( | ) | [inline] |
Start an iteration.
void mln::Site_Iterator< neighb_fwd_niter< W > >::invalidate | ( | ) | [inherited] |
void mln::neighb_fwd_niter< W >::invalidate_ | ( | ) | [inline] |
Invalidate the iterator.
bool mln::Site_Iterator< neighb_fwd_niter< W > >::is_valid | ( | ) | const [inherited] |
bool mln::neighb_fwd_niter< W >::is_valid_ | ( | ) | const [inline] |
Test the iterator validity.
void mln::Site_Iterator< neighb_fwd_niter< W > >::next | ( | ) | [inherited] |
Go to the next element.
void mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::next_ | ( | ) | [inherited] |
Go to the next point.
const neighb< W > ::psite& mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::p_hook_ | ( | ) | const [inherited] |
Hook to the current location.
const neighb< W > & mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::site_set | ( | ) | const [inherited] |
Give the site set (neighborhood or window) that this iterator browses.
void mln::Site_Iterator< neighb_fwd_niter< W > >::start | ( | ) | [inherited] |
void mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::start_ | ( | ) | [inherited] |
Start an iteration.
const neighb< W > ::psite& mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::subj_ | ( | ) | [inherited] |
This overriding is very useful: it adds a test to prevent getting an invalid iterator when its center has moved.
Some sub-classes provide an update() method for the client to say that she really want to read the iterator just after the center has changed.
Reimplemented from mln::internal::site_iterator_base< neighb< W >, neighb_fwd_niter< W > >.
const neighb< W > *& mln::internal::site_iterator_base< neighb< W > , neighb_fwd_niter< W > >::target_ | ( | ) | [inherited] |
Give the target address. It might be 0.
const neighb< W > ::site& mln::internal::site_iterator_base< neighb< W > , neighb_fwd_niter< W > >::to_site | ( | ) | const [inherited] |
Return the site it points to (as a Site_Proxy).
neighb_fwd_niter< W > & mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::update | ( | ) | [inherited] |
Warning: this method is an advanced tool provided for very special occasions; if you are a regular user, you should never use it! Calling this method forces this relative iterator to synchronize with its center when it has just moved and when the relative iterator still makes sense.
const neighb< W > ::psite* mln::internal::site_relative_iterator_base< neighb< W > , neighb_fwd_niter< W > >::c_ [protected, inherited] |
A pointer to the center psite around which this iterator moves.
W ::fwd_qiter mln::neighb_fwd_niter< W >::i_ [protected] |
const neighb< W > * mln::internal::site_iterator_base< neighb< W > , neighb_fwd_niter< W > >::s_ [protected, inherited] |
The target.