|
|
@ -10,15 +10,14 @@ import ( |
|
|
|
"strings" |
|
|
|
"strings" |
|
|
|
|
|
|
|
|
|
|
|
"github.com/Unknwon/macaron" |
|
|
|
"github.com/Unknwon/macaron" |
|
|
|
|
|
|
|
"github.com/mcuadros/go-version" |
|
|
|
|
|
|
|
"github.com/mssola/user_agent" |
|
|
|
|
|
|
|
|
|
|
|
"github.com/gogits/gogs/models" |
|
|
|
"github.com/gogits/gogs/models" |
|
|
|
"github.com/gogits/gogs/modules/base" |
|
|
|
"github.com/gogits/gogs/modules/base" |
|
|
|
"github.com/gogits/gogs/modules/git" |
|
|
|
"github.com/gogits/gogs/modules/git" |
|
|
|
"github.com/gogits/gogs/modules/log" |
|
|
|
"github.com/gogits/gogs/modules/log" |
|
|
|
"github.com/gogits/gogs/modules/setting" |
|
|
|
"github.com/gogits/gogs/modules/setting" |
|
|
|
|
|
|
|
|
|
|
|
"github.com/hashicorp/go-version" |
|
|
|
|
|
|
|
"github.com/mssola/user_agent" |
|
|
|
|
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
const ( |
|
|
|
const ( |
|
|
@ -355,22 +354,11 @@ func RepoAssignment(redirect bool, args ...bool) macaron.Handler { |
|
|
|
ctx.Data["CommitId"] = ctx.Repo.CommitId |
|
|
|
ctx.Data["CommitId"] = ctx.Repo.CommitId |
|
|
|
|
|
|
|
|
|
|
|
userAgent := ctx.Req.Header.Get("User-Agent") |
|
|
|
userAgent := ctx.Req.Header.Get("User-Agent") |
|
|
|
ua := user_agent.New(userAgent); |
|
|
|
ua := user_agent.New(userAgent) |
|
|
|
browserName, browserVer := ua.Browser() |
|
|
|
browserName, browserVer := ua.Browser() |
|
|
|
|
|
|
|
|
|
|
|
sliceVer := strings.Split(browserVer, ".") |
|
|
|
ctx.Data["BrowserSupportsCopy"] = (browserName == "Chrome" && version.Compare(browserVer, CHROME_COPY_SUPPORT, ">=")) || |
|
|
|
var max int |
|
|
|
(browserName == "Firefox" && version.Compare(browserVer, FIREFOX_COPY_SUPPORT, ">=")) |
|
|
|
if max = len(sliceVer); 3 < max { |
|
|
|
|
|
|
|
max = 3 |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
browserVer = strings.Join(sliceVer[:max], ".") |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
browserVersion, err := version.NewVersion(browserVer) |
|
|
|
|
|
|
|
chromeConstraint, err := version.NewConstraint(">= " + CHROME_COPY_SUPPORT) |
|
|
|
|
|
|
|
firefoxConstraint, err := version.NewConstraint(">= " + FIREFOX_COPY_SUPPORT) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ctx.Data["BrowserSupportsCopy"] = (browserName == "Chrome" && chromeConstraint.Check(browserVersion)) || (browserName == "Firefox" && firefoxConstraint.Check(browserVersion)) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|