source/File: Fix data races
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 21 Jul 2015 18:02:42 +0000 (20:02 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 21 Jul 2015 18:02:42 +0000 (20:02 +0200)
source/file.go

index 982a73312bacedb554c8cb37b64833ee7db8857e..53524ced4bf678add1e3b5579af82e31f97ea9b8 100644 (file)
@@ -31,9 +31,6 @@ type File struct {
 }
 
 func (f *File) UniqueID() string {
-       if f.uniqueID == "" {
-               f.uniqueID = helpers.Md5String(f.LogicalName())
-       }
        return f.uniqueID
 }
 
@@ -51,18 +48,10 @@ func (f *File) BaseFileName() string {
 }
 
 func (f *File) Section() string {
-       if f.section != "" {
-               return f.section
-       }
-       f.section = helpers.GuessSection(f.Dir())
        return f.section
 }
 
 func (f *File) LogicalName() string {
-       if f.logicalName != "" {
-               return f.logicalName
-       }
-       _, f.logicalName = filepath.Split(f.relpath)
        return f.logicalName
 }
 
@@ -71,18 +60,10 @@ func (f *File) SetDir(dir string) {
 }
 
 func (f *File) Dir() string {
-       if f.dir != "" {
-               return f.dir
-       }
-       f.dir, _ = filepath.Split(f.relpath)
        return f.dir
 }
 
 func (f *File) Extension() string {
-       if f.ext != "" {
-               return f.ext
-       }
-       f.ext = strings.TrimPrefix(filepath.Ext(f.LogicalName()), ".")
        return f.ext
 }
 
@@ -101,9 +82,17 @@ func NewFileWithContents(relpath string, content io.Reader) *File {
 }
 
 func NewFile(relpath string) *File {
-       return &File{
+       f := &File{
                relpath: relpath,
        }
+
+       f.dir, _ = filepath.Split(f.relpath)
+       _, f.logicalName = filepath.Split(f.relpath)
+       f.ext = strings.TrimPrefix(filepath.Ext(f.LogicalName()), ".")
+       f.section = helpers.GuessSection(f.Dir())
+       f.uniqueID = helpers.Md5String(f.LogicalName())
+
+       return f
 }
 
 func NewFileFromAbs(base, fullpath string, content io.Reader) (f *File, err error) {