Git with a cup of tea, painless self-hosted git service Mirror for internal git.with.parts use https://git.with.parts
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.
 
 
 
 
 
 
gitea/vendor/mvdan.cc/xurls/v2
6543 4ad10ac015
Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407)
4 years ago
..
.gitignore Use Go1.11 module (#5743) 6 years ago
LICENSE Use Go1.11 module (#5743) 6 years ago
README.md Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407) 4 years ago
go.mod Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407) 4 years ago
go.sum Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407) 4 years ago
schemes.go Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407) 4 years ago
tlds.go Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407) 4 years ago
tlds_pseudo.go Use Go1.11 module (#5743) 6 years ago
xurls.go Vendor: mvdan.cc/xurls v2.1.0 -> v2.2.0 (#13407) 4 years ago

README.md

xurls

GoDoc

Extract urls from text using regular expressions. Requires Go 1.13 or later.

import "mvdan.cc/xurls/v2"

func main() {
	rxRelaxed := xurls.Relaxed()
	rxRelaxed.FindString("Do gophers live in golang.org?")  // "golang.org"
	rxRelaxed.FindString("This string does not have a URL") // ""

	rxStrict := xurls.Strict()
	rxStrict.FindAllString("must have scheme: http://foo.com/.", -1) // []string{"http://foo.com/"}
	rxStrict.FindAllString("no scheme, no match: foo.com", -1)       // []string{}
}

Since API is centered around regexp.Regexp, many other methods are available, such as finding the byte indexes for all matches.

Note that calling the exposed functions means compiling a regular expression, so repeated calls should be avoided.

cmd/xurls

To install the tool globally:

cd $(mktemp -d); go mod init tmp; GO111MODULE=on go get mvdan.cc/xurls/v2/cmd/xurls
$ echo "Do gophers live in http://golang.org?" | xurls
http://golang.org