-
Contributions in the form of feedback and issue is very much welcome. Might it be a suggestion, a bug report or maybe some questions that you have. It helps improving Lucid in the long run and these are probably the best kind of contributions to start with. Do not hesitate to add thumbs up 👍 on open issues you support to show your interest.
Deno does not treat "index.js" or "index.ts" in a special way. By using these filenames, it suggests that they can be left out of the module specifier when they cannot. This is confusing.
If a directory of code needs a default entry point, use the filename mod.ts
.
The filename mod.ts
follows Rust’s convention, is shorter than index.ts
, and
doesn’t come with any preconceived notions about how it might work.
Example: Use merkle_tree.ts
instead of merkle-tree.ts
or merkleTree.ts
.
// BAD. If the second argument was not optional, it would be OKAY to do it like this.
export function fromSeed(
address: string,
addressType?: "Base" | "Enterprise",
accountIndex?: number,
): string {}
// GOOD.
export interface SeedOptions {
addressType?: "Base" | "Enterprise";
accountIndex?: number;
}
export function fromSeed(
address: string,
options: SeedOptions = {},
): string {}
// BAD.
export const add = (a: number, b: number): number => a + b;
// GOOD.
export function add(a: number, b: number): number {
return a + b;
}
// BAD. Return type is only implicitly determined.
export function add(a: number, b: number) {
return a + b;
}
// GOOD.
export function add(a: number, b: number): number {
return a + b;
}
But if the return type is void
then don't explicitly mention it:
// GOOD.
export function log(str: string) {
console.log(str);
}
Single line comment:
// This is a comment.
Multiline comment:
/*
This is a comment on line 1.
This is a comment on line 2.
*/
Single line comment to describe a function/variable:
/** This functions adds two numbers together. */
export function add(a: number, b: number): number {
return a + b;
}
Multiline comment to describe a function/variable:
/**
* This functions adds two numbers together.
* This is another random comment.
*/
export function add(a: number, b: number): number {
return a + b;
}
Always end comments with a dot .
(If they are just a few words then it's not necessary).
Avoid JSDoc @param
. If @param
is used, it should not include the type
as
TypeScript is already strongly-typed:
/**
* Function with non-obvious param.
* @param foo Description of non-obvious parameter.
*/