本文整理匯總了Golang中github.com/Unknwon/com.Expand函數的典型用法代碼示例。如果您正苦於以下問題:Golang Expand函數的具體用法?Golang Expand怎麽用?Golang Expand使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Expand函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: msgWrite
func (as *ArticleService) msgWrite(isUpdate bool, article *model.Article) {
data := map[string]string{
"type": fmt.Sprint(model.MESSAGE_TYPE_ARTICLE_CREATE),
"author": article.User().Name,
"link": article.Href(),
"title": article.Title,
"time": utils.TimeUnixFormat(article.CreateTime, "01/02 15:04:05"),
}
var body string
if isUpdate {
data["type"] = fmt.Sprint(model.MESSAGE_TYPE_ARTICLE_UPDATE)
data["time"] = utils.TimeUnixFormat(article.UpdateTime, "01/02 15:04:05")
body = com.Expand(MessageArticleUpdateTemplate, data)
} else {
body = com.Expand(MessageArticleCreateTemplate, data)
}
message := &model.Message{
UserId: article.UserId,
From: model.MESSAGE_FROM_ARTICLE,
FromId: article.Id,
Type: model.MESSAGE_TYPE_ARTICLE_CREATE,
Body: body,
CreateTime: article.CreateTime,
}
if isUpdate {
message.Type = model.MESSAGE_TYPE_ARTICLE_UPDATE
}
Message.Save(message)
}
示例2: msgSave
func (cs *CommentService) msgSave(cmt *model.Comment) {
data := map[string]string{
"type": fmt.Sprint(model.MESSAGE_TYPE_COMMENT_CREATE),
"time": utils.TimeUnixFormat(cmt.CreateTime, "01/02 15:04:05"),
"author": cmt.Name,
"site": cmt.AuthorUrl(),
"body": cmt.Body,
"title": cmt.FromTitle(),
}
message := &model.Message{
UserId: cmt.UserId,
From: model.MESSAGE_FROM_COMMENT,
FromId: cmt.Id,
Type: model.MESSAGE_TYPE_COMMENT_CREATE,
CreateTime: cmt.CreateTime,
}
if cmt.ParentId > 0 {
if p := cmt.GetParent(); p != nil {
data["parent"] = p.Name
data["parent_content"] = p.Body
fmt.Println("--------------", p)
message.Type = model.MESSAGE_TYPE_COMMENT_REPLY
message.Body = com.Expand(MessageCommentReplyTemplate, data)
Message.Save(message)
return
}
}
message.Body = com.Expand(MessageCommentLeaveTemplate, data)
Message.Save(message)
}
示例3: getDynamic
func getDynamic(importPath, etag string) (pdoc *Package, err error) {
match, err := fetchMeta(importPath)
if err != nil {
return nil, err
}
if match["projectRoot"] != importPath {
rootMatch, err := fetchMeta(match["projectRoot"])
if err != nil {
return nil, err
}
if rootMatch["projectRoot"] != match["projectRoot"] {
return nil, errors.New("Project root mismatch")
}
}
pdoc, err = getStatic(com.Expand("{repo}{dir}", match), etag)
// if err == ErrNoServiceMatch {
// pdoc, err = getVCSDoc(client, match, etag)
// }
if err != nil {
return nil, err
}
if pdoc != nil {
pdoc.ImportPath = importPath
pdoc.ProjectPath = importPath
// pdoc.ProjectName = match["projectName"]
}
return pdoc, err
}
示例4: earlyResponseForGoGetMeta
// earlyResponseForGoGetMeta responses appropriate go-get meta with status 200
// if user does not have actual access to the requested repository,
// or the owner or repository does not exist at all.
// This is particular a workaround for "go get" command which does not respect
// .netrc file.
func earlyResponseForGoGetMeta(ctx *Context) {
ctx.PlainText(200, []byte(com.Expand(`<meta name="go-import" content="{GoGetImport} git {CloneLink}">`,
map[string]string{
"GoGetImport": composeGoGetImport(ctx.Params(":username"), ctx.Params(":reponame")),
"CloneLink": models.ComposeHTTPSCloneURL(ctx.Params(":username"), ctx.Params(":reponame")),
})))
}
示例5: msgDelete
func (as *ArticleService) msgDelete(id int64) {
article := new(model.Article)
if _, err := core.Db.Where("id = ?", id).Get(article); err != nil {
return
}
if article == nil || article.Id != id {
return
}
data := map[string]string{
"type": fmt.Sprint(model.MESSAGE_TYPE_ARTICLE_REMOVE),
"author": article.User().Name,
"title": article.Title,
"time": utils.TimeUnixFormat(article.CreateTime, "01/02 15:04:05"),
}
body := com.Expand(MessageArticleRemoveTemplate, data)
message := &model.Message{
UserId: article.UserId,
From: model.MESSAGE_FROM_ARTICLE,
FromId: article.Id,
Type: model.MESSAGE_TYPE_ARTICLE_REMOVE,
Body: body,
CreateTime: article.CreateTime,
}
Message.Save(message)
}
示例6: getDynamic
func getDynamic(client *http.Client, importPath, tag, etag string) (pdoc *hv.Package, err error) {
match, err := fetchMeta(client, importPath)
if err != nil {
return nil, err
}
if match["projectRoot"] != importPath {
rootMatch, err := fetchMeta(client, match["projectRoot"])
if err != nil {
return nil, err
}
if rootMatch["projectRoot"] != match["projectRoot"] {
return nil, com.NotFoundError{"Project root mismatch."}
}
}
pdoc, err = getStatic(client, com.Expand("{repo}{dir}", match), tag, etag)
if err == errNoMatch {
//pdoc, err = getVCSDoc(client, match, etag)
}
if err != nil {
return nil, err
}
if pdoc != nil {
pdoc.ImportPath = importPath
pdoc.ProjectName = match["projectName"]
}
return pdoc, err
}
示例7: RenderIssueIndexPattern
// RenderIssueIndexPattern renders issue indexes to corresponding links.
func RenderIssueIndexPattern(rawBytes []byte, urlPrefix string, metas map[string]string) []byte {
urlPrefix = cutoutVerbosePrefix(urlPrefix)
pattern := IssueNumericPattern
if metas["style"] == ISSUE_NAME_STYLE_ALPHANUMERIC {
pattern = IssueAlphanumericPattern
}
ms := pattern.FindAll(rawBytes, -1)
for _, m := range ms {
if m[0] == ' ' || m[0] == '(' {
m = m[1:] // ignore leading space or opening parentheses
}
var link string
if metas == nil {
link = fmt.Sprintf(`<a href="%s/issues/%s">%s</a>`, urlPrefix, m[1:], m)
} else {
// Support for external issue tracker
if metas["style"] == ISSUE_NAME_STYLE_ALPHANUMERIC {
metas["index"] = string(m)
} else {
metas["index"] = string(m[1:])
}
link = fmt.Sprintf(`<a href="%s">%s</a>`, com.Expand(metas["format"], metas), m)
}
rawBytes = bytes.Replace(rawBytes, m, []byte(link), 1)
}
return rawBytes
}
示例8: getDynamic
func getDynamic(importPath, etag string) (pdoc *Package, err error) {
match, err := fetchMeta(importPath)
if err != nil {
return nil, err
}
if match["projectRoot"] != importPath {
rootMatch, err := fetchMeta(match["projectRoot"])
if err != nil {
return nil, err
}
if rootMatch["projectRoot"] != match["projectRoot"] {
return nil, errors.New("Project root mismatch")
}
}
if strings.HasPrefix(match["repo"], "go.googlesource.com") {
match["dir"] = "/" + path.Base(match["repo"])
match["repo"] = "github.com/golang"
}
pdoc, err = getStatic(com.Expand("{repo}{dir}", match), etag)
if err == ErrNoServiceMatch {
pdoc, err = getVCSDoc(match, etag)
} else if pdoc != nil {
pdoc.ImportPath = importPath
}
if err != nil {
return nil, err
}
return pdoc, err
}
示例9: renderEditPage
func renderEditPage(ctx *middleware.Context, documentPath string) {
if setting.Extension.EnableEditPage {
ctx.Data["EditPageLink"] = com.Expand(setting.Extension.EditPageLinkFormat, map[string]string{
"lang": ctx.Locale.Language(),
"blob": documentPath + ".md",
})
}
}
示例10: NewSearch
func NewSearch(key string) (*SearchPackages, error) {
url := com.Expand(searchApi, map[string]string{
"keyword": key,
})
packages := new(SearchPackages)
err := com.HttpGetJSON(httpClient, url, packages)
return packages, err
}
示例11: ExampleExpand
func ExampleExpand() {
match := map[string]string{
"domain": "gowalker.org",
"subdomain": "github.com",
}
s := "http://{domain}/{subdomain}/{0}/{1}"
fmt.Println(com.Expand(s, match, "Unknwon", "gowalker"))
// Output: http://gowalker.org/github.com/Unknwon/gowalker
}
示例12: getBitbucketArchive
func getBitbucketArchive(client *http.Client, match map[string]string, n *Node) error {
match["sha"] = n.Revision
// Downlaod archive.
if err := com.HttpGetToFile(client,
com.Expand("https://bitbucket.org/{owner}/{repo}/get/{sha}.zip", match), nil, n.ArchivePath); err != nil {
return fmt.Errorf("fail to download archive(%s): %v", n.ImportPath, err)
}
return nil
}
示例13: GetMission
func (r *Rpc) GetMission(args *HostInfo, rep *Mission) error {
log.Debugf("arch: %v, host: %v", args.Arch, args.Host)
tasks, err := models.GetAvaliableTasks(args.Os, args.Arch)
if err == models.ErrTaskNotAvaliable {
rep.Idle = time.Second * 3
return nil
}
if err != nil {
log.Errorf("rpc: get mission error: %v", err)
return err
}
task := tasks[0] // use first task
rep.Mid = task.Id
rep.Repo = task.Repo
rep.PushURI = task.PushType + ":" + task.PushValue
rep.CgoEnable = task.CgoEnable
rep.PkgInfo, _ = json.MarshalIndent(PkgInfo{
PushURI: task.PushType + ":" + task.PushValue,
Author: []string{"unknown"},
Description: "unknown",
}, "", " ")
for _, tk := range tasks {
if tk.TagBranch == "" {
tk.TagBranch = "temp-" + tk.PushType + ":" + tk.PushValue
}
filename := fmt.Sprintf("%s-%s-%s.%s", filepath.Base(rep.Repo.Uri), tk.Os, tk.Arch, "zip")
if tk.Action == models.AC_SRCPKG {
filename = fmt.Sprintf("%s-all-source.%s", filepath.Base(rep.Repo.Uri), "zip")
}
key := com.Expand("m{tid}/{reponame}/br-{branch}/{filename}", map[string]string{
"tid": strconv.Itoa(int(rep.Mid)),
"reponame": rep.Repo.Uri,
"branch": tk.TagBranch,
"filename": filename,
})
bi := BuildInfo{
Action: tk.Action,
Os: tk.Os,
Arch: tk.Arch,
UploadType: UT_QINIU,
UploadData: base.Objc2Str(QiniuInfo{
Bulket: defaultBulket,
Key: key,
Token: qntoken(key),
}),
}
rep.Builds = append(rep.Builds, bi)
}
return nil
}
示例14: getGoogleVCS
func getGoogleVCS(client *http.Client, match map[string]string) error {
// Scrape the HTML project page to find the VCS.
p, err := com.HttpGetBytes(client, com.Expand("http://code.google.com/p/{repo}/source/checkout", match), nil)
if err != nil {
return errors.New("doc.getGoogleVCS(" + match["importPath"] + ") -> " + err.Error())
}
m := googleRepoRe.FindSubmatch(p)
if m == nil {
return com.NotFoundError{"Could not VCS on Google Code project page."}
}
match["vcs"] = string(m[1])
return nil
}
示例15: getGoogleVCS
func getGoogleVCS(client *http.Client, match map[string]string) error {
// Scrape the HTML project page to find the VCS.
p, err := com.HttpGetBytes(client, com.Expand("http://code.google.com/p/{repo}/source/checkout", match), nil)
if err != nil {
return fmt.Errorf("fail to fetch page: %v", err)
}
m := googleRepoRe.FindSubmatch(p)
if m == nil {
return com.NotFoundError{"Could not VCS on Google Code project page."}
}
match["vcs"] = string(m[1])
return nil
}