github.com/aidoskuneen/adk-node@v0.0.0-20220315131952-2e32567cb7f4/rlp/iterator.go (about)

     1  // Copyright 2021 The adkgo Authors
     2  // This file is part of the adkgo library (adapted for adkgo from go--ethereum v1.10.8).
     3  //
     4  // the adkgo library is free software: you can redistribute it and/or modify
     5  // it under the terms of the GNU Lesser General Public License as published by
     6  // the Free Software Foundation, either version 3 of the License, or
     7  // (at your option) any later version.
     8  //
     9  // the adkgo library is distributed in the hope that it will be useful,
    10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
    12  // GNU Lesser General Public License for more details.
    13  //
    14  // You should have received a copy of the GNU Lesser General Public License
    15  // along with the adkgo library. If not, see <http://www.gnu.org/licenses/>.
    16  
    17  package rlp
    18  
    19  type listIterator struct {
    20  	data []byte
    21  	next []byte
    22  	err  error
    23  }
    24  
    25  // NewListIterator creates an iterator for the (list) represented by data
    26  // TODO: Consider removing this implementation, as it is no longer used.
    27  func NewListIterator(data RawValue) (*listIterator, error) {
    28  	k, t, c, err := readKind(data)
    29  	if err != nil {
    30  		return nil, err
    31  	}
    32  	if k != List {
    33  		return nil, ErrExpectedList
    34  	}
    35  	it := &listIterator{
    36  		data: data[t : t+c],
    37  	}
    38  	return it, nil
    39  
    40  }
    41  
    42  // Next forwards the iterator one step, returns true if it was not at end yet
    43  func (it *listIterator) Next() bool {
    44  	if len(it.data) == 0 {
    45  		return false
    46  	}
    47  	_, t, c, err := readKind(it.data)
    48  	it.next = it.data[:t+c]
    49  	it.data = it.data[t+c:]
    50  	it.err = err
    51  	return true
    52  }
    53  
    54  // Value returns the current value
    55  func (it *listIterator) Value() []byte {
    56  	return it.next
    57  }
    58  
    59  func (it *listIterator) Err() error {
    60  	return it.err
    61  }