forked from mystiq/dex
79 lines
1.4 KiB
Go
79 lines
1.4 KiB
Go
|
package main
|
||
|
|
||
|
import (
|
||
|
"archive/zip"
|
||
|
"bytes"
|
||
|
"fmt"
|
||
|
"io"
|
||
|
"io/ioutil"
|
||
|
"log"
|
||
|
"net/http"
|
||
|
"os"
|
||
|
"path"
|
||
|
"path/filepath"
|
||
|
"strings"
|
||
|
|
||
|
"github.com/PuerkitoBio/goquery"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
site := "https://www.sqlite.org/download.html"
|
||
|
fmt.Printf("scraping %v\n", site)
|
||
|
doc, err := goquery.NewDocument(site)
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
var url string
|
||
|
doc.Find("a").Each(func(_ int, s *goquery.Selection) {
|
||
|
if url == "" && strings.HasPrefix(s.Text(), "sqlite-amalgamation-") {
|
||
|
url = "https://www.sqlite.org/2016/" + s.Text()
|
||
|
}
|
||
|
})
|
||
|
if url == "" {
|
||
|
return
|
||
|
}
|
||
|
fmt.Printf("downloading %v\n", url)
|
||
|
resp, err := http.Get(url)
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
defer resp.Body.Close()
|
||
|
|
||
|
b, err := ioutil.ReadAll(resp.Body)
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
|
||
|
fmt.Printf("extracting %v\n", path.Base(url))
|
||
|
r, err := zip.NewReader(bytes.NewReader(b), resp.ContentLength)
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
for _, zf := range r.File {
|
||
|
var f *os.File
|
||
|
switch path.Base(zf.Name) {
|
||
|
case "sqlite3.c":
|
||
|
f, err = os.Create("sqlite3-binding.c")
|
||
|
case "sqlite3.h":
|
||
|
f, err = os.Create("sqlite3-binding.h")
|
||
|
case "sqlite3ext.h":
|
||
|
f, err = os.Create("sqlite3ext.h")
|
||
|
default:
|
||
|
continue
|
||
|
}
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
zr, err := zf.Open()
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
_, err = io.Copy(f, zr)
|
||
|
f.Close()
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
fmt.Printf("extracted %v\n", filepath.Base(f.Name()))
|
||
|
}
|
||
|
}
|