mirror of https://github.com/dirtbags/moth.git
Merge branch 'mothv3' of https://github.com/dirtbags/moth into mothv3
This commit is contained in:
commit
8fdacbc36a
|
@ -1,6 +1,6 @@
|
||||||
FROM neale/eris
|
FROM neale/eris
|
||||||
|
|
||||||
RUN apk --no-cache add lua5.2 lua5.3
|
RUN apk --no-cache add lua5.1 lua5.2 lua5.3
|
||||||
RUN ln -s lua5.2 /usr/bin/lua
|
RUN ln -s lua5.2 /usr/bin/lua
|
||||||
|
|
||||||
# Install MOTH. This could be less obtuse.
|
# Install MOTH. This could be less obtuse.
|
||||||
|
|
52
mothball.go
52
mothball.go
|
@ -1,52 +0,0 @@
|
||||||
package mothball
|
|
||||||
|
|
||||||
import (
|
|
||||||
"archive/zip"
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Mothball struct {
|
|
||||||
zf *zipfile.File,
|
|
||||||
filename string,
|
|
||||||
mtime time.Time,
|
|
||||||
}
|
|
||||||
|
|
||||||
func Open(filename string) (*Mothball, error) {
|
|
||||||
var m Mothball
|
|
||||||
|
|
||||||
m.filename = filename
|
|
||||||
|
|
||||||
err := m.Refresh()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return &m
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m Mothball) Close() (error) {
|
|
||||||
return m.zf.Close()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m Mothball) Refresh() (error) {
|
|
||||||
mtime, err := os.Stat(m.filename)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if mtime == m.mtime {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
zf, err := zip.OpenReader(m.filename)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
m.zf.Close()
|
|
||||||
m.zf = zf
|
|
||||||
m.mtime = mtime
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m Mothball)
|
|
|
@ -0,0 +1,67 @@
|
||||||
|
package mothball
|
||||||
|
|
||||||
|
import (
|
||||||
|
"archive/zip"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Mothball struct {
|
||||||
|
zf *zip.ReadCloser
|
||||||
|
filename string
|
||||||
|
mtime time.Time
|
||||||
|
}
|
||||||
|
|
||||||
|
func Open(filename string) (*Mothball, error) {
|
||||||
|
var m Mothball
|
||||||
|
|
||||||
|
m.filename = filename
|
||||||
|
|
||||||
|
err := m.Refresh()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &m, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Mothball) Close() (error) {
|
||||||
|
return m.zf.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Mothball) Refresh() (error) {
|
||||||
|
info, err := os.Stat(m.filename)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
mtime := info.ModTime()
|
||||||
|
|
||||||
|
if mtime == m.mtime {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
zf, err := zip.OpenReader(m.filename)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if m.zf != nil {
|
||||||
|
m.zf.Close()
|
||||||
|
}
|
||||||
|
m.zf = zf
|
||||||
|
m.mtime = mtime
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Mothball) Open(filename string) (io.ReadCloser, error) {
|
||||||
|
for _, f := range m.zf.File {
|
||||||
|
if filename == f.Name {
|
||||||
|
ret, err := f.Open()
|
||||||
|
return ret, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("File not found: %s in %s", filename, m.filename)
|
||||||
|
}
|
|
@ -0,0 +1,63 @@
|
||||||
|
package mothball
|
||||||
|
|
||||||
|
import (
|
||||||
|
"archive/zip"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestMothball(t *testing.T) {
|
||||||
|
tf, err := ioutil.TempFile("", "mothball")
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer os.Remove(tf.Name())
|
||||||
|
|
||||||
|
w := zip.NewWriter(tf)
|
||||||
|
f, err := w.Create("moo.txt")
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// no Close method
|
||||||
|
|
||||||
|
_, err = fmt.Fprintln(f, "The cow goes moo")
|
||||||
|
//.Write([]byte("The cow goes moo"))
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.Close()
|
||||||
|
tf.Close()
|
||||||
|
|
||||||
|
// Now read it in
|
||||||
|
mb, err := Open(tf.Name())
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
cow, err := mb.Open("moo.txt")
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
line := make([]byte, 200)
|
||||||
|
n, err := cow.Read(line)
|
||||||
|
if (err != nil) && (err != io.EOF) {
|
||||||
|
t.Error(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if string(line[:n]) != "The cow goes moo\n" {
|
||||||
|
t.Log(line)
|
||||||
|
t.Error("Contents didn't match")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -92,6 +92,7 @@ window.addEventListener("load", init);
|
||||||
<img src="images/logo1.png" alt="">
|
<img src="images/logo1.png" alt="">
|
||||||
<img src="images/logo2.png" alt="">
|
<img src="images/logo2.png" alt="">
|
||||||
<img src="images/logo3.png" alt="">
|
<img src="images/logo3.png" alt="">
|
||||||
|
<img src="images/logo4.png" alt="">
|
||||||
</section>
|
</section>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 144 B |
|
@ -71,6 +71,7 @@
|
||||||
<img src="images/logo1.png" alt="">
|
<img src="images/logo1.png" alt="">
|
||||||
<img src="images/logo2.png" alt="">
|
<img src="images/logo2.png" alt="">
|
||||||
<img src="images/logo3.png" alt="">
|
<img src="images/logo3.png" alt="">
|
||||||
|
<img src="images/logo4.png" alt="">
|
||||||
</section>
|
</section>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -46,6 +46,7 @@
|
||||||
<img src="images/logo1.png" alt="">
|
<img src="images/logo1.png" alt="">
|
||||||
<img src="images/logo2.png" alt="">
|
<img src="images/logo2.png" alt="">
|
||||||
<img src="images/logo3.png" alt="">
|
<img src="images/logo3.png" alt="">
|
||||||
|
<img src="images/logo4.png" alt="">
|
||||||
</section>
|
</section>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -118,6 +118,7 @@
|
||||||
<img src="images/logo1.png" alt="">
|
<img src="images/logo1.png" alt="">
|
||||||
<img src="images/logo2.png" alt="">
|
<img src="images/logo2.png" alt="">
|
||||||
<img src="images/logo3.png" alt="">
|
<img src="images/logo3.png" alt="">
|
||||||
|
<img src="images/logo4.png" alt="">
|
||||||
</section>
|
</section>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
Loading…
Reference in New Issue