On Thursday, 31 August 2023 at 05:16:02 UTC, Vino wrote:
Hi All,

  Request your help on the below error

Program
```
void main()
{
        import std.stdio:writeln;
        import std.algorithm.iteration : splitter;
        
        auto splitter_ptr = &splitter!((a, b) => a.splitter(b).array);
    string str = "TEST1;TEST2;TEST3";
    auto words = splitter_ptr(str, ';');
    foreach (word; words) { writeln(word); }
}
```
```
Error: template instance `splitter!((a, b) => a.splitter(b).array)` does not match any template declaration
```

From,
Vino

I'm assuming you want to instantiate `splitter` and take the address of the resulting function, so that `splitter_ptr` will be a function pointer or a delegate.

You are getting the compile time arguments to `splitter` utterly wrong. It should take:

- A function that checks equality between an element and a separator.

 - a `keepSeparators` flag.

 - type of the range you're passing in, `string` in this case.

 - type of the separator, `char` or `dchar` in this case.

You can find this all in [the docs](https://dlang.org/phobos/std_algorithm_iteration.html#.splitter). I think you accidentally passed what you wanted to do with `splitter` as a compile-time parameter to it.

I don't think it's very practical to try instantiating a complex templated function like `splitter` without calling it. It's just not designed for that. I'd rather define a function that wraps a call to it, like (not tested, may have errors):

```D
auto splitter_ptr = (string str, dchar sep) => str.splitter(sep).array;
```

Maybe that's what you tried in the first place. You don't need `&` here, because a lambda (which we use here) is already a function pointer (or a delegate).

Reply via email to