From 8f9b66f6c8565f08e18098e330dfe73c22592b9f Mon Sep 17 00:00:00 2001 From: Jeff Carr Date: Thu, 19 Dec 2024 10:31:42 -0600 Subject: [PATCH] blobby --- .gitignore | 1 + blobby/Makefile | 28 +++++++++++++++++++++++ blobby/main.go | 55 ++++++++++++++++++++++++++++++++++++++++++++++ going2git/Makefile | 2 +- 4 files changed, 85 insertions(+), 1 deletion(-) create mode 100644 blobby/Makefile create mode 100644 blobby/main.go diff --git a/.gitignore b/.gitignore index 34a0698..6c14895 100644 --- a/.gitignore +++ b/.gitignore @@ -14,3 +14,4 @@ go-clone-test/go-clone-test go-clone-test/goclonetest go-clone-test/goclonetesttest going2git/going2git +blobby/blobby 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/" + "context" + "fmt" + + _ "gocloud.dev/blob/mysql" +) + +func main() { + bucket, err := blob.OpenBucket(context.Background(), "") + 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 will be translated to "a/subfolder/". + + // 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 will be translated to "a/subfolder/". +} diff --git a/going2git/Makefile b/going2git/Makefile index 1e8c9f8..07bcba5 100644 --- a/going2git/Makefile +++ b/going2git/Makefile @@ -5,7 +5,7 @@ BUILDTIME = $(shell date +%s) all: build build: goimports - GO111MODULE=off go build \ + GO111MODULE=off go build -v \ -ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}" vet: