summaryrefslogtreecommitdiff
path: root/blobby
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2024-12-19 10:31:42 -0600
committerJeff Carr <[email protected]>2024-12-19 10:31:42 -0600
commit8f9b66f6c8565f08e18098e330dfe73c22592b9f (patch)
tree672c89ed98e4f08a04f35329d1b4779dadeb6575 /blobby
parentc5fb46c60d4a0383e0e3586bd2d4968e8a8907b7 (diff)
blobby
Diffstat (limited to 'blobby')
-rw-r--r--blobby/Makefile28
-rw-r--r--blobby/main.go55
2 files changed, 83 insertions, 0 deletions
diff --git a/blobby/Makefile b/blobby/Makefile
new file mode 100644
index 0000000..07bcba5
--- /dev/null
+++ b/blobby/Makefile
@@ -0,0 +1,28 @@
+VERSION = $(shell git describe --tags)
+GUIVERSION = $(shell git describe --tags)
+BUILDTIME = $(shell date +%s)
+
+all: build
+
+build: goimports
+ GO111MODULE=off go build -v \
+ -ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}"
+
+vet:
+ GO111MODULE=off go vet
+
+goimports:
+ goimports -w *.go
+ # // to globally reset paths:
+ # // gofmt -w -r '"go.wit.com/gui/gadgets" -> "go.wit.com/lib/gadgets"' *.go
+
+gocui: build
+ reset
+ ./go-clone-test --gui gocui
+
+install: goimports
+ GO111MODULE=off go install \
+ -ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}"
+
+force: build
+ ./go-clone-test --force
diff --git a/blobby/main.go b/blobby/main.go
new file mode 100644
index 0000000..5b6f89f
--- /dev/null
+++ b/blobby/main.go
@@ -0,0 +1,55 @@
+package main
+
+import (
+ "gocloud.dev/blob"
+ // _ "gocloud.dev/blob/<driver>"
+ "context"
+ "fmt"
+
+ _ "gocloud.dev/blob/mysql"
+)
+
+func main() {
+ bucket, err := blob.OpenBucket(context.Background(), "<driver-url>")
+ if err != nil {
+ return fmt.Errorf("could not open bucket: %v", err)
+ }
+ defer bucket.Close()
+ // bucket is a *blob.Bucket; see usage below
+
+ // You can wrap a *blob.Bucket to always operate on a subfolder of the bucket using blob.PrefixedBucket:
+
+ // import "gocloud.dev/blob"
+
+ // Wrap the bucket using blob.PrefixedBucket.
+ // The prefix should end with "/", so that the resulting bucket operates
+ // in a subfolder.
+ bucket = blob.PrefixedBucket(bucket, "a/subfolder/")
+
+ // The original bucket is no longer usable; it has been closed.
+ // The wrapped bucket should be closed when done.
+ defer bucket.Close()
+
+ // Bucket operations on <key> will be translated to "a/subfolder/<key>".
+
+ // Alternatively, you can configure the prefix directly in the blob.OpenBucket URL:
+
+ /*
+ import (
+ "context"
+ "gocloud.dev/blob"
+ )
+ */
+
+ // Connect to a bucket using a URL, using the "prefix" query parameter to
+ // target a subfolder in the bucket.
+ // The prefix should end with "/", so that the resulting bucket operates
+ // in a subfolder.
+ b, err := blob.OpenBucket(ctx, "mem://?prefix=a/subfolder/")
+ if err != nil {
+ return err
+ }
+ defer b.Close()
+
+ // Bucket operations on <key> will be translated to "a/subfolder/<key>".
+}