forked from vlang/gitly
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommit.v
130 lines (117 loc) · 2.68 KB
/
commit.v
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
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
// Use of this source code is governed by a GPL license that can be found in the LICENSE file.
module main
import time
struct Commit {
mut:
id int
author_id int
author string
hash string
created_at int
repo_id int
message string
}
struct Change {
mut:
file string
additions int
deletions int
diff string
message string
}
fn (commit Commit) relative() string {
return time.unix(commit.created_at).relative()
}
fn (commit Commit) get_changes(repo Repo) []Change {
changes_s := repo.git('show $commit.hash')
mut tmp_change := Change{}
mut changes := []Change{}
mut started := false
for line in changes_s.split_into_lines() {
args := line.split(' ')
if args.len <= 0 {
continue
}
match args[0] {
'diff' {
started = true
if tmp_change.file.len > 0 {
changes << tmp_change
tmp_change = Change{}
}
tmp_change.file = args[2][2..]
}
'index' {
continue
}
'---' {
continue
}
'+++' {
continue
}
'@@' {
tmp_change.diff = line
}
else {
if started {
if line.bytes()[0] == `+` {
tmp_change.additions++
}
if line.bytes()[0] == `-` {
tmp_change.deletions++
}
tmp_change.message += '$line\n'
}
}
}
}
changes << tmp_change
return changes
}
fn (mut app App) insert_commit(commit Commit) {
sql app.db {
insert commit into Commit
}
}
fn (mut app App) find_repo_commits(repo_id int) []Commit {
return sql app.db {
select from Commit where repo_id == repo_id limit 10
}
}
fn (mut app App) find_repo_commits_as_page(repo_id int, page int) []Commit {
offs := page * commits_per_page
return sql app.db {
select from Commit where repo_id == repo_id order by created_at desc limit 35 offset offs
}
}
fn (mut app App) nr_repo_commits(repo_id int) int {
return sql app.db {
select count from Commit where repo_id == repo_id
}
}
fn (mut app App) find_repo_commit_by_hash(repo_id int, hash string) Commit {
commits := sql app.db {
select from Commit where repo_id == repo_id && hash == hash
}
if commits.len == 1 {
return commits[0]
}
return Commit{}
}
fn (mut app App) find_repo_last_commit(repo_id int) Commit {
return sql app.db {
select from Commit where repo_id == repo_id order by created_at desc limit 1
}
}
fn (mut app App) find_repo_first_commit(repo_id int) Commit {
return sql app.db {
select from Commit where repo_id == repo_id order by created_at limit 1
}
}
fn (mut app App) find_repo_commits_by_author(repo_id int, author string) []Commit {
return sql app.db {
select from Commit where repo_id == repo_id && author == author limit 10
}
}