mirror of https://github.com/gogits/gogs.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
125 lines
3.0 KiB
125 lines
3.0 KiB
// Copyright 2013 gopm authors. |
|
// |
|
// Licensed under the Apache License, Version 2.0 (the "License"): you may |
|
// not use this file except in compliance with the License. You may obtain |
|
// a copy of the License at |
|
// |
|
// http://www.apache.org/licenses/LICENSE-2.0 |
|
// |
|
// Unless required by applicable law or agreed to in writing, software |
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
|
// License for the specific language governing permissions and limitations |
|
// under the License. |
|
|
|
package doc |
|
|
|
import ( |
|
"fmt" |
|
"go/token" |
|
"net/http" |
|
"os" |
|
"regexp" |
|
"time" |
|
|
|
"github.com/codegangsta/cli" |
|
) |
|
|
|
const ( |
|
TRUNK = "trunk" |
|
MASTER = "master" |
|
DEFAULT = "default" |
|
TAG = "tag" |
|
BRANCH = "branch" |
|
COMMIT = "commit" |
|
LOCAL = "local" |
|
) |
|
|
|
type Pkg struct { |
|
ImportPath string |
|
RootPath string |
|
Type string |
|
Value string // Branch, tag, commit or local. |
|
} |
|
|
|
// If the package is fixed and no need to updated. |
|
// For commit, tag and local, it's fixed. For branch |
|
func (pkg *Pkg) IsFixed() bool { |
|
if pkg.Type == BRANCH || len(pkg.Value) == 0 { |
|
return false |
|
} |
|
return true |
|
} |
|
|
|
func (pkg *Pkg) VerString() string { |
|
if pkg.Value == "" { |
|
return pkg.Type |
|
} |
|
return fmt.Sprintf("%v:%v", pkg.Type, pkg.Value) |
|
} |
|
|
|
func NewPkg(importPath, tp, value string) *Pkg { |
|
return &Pkg{importPath, "", tp, value} |
|
} |
|
|
|
func NewDefaultPkg(importPath string) *Pkg { |
|
return NewPkg(importPath, BRANCH, "") |
|
} |
|
|
|
type Node struct { |
|
Pkg |
|
DownloadURL string |
|
Synopsis string |
|
IsGetDeps bool |
|
IsGetDepsOnly bool |
|
Revision string |
|
} |
|
|
|
func NewNode(importPath, downloadUrl, tp, value string, isGetDeps bool) *Node { |
|
return &Node{ |
|
Pkg: Pkg{ |
|
ImportPath: importPath, |
|
Type: tp, |
|
Value: value, |
|
}, |
|
DownloadURL: downloadUrl, |
|
IsGetDeps: isGetDeps, |
|
} |
|
} |
|
|
|
// source is source code file. |
|
type source struct { |
|
rawURL string |
|
name string |
|
data []byte |
|
} |
|
|
|
func (s *source) Name() string { return s.name } |
|
func (s *source) Size() int64 { return int64(len(s.data)) } |
|
func (s *source) Mode() os.FileMode { return 0 } |
|
func (s *source) ModTime() time.Time { return time.Time{} } |
|
func (s *source) IsDir() bool { return false } |
|
func (s *source) Sys() interface{} { return nil } |
|
|
|
// walker holds the state used when building the documentation. |
|
type walker struct { |
|
ImportPath string |
|
srcs map[string]*source // Source files. |
|
fset *token.FileSet |
|
} |
|
|
|
// service represents a source code control service. |
|
type service struct { |
|
pattern *regexp.Regexp |
|
prefix string |
|
get func(*http.Client, map[string]string, string, *Node, *cli.Context) ([]string, error) |
|
} |
|
|
|
// services is the list of source code control services handled by gopkgdoc. |
|
var services = []*service{ |
|
{githubPattern, "github.com/", getGithubDoc}, |
|
{googlePattern, "code.google.com/", getGoogleDoc}, |
|
{bitbucketPattern, "bitbucket.org/", getBitbucketDoc}, |
|
{launchpadPattern, "launchpad.net/", getLaunchpadDoc}, |
|
{oscPattern, "git.oschina.net/", getOSCDoc}, |
|
}
|
|
|