pscIdeServerArgs: {}, // for example, to change the port {port: 4088}
pscIdeRebuildArgs: {} // for example, for sourcemaps {codegen: ['js', 'sourcemaps']}
pscIdeColors: false, // defaults to true if psc === 'psa'
- pscPackage: false,
+ pscPackage: false, // include dependencies from psc-package
+ spago: false, // include dependencies from spago
bundleOutput: 'output/bundle.js',
bundleNamespace: 'PS',
bundle: false,
output: 'output',
src: [
path.join('src', '**', '*.purs'),
- // if pscPackage = false
- path.join('bower_components', 'purescript-*', 'src', '**', '*.purs')
// if pscPackage = true
// source paths reported by `psc-package sources`
+ // if spago = true
+ // source paths reported by `spago sources`
+ // if pscPackage = false and spago = false
+ path.join('bower_components', 'purescript-*', 'src', '**', '*.purs')
]
}
```
Set `pscPackage` query parameter to `true` to enable `psc-package` support. The `psc-package`-supplied source paths
will be appended to `src` parameter.
+### `spago` support (experimental)
+
+Set `spago` query parameter to `true` to enable `spago` support. The `spago`-supplied source paths
+will be appended to `src` parameter.
+
### Troubleshooting
#### Slower webpack startup after enabling psc-ide support?
srcOption: []
};
+// include src files provided by psc-package or Spago
+function requestDependencySources(packagerCommand, srcPath, loaderOptions) {
+ const packagerArgs = ['sources'];
+
+ const loaderSrc = loaderOptions.src || [
+ srcPath
+ ];
+
+ debug('%s %o', packagerCommand, packagerArgs);
+
+ const cmd = spawn(packagerCommand, packagerArgs);
+
+ if (cmd.error) {
+ throw new Error(cmd.error);
+ }
+ else if (cmd.status !== 0) {
+ const error = cmd.stdout.toString();
+
+ throw new Error(error);
+ }
+ else {
+ const result = cmd.stdout.toString().split(eol).filter(v => v != '').concat(loaderSrc);
+
+ debug('%s result: %o', packagerCommand, result);
+
+ CACHE_VAR.srcOption = result;
+
+ return result;
+ }
+}
+
module.exports = function purescriptLoader(source, map) {
this.cacheable && this.cacheable();
const loaderOptions = loaderUtils.getOptions(this) || {};
- const srcOption = (pscPackage => {
+ const srcOption = ((pscPackage, spago) => {
const srcPath = path.join('src', '**', '*.purs');
const bowerPath = path.join('bower_components', 'purescript-*', 'src', '**', '*.purs');
return CACHE_VAR.srcOption;
}
else if (pscPackage) {
- const pscPackageCommand = 'psc-package';
-
- const pscPackageArgs = ['sources'];
-
- const loaderSrc = loaderOptions.src || [
- srcPath
- ];
-
- debug('psc-package %s %o', pscPackageCommand, pscPackageArgs);
-
- const cmd = spawn(pscPackageCommand, pscPackageArgs);
-
- if (cmd.error) {
- throw new Error(cmd.error);
- }
- else if (cmd.status !== 0) {
- const error = cmd.stdout.toString();
-
- throw new Error(error);
- }
- else {
- const result = cmd.stdout.toString().split(eol).filter(v => v != '').concat(loaderSrc);
-
- debug('psc-package result: %o', result);
-
- CACHE_VAR.srcOption = result;
-
- return result;
- }
+ return requestDependencySources('psc-package', srcPath, loaderOptions)
}
+ else if (spago) {
+ return requestDependencySources('spago', srcPath, loaderOptions)
+ }
else {
const result = loaderOptions.src || [
bowerPath,
return result;
}
- })(loaderOptions.pscPackage);
+ })(loaderOptions.pscPackage, loaderOptions.spago);
const options = Object.assign({
context: webpackContext,
pscIde: false,
pscIdeColors: loaderOptions.psc === 'psa',
pscPackage: false,
+ spago: false,
bundleOutput: 'output/bundle.js',
bundleNamespace: 'PS',
bundle: false,