Fix: file close even if file was not opened (#1417)

Fixed a bug where in many implementations of load-file functions the file-close was still
executed even if the file-open resulted in an error.
This commit is contained in:
EnameEtavir
2021-05-24 23:52:55 +02:00
committed by GitHub
parent 0472cd9996
commit dc453c193d
11 changed files with 11 additions and 11 deletions

View File

@@ -29,10 +29,10 @@ type Gallery struct {
func LoadGalleryFile(filePath string) (*Gallery, error) {
var gallery Gallery
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&gallery)

View File

@@ -33,10 +33,10 @@ type Image struct {
func LoadImageFile(filePath string) (*Image, error) {
var image Image
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&image)

View File

@@ -26,10 +26,10 @@ type Mappings struct {
func LoadMappingsFile(filePath string) (*Mappings, error) {
var mappings Mappings
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&mappings)

View File

@@ -27,10 +27,10 @@ type Movie struct {
func LoadMovieFile(filePath string) (*Movie, error) {
var movie Movie
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&movie)

View File

@@ -40,10 +40,10 @@ type Performer struct {
func LoadPerformerFile(filePath string) (*Performer, error) {
var performer Performer
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&performer)

View File

@@ -61,10 +61,10 @@ type Scene struct {
func LoadSceneFile(filePath string) (*Scene, error) {
var scene Scene
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&scene)

View File

@@ -27,10 +27,10 @@ type ScrapedItem struct {
func LoadScrapedFile(filePath string) ([]ScrapedItem, error) {
var scraped []ScrapedItem
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&scraped)

View File

@@ -22,10 +22,10 @@ type Studio struct {
func LoadStudioFile(filePath string) (*Studio, error) {
var studio Studio
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&studio)

View File

@@ -18,10 +18,10 @@ type Tag struct {
func LoadTagFile(filePath string) (*Tag, error) {
var tag Tag
file, err := os.Open(filePath)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
var json = jsoniter.ConfigCompatibleWithStandardLibrary
jsonParser := json.NewDecoder(file)
err = jsonParser.Decode(&tag)

View File

@@ -211,10 +211,10 @@ func loadPluginFromYAML(reader io.Reader) (*Config, error) {
func loadPluginFromYAMLFile(path string) (*Config, error) {
file, err := os.Open(path)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
ret, err := loadPluginFromYAML(file)
if err != nil {

View File

@@ -209,10 +209,10 @@ func loadScraperFromYAML(id string, reader io.Reader) (*config, error) {
func loadScraperFromYAMLFile(path string) (*config, error) {
file, err := os.Open(path)
defer file.Close()
if err != nil {
return nil, err
}
defer file.Close()
// set id to the filename
id := filepath.Base(path)