mirror of
https://github.com/ericchiang/pup
synced 2025-01-15 10:11:16 +00:00
selector is now an interface
This commit is contained in:
parent
abd4c986bf
commit
66251a1061
4
main.go
4
main.go
@ -11,7 +11,7 @@ import (
|
||||
"strings"
|
||||
)
|
||||
|
||||
const VERSION string = "0.1.1"
|
||||
const VERSION string = "0.1.2a"
|
||||
|
||||
var (
|
||||
// Flags
|
||||
@ -125,7 +125,7 @@ func main() {
|
||||
PrintNode(root, 0)
|
||||
os.Exit(0)
|
||||
}
|
||||
selectors := make([]*selector.Selector, len(cmds))
|
||||
selectors := make([]selector.Selector, len(cmds))
|
||||
for i, cmd := range cmds {
|
||||
if i+1 == len(cmds) {
|
||||
d, err := funcs.NewDisplayFunc(cmd)
|
||||
|
@ -8,11 +8,20 @@ import (
|
||||
)
|
||||
|
||||
// A CSS Selector
|
||||
type Selector struct {
|
||||
type BasicSelector struct {
|
||||
Name *regexp.Regexp
|
||||
Attrs map[string]*regexp.Regexp
|
||||
}
|
||||
|
||||
type Selector interface {
|
||||
// Does this selector match a given node?
|
||||
Match(node *html.Node) bool
|
||||
// Find all nodes which match a selector. May return itself.
|
||||
FindAll(node *html.Node) []*html.Node
|
||||
// Find all child nodes which match a selector.
|
||||
FindAllChildren(node *html.Node) []*html.Node
|
||||
}
|
||||
|
||||
type selectorField int
|
||||
|
||||
const (
|
||||
@ -63,7 +72,7 @@ func parseAttrField(command string) (attrKey string, matcher *regexp.Regexp,
|
||||
}
|
||||
|
||||
// Set a field of this selector.
|
||||
func (s *Selector) setFieldValue(f selectorField, v string) error {
|
||||
func (s *BasicSelector) setFieldValue(f selectorField, v string) error {
|
||||
if v == "" {
|
||||
return nil
|
||||
}
|
||||
@ -98,9 +107,9 @@ func (s *Selector) setFieldValue(f selectorField, v string) error {
|
||||
}
|
||||
|
||||
// Convert a string to a selector.
|
||||
func NewSelector(s string) (*Selector, error) {
|
||||
func NewSelector(s string) (Selector, error) {
|
||||
attrs := map[string]*regexp.Regexp{}
|
||||
selector := &Selector{nil, attrs}
|
||||
selector := BasicSelector{nil, attrs}
|
||||
nextField := NameField
|
||||
start := 0
|
||||
// Parse the selector character by character
|
||||
@ -153,7 +162,7 @@ func NewSelector(s string) (*Selector, error) {
|
||||
}
|
||||
|
||||
// Find all nodes which match a selector.
|
||||
func (sel *Selector) FindAllChildren(node *html.Node) []*html.Node {
|
||||
func (sel BasicSelector) FindAllChildren(node *html.Node) []*html.Node {
|
||||
selected := []*html.Node{}
|
||||
child := node.FirstChild
|
||||
for child != nil {
|
||||
@ -165,7 +174,7 @@ func (sel *Selector) FindAllChildren(node *html.Node) []*html.Node {
|
||||
}
|
||||
|
||||
// Find all nodes which match a selector. May return itself.
|
||||
func (sel *Selector) FindAll(node *html.Node) []*html.Node {
|
||||
func (sel BasicSelector) FindAll(node *html.Node) []*html.Node {
|
||||
selected := []*html.Node{}
|
||||
if sel.Match(node) {
|
||||
return []*html.Node{node}
|
||||
@ -180,7 +189,7 @@ func (sel *Selector) FindAll(node *html.Node) []*html.Node {
|
||||
}
|
||||
|
||||
// Does this selector match a given node?
|
||||
func (sel *Selector) Match(node *html.Node) bool {
|
||||
func (sel BasicSelector) Match(node *html.Node) bool {
|
||||
if node.Type != html.ElementNode {
|
||||
return false
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user