Security News
PyPI Now Supports iOS and Android Wheels for Mobile Python Development
PyPI now supports iOS and Android wheels, making it easier for Python developers to distribute mobile packages.
@mrdiggles2/mux
Advanced tools
Process muxer written in TypeScript.
Allows configuration of installation, runtime, and clean up of individual processes. Built in menu allows tailing, restarting, and rebuilding of processes within a single terminal session.
Particularly useful for monorepo setups where you have to run frontend, backend, and infrastructure locally.
npm install @mrdiggles2/mux
mux.config.ts
at the root level of your project. Sample:import { MuxConfig } from '@mrdiggles2/mux/config';
const config: MuxConfig = {
rootDir: __dirname,
logPath: '.mux/logs',
processes: [
{
name: 'long sleeper',
run: {
exec: 'sleep 1000',
}
}
]
};
export default config;
mux
npx mux
Each process in mux.config.ts
can be configured:
...
{
name: 'YOUR PROCESS NAME HERE',
run: MuxCommand,
install?: MuxCommand,
cleanup?: MuxCommand,
},
...
Where MuxCommand
takes the form:
{
exec: <Command to run in a separate process>;
dir?: <Path to run `exec` from. Appended to provided `rootDir` in mux.config.ts>
env?: {
<Additional environment variables to run command with>
}
}
Since mux.config.ts
is a TypeScript file, you can also add dynamic configuration. Here is a more complete sample:
import path from "path";
import { MuxConfig } from '@mrdiggles2/mux/config';
const dockerComposeFiles = [
'docker-compose.yml',
'docker-compose.local.yaml'
].map(file => path.join(__dirname, file));
const dcBin = `docker compose --ansi=always ` + dockerComposeFiles.map(file => `-f ${file}`).join(' ');
const config: MuxConfig = {
rootDir: __dirname,
logPath: '.mux',
processes: [
{
name: 'docker-services',
install: {
exec: `${dcBin} up --build -d --remove-orphans --wait`
},
run: {
// Run `up` here again to smoothly support restarts. Effectively a no-op
// if the containers are already running
exec: `${dcBin} up -d --remove-orphans --wait && ${dcBin} logs -f`
},
stop: {
exec: `${dcBin} down`
}
},
{
name: 'nest-backend',
install: {
exec: 'npm ci',
dir: 'backend',
},
run: {
exec: 'npx nest --watch',
dir: 'backend',
env: {
NODE_ENV: development
...<ENV VARS>
},
}
},
{
name: 'react-frontend',
install: {
exec: `npm ci`,
dir: 'frontend',
},
run: {
exec: `npx react-scripts start`,
dir: 'frontend',
env: {
FORCE_COLOR: '1'
...<ENV VARS>
}
}
},
]
};
export default config;
FAQs
muxer in typescript
We found that @mrdiggles2/mux demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PyPI now supports iOS and Android wheels, making it easier for Python developers to distribute mobile packages.
Security News
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.