a074773e6c
This will allow to make use of func (*Reader) Seek, instead of re-recreating a new reader. It's a large commit for a small change, but anything to simply the reader/buffer/ReadAll/… mess is a step in the right direction I think, and it should enable more follow-up simplifications.
21 lines
598 B
Go
21 lines
598 B
Go
// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package rss // import "miniflux.app/v2/internal/reader/rss"
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
|
|
"miniflux.app/v2/internal/model"
|
|
"miniflux.app/v2/internal/reader/xml"
|
|
)
|
|
|
|
// Parse returns a normalized feed struct from a RSS feed.
|
|
func Parse(baseURL string, data io.ReadSeeker) (*model.Feed, error) {
|
|
feed := new(rssFeed)
|
|
if err := xml.NewXMLDecoder(data).Decode(feed); err != nil {
|
|
return nil, fmt.Errorf("rss: unable to parse feed: %w", err)
|
|
}
|
|
return feed.Transform(baseURL), nil
|
|
}
|