Documentation ¶
Index ¶
- Constants
- func CountSlashesInProjectFolder(directory string) int
- func Detect(ctx context.Context, patterns []MapPattern, args ...DetecterArg) (Result, DetectorID)
- func Filter(h heartbeat.Heartbeat, config FilterConfig) error
- func FindFileOrDirectory(ctx context.Context, directory, filename string) (string, bool)
- func FormatProjectFolder(ctx context.Context, fp string) string
- func ReadFile(ctx context.Context, fp string, max int) ([]string, error)
- func WithDetection(config Config) heartbeat.HandleOption
- func WithFiltering(config FilterConfig) heartbeat.HandleOption
- func Write(folder, project string) error
- type Config
- type Detecter
- type DetecterArg
- type DetectorID
- type File
- type FilterConfig
- type Git
- type Map
- type MapPattern
- type Mercurial
- type Result
- type Submodule
- type Subversion
- type Tfvc
Constants ¶
const ( // WakaTimeProjectFile is the special file which if present should contain the project name and optional branch name // that will be used instead of the auto-detected project and branch names. WakaTimeProjectFile = ".wakatime-project" )
Variables ¶
This section is empty.
Functions ¶
func CountSlashesInProjectFolder ¶ added in v1.62.1
CountSlashesInProjectFolder counts the number of slashes in a folder path.
func Detect ¶
func Detect(ctx context.Context, patterns []MapPattern, args ...DetecterArg) (Result, DetectorID)
Detect finds the current project and branch from config plugins.
func Filter ¶ added in v1.35.1
func Filter(h heartbeat.Heartbeat, config FilterConfig) error
Filter determines, following the passed in configurations, if a heartbeat should be skipped.
func FindFileOrDirectory ¶ added in v1.18.10
FindFileOrDirectory searches current and all parent folders for a file or directory named `filename`. Starts in `directory` and traverses through all parent directories. `directory` may also be a file, and in that case will start from the file's directory.
func FormatProjectFolder ¶ added in v1.62.1
FormatProjectFolder returns the abs and real path for the given directory path.
func ReadFile ¶ added in v1.73.1
ReadFile reads a file until max number of lines and return an array of lines.
func WithDetection ¶
func WithDetection(config Config) heartbeat.HandleOption
WithDetection finds the current project and branch. First looks for a .wakatime-project file or project map. Second, uses the --project arg. Third, try to auto-detect using a revision control repository. Last, uses the --alternate-project arg.
func WithFiltering ¶ added in v1.35.1
func WithFiltering(config FilterConfig) heartbeat.HandleOption
WithFiltering initializes and returns a heartbeat handle option, which can be used in a heartbeat processing pipeline to filter heartbeats following the provided configurations.
Types ¶
type Config ¶
type Config struct { // HideProjectNames determines if the project name should be obfuscated by matching its path. HideProjectNames []regex.Regex // Patterns contains the overridden project name per path. MapPatterns []MapPattern // ProjectFromGitRemote when enabled uses the git remote as the project name instead of local git folder. ProjectFromGitRemote bool // Submodule contains the submodule configurations. Submodule Submodule }
Config contains project detection configurations.
type DetecterArg ¶ added in v1.45.2
DetecterArg determines for a given path if it needs to run.
type DetectorID ¶ added in v1.45.2
type DetectorID int
DetectorID represents a detector ID.
const ( // UnknownDetector is the detector ID used when not detected. UnknownDetector DetectorID = iota // FileDetector is the detector ID for file detector. FileDetector // MapDetector is the detector ID for map detector. MapDetector // GitDetector is the detector ID for git detector. GitDetector // MercurialDetector is the detector ID for mercurial detector. MercurialDetector // SubversionDetector is the detector ID for subversion detector. SubversionDetector // TfvcDetector is the detector ID for tfvc detector. TfvcDetector )
func (DetectorID) String ¶ added in v1.45.2
func (d DetectorID) String() string
String implements fmt.Stringer interface.
type File ¶
type File struct {
Filepath string
}
File contains file data.
type FilterConfig ¶ added in v1.35.1
type FilterConfig struct { // ExcludeUnknownProject determines if heartbeat should be skipped when the project cannot be detected. ExcludeUnknownProject bool }
FilterConfig contains project filtering configurations.
type Git ¶
type Git struct { // Filepath contains the entity path. Filepath string // ProjectFromGitRemote when enabled uses the git remote as the project name instead of local git folder. ProjectFromGitRemote bool // SubmoduleDisabledPatterns will be matched against the submodule path and if matching, will skip it. SubmoduleDisabledPatterns []regex.Regex // SubmoduleProjectMapPatterns will be matched against the submodule path and if matching, will use the project map. SubmoduleProjectMapPatterns []MapPattern }
Git contains git data.
type Map ¶
type Map struct { Filepath string Patterns []MapPattern }
Map contains map data.
func (Map) Detect ¶
Detect use the ~/.wakatime.cfg file to set custom project names by matching files with regex patterns. Project maps go under the [projectmap] config section.
For example:
[projectmap] /home/user/projects/foo = new project name /home/user/projects/bar(\d+)/ = project{0}
Will result in file '/home/user/projects/foo/src/main.c' to have project name 'new project name' and file '/home/user/projects/bar42/main.c' to have project name 'project42'.
type MapPattern ¶
type MapPattern struct { // Name is the project name. Name string // Regex is the regular expression for a specific path. Regex regex.Regex }
MapPattern contains the project name and regular expression for a specific path.
type Mercurial ¶
type Mercurial struct { // Filepath contains the entity path. Filepath string }
Mercurial contains mercurial data.
type Result ¶
Result contains the result of Detect().
func DetectWithRevControl ¶
func DetectWithRevControl( ctx context.Context, submoduleDisabledPatterns []regex.Regex, submoduleProjectMapPatterns []MapPattern, projectFromGitRemote bool, args ...DetecterArg) Result
DetectWithRevControl finds the current project and branch from rev control.
type Submodule ¶ added in v1.61.0
type Submodule struct { // DisabledPatterns contains the paths to match against submodules // and if matched it will skip the project detection. DisabledPatterns []regex.Regex // MapPatterns contains the overridden project name per path for submodule. MapPatterns []MapPattern }
Submodule contains the submodule configurations.
type Subversion ¶
type Subversion struct { // Filepath contains the entity path. Filepath string }
Subversion contains svn data.