Interesting. I will look. the issue is the level of the smartness. gg is
basic (tokens) and below a full parse (syntax). The higher you go, the
different the search questions can be.

If you downloaded, please update and rebuild. I had mail about a
performance problem and found an error of configuration. It is better now.

Michael

On Thu, Jul 4, 2019 at 5:59 PM Andy Balholm <andybalh...@gmail.com> wrote:

> I recently ran across https://github.com/mvdan/gogrep. It does some of
> that.
>
> Andy
>
> On Jul 4, 2019, at 5:30 PM, Bakul Shah <ba...@bitblocks.com> wrote:
>
> Very nice!
>
> A natural great extension[1] would be language aware grep/sed/awk:
> - return an *enclosing* parse construct after matching something
> - match on a construct with some pieces wildcarded
> - replace one structure with another (but based on the match)
>
> Possible uses:
> - when you change an API of a package, fix up its users
> - rename variables
> - replace Go1 constructs with simpler/more efficient Go2 ones.
> - write generic code and replace with type specific code
> - program construction (ala Beta language's fragment system)
> - literate programming (tangle/weave)
> - optimize code
> - program analysis
> - structured diff/merge
>
> The tough part would be coming up with a simple but flexible
> structured regular expression language. [Initially I had thought
> this is what Rob was writing about in his "Structured Regular
> Expressions" paper! So the idea is very old.]
>
> [1] No good deed goes unpunished :-)
>
>
> On Jul 4, 2019, at 9:10 AM, Michael Jones <michael.jo...@gmail.com> wrote:
>
> Recently I shared my Survey <https://github.com/MichaelTJones/survey>
> program, saying that it was a sidestep from what I was working on but
> interesting and hopefully useful to others. Here is the real thing, named
> gg, that Survey was a test for. GG combines lexical analysis and Go-native
> pattern matching to extend grep(1) for Go developers
>
> GG is smart; the search is restricted, seeking matches only in chosen
> token classes.  A search in number literals can match values in addition to
> patterns: "v 255" matches the numeric value 255 in source code as
> 0b1111_1111, 0377, 0o377, 255, 0xff, etc.  Go's linear-time regular
> expression engine is Unicode-aware and supports many extensions: numbers in
> identifiers are found with "gg i [0-9]" or "gg i [\d]", find comments with
> math symbols using "gg c \p{Sm}", and Greek in strings via "gg s \p{Greek}".
>
> GG is fast, uses all cores, understands filesystem hierarchies, archives,
> and compression schemes, and is general like grep while focused in a new
> way: find within package names, identifiers, types, strings, comments, and
> more.
>
> Source code:
> https://github.com/MichaelTJones/gg
>
> Man page (all is explained here):
> https://github.com/MichaelTJones/gg/blob/master/gg.pdf
>
> Examples:
>
> Search the Go 1.13 source code for strings containing Megalosaurus, but
> not comments:
>
> $ gg -r s Megalosaurus ~/go
> /Users/mtj/go/src/cmd/link/link_test.go:`text:"London. Michaelmas term
> lately over, and the Lord Chancellor sitting in Lincoln’s Inn Hall.
> Implacable November weather. As much mud in the streets as if the waters
> had but newly retired from the face of the earth, and it would not be
> wonderful to meet a Megalosaurus, forty feet long or so, waddling like an
> elephantine lizard up Holborn Hill. ...
>
>
> Search the Go 1.13 source code for identifiers with greek letters (but not
> strings or comments):
>
> $ gg -r i '\p{Greek}' ~/go
> /Users/mtj/go/src/encoding/json/encode_test.go: A0, À, Aβ int
> /Users/mtj/go/src/math/cmplx/polar.go:func Polar(x complex128) (r, θ
> float64) {
> /Users/mtj/go/src/math/cmplx/rect.go:func Rect(r, θ float64) complex128 {
> /Users/mtj/go/src/math/cmplx/rect.go: s, c := math.Sincos(θ)
> /Users/mtj/go/src/math/rand/rand_test.go: var χ2 float64
> :
>
>
> Best to all,
> Michael
>
> --
>
> *Michael T. jonesmichael.jo...@gmail.com <michael.jo...@gmail.com>*
>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/CALoEmQz-KdFaWjS%2Bfyd-QQS4LEgYmnofiZNmugnoQ7sNaG0HEA%40mail.gmail.com
> <https://groups.google.com/d/msgid/golang-nuts/CALoEmQz-KdFaWjS%2Bfyd-QQS4LEgYmnofiZNmugnoQ7sNaG0HEA%40mail.gmail.com?utm_medium=email&utm_source=footer>
> .
> For more options, visit https://groups.google.com/d/optout.
>
>
>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/18AEB87E-E8A1-40BB-A63C-1DA84A607AF7%40bitblocks.com
> <https://groups.google.com/d/msgid/golang-nuts/18AEB87E-E8A1-40BB-A63C-1DA84A607AF7%40bitblocks.com?utm_medium=email&utm_source=footer>
> .
> For more options, visit https://groups.google.com/d/optout.
>
>
>

-- 

*Michael T. jonesmichael.jo...@gmail.com <michael.jo...@gmail.com>*

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/CALoEmQwDvAxbxsKDULBDhyJQO%2B7HKJ_gb8upjYpYr5r%2BSHZaPw%40mail.gmail.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to