-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathmodGit.bas
162 lines (138 loc) · 5.41 KB
/
modGit.bas
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
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
Attribute VB_Name = "modGit"
Option Explicit
' Module to provide 'git' access form Immediate window.
' Usage: Type something like: git "status"
'
' Note: `git` is a function. Everything after that is passed as a single string. To put quotes in that, double them. e.g.
' git "commit -am ""my commit message"""
'
' Also note that you cannot do interactive git commands, such as `git commit -p`
' For simple commands, such as status and push, the constants below allow the general syntax: `git push`, `git status`. Just dont be
' confused and think this is a terminal. It's still just a VB6 function running, and it only takes VB6 arguments.
Public Const Status As String = "status "
Public Const St As String = "status "
Public Const Commit As String = "commit -m "
Public Const Push As String = "push "
Public Const Pull As String = "pull "
Public Const Branch As String = "branch "
Public Const BR As String = "branch "
Public Const Stash As String = "stash"
Public Const CheckOut As String = "checkout "
Private Function GitFolder() As String
GitFolder = App.Path & "\"
End Function
Public Function GitCmd(ByVal C As String, Optional ByVal NoOutput As Boolean = False, Optional ByVal HideCommand As Boolean = False) As String
Dim ErrSt As String
PushDir GitFolder
If Not HideCommand Then GitOut "$ " & C
GitCmd = RunCmdToOutput(C, ErrSt)
PopDir
If Not NoOutput Then GitOut GitCmd
If ErrSt <> "" Then GitOut "ERR: " & ErrSt
End Function
Private Function GitOut(ByVal Msg As String) As Boolean
Msg = Trim(Msg)
Do While (Left(Msg, 1) = vbCr Or Left(Msg, 1) = vbLf): Msg = Mid(Msg, 2): Loop
If Len(Msg) > 0 Then Debug.Print Msg
End Function
Public Function Git(ByVal C As String) As Boolean
If LCase(Left(C, 4)) <> "git " Then C = "git " & C
GitCmd C
Git = True
End Function
Public Sub GitConf(Optional ByVal vName As String = "", Optional ByVal vEMail As String = "", Optional ByVal Clear As Boolean = False)
If Not IsIDE Then Exit Sub
GitCmd "git config --unset user.name", True, True
GitCmd "git config --unset user.email", True, True
If Clear Then
GitCmd "git config --unset --global user.name", True
GitCmd "git config --unset --global user.email", True
ElseIf vName = "" Or vEMail = "" Then
Debug.Print "user.name=" & Trim(Replace(Replace(GitCmd("git config --global user.name", True, True), vbCr, ""), vbLf, ""))
Debug.Print "user.email=" & Trim(Replace(Replace(GitCmd("git config --global user.email", True, True), vbCr, ""), vbLf, ""))
Else
' GitCmd "git config --unset --global user.name", True
' GitCmd "git config --unset --global user.email", True
GitCmd "git config --global user.name " & vName
GitCmd "git config --global user.email " & vEMail
End If
End Sub
Public Function GitPull(Optional ByVal withReset As Boolean = True) As Boolean
If Not IsIDE Then Exit Function
' If withReset Then GitReset
If withReset Then
GitCmd "git stash"
GitCmd "git checkout master"
End If
GitCmd "git pull -r"
If MsgBox("Restarting IDE in 5s...", vbOKCancel) = vbCancel Then Exit Function
' RestartIDE
GitPull = True
End Function
Public Function GitStatus() As String
If Not IsIDE Then Exit Function
GitStatus = GitCmd("git status")
End Function
Public Function GitVersion() As String
If Not IsIDE Then Exit Function
GitVersion = GitCmd("git --version")
End Function
Public Function HasGit() As Boolean
If Not IsIDE Then Exit Function
HasGit = GitVersion <> ""
End Function
Public Function GitReset(Optional ByVal Hard As Boolean = False, Optional ByVal toMaster As Boolean = False) As Boolean
If Not IsIDE Then Exit Function
If Not Hard Then
GitCmd "git checkout -- ."
If toMaster Then GitCmd "git checkout master -f"
Else
If toMaster Then GitCmd "git checkout master -f"
GitCmd "git reset --hard"
GitCmd "git pull -r --force"
End If
' RestartIDE
GitReset = True
End Function
Public Function GitPush(ByVal Committer As String, ByVal CommitMessage As String) As Boolean
If Not IsIDE Then Exit Function
GitCmd "git add ."
GitCmd "git status"
' If MsgBox("Continue with Commit?", vbOKCancel + vbQuestion + vbDefaultButton1, "git push", , , 10) = vbCancel Then
' GitCmd "git stash clear"
' GitCmd "Stash cleared."
' Exit Function
' End If
GitCmd "git commit -m """ & CommitMessage & """"
GitCmd "git pull -r"
' If MsgBox("Continue with Push?", vbOKCancel + vbQuestion + vbDefaultButton1, "git push", , , 10) = vbCancel Then
' GitCmd "git stash clear"
' GitCmd "Stash cleared."
' Exit Function
' End If
GitCmd "git push", True
GitCmd "git status"
GitOut "GitPush Complete."
' If MsgBox("Clear Credentials?", vbYesNo + vbExclamation + vbDefaultButton2, "Done?", , , 10) = vbYes Then
' GitProgress True
' GitConf Clear:=True
' GitProgress
' End If
'
GitPush = True
End Function
Public Sub GitLog(Optional ByVal CharLimit As Long = 3000)
Dim Res As String
If Not IsIDE Then Exit Sub
Res = GitCmd("git log", True)
Res = Left(Res, CharLimit)
Debug.Print Res
End Sub
Public Function GitCommits() As Boolean
GitCmd "git log --pretty=format:""%h - %an, %ar : %s"" -10"
GitCommits = True
End Function
Public Function GitRemoteBranches() As Boolean
GitCmd "git branch --remote --list"
GitRemoteBranches = True
End Function