use strict;
my $str = 'export { default } from \'./make\'
export {
DEFAULTS,
plugin as default,
type Options
} from \'./plugin\'
export type { Config, Result } from \'./interfaces\'
export type { default as Options } from \'./options\'
export type Foo from \'#foo\'
export type * from "./spaceship"
export type * as vehicles from "./spaceship"
export * as constants from \'./constants\'
export * from \'./interfaces\'
export * from \'./lib\'
export * from \'./types\'
export * from "module-name";
export * as name1 from "module-name";var g;export{name1}from"module-name";
export { name1, /* */ nameN } from "module-name";
export { import1 as name1, import2 as name2, /* */ nameN } from "module-name";
export { default, /* */ } from "module-name";
declare module \'module-name\' {
export { default } from \'./make\'
export {
DEFAULTS,
plugin as default,
type Options
} from \'./plugin\'
}
export {
DEFAULTS,
plugin as default,
type Options
}
export { defineBuildConfig, type BuildConfig } from "#src"
export type {
JsonObject,
LiteralUnion,
Nullable
} from \'@flex-development/tutils\'
export {
addFive,
addFour,
addThree,
addTwo,
squareFive,
squareFour,
squareThree,
squareTwo
} from \'./lib\'
export * as constants from "./constants"
export type { default as Options }
export type { default as Options } from "./options"
export * from \'./utils\'
export interface User {}
export abstract class House {}
export const { name1, name2: bar } = o;
export const [ name1, name2 ] = array;
export default async function foo() {}
export default foo
export default 1 + 1;
export type { Config, Result }
"export type { default as Statement }"
export { name1, /* */ nameN };
export { variable1 as name1, variable2 as name2, /* */ nameN };
export { variable1 as "string name" };
export { name1 as default /*, */ };
export type { CompilerOptionsJson as default };
export { default }
export {
DEFAULTS,
plugin as default,
type Options
}
export type { Config, Result }
export type { default as Options }
var g;export{name1}; export{name1}
export { name1, /* */ nameN }
export { import1 as ", import2 as name2, /* */ nameN }
export { default, /* */ }
// export * from \'./constants\'
// export type { default as Statement }
/**
*
* @example
* export { default }
* export { Config, Result }
* export type { default as Options }
*/
// export * from \'./constants\'
//export type { default as Statement } from \'./statement\'
/* export type { default as Statement } from \'./statement\' */
/*export type { default as Statement } from \'./statement\' */
/*
* @example
* export * from \'./constants\'
*/
/**
* @example
* export * from \'./constants\'
*/
/**
*
* @example
* export { default } from \'./make\'
* export { Config, Result } from \'./interfaces\'
* export type { default as Options } from \'./options\'
*/
export type { Config, Result } from \'./interfaces\'';
my $regex = qr/(?<=^[\t ]*|[\n;](?:[\t ]*(?:\w+ )?)?)export(?:(?: *(?<type>type) *)|[\t\n ]*)(?<exports>(?:\*(?: +as +\S+)?)|\S+|(?:{[\w\t\n\r "$'*,./-]+?}))[\t ]*from[\t ]*["']\s*(?<specifier>(?:(?<=' *)[^']*[^\s'](?= *'))|(?:(?<=" *)[^"]*[^\s"](?= *"))) *["']/p;
if ( $str =~ /$regex/g ) {
print "Whole match is ${^MATCH} and its start/end positions can be obtained via \$-[0] and \$+[0]\n";
# print "Capture Group 1 is $1 and its start/end positions can be obtained via \$-[1] and \$+[1]\n";
# print "Capture Group 2 is $2 ... and so on\n";
}
# ${^POSTMATCH} and ${^PREMATCH} are also available with the use of '/p'
# Named capture groups can be called via $+{name}
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for Perl, please visit: http://perldoc.perl.org/perlre.html