// Copyright 2020 The go-ethereum Authors // This file is part of the go-ethereum library. // // The go-ethereum library is free software: you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // The go-ethereum library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with the go-ethereum library. If not, see . package rlp type listIterator struct { data []byte next []byte err error } // NewListIterator creates an iterator for the (list) represented by data func NewListIterator(data RawValue) (*listIterator, error) { k, t, c, err := readKind(data) if err != nil { return nil, err } if k != List { return nil, ErrExpectedList } it := &listIterator{ data: data[t : t+c], } return it, nil } // Next forwards the iterator one step. // Returns true if there is a next item or an error occurred on this step (check Err()). // On parse error, the iterator is marked finished and subsequent calls return false. func (it *listIterator) Next() bool { if len(it.data) == 0 { return false } _, t, c, err := readKind(it.data) if err != nil { it.next = nil it.err = err // Mark iteration as finished to avoid potential infinite loops on subsequent Next calls. it.data = nil return true } it.next = it.data[:t+c] it.data = it.data[t+c:] it.err = nil return true } // Value returns the current value func (it *listIterator) Value() []byte { return it.next } func (it *listIterator) Err() error { return it.err }