mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-30 15:05:27 +00:00
Merge pull request #72406 from wojtek-t/speedup_listers
Speedup listers for empty selectors
This commit is contained in:
commit
7c112762b0
@ -31,7 +31,14 @@ import (
|
|||||||
type AppendFunc func(interface{})
|
type AppendFunc func(interface{})
|
||||||
|
|
||||||
func ListAll(store Store, selector labels.Selector, appendFn AppendFunc) error {
|
func ListAll(store Store, selector labels.Selector, appendFn AppendFunc) error {
|
||||||
|
selectAll := selector.Empty()
|
||||||
for _, m := range store.List() {
|
for _, m := range store.List() {
|
||||||
|
if selectAll {
|
||||||
|
// Avoid computing labels of the objects to speed up common flows
|
||||||
|
// of listing all objects.
|
||||||
|
appendFn(m)
|
||||||
|
continue
|
||||||
|
}
|
||||||
metadata, err := meta.Accessor(m)
|
metadata, err := meta.Accessor(m)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -44,8 +51,15 @@ func ListAll(store Store, selector labels.Selector, appendFn AppendFunc) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func ListAllByNamespace(indexer Indexer, namespace string, selector labels.Selector, appendFn AppendFunc) error {
|
func ListAllByNamespace(indexer Indexer, namespace string, selector labels.Selector, appendFn AppendFunc) error {
|
||||||
|
selectAll := selector.Empty()
|
||||||
if namespace == metav1.NamespaceAll {
|
if namespace == metav1.NamespaceAll {
|
||||||
for _, m := range indexer.List() {
|
for _, m := range indexer.List() {
|
||||||
|
if selectAll {
|
||||||
|
// Avoid computing labels of the objects to speed up common flows
|
||||||
|
// of listing all objects.
|
||||||
|
appendFn(m)
|
||||||
|
continue
|
||||||
|
}
|
||||||
metadata, err := meta.Accessor(m)
|
metadata, err := meta.Accessor(m)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -74,6 +88,12 @@ func ListAllByNamespace(indexer Indexer, namespace string, selector labels.Selec
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
for _, m := range items {
|
for _, m := range items {
|
||||||
|
if selectAll {
|
||||||
|
// Avoid computing labels of the objects to speed up common flows
|
||||||
|
// of listing all objects.
|
||||||
|
appendFn(m)
|
||||||
|
continue
|
||||||
|
}
|
||||||
metadata, err := meta.Accessor(m)
|
metadata, err := meta.Accessor(m)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
Loading…
Reference in New Issue
Block a user