Kiln » gitkiln Read More
Clone URL:  
Pushed to one repository · View In Graph Contained in master

add create-branch command

Changeset 3dd53a8cb267

Parent ecc7c507cff2

by Profile picture of User 12Benjamin Pollack <benjamin@fogcreek.com>

Changes to 2 files · Browse files at 3dd53a8cb267 Showing diff from parent ecc7c507cff2 Diff from another changeset...

Change 1 of 2 Show Changes Only kiln/​api.go Stacked
1
2
3
4
5
 
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
 package kiln    import (   "encoding/json"   "fmt" + "strconv"   "strings"  )    // Represents the error JSON returned by Kiln API requests  type KilnError struct {   // Guaranteed-unique code for Kiln errors   Code string `json:"codeError"`   // Human-readable description   Description string `json:"sError"`  }    // Represents the project JSON returned from the Kiln API  type KilnProject struct {   Id int64 `json:"ixProject"`   Slug string `json:"sSlug"`   Name string `json:"sName"`   Description string `json:"sDescription"`   DefaultPermission string `json:"permissionDefault"`   RepoGroups []KilnRepoGroup  }    type KilnRepoGroup struct {   Id int64 `json:"ixRepoGroup"`   ProjectId int64 `json:"ixProject"`   Slug string `json:"sSlug"`   Name string `json:"sName"`   Repos []KilnRepo `json:"repos"`  }    type KilnRepo struct {   Id int64 `json:"ixRepo"`   RepoGroupId int64 `json:"ixRepoGroup"`   ParentId int64 `json:"ixParent"`   IsCentral bool `json:"fCentral"`   Slug string `json:"sSlug"`   GroupSlug string `json:"sGroupSlug"`   ProjectSlug string `json:"sProjectSlug"`   GitUrl string `json:"sGitUrl"`   GitSshUrl string `json:"sGitSshUrl"`   Name string `json:"sName"`   Description string `json:"sDescription"`   Status string `json:"sStatus"`   Size int64 `json:"bytesSize"`   Vcs int `json:"vcs"`   Creator KilnPerson `json:"personCreator"`   DefaultPermission string `json:"permissionDefault"`   Branches []KilnRepo `json:"repoBranches"`  }    type KilnPerson struct {   Id int64 `json:"ixPerson"`   Name string `json:"sName"`   Email string `json:"sEmail"`  }   +func (k *KilnClient) CreateBranch(repoPath, branchName string) (newRepo *KilnRepo, err error) { + r, err := k.RepoForPath(repoPath) + if err != nil { + return + } + params := apiParams{ + "sName": branchName, + "ixRepoGroup": strconv.FormatInt(r.RepoGroupId, 10), + "ixParent": strconv.FormatInt(r.Id, 10), + "fCentral": "false", + } + var resp []byte + if resp, err = k.apiPost("Repo/Create", params); err == nil { + var errors map[string][]KilnError + if err = json.Unmarshal(resp, &errors); err == nil { + if kilnErr, _ := errors["errors"]; len(kilnErr) > 0 { + err = fmt.Errorf("failed: %v\n", kilnErr[0].Description) + return + } + } + newRepo = new(KilnRepo) + err = json.Unmarshal(resp, newRepo) + return + } + return +} +  func (k *KilnClient) Projects() (projects []KilnProject, err error) {   if resp, err := k.apiGet("Project", apiParams{}); err == nil {   err = json.Unmarshal(resp, &projects)   }   return  }    func (k *KilnClient) RepoForPath(repoPath string) (*KilnRepo, error) {   parts := strings.Split(repoPath, "/")   if len(parts) != 3 {   return nil, fmt.Errorf("unknown repository target: %v", repoPath)   }   if projects, err := k.Projects(); err == nil {   for _, project := range projects {   for _, repoGroup := range project.RepoGroups {   for _, repo := range repoGroup.Repos {   if strings.EqualFold(repo.ProjectSlug, parts[0]) &&   strings.EqualFold(repo.GroupSlug, parts[1]) &&   strings.EqualFold(repo.Slug, parts[2]) {   return &repo, nil   }   }   }   }   }   return nil, fmt.Errorf("repository not found")  }    func (k *KilnClient) IdForRepo(repoPath string) (int64, error) {   repo, err := k.RepoForPath(repoPath)   if err != nil {   return -1, err   }   return repo.Id, nil  }    func (k *KilnClient) RelatedRepos(repoPath string) (repos []KilnRepo, err error) {   repoId, err := k.IdForRepo(repoPath)   if err == nil {   resp, err := k.apiGet(fmt.Sprintf("Repo/%v/Related", repoId), apiParams{})   if err == nil {   err = json.Unmarshal(resp, &repos)   }   }   return  }
Change 1 of 1 Show Entire File main.go Stacked
 
206
207
208
 
 
 
 
 
 
 
 
 
 
209
210
211
 
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
@@ -206,6 +206,16 @@
  k.BrowseAnnotatedFile(repoPath, file)   }   } + case "create-branch": + if ensureArgs(3, "you must provide a branch name to create") { + requireAuth(k) + r, err := k.CreateBranch(repoPath, os.Args[2]) + if err != nil { + fmt.Fprintf(os.Stderr, "could not create branch: %v\n", err) + } else { + fmt.Printf("created: %v\n", r.GitUrl) + } + }   case "filehistory":   if ensureArgs(3, "you must provide at least one file to view") {   for _, file := range os.Args[2:len(os.Args)] {