Skip to main content
Glama

protolint-mcp

by yoheimuta
rpcsHaveCommentRule.go2.14 kB
package rules import ( "github.com/yoheimuta/go-protoparser/v4/parser" "github.com/yoheimuta/protolint/linter/report" "github.com/yoheimuta/protolint/linter/rule" "github.com/yoheimuta/protolint/linter/visitor" ) // RPCsHaveCommentRule verifies that all rpcs have a comment. type RPCsHaveCommentRule struct { RuleWithSeverity // Golang style comments should begin with the name of the thing being described. // See https://github.com/golang/go/wiki/CodeReviewComments#comment-sentences shouldFollowGolangStyle bool } // NewRPCsHaveCommentRule creates a new RPCsHaveCommentRule. func NewRPCsHaveCommentRule( severity rule.Severity, shouldFollowGolangStyle bool, ) RPCsHaveCommentRule { return RPCsHaveCommentRule{ RuleWithSeverity: RuleWithSeverity{severity: severity}, shouldFollowGolangStyle: shouldFollowGolangStyle, } } // ID returns the ID of this rule. func (r RPCsHaveCommentRule) ID() string { return "RPCS_HAVE_COMMENT" } // Purpose returns the purpose of this rule. func (r RPCsHaveCommentRule) Purpose() string { return "Verifies that all rpcs have a comment." } // IsOfficial decides whether or not this rule belongs to the official guide. func (r RPCsHaveCommentRule) IsOfficial() bool { return false } // Apply applies the rule to the proto. func (r RPCsHaveCommentRule) Apply(proto *parser.Proto) ([]report.Failure, error) { v := &rpcsHaveCommentVisitor{ BaseAddVisitor: visitor.NewBaseAddVisitor(r.ID(), string(r.Severity())), shouldFollowGolangStyle: r.shouldFollowGolangStyle, } return visitor.RunVisitor(v, proto, r.ID()) } type rpcsHaveCommentVisitor struct { *visitor.BaseAddVisitor shouldFollowGolangStyle bool } // VisitRPC checks the rpc. func (v *rpcsHaveCommentVisitor) VisitRPC(rpc *parser.RPC) bool { n := rpc.RPCName if v.shouldFollowGolangStyle && !hasGolangStyleComment(rpc.Comments, n) { v.AddFailuref(rpc.Meta.Pos, `RPC %q should have a comment of the form "// %s ..."`, n, n) } else if !hasComments(rpc.Comments, rpc.InlineComment, rpc.InlineCommentBehindLeftCurly) { v.AddFailuref(rpc.Meta.Pos, `RPC %q should have a comment`, n) } return false }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/yoheimuta/protolint'

If you have feedback or need assistance with the MCP directory API, please join our Discord server