In Variables§

See primary documentation in context for The $/ variable.

$/ is the match variable. A fresh one is created in every routine. It is set to the result of the last Regex match and so usually contains objects of type Match.

'abc 12' ~~ /\w+/;  # sets $/ to a Match object
say $/.Str;         # OUTPUT: «abc␤»

The Grammar.parse method also sets the caller's $/ to the resulting Match object. For the following code:

use XML::Grammar; # zef install XML
XML::Grammar.parse("<p>some text</p>");
say $/;

# OUTPUT: «「<p>some text</p>」
#           root => 「<p>some text</p>」
#            name => 「p」
#            child => 「some text」
#             text => 「some text」
#             textnode => 「some text」
#           element => 「<p>some text</p>」
#            name => 「p」
#            child => 「some text」
#             text => 「some text」
#             textnode => 「some text」␤»

Prior to the 6.d version, you could use $() shortcut to get the ast value from $/ Match if that value is truthy, or the stringification of the Match object otherwise.

'test' ~~ /.../;
# 6.c language only:
say $(); # OUTPUT: «tes␤»;
$/.make: 'McTesty';
say $(); # OUTPUT: «McTesty␤»;

This (non-)feature has been deprecated as of version 6.d.