On Mon, Jan 1, 2018 at 10:21 PM, Ian Lance Taylor <i...@golang.org> wrote:

> On Mon, Jan 1, 2018 at 6:46 PM, Tong Sun <suntong...@gmail.com> wrote:
> >
> > I think I generally understand how embedding
> > (https://golang.org/doc/effective_go.html#embedding) works in GO.
> > However, when it comes to the following problem, I'm at lost again.
> >
> > I'm trying to extend the `html.Tokenizer` with new methods of my own:
> >
> > type MyTokenizer struct {
> >  html.Tokenizer
> > }
> >
> >
> > func NewMyTokenizer(i io.Reader) *MyTokenizer {
> >  z := html.NewTokenizer(i)
> >  return *MyTokenizer(z)
> >  return &MyTokenizer{z}
> > }
> >
> >
> >
> > so code like
> >
> >  z := html.NewTokenizer(body)
> > ...
> > func parseBody(z *html.Tokenizer) {
> >   tt := z.Next()
> > ...
> >  testt := z.Token()
> > ...
> >
> >
> > can become:
> >
> >  z := NewMyTokenizer(body)
> > ...
> > func (z *MyTokenizer) parseBody() {
> >  tt := z.Next()
> > ...
> >
> >  testt := z.Token()
> > ...
> >
> >
> >
> >
> > However, I'm really struggling to make it work as I was expected.
> >
> > Somebody help please, what's the proper way to extend a type with new
> > methods of my own, while still able to access all existing methods?
>
> The best way to get help for this is to show us precisely what you
> did, ideally in a small complete, stand-alone, example,


The *small complete, stand-alone, example *has been provided in OP as

https://github.com/suntong/lang/blob/master/lang/Go/src/xml/htmlParserTokens.go

and tell us
> what you expected to happen, and tell us precisely what happened
> instead.


*What expected to happen*: adding the following would work:

type MyTokenizer struct {
 html.Tokenizer
}


func NewMyTokenizer(i io.Reader) *MyTokenizer {
 z := html.NewTokenizer(i)
 return *MyTokenizer(z)
 return &MyTokenizer{z}
}


> In this case I don't know what to suggest because you didn't
> say what you expect and you didn't say what happened.
>

Can't make it work. The

 return *MyTokenizer(z)
 return &MyTokenizer{z}

Are just the last two attempts that I make, apart from many other failed
attempts that I've lost track of, but *neither compiles*.

> Further more, how to extend the above even further? --
> >
> > - I plan to define an interface with a new method `WalkBody()`, in which
> a
> > "virtual" method of `VisitToken()` is used.
> > - Then I plan to define two different type of MyTokenizer, with their own
> > `VisitToken()` methods, so the same `WalkBody()` method defined in
> > MyTokenizer will behave differently for those two different types.
> >
> > How to architect above in Go?
>
> First, think in Go terms, don't think in terms like "virtual method"
> that do not exist in Go.
>
> What you want is something like
>
> type TokenVisitor interface {
>     VisitToken()
> }
>
> Then your WalkBody function will take a TokenVisitor, and your
> different types will implement different VisitToken methods.
>
> (I see that you said WalkBody method, but you probably want a WalkBody
> function instead.)
>

I did meant WalkBody method. See:

https://github.com/suntong/lang/blob/master/lang/Go/src/xml/htmlParserTokens.go#L54

-- 
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.
For more options, visit https://groups.google.com/d/optout.

Reply via email to