// tree node type
type Node = {
id: number;
children: () => Promise<Node[]>
}
// results array
const results: Node[] = [];
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
unalias gbl | |
function gbl() { | |
# todo: colorize branches by last commit | |
# todo: show 10 by default | |
gb --sort=committerdate | | |
tail -n 5 | | |
gum filter --limit=1 --header="Type to checkout a branch" --placeholder="" | | |
xargs -I _ git checkout _ || echo Current branch already checked out. | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
type ObjectPathValue<T, U extends readonly string[]> = U extends [ | |
infer FirstProp extends keyof T, | |
...infer RestProps extends readonly string[] | |
] | |
? ObjectPathValue<T[FirstProp], RestProps> | |
: T; | |
function $get<T extends object, U extends readonly string[]>( | |
target: T, | |
path: [...U] |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
type TokenSpec<T = any> = { match: RegExp; value: (s: string) => T }; | |
type TokenConfig = Record<string, RegExp | TokenSpec>; | |
type TokenTypes<T extends TokenConfig> = { | |
[Type in keyof T]: T[Type] extends TokenSpec | |
? { type: Type; value: ReturnType<T[Type]['value']> } | |
: { type: Type; value: string }; | |
}[keyof T]; | |
/** | |
* @param str The input string |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
export function range(start: number, stop = start, step = 1) { | |
start = stop === start ? 0 : start; | |
const end = stop === start ? start : stop; | |
return { | |
*[Symbol.iterator]() { | |
for (let i = start; i < end; i += step) yield i; | |
}, | |
}; | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const dogs = [ | |
{ name: 'Fido', favorites: ['sam', 'mark', 'bob'] }, | |
{ name: 'Happy', favorites: ['mark'] }, | |
{ name: 'Buddy', favorites: ['bob'] }, | |
{ name: 'Oscar', favorites: ['mark', 'sam', 'bob'] }, | |
]; | |
const friends = [ | |
{ name: 'sam', age: 22, toes: 5 }, | |
{ name: 'mark', age: 37, toes: 9 }, |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function render(template: string, data: any, brackets = ['{{', '}}']) { | |
const output: string[] = []; | |
const [left, right] = | |
brackets.length > 1 ? brackets : [...brackets, ...brackets]; | |
let pos = 0; | |
while (pos < template.length) { | |
const start = template.indexOf(left, pos); | |
if (start < 0) break; |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function gcz() { | |
if [[ -z $1 ]]; then | |
git checkout $(gb | fzf | tr -d ' *') | |
else | |
git checkout $(gb | fzf -1 -q $1 | tr -d ' *') | |
fi | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env node | |
const fs = require('fs'); | |
const path = require('path'); | |
const tweetCSVFile = path.resolve(__dirname, '../all_tweets_classified.csv'); | |
const outFile = path.resolve(__dirname, '../all_tweets_classified.json'); | |
const [header, rows] = parseCSV(tweetCSVFile); | |
const jsonData = csvToJson([header, rows], { | |
msg_id: String, |
- Install the ESLint extension in VSCode.
- This actually parses the Javascript you write and applies syntax and semantic rules.
- Install the Prettier code formatter extension in VSCode.
- All this does is format the code you've written to look nice. No syntax checking or parsing of your Javascript. If you don't install this, you'll still get all the benefits of linting and VSCode's built-in formatter.
NewerOlder