Skip to content

Commit

Permalink
feat: add text imports (#79)
Browse files Browse the repository at this point in the history
  • Loading branch information
sarahschwartz authored Oct 12, 2023
1 parent 8ba20ca commit 5d35f86
Show file tree
Hide file tree
Showing 9 changed files with 223 additions and 67 deletions.
18 changes: 17 additions & 1 deletion docs/guides/docs/installation/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,17 @@ This guide covers the following topics:

## Installing Rust

{/* install_rust:example:start */}
The Fuel toolchain is built on top of the Rust programming language. To install Rust, you can use the `rustup` tool.
{/* install_rust:example:end */}

Run the following command in your shell; this downloads and runs rustup-init.sh, which in turn downloads and runs the correct version of the `rustup-init` executable for your platform.

{/* install_rust_command:example:start */}
```console
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
```
{/* install_rust_command:example:end */}

Check the official Rust documentation to get more information on [installing the Rust toolchain](https://www.rust-lang.org/tools/install).

Expand All @@ -35,16 +39,19 @@ toolchains and keep them updated. It makes building and maintaining Sway applica

> 💡 Check out the [fuelup docs](docs/fuelup) for more information.

### Running fuelup-init

{/* install_fuelup:example:start */}
To install the Fuel toolchain, you'll use the `fuelup-init` script. This will install `forc`, `forc-client`, `forc-fmt`, `forc-lsp`, `forc-wallet` as well as `fuel-core` in `~/.fuelup/bin`.
{/* install_fuelup:example:end */}

👉 Just paste the following line in your terminal and press _Enter_.

{/* install_fuelup_command:example:start */}
```sh
curl --proto '=https' --tlsv1.2 -sSf https://install.fuel.network/fuelup-init.sh | sh
```
{/* install_fuelup_command:example:end */}

> 🚧 Be aware that currently we do not natively support Windows. If you wish to use `fuelup` on Windows, please use Windows Subsystem for Linux.
Expand Down Expand Up @@ -119,11 +126,16 @@ The `beta-4` network is the latest Fuel testnet. This includes public infrastruc

To properly interact with the `beta-4` network it is necessary to use its corresponding toolchain.

{/* install_beta-4:example:start */}
👉 Run the following command to install the `beta-4` toolchain:
{/* install_beta-4:example:end */}

{/* install_beta-4_command:example:start */}
```console
fuelup toolchain install beta-4
```
{/* install_beta-4_command:example:end */}

If the toolchain was successfully installed, you will see this output:

```sh
Expand All @@ -132,11 +144,15 @@ The Fuel toolchain is installed and up to date

The toolchain was installed correctly, however is not in use yet. Next, you need to configure `fuelup` to use the `beta-4` toolchain as the default.

{/* set_default_beta-4:example:start */}
👉 Set `beta-4` as your default toolchain with the following command:
{/* set_default_beta-4:example:end */}

{/* set_default_beta-4_command:example:start */}
```console
fuelup default beta-4
```
{/* set_default_beta-4_command:example:end */}

You will get the following output indicating that you have successfully set `beta-4` as your default toolchain.

Expand Down
58 changes: 57 additions & 1 deletion docs/guides/docs/quickstart/building-a-smart-contract.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,63 @@ parent:

## Installation

Please visit the [installation guide](guides/installation) to install the Fuel toolchain binaries and prerequisites.
<TextImport
file="../installation/index.mdx"
comment="install_rust"
commentType="{/*"
/>

<CodeImport
file="../installation/index.mdx"
comment="install_rust_command"
commentType="{/*"
lang="sh"
trim="true"
/>

<TextImport
file="../installation/index.mdx"
comment="install_fuelup"
commentType="{/*"
/>

<CodeImport
file="../installation/index.mdx"
comment="install_fuelup_command"
commentType="{/*"
lang="sh"
trim="true"
/>

<TextImport
file="../installation/index.mdx"
comment="install_beta-4"
commentType="{/*"
/>

<CodeImport
file="../installation/index.mdx"
comment="install_beta-4_command"
commentType="{/*"
lang="sh"
trim="true"
/>

<TextImport
file="../installation/index.mdx"
comment="set_default_beta-4"
commentType="{/*"
/>

<CodeImport
file="../installation/index.mdx"
comment="set_default_beta-4_command"
commentType="{/*"
lang="sh"
trim="true"
/>

For more detailed instructions on installing `fuelup`, visit the [installation guide](guides/installation).

> Having problems with this part? Post your question on our forum [https://forum.fuel.network/](https://forum.fuel.network/). To help you as efficiently as possible, include the output of this command in your post: `fuelup show.`
Expand Down
2 changes: 1 addition & 1 deletion scripts/update-latest/gitUtils.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ export const checkoutVersion = async (version, dir) => {

export const commitAll = async (message) => {
await exec('git', ['add', '.']);
await exec('git', ['commit', '-m', `'${message}'`]);
await exec('git', ['commit', '-m', message]);
};

export const updateSubmodule = async (submdoule) => {
Expand Down
22 changes: 0 additions & 22 deletions src/components/CodeImport.tsx

This file was deleted.

8 changes: 0 additions & 8 deletions src/lib/imports.ts
Original file line number Diff line number Diff line change
Expand Up @@ -50,19 +50,11 @@ export function getComponents(docSlug: string, isLatest: boolean) {
}

if (docSlug.includes('guides/')) {
components.CodeImport = loadComponent(
import('~/src/components/CodeImport'),
'CodeImport'
);
components.TestAction = TestAction;
} else if (
docSlug.includes('docs/wallet') ||
docSlug.includes('docs/latest/wallet')
) {
components.CodeImport = loadComponent(
import('~/src/components/CodeImport'),
'CodeImport'
);
components.td = TD;
components.th = TH;

Expand Down
2 changes: 2 additions & 0 deletions src/lib/md-doc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { codeImport as walletCodeImport } from '~/docs/fuels-wallet/packages/doc
import { codeExamples as latestCodeExamples } from '~/docs/latest/fuel-graphql-docs/src/lib/code-examples';
import { codeImport as latestWalletCodeImport } from '~/docs/latest/fuels-wallet/packages/docs/src/lib/code-import';
import { codeImport } from '~/src/lib/plugins/code-import';
import { textImport } from '~/src/lib/plugins/text-import';

import { DOCS_DIRECTORY } from '../config/constants';
import type { Config, DocType, SidebarLinkItem } from '../types';
Expand Down Expand Up @@ -197,6 +198,7 @@ export class Doc {
plugins = plugins.concat([[latestCodeExamples, { filepath }] as any]);
} else if (this.md.slug.includes('guides')) {
plugins = plugins.concat([[codeImport, { filepath }] as any]);
plugins = plugins.concat([[textImport, { filepath }] as any]);
}

return plugins;
Expand Down
47 changes: 14 additions & 33 deletions src/lib/plugins/code-import.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ import * as prettier from 'prettier';
import type { Root } from 'remark-gfm';
import { visit } from 'unist-util-visit';

import { getEndCommentType } from './text-import';
import type { CommentTypes } from './text-import';

function toAST(content: string) {
return acorn.parse(content, {
ecmaVersion: 'latest',
Expand Down Expand Up @@ -43,8 +46,6 @@ function extractLines(
}
}

type CommentTypes = '<!--' | '{/*' | '//' | '/*';

function extractCommentBlock(
content: string,
comment: string,
Expand All @@ -55,29 +56,20 @@ function extractCommentBlock(
let lineStart = 1;
let lineEnd = 1;

const endCommentType =
commentType === '<!--'
? ' -->'
: commentType === '{/*'
? ' */}'
: commentType === '/*'
? ' */'
: '';
const endCommentType = getEndCommentType(commentType);

for (let i = 0; i < lines.length; i++) {
const g = `${commentType} ANCHOR: ${comment}${endCommentType}`;
const start =
lines[i] === `${commentType} ${comment}:example:start${endCommentType}` ||
lines[i] === `${commentType}${comment}:example:start${endCommentType}` ||
lines[i] === g;
if (start === true) {
const startLineA = `${commentType}ANCHOR:${comment}${endCommentType}`;
const endLineA = `${commentType}ANCHOR_END:${comment}${endCommentType}`;
const startLineB = `${commentType}${comment}:example:start${endCommentType}`;
const endLineB = `${commentType}${comment}:example:end${endCommentType}`;
const cleanLine = lines[i].replace(/\s+/g, '');
const start = cleanLine === startLineA || cleanLine === startLineB;
if (start) {
lineStart = i + 1;
} else {
const x = `${commentType} ANCHOR_END: ${comment}${endCommentType}`;
const end =
lines[i] === `${commentType} ${comment}:example:end${endCommentType}` ||
lines[i] === `${commentType}${comment}:example:end${endCommentType}` ||
lines[i] === x;
if (end === true) {
const end = cleanLine === endLineA || cleanLine === endLineB;
if (end) {
lineEnd = i;
}
}
Expand Down Expand Up @@ -151,7 +143,6 @@ function extractTestCase(source: string, testCase: string) {
};
}

const ROOT_DIR = path.resolve(__dirname, '../../../../../../../');
export function codeImport() {
return function transformer(tree: Root, file: any) {
const rootDir = process.cwd();
Expand Down Expand Up @@ -224,16 +215,6 @@ export function codeImport() {
type: 'mdxJsxAttribute',
value: content,
},
{
name: '__filepath',
type: 'mdxJsxAttribute',
value: path.resolve(dirname, file).replace(`${ROOT_DIR}/`, ''),
},
{
name: '__filename',
type: 'mdxJsxAttribute',
value: path.parse(file).base,
},
{
name: '__language',
type: 'mdxJsxAttribute',
Expand Down
9 changes: 8 additions & 1 deletion src/lib/plugins/rehype-code.ts
Original file line number Diff line number Diff line change
Expand Up @@ -176,6 +176,9 @@ function codeLanguage() {
if (lang?.includes('tsx')) {
node.properties.className[0] = 'language-typescript';
}
if (lang?.includes('sh')) {
node.properties.className[0] = 'language-sh';
}
});
};
}
Expand Down Expand Up @@ -254,7 +257,11 @@ function codeImport() {
node.type = 'element';
node.tagName = 'pre';
const lang = node.attributes?.find((a: any) => a.name === '__language');
const code = h('code', { class: lang?.value }, content?.value);
const code = h(
'code',
{ class: lang?.value },
content?.value.replace(/\r/g, '')
);
node.children = [code];
});
};
Expand Down
Loading

0 comments on commit 5d35f86

Please sign in to comment.