Documentation ¶
Index ¶
- Constants
- func FlagsToString(f int) string
- func MemoryLimiterThread(maxFileSize int)
- type BlockChecker
- type BlockCheckerCreateFunc
- type BlockCheckerDefaults
- type BlockContext
- func (ctx *BlockContext) AddQuickfix(checkName string, fix quickfix.TextEdit)
- func (ctx *BlockContext) ClassParseState() *meta.ClassParseState
- func (ctx *BlockContext) ExprType(e ir.Node) types.Map
- func (ctx *BlockContext) File() *workspace.File
- func (ctx *BlockContext) Filename() string
- func (ctx *BlockContext) IsRootLevel() bool
- func (ctx *BlockContext) IsStatement(n ir.Node) bool
- func (ctx *BlockContext) NodePath() irutil.NodePath
- func (ctx *BlockContext) PrematureExitFlags() int
- func (ctx *BlockContext) Report(n ir.Node, level int, checkName, msg string, args ...interface{})
- func (ctx *BlockContext) ReportLocation(location ir.Location, level int, checkName, msg string, args ...interface{})
- func (ctx *BlockContext) ReportPHPDoc(phpDocLocation PHPDocLocation, level int, checkName, msg string, ...)
- func (ctx *BlockContext) RootState() map[string]interface{}
- func (ctx *BlockContext) Scope() *meta.Scope
- type CheckerInfo
- type CheckersFilter
- type CheckersRegistry
- func (reg *CheckersRegistry) AddBlockChecker(c BlockCheckerCreateFunc)
- func (reg *CheckersRegistry) AddRootChecker(c RootCheckerCreateFunc)
- func (reg *CheckersRegistry) AddRootCheckerWithCacher(cacher MetaCacher, c RootCheckerCreateFunc)
- func (reg *CheckersRegistry) Contains(name string) bool
- func (reg *CheckersRegistry) DeclareChecker(info CheckerInfo)
- func (reg *CheckersRegistry) DeclareRules(rset *rules.Set)
- func (reg *CheckersRegistry) ListDeclared() []CheckerInfo
- type Config
- type Linter
- func (l *Linter) AnalyzeFiles(readFileNamesFunc workspace.ReadCallback) []*Report
- func (l *Linter) Config() *Config
- func (l *Linter) InitStubs(readFileNamesFunc workspace.ReadCallback)
- func (l *Linter) InitStubsFromDir(dir string)
- func (l *Linter) MetaInfo() *meta.Info
- func (l *Linter) NewIndexingWorker(id int) *Worker
- func (l *Linter) NewLintingWorker(id int) *Worker
- func (l *Linter) UseCheckersFilter(checks *CheckersFilter)
- type MetaCacher
- type PHPDocError
- type PHPDocErrors
- type PHPDocLocation
- type ParseResult
- type QuickFixGenerator
- type Report
- type RootChecker
- type RootCheckerCreateFunc
- type RootCheckerDefaults
- type RootContext
- func (ctx *RootContext) ClassParseState() *meta.ClassParseState
- func (ctx *RootContext) File() *workspace.File
- func (ctx *RootContext) Filename() string
- func (ctx *RootContext) ParsePHPDoc(doc string) phpdoc.Comment
- func (ctx *RootContext) Report(n ir.Node, level int, checkName, msg string, args ...interface{})
- func (ctx *RootContext) ReportLocation(location ir.Location, level int, checkName, msg string, args ...interface{})
- func (ctx *RootContext) ReportPHPDoc(phpDocLocation PHPDocLocation, level int, checkName, msg string, ...)
- func (ctx *RootContext) Scope() *meta.Scope
- func (ctx *RootContext) State() map[string]interface{}
- type Worker
- type WorkerContext
Constants ¶
const ( // FlagReturn shows whether or not block has "return" FlagReturn = 1 << iota FlagBreak FlagContinue FlagThrow FlagDie )
const ( LevelError = lintapi.LevelError LevelWarning = lintapi.LevelWarning LevelNotice = lintapi.LevelNotice LevelSecurity = lintapi.LevelSecurity // Like warning, but reported without a context line )
const (
// IgnoreLinterMessage is a commit message that you specify if you want to cancel linter checks for this changeset
IgnoreLinterMessage = "@linter disable"
)
Variables ¶
This section is empty.
Functions ¶
func FlagsToString ¶
FlagsToString is designed for debugging flags.
func MemoryLimiterThread ¶
func MemoryLimiterThread(maxFileSize int)
MemoryLimiterThread starts memory limiter goroutine that disallows to use parse files more than maxFileSize total bytes.
Types ¶
type BlockChecker ¶
type BlockChecker interface { BeforeEnterNode(ir.Node) AfterEnterNode(ir.Node) BeforeLeaveNode(ir.Node) AfterLeaveNode(ir.Node) }
BlockChecker is a custom linter that is called on block level
type BlockCheckerCreateFunc ¶
type BlockCheckerCreateFunc func(*BlockContext) BlockChecker
BlockCheckerCreateFunc is a factory function for BlockChecker
type BlockCheckerDefaults ¶
type BlockCheckerDefaults struct{}
BlockCheckerDefaults is a type for embedding into checkers to get default (empty) BlockChecker implementations.
You can "override" any required methods while ignoring the others.
The benefit is higher backwards-compatibility. If new methods are added to BlockChecker, you wouldn't need to change your code right away (especially if you don't need a new hook).
func (BlockCheckerDefaults) AfterEnterNode ¶
func (BlockCheckerDefaults) AfterEnterNode(ir.Node)
func (BlockCheckerDefaults) AfterLeaveNode ¶
func (BlockCheckerDefaults) AfterLeaveNode(ir.Node)
func (BlockCheckerDefaults) BeforeEnterNode ¶
func (BlockCheckerDefaults) BeforeEnterNode(ir.Node)
func (BlockCheckerDefaults) BeforeLeaveNode ¶
func (BlockCheckerDefaults) BeforeLeaveNode(ir.Node)
type BlockContext ¶
type BlockContext struct {
// contains filtered or unexported fields
}
BlockContext is the context for block checker.
func (*BlockContext) AddQuickfix ¶ added in v0.3.0
func (ctx *BlockContext) AddQuickfix(checkName string, fix quickfix.TextEdit)
AddQuickfix adds a new quick fix.
func (*BlockContext) ClassParseState ¶
func (ctx *BlockContext) ClassParseState() *meta.ClassParseState
ClassParseState returns class parse state (namespace, class, etc).
func (*BlockContext) ExprType ¶ added in v0.3.0
func (ctx *BlockContext) ExprType(e ir.Node) types.Map
ExprType resolves the type of e expression node.
func (*BlockContext) File ¶ added in v0.3.0
func (ctx *BlockContext) File() *workspace.File
File returns the file being analyzed.
func (*BlockContext) Filename ¶
func (ctx *BlockContext) Filename() string
Filename returns the file name of the file being analyzed.
func (*BlockContext) IsRootLevel ¶
func (ctx *BlockContext) IsRootLevel() bool
IsRootLevel reports whether we are analysing root-level code currently.
func (*BlockContext) IsStatement ¶
func (ctx *BlockContext) IsStatement(n ir.Node) bool
IsStatement reports whether or not specified node is a statement.
func (*BlockContext) NodePath ¶ added in v0.3.0
func (ctx *BlockContext) NodePath() irutil.NodePath
NodePath returns a node path up to the current traversal position. The path includes the node that is being traversed as well.
func (*BlockContext) PrematureExitFlags ¶
func (ctx *BlockContext) PrematureExitFlags() int
func (*BlockContext) Report ¶
func (ctx *BlockContext) Report(n ir.Node, level int, checkName, msg string, args ...interface{})
Report records linter warning of specified level. chechName is a key that identifies the "checker" (diagnostic name) that found issue being reported.
func (*BlockContext) ReportLocation ¶ added in v0.4.0
func (ctx *BlockContext) ReportLocation(location ir.Location, level int, checkName, msg string, args ...interface{})
ReportLocation records linter warning in specified location of specified level. checkName is a key that identifies the "checker" (diagnostic name) that found issue being reported.
func (*BlockContext) ReportPHPDoc ¶ added in v0.4.0
func (ctx *BlockContext) ReportPHPDoc(phpDocLocation PHPDocLocation, level int, checkName, msg string, args ...interface{})
ReportPHPDoc records linter warning in PHPDoc of specified level. checkName is a key that identifies the "checker" (diagnostic name) that found issue being reported.
func (*BlockContext) RootState ¶
func (ctx *BlockContext) RootState() map[string]interface{}
RootState returns state from root context.
func (*BlockContext) Scope ¶
func (ctx *BlockContext) Scope() *meta.Scope
Scope returns variables declared in this block.
type CheckerInfo ¶ added in v0.4.0
type CheckerInfo struct { // Name is a diagnostic short name. // If several words are needed, prefer camelCase. Name string // Default controls whether diagnostic is // enabled by default or it should be included by allow-checks explicitly. Default bool // Quickfix tells whether this checker can automatically fix the reported // issues when linter works in -fix mode. Quickfix bool // Comment is a short summary of what this diagnostic does. // A single descriptive sentence is a perfect format for it. Comment string // Before is a non-compliant code example (before the fix). // Optional, but if present, After should also be non-empty. Before string // After is a compliant code example (after the fix). // Optional, but if present, Before should also be non-empty. After string // Extends tells the check is created by a dynamic rule that // extends the internal linter rule. Extends bool }
CheckerInfo provides a single checker (diagnostic) metadata.
This structure may change with different revisions of noverify and get new fields that may be used by the linter.
type CheckersFilter ¶ added in v0.4.0
type CheckersFilter struct { All []CheckerInfo EnableAll bool Allowed map[string]bool Excluded map[string]bool Critical map[string]bool ExcludeFileRegexp *regexp.Regexp }
func NewCheckersFilter ¶ added in v0.4.0
func NewCheckersFilter() *CheckersFilter
func NewCheckersFilterWithEnabledAll ¶ added in v0.4.0
func NewCheckersFilterWithEnabledAll() *CheckersFilter
func (*CheckersFilter) IsCriticalReport ¶ added in v0.4.0
func (c *CheckersFilter) IsCriticalReport(r *Report) bool
func (*CheckersFilter) IsEnabledCheck ¶ added in v0.4.0
func (c *CheckersFilter) IsEnabledCheck(checkName string) bool
func (*CheckersFilter) IsEnabledReport ¶ added in v0.4.0
func (c *CheckersFilter) IsEnabledReport(checkName, fileName string) bool
type CheckersRegistry ¶ added in v0.4.0
type CheckersRegistry struct {
// contains filtered or unexported fields
}
func (*CheckersRegistry) AddBlockChecker ¶ added in v0.4.0
func (reg *CheckersRegistry) AddBlockChecker(c BlockCheckerCreateFunc)
AddBlockChecker registers a custom block linter that will be used on block level.
func (*CheckersRegistry) AddRootChecker ¶ added in v0.4.0
func (reg *CheckersRegistry) AddRootChecker(c RootCheckerCreateFunc)
AddRootChecker registers a custom root linter that will be used on root level.
Root checker indexing phase is expected to be stateless. If indexing results need to be saved (and cached), use RegisterRootCheckerWithCacher.
func (*CheckersRegistry) AddRootCheckerWithCacher ¶ added in v0.4.0
func (reg *CheckersRegistry) AddRootCheckerWithCacher(cacher MetaCacher, c RootCheckerCreateFunc)
AddRootCheckerWithCacher registers a custom root linter that will be used on root level. Specified cacher is used to save (and load) indexing phase results.
func (*CheckersRegistry) Contains ¶ added in v0.4.0
func (reg *CheckersRegistry) Contains(name string) bool
Contains checks the presence of a checker with the given name.
func (*CheckersRegistry) DeclareChecker ¶ added in v0.4.0
func (reg *CheckersRegistry) DeclareChecker(info CheckerInfo)
DeclareChecker declares a checker described by an info. It's a good practice to declare *all* provided checks.
If checker is not declared, for example, there is no way to make it enabled by default.
func (*CheckersRegistry) DeclareRules ¶ added in v0.4.0
func (reg *CheckersRegistry) DeclareRules(rset *rules.Set)
func (*CheckersRegistry) ListDeclared ¶ added in v0.4.0
func (reg *CheckersRegistry) ListDeclared() []CheckerInfo
ListDeclared returns a list of all checkers that were declared. Slice is sorted by checker names.
type Config ¶ added in v0.4.0
type Config struct { // BaselineProfile is a suppression database for warnings. // Nil profile is an empty suppression profile. BaselineProfile *baseline.Profile ComputeBaselineHashes bool // Whether we need to compute report hashes ConservativeBaseline bool ApplyQuickFixes bool // KPHP tells whether we're working in KPHP-compatible mode. KPHP bool CacheDir string // TypoFixer is a rule set for English typos correction. // If nil, no misspell checking is performed. // See github.com/client9/misspell for details. TypoFixer *misspell.Replacer // SrcInput implements source code reading from files and buffers. SrcInput inputs.SourceInput // Rules is a set of dynamically loaded linter diagnostics. Rules *rules.Set StubsDir string Debug bool // MaxConcurrency limits the linter concurrency. MaxConcurrency int // DebugParseDuration specifies the minimum parse duration for it to be printed to debug output. DebugParseDuration time.Duration CheckAutoGenerated bool IsDiscardVar func(varname string) bool ExcludeRegex *regexp.Regexp AllowDisable *regexp.Regexp PhpExtensions []string Checkers *CheckersRegistry IgnoreTriggerError bool PhpVersion *version.Version StrictMixed bool }
type Linter ¶ added in v0.4.0
type Linter struct {
// contains filtered or unexported fields
}
func NewLinterWithInfo ¶ added in v0.4.0
func (*Linter) AnalyzeFiles ¶ added in v0.4.0
func (l *Linter) AnalyzeFiles(readFileNamesFunc workspace.ReadCallback) []*Report
AnalyzeFiles runs linter on the files that are provided by the readFileNamesFunc function.
func (*Linter) InitStubs ¶ added in v0.4.0
func (l *Linter) InitStubs(readFileNamesFunc workspace.ReadCallback)
func (*Linter) InitStubsFromDir ¶ added in v0.4.0
InitStubsFromDir parses directory with PHPStorm stubs which has all internal PHP classes and functions declared.
func (*Linter) NewIndexingWorker ¶ added in v0.4.0
func (*Linter) NewLintingWorker ¶ added in v0.4.0
func (*Linter) UseCheckersFilter ¶ added in v0.4.0
func (l *Linter) UseCheckersFilter(checks *CheckersFilter)
type MetaCacher ¶
type MetaCacher interface { // Version returns a unique cache version identifier. // When underlying cache structure is updated, version // should return different value. // // Preferably something unique, prefixed with a vendor // name, like `mylints-1.0.0` or `extension-abc4`. // // Returned value is written before Encode() is called to // the same writer. It's also read from the reader before // Decode() is invoked. Version() string // Encode stores custom meta cache part data into provided writer. // RootChecker is expected to carry the necessary indexing phase results. Encode(io.Writer, RootChecker) error // Decode loads custom meta cache part data from provided reader. // Those results are used insted of running the associated indexer. Decode(r io.Reader, filename string) error }
MetaCacher is an interface for integrating checker-specific indexing results into NoVerify cache.
Usually, every vendor contains a global meta object that can implement MetaCacher and be associated with a relevant root checker.
type PHPDocError ¶ added in v0.4.0
type PHPDocError struct { Location PHPDocLocation Message string }
type PHPDocErrors ¶ added in v0.4.0
type PHPDocErrors struct {
// contains filtered or unexported fields
}
type PHPDocLocation ¶ added in v0.4.0
type PHPDocLocation struct { Node ir.Node Line int Field int WholeLine bool // RelativeLine is set if the line number is relative to the // given node; otherwise, the line number is considered to be // absolute and can be used directly. RelativeLine bool }
func PHPDocAbsoluteLine ¶ added in v0.4.0
func PHPDocAbsoluteLine(line int) PHPDocLocation
func PHPDocAbsoluteLineField ¶ added in v0.4.0
func PHPDocAbsoluteLineField(line int, field int) PHPDocLocation
func PHPDocLine ¶ added in v0.4.0
func PHPDocLine(n ir.Node, line int) PHPDocLocation
func PHPDocLineField ¶ added in v0.4.0
func PHPDocLineField(n ir.Node, line int, field int) PHPDocLocation
type ParseResult ¶ added in v0.4.0
type QuickFixGenerator ¶ added in v0.5.0
type QuickFixGenerator struct {
// contains filtered or unexported fields
}
func NewQuickFixGenerator ¶ added in v0.5.0
func NewQuickFixGenerator(file *workspace.File) *QuickFixGenerator
func (*QuickFixGenerator) Array ¶ added in v0.5.0
func (g *QuickFixGenerator) Array(arr *ir.ArrayExpr) quickfix.TextEdit
func (*QuickFixGenerator) NullForNotNullableProperty ¶ added in v0.5.0
func (g *QuickFixGenerator) NullForNotNullableProperty(prop *ir.PropertyStmt) quickfix.TextEdit
type Report ¶
type Report struct { CheckName string `json:"check_name"` Level int `json:"level"` Context string `json:"context"` Message string `json:"message"` Filename string `json:"filename"` Line int `json:"line"` StartChar int `json:"start_char"` EndChar int `json:"end_char"` Hash uint64 `json:"hash"` }
Report is a linter report message.
func DiffReports ¶
func DiffReports(gitRepo string, diffArgs []string, changesList []git.Change, changeLog []git.Commit, oldList, newList []*Report, maxConcurrency int) (res []*Report, err error)
DiffReports returns only reports that are new. Pass diffArgs=nil if we are called from diff in working copy.
func (*Report) IsCritical ¶
IsCritical returns whether or not we need to reject whole commit when found this kind of report.
type RootChecker ¶
type RootChecker interface { BeforeEnterFile() AfterLeaveFile() BeforeEnterNode(ir.Node) AfterEnterNode(ir.Node) BeforeLeaveNode(ir.Node) AfterLeaveNode(ir.Node) }
RootChecker is a custom linter that should operator only at root level. Block level analysis (function and method bodies and all if/else/for/etc blocks) must be performed in BlockChecker.
type RootCheckerCreateFunc ¶
type RootCheckerCreateFunc func(*RootContext) RootChecker
RootCheckerCreateFunc is a factory function for RootChecker
type RootCheckerDefaults ¶
type RootCheckerDefaults struct{}
RootCheckerDefaults is a type for embedding into checkers to get default (empty) RootChecker implementations.
You can "override" any required methods while ignoring the others.
The benefit is higher backwards-compatibility. If new methods are added to RootChecker, you wouldn't need to change your code right away (especially if you don't need a new hook).
func (RootCheckerDefaults) AfterEnterNode ¶
func (RootCheckerDefaults) AfterEnterNode(ir.Node)
func (RootCheckerDefaults) AfterLeaveFile ¶
func (RootCheckerDefaults) AfterLeaveFile()
func (RootCheckerDefaults) AfterLeaveNode ¶
func (RootCheckerDefaults) AfterLeaveNode(ir.Node)
func (RootCheckerDefaults) BeforeEnterFile ¶ added in v0.3.0
func (RootCheckerDefaults) BeforeEnterFile()
func (RootCheckerDefaults) BeforeEnterNode ¶
func (RootCheckerDefaults) BeforeEnterNode(ir.Node)
func (RootCheckerDefaults) BeforeLeaveNode ¶
func (RootCheckerDefaults) BeforeLeaveNode(ir.Node)
type RootContext ¶
type RootContext struct {
// contains filtered or unexported fields
}
RootContext is the context for root checker to run on.
func (*RootContext) ClassParseState ¶
func (ctx *RootContext) ClassParseState() *meta.ClassParseState
ClassParseState returns class parse state (namespace, class, etc).
func (*RootContext) File ¶ added in v0.3.0
func (ctx *RootContext) File() *workspace.File
File returns analyzed file.
Experimental API.
func (*RootContext) Filename ¶
func (ctx *RootContext) Filename() string
Filename returns the file name of the file being analyzed.
func (*RootContext) ParsePHPDoc ¶ added in v0.3.0
func (ctx *RootContext) ParsePHPDoc(doc string) phpdoc.Comment
ParsePHPDoc returns parsed phpdoc comment parts.
func (*RootContext) Report ¶
func (ctx *RootContext) Report(n ir.Node, level int, checkName, msg string, args ...interface{})
Report records linter warning of specified level. checkName is a key that identifies the "checker" (diagnostic name) that found issue being reported.
func (*RootContext) ReportLocation ¶ added in v0.4.0
func (ctx *RootContext) ReportLocation(location ir.Location, level int, checkName, msg string, args ...interface{})
ReportLocation records linter warning in specified location of specified level. checkName is a key that identifies the "checker" (diagnostic name) that found issue being reported.
func (*RootContext) ReportPHPDoc ¶ added in v0.4.0
func (ctx *RootContext) ReportPHPDoc(phpDocLocation PHPDocLocation, level int, checkName, msg string, args ...interface{})
ReportPHPDoc records linter warning in PHPDoc of specified level. checkName is a key that identifies the "checker" (diagnostic name) that found issue being reported.
func (*RootContext) Scope ¶
func (ctx *RootContext) Scope() *meta.Scope
Scope returns variables declared at root level.
func (*RootContext) State ¶
func (ctx *RootContext) State() map[string]interface{}
State returns state that can be modified and passed into block context
type Worker ¶ added in v0.3.0
Worker is a linter handle that is expected to be executed in a single goroutine context.
It's not thread-safe and contains the state that will be re-used between the linter API calls.
See NewLintingWorker and NewIndexingWorker.
func (*Worker) IndexFile ¶ added in v0.3.0
IndexFile parses the file and fills in the meta info. Can use cache.
func (*Worker) ParseContents ¶ added in v0.3.0
func (w *Worker) ParseContents(fileInfo workspace.FileInfo) (result ParseResult, err error)
ParseContents parses specified contents (or file) and returns *RootWalker. Function does not update global meta.
type WorkerContext ¶ added in v0.3.0
type WorkerContext struct {
// contains filtered or unexported fields
}
WorkerContext is a state that is shared between all worker-owned RootWalker's and BlockWalker's.
A worker is a separate goroutine that processed the incoming files.
Since workerContext is worker-bound, that state is never accessed from different threads, so we can re-use it without synchronization.
func NewWorkerContext ¶ added in v0.3.0
func NewWorkerContext() *WorkerContext
Source Files ¶
- and_walker.go
- block.go
- block_context.go
- block_linter.go
- block_utils.go
- cache.go
- checks.go
- conf.go
- custom.go
- fmtstring.go
- limits.go
- linter.go
- phpdoc_util.go
- quickfix.go
- regexpsimplify.go
- regexpvet.go
- report.go
- root.go
- root_checker.go
- root_context.go
- superglobals.go
- utils.go
- worker.go
- worker_context.go