1.1.1 • Published 10 months ago

traverse-md v1.1.1

Weekly downloads
-
License
MIT
Repository
-
Last release
10 months ago

traverse-md

traverse-md is a simple command-line tool that generates a markdown-compatible directory structure of a given folder and writes it to a README file. It’s perfect for documenting project structures or creating navigable outlines in README.md files.

Features

  • Outputs the directory and file structure in a markdown tree format
  • Automatically writes to README.md or updates the existing structure within the file
  • Customizable root directory path

Installation

You can use traverse-md directly with npx, or install it globally.

Using npx

npx traverse-md "path/to/directory"

Global Installation

Install traverse-md globally to use it without npx:

npm install -g traverse-md

Usage

Basic Command

To generate the structure of the current working directory, run:

npx traverse-md .

Or, if installed globally:

traverse-md .

This will create or update a README.md file in the specified directory with a structured outline of your project.

Specifying a Directory

Provide a specific path if you want to outline a different directory:

npx traverse-md path/to/your-directory

Interactive Mode

If you want to specify directories to ignore, run the command without arguments:

npx traverse-md

The tool will prompt you to enter:

The path of the directory to traverse.

  • A list of directories to ignore, separated by commas.
  • Ignored Directories By default, the following directories are ignored:
  1. .git
  2. .next
  3. node_modules
  4. vendor
  5. Log files and temporary files

You can also add your own directories to ignore by passing them as a command line argument:

npx traverse-md . --ignore "dir1,dir2"

Example Output

Running traverse-md in a Next.js project might produce the following output in your README.md:

my-nextjs-app/
├── public/              # Static files (images, fonts, etc.)
│   └── favicon.ico
├── src/                 # Source folder
│   ├── app/             # App directory for Next.js 13+ App Router
│   │   ├── api/         # API routes
│   │   └── layout.tsx   # Global layout for the app
│   └── components/      # Reusable components
│       ├── Button.tsx
│       └── Header.tsx
│   └── hooks/           # Custom React hooks
│       └── useAuth.ts
├── .env                 # Environment variables
├── next.config.js       # Next.js configuration
├── package.json         # Package dependencies and scripts
├── tsconfig.json        # TypeScript configuration
└── README.md            # Project documentation

Customization

  • File Path: Run the command with npx traverse-md "path/to/directory" to specify which directory to structure.
  • Updating the README: If README.md exists, traverse-md will update the section containing the folder structure instead of appending a duplicate.

Configuration Options

traverse-md can be extended with future updates. The current implementation writes the folder structure in the README.md file automatically, ensuring a neat, collapsible section. Custom configurations can be added by modifying the codebase to accept parameters for output format or additional information (e.g., file sizes).

Contributing

I welcome contributions to enhance traverse-md! Here are ways to get involved:

  1. Report issues: If you find bugs, report them on the GitHub issues page.
  2. Submit PRs: Fork the repository and submit pull requests for improvements.
  3. Feature requests: Let us know what features you'd like to see in future versions.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Directory Structure

└── .github └── workflows ├── npm-publish.yml ├── .gitignore ├── index.js ├── package-lock.json ├── package.json ├── README.md

End Directory Structure

1.1.1

10 months ago

1.1.0

10 months ago

1.0.0

10 months ago