aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--repository_plan9_test.go47
-rw-r--r--worktree_plan9.go31
2 files changed, 78 insertions, 0 deletions
diff --git a/repository_plan9_test.go b/repository_plan9_test.go
new file mode 100644
index 0000000..00ebeed
--- /dev/null
+++ b/repository_plan9_test.go
@@ -0,0 +1,47 @@
+package git
+
+import (
+ "fmt"
+ "strings"
+)
+
+// preReceiveHook returns the bytes of a pre-receive hook script
+// that prints m before exiting successfully
+func preReceiveHook(m string) []byte {
+ return []byte(fmt.Sprintf("#!/bin/rc\necho -n %s\n", quote(m)))
+}
+
+const quoteChar = '\''
+
+func needsQuote(s string) bool {
+ for i := 0; i < len(s); i++ {
+ c := s[i]
+ if c == quoteChar || c <= ' ' { // quote, blanks, or control characters
+ return true
+ }
+ }
+ return false
+}
+
+// Quote adds single quotes to s in the style of rc(1) if they are needed.
+// The behaviour should be identical to Plan 9's quote(3).
+func quote(s string) string {
+ if s == "" {
+ return "''"
+ }
+ if !needsQuote(s) {
+ return s
+ }
+ var b strings.Builder
+ b.Grow(10 + len(s)) // Enough room for few quotes
+ b.WriteByte(quoteChar)
+ for i := 0; i < len(s); i++ {
+ c := s[i]
+ if c == quoteChar {
+ b.WriteByte(quoteChar)
+ }
+ b.WriteByte(c)
+ }
+ b.WriteByte(quoteChar)
+ return b.String()
+}
diff --git a/worktree_plan9.go b/worktree_plan9.go
new file mode 100644
index 0000000..16d3915
--- /dev/null
+++ b/worktree_plan9.go
@@ -0,0 +1,31 @@
+package git
+
+import (
+ "syscall"
+ "time"
+
+ "gopkg.in/src-d/go-git.v4/plumbing/format/index"
+)
+
+func init() {
+ fillSystemInfo = func(e *index.Entry, sys interface{}) {
+ if os, ok := sys.(*syscall.Dir); ok {
+ // Plan 9 doesn't have a CreatedAt field.
+ e.CreatedAt = time.Unix(int64(os.Mtime), 0)
+
+ e.Dev = uint32(os.Dev)
+
+ // Plan 9 has no Inode.
+ // ext2srv(4) appears to store Inode in Qid.Path.
+ e.Inode = uint32(os.Qid.Path)
+
+ // Plan 9 has string UID/GID
+ e.GID = 0
+ e.UID = 0
+ }
+ }
+}
+
+func isSymlinkWindowsNonAdmin(err error) bool {
+ return true
+}