Home / File/ markdown-cc2.js — astro Source File

markdown-cc2.js — astro Source File

Architecture documentation for markdown-cc2.js, a javascript file in the astro codebase. 2 imports, 0 dependents.

Entity Profile

Dependency Diagram

graph LR
  6c836b62_4954_fd03_cd12_825eb19578bc["markdown-cc2.js"]
  17367d98_9f85_0bd4_ea15_5ffb13d9f3ed["_util.js"]
  6c836b62_4954_fd03_cd12_825eb19578bc --> 17367d98_9f85_0bd4_ea15_5ffb13d9f3ed
  b7152389_6184_10c1_bcfb_79b1277b6ec9["promises"]
  6c836b62_4954_fd03_cd12_825eb19578bc --> b7152389_6184_10c1_bcfb_79b1277b6ec9
  style 6c836b62_4954_fd03_cd12_825eb19578bc fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import fs from 'node:fs/promises';
import { loremIpsumMd } from './_util.js';

/**
 * @param {URL} projectDir
 */
export async function run(projectDir) {
	await fs.rm(projectDir, { recursive: true, force: true });
	await fs.mkdir(new URL('./src/pages/blog', projectDir), { recursive: true });
	await fs.mkdir(new URL('./data/blog', projectDir), { recursive: true });
	await fs.mkdir(new URL('./src/content', projectDir), { recursive: true });
	await fs.copyFile(new URL('./image.jpg', import.meta.url), new URL('./image.jpg', projectDir));

	const promises = [];

	for (let i = 0; i < 10000; i++) {
		const content = `\
# Article ${i}

${loremIpsumMd}

![image ${i}](../../image.jpg)

`;
		promises.push(
			fs.writeFile(new URL(`./data/blog/article-${i}.md`, projectDir), content, 'utf-8'),
		);
	}

	await fs.writeFile(
		new URL(`./src/content.config.ts`, projectDir),
		/*ts */ `
		import { defineCollection } from 'astro:content';
		import { z } from 'astro/zod';
		import { glob } from 'astro/loaders';

		const blog = defineCollection({
			loader: glob({ pattern: '*', base: './data/blog' }),
		});
		
		export const collections = { blog }

		`,
	);

	await fs.writeFile(
		new URL(`./src/pages/blog/[...slug].astro`, projectDir),
		`\
---
import { getCollection, render } from 'astro:content';
export async function getStaticPaths() {
  const blogEntries = await getCollection('blog');
  return blogEntries.map(entry => ({
    params: { slug: entry.id }, props: { entry },
  }));
}
const { entry } = Astro.props;
const { Content } = await render(entry);

---
<h1>{entry.data.title}</h1>
<Content />
`,
		'utf-8',
	);

	await Promise.all(promises);

	await fs.writeFile(
		new URL('./astro.config.js', projectDir),
		`\
import { defineConfig } from 'astro/config';

export default defineConfig({});`,
		'utf-8',
	);
}

Subdomains

Functions

Dependencies

Frequently Asked Questions

What does markdown-cc2.js do?
markdown-cc2.js is a source file in the astro codebase, written in javascript. It belongs to the BenchmarkToolkit domain, ProjectGenerator subdomain.
What functions are defined in markdown-cc2.js?
markdown-cc2.js defines 1 function(s): run.
What does markdown-cc2.js depend on?
markdown-cc2.js imports 2 module(s): _util.js, promises.
Where is markdown-cc2.js in the architecture?
markdown-cc2.js is located at benchmark/make-project/markdown-cc2.js (domain: BenchmarkToolkit, subdomain: ProjectGenerator, directory: benchmark/make-project).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free