
Security News
Browserslist-rs Gets Major Refactor, Cutting Binary Size by Over 1MB
Browserslist-rs now uses static data to reduce binary size by over 1MB, improving memory use and performance for Rust-based frontend tools.
marcosc-async
Advanced tools
This is a light-weight approximate implementation of ES7's async-await pattern.
You can npm install it.
npm install marcosc-async --save
You can play with the async API through gh-pages.
Once you import it (using either a script tag or require), there will be an "async" function you can use on the global object.
The async function takes generator, and returns a function that you can call as needed. It returns a promise.
const doAsyncThing = async(function*(args) {
var result = yield Promise.resolve(1);
return result;
});
doAsyncThing()
.then(value => console.log(value)); // 1
You can create simple async functions like so:
const async = require("marcosc-async");
var doSomethingAsync = async(function*(){
return yield Promise.resolve("hi")
});
doSomethingAsync()
.then(value => console.log(value)); // "hi"
Simple example for downloading a list of URLs.
const urls = ["/a", "/b"];
const doAsyncThing = async(function*(listOfURLs) {
let responses = [];
for (let url of listOfURLs) {
responses.push(yield fetch(url));
}
return yield Promise.all(responses.map(res => res.toJSON()));
});
doAsyncThing(urls)
.then(doSomethingElse)
.catch(err => console.error(error));
It allows for simple creation of async function and "tasks". For example:
const async = require("marcosc-async");
const myThinger = {
doAsynThing: async(function*(url) {
const response = yield fetch(url);
const text = yield response.text();
return process(result);
}),
};
And task-like things can be created as follows:
const async = require("marcosc-async");
// Run immediately
const myTask = async.task(function*(url) {
const response = yield fetch(url);
const text = yield response.text();
return process(result);
}).then(doSomethingElse);
this
You can also correctly bind this
like so:
const async = require("marcosc-async");
const myThinger = {
someValue: "value",
asyncTaskA(...args) {
return async(function*() {
return yield this.asyncTaskB(...args)
}, this);
},
asyncTaskB(...args) {
async(function*() {
return this.value;
}, this);
},
};
FAQs
Lightweight promise/generator machinery.
The npm package marcosc-async receives a total of 7,385 weekly downloads. As such, marcosc-async popularity was classified as popular.
We found that marcosc-async demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers 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
Browserslist-rs now uses static data to reduce binary size by over 1MB, improving memory use and performance for Rust-based frontend tools.
Research
Security News
Eight new malicious Firefox extensions impersonate games, steal OAuth tokens, hijack sessions, and exploit browser permissions to spy on users.
Security News
The official Go SDK for the Model Context Protocol is in development, with a stable, production-ready release expected by August 2025.