mirror of
https://git.mirrors.martin98.com/https://github.com/ceph/ceph-csi.git
synced 2025-08-12 12:48:59 +08:00

Several packages are only used while running the e2e suite. These packages are less important to update, as the they can not influence the final executable that is part of the Ceph-CSI container-image. By moving these dependencies out of the main Ceph-CSI go.mod, it is easier to identify if a reported CVE affects Ceph-CSI, or only the testing (like most of the Kubernetes CVEs). Signed-off-by: Niels de Vos <ndevos@ibm.com>
57 lines
1.5 KiB
Go
57 lines
1.5 KiB
Go
// Copyright 2024 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
//go:build go1.23
|
|
|
|
package html
|
|
|
|
import "iter"
|
|
|
|
// Ancestors returns an iterator over the ancestors of n, starting with n.Parent.
|
|
//
|
|
// Mutating a Node or its parents while iterating may have unexpected results.
|
|
func (n *Node) Ancestors() iter.Seq[*Node] {
|
|
_ = n.Parent // eager nil check
|
|
|
|
return func(yield func(*Node) bool) {
|
|
for p := n.Parent; p != nil && yield(p); p = p.Parent {
|
|
}
|
|
}
|
|
}
|
|
|
|
// ChildNodes returns an iterator over the immediate children of n,
|
|
// starting with n.FirstChild.
|
|
//
|
|
// Mutating a Node or its children while iterating may have unexpected results.
|
|
func (n *Node) ChildNodes() iter.Seq[*Node] {
|
|
_ = n.FirstChild // eager nil check
|
|
|
|
return func(yield func(*Node) bool) {
|
|
for c := n.FirstChild; c != nil && yield(c); c = c.NextSibling {
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
// Descendants returns an iterator over all nodes recursively beneath
|
|
// n, excluding n itself. Nodes are visited in depth-first preorder.
|
|
//
|
|
// Mutating a Node or its descendants while iterating may have unexpected results.
|
|
func (n *Node) Descendants() iter.Seq[*Node] {
|
|
_ = n.FirstChild // eager nil check
|
|
|
|
return func(yield func(*Node) bool) {
|
|
n.descendants(yield)
|
|
}
|
|
}
|
|
|
|
func (n *Node) descendants(yield func(*Node) bool) bool {
|
|
for c := range n.ChildNodes() {
|
|
if !yield(c) || !c.descendants(yield) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|