diff --git a/Create user-facing docs from your codebase.md b/Create user-facing docs from your codebase.md index cc883a616..2e3b7dc21 100644 --- a/Create user-facing docs from your codebase.md +++ b/Create user-facing docs from your codebase.md @@ -1,6 +1,4 @@ - - - # How to Use and Customize the "Populate External Docs" Command in the VS Code Extension +# How to Use and Customize the "Populate External Docs" Command in the VS Code Extension ## Step 1: Access the Command @@ -8,7 +6,6 @@ 2. Press `Cmd+Shift+P` (Mac) or `Ctrl+Shift+P` (Windows/Linux) to open the command palette 3. Type "Populate External Docs" and select the command - ## Step 2: Customizing Generation with dev-docs.json To customize the documentation generation, modify the `dev-docs.json` file in your project root: @@ -48,6 +45,13 @@ After running the command: 2. Review and edit the generated content as needed 3. Commit changes to your repository -By following these steps and customizing the `dev-docs.json`, you can efficiently generate and manage external documentation for your project using the VS Code extension. +## Step 4: Refine and Iterate + +To improve the quality of generated documentation: + +1. Analyze the initial output and identify areas for improvement +2. Adjust the `externalDocPrompt` in `dev-docs.json` to provide more specific guidance +3. Re-run the "Populate External Docs" command to generate updated documentation +4. Repeat this process until you achieve the desired level of detail and accuracy - \ No newline at end of file +By following these steps and customizing the `dev-docs.json`, you can efficiently generate, manage, and refine external documentation for your project using the VS Code extension. \ No newline at end of file diff --git a/blog/Static Generated Sites are You Need.md b/blog/Static Generated Sites are You Need.md index cf6ff6ce8..ef3765d0c 100644 --- a/blog/Static Generated Sites are You Need.md +++ b/blog/Static Generated Sites are You Need.md @@ -1,55 +1,61 @@ --- -title: Why a Static Generated Site is the Best Choice for Developer Docs and Landing Pages +title: Why Static Generated Sites are What You Need for Developer Docs and Landing Pages authors: andrew header_image: /img/dev-docs-assets/ClippedHeroBg.png text_color: white -tags: [markdown, docusaurus, developerdocs] +tags: [markdown, docusaurus, developerdocs, staticsite] --- -# Why a Static Generated Site is the Best Choice for Developer Docs and Landing Pages +# Why Static Generated Sites are What You Need for Developer Docs and Landing Pages -In the fast-paced world of software development, efficient documentation is crucial. Static generated sites, particularly those using Markdown and platforms like GitHub and Docusaurus, offer an optimal solution for developer docs and landing pages. Here's why: +In the ever-evolving landscape of software development, efficient and accessible documentation is paramount. Static generated sites, particularly those utilizing Markdown and platforms like GitHub and Docusaurus, offer an unparalleled solution for developer docs and landing pages. Here's why they're exactly what you need: ## 1. Simplicity and Speed with Markdown -Static site generators like Docusaurus leverage Markdown, allowing developers to create lightning-fast documentation. Pages load instantly, enhancing user experience and reducing bounce rates. +Static site generators like Docusaurus harness the power of Markdown, enabling developers to create blazing-fast documentation. Pages load in the blink of an eye, significantly enhancing user experience and reducing bounce rates. ## 2. Cost-Effective Hosting on GitHub or Vercel -Hosting developer docs on platforms like GitHub Pages is incredibly cost-effective, often free. This is perfect for open-source projects and startups looking to minimize expenses. +Hosting developer docs on platforms like GitHub Pages or Vercel is incredibly cost-effective, often completely free. This is ideal for open-source projects and startups aiming to minimize overhead costs. ## 3. Enhanced Security for Developer Docs -Static sites, including those built with Docusaurus, are inherently more secure. With no dynamic content or databases, there are fewer vulnerabilities for potential attackers to exploit. +Static sites, including those built with Docusaurus, are inherently more secure. With no dynamic content or databases to manage, there are significantly fewer vulnerabilities for potential attackers to exploit. ## 4. Version Control with GitHub -Integrating your developer docs with GitHub allows for seamless version control. This makes collaboration easier and provides a comprehensive history of documentation changes. +Integrating your developer docs with GitHub allows for seamless version control. This not only facilitates easier collaboration but also provides a comprehensive history of documentation changes. ## 5. Focus on Content with Markdown -Markdown, the preferred format for many static site generators, allows developers to focus on writing clear, concise documentation without worrying about complex formatting. +Markdown, the preferred format for many static site generators, allows developers to concentrate on writing clear, concise documentation without getting bogged down by complex formatting issues. ## 6. SEO-Friendly Developer Docs -Static sites built with tools like Docusaurus are easily crawlable by search engines. Their fast load times and structured content contribute to better SEO rankings for your developer docs. +Static sites built with tools like Docusaurus are easily crawlable by search engines. Their rapid load times and structured content contribute to better SEO rankings for your developer docs. ## 7. Easy Maintenance with Docusaurus -Once set up, maintaining developer docs on a static site is straightforward. Docusaurus makes it easy to update content without dealing with complex CMS systems. +Once set up, maintaining developer docs on a static site is straightforward. Docusaurus simplifies the process of updating content without the need to wrestle with complex CMS systems. ## 8. Scalability for Growing Projects -Static sites can handle high traffic volumes, making them ideal for popular open-source projects hosted on GitHub with extensive developer docs. +Static sites can effortlessly handle high traffic volumes, making them perfect for popular open-source projects hosted on GitHub with extensive developer docs. ## 9. Modern Development Workflow -Static site generators like Docusaurus integrate well with modern development tools and practices, facilitating continuous integration and deployment of your developer docs. +Static site generators like Docusaurus integrate seamlessly with modern development tools and practices, facilitating continuous integration and deployment of your developer docs. ## 10. Flexibility with Markdown and JavaScript -Despite being "static," these sites can incorporate dynamic elements through JavaScript and APIs, giving your developer docs the best of both worlds. +While "static" by nature, these sites can incorporate dynamic elements through JavaScript and APIs, providing your developer docs with the best of both worlds. -In conclusion, for developer docs and landing pages, a static generated site using Markdown and tools like Docusaurus provides an excellent balance of simplicity, performance, and functionality. It's a powerful approach that can help your project's documentation stand out on platforms like GitHub. +## 11. Customization and Theming - +Static site generators often offer extensive customization options. With Docusaurus, you can easily apply themes and styles to match your brand identity, ensuring your developer docs look professional and cohesive. + +## 12. Community Support and Plugins + +The vibrant community around static site generators like Docusaurus provides a wealth of plugins and extensions. This ecosystem allows you to extend the functionality of your developer docs with features like search, analytics, and interactive components. + +In conclusion, for developer docs and landing pages, static generated sites using Markdown and tools like Docusaurus provide an optimal balance of simplicity, performance, and functionality. They're not just a trend, but a robust solution that can elevate your project's documentation, making it stand out on platforms like GitHub and beyond. \ No newline at end of file diff --git a/dev-docs/context-docs-editor-modify a draft.md.md b/dev-docs/context-docs-editor-modify a draft.md.md index 90a9f287e..db5ca4407 100644 --- a/dev-docs/context-docs-editor-modify a draft.md.md +++ b/dev-docs/context-docs-editor-modify a draft.md.md @@ -1,9 +1,7 @@ - - - --- +--- # High Level Context ## context -This Markdown file provides step-by-step instructions on how to modify a previously published draft in a content management system or editor interface. The document outlines three main steps: +This Markdown file provides step-by-step instructions on how to Modify a Draft that was previously published in a content management system or editor interface. The document outlines three main steps: 1. Navigating to the "Published" section under "DRAFTS" in the sidebar and selecting the draft to modify. 2. Loading the selected draft's content in the main editing area for review. @@ -11,4 +9,7 @@ This Markdown file provides step-by-step instructions on how to modify a previou The instructions are accompanied by images to illustrate each step visually, making it easier for users to follow the process. This guide is likely part of a larger user manual or documentation for a content management or editing platform. - \ No newline at end of file +## Additional Information +- The system may include a versioning feature that allows users to view and compare different versions of the draft. +- Users should be aware that modifying a published draft might affect its visibility or status on the live site. +- It's recommended to preview changes before moving the draft back to the published state to ensure all modifications appear as intended. \ No newline at end of file diff --git a/docs/chat.md b/docs/chat.md new file mode 100644 index 000000000..8ff3cceec --- /dev/null +++ b/docs/chat.md @@ -0,0 +1,75 @@ +# chat Documentation + +## Brief Description +The `chat` method enables communication with an AI model, allowing for multi-turn conversations and the inclusion of images in messages. + +## Usage +To use the `chat` method, you need to create an instance of the Ollama class and then call the `chat` method with the appropriate parameters. + +```javascript +import { Ollama } from 'ollama-js'; + +const ollama = new Ollama(); +const response = await ollama.chat(chatRequest); +``` + +## Parameters +- `request` (ChatRequest): An object containing the following properties: + - `model` (string, required): The name of the model to use for the chat. + - `messages` (Message[], optional): An array of message objects representing the conversation history. + - `stream` (boolean, optional): If true, the response will be streamed. + - `format` (string | object, optional): The desired format for the response. + - `keep_alive` (string | number, optional): Duration to keep the model loaded in memory. + - `tools` (Tool[], optional): An array of tool objects that the model can use. + - `options` (Partial, optional): Additional options for the chat request. + +## Return Value +The `chat` method returns a Promise that resolves to either: +- `ChatResponse`: An object containing the model's response and metadata. +- `AbortableAsyncIterator`: An async iterator that yields response messages if streaming is enabled. + +## Examples + +### Basic chat example +```javascript +const response = await ollama.chat({ + model: 'llama2', + messages: [{ role: 'user', content: 'Hello, how are you?' }] +}); +console.log(response.message.content); +``` + +### Chat with streaming +```javascript +const stream = await ollama.chat({ + model: 'llama2', + messages: [{ role: 'user', content: 'Tell me a story' }], + stream: true +}); + +for await (const chunk of stream) { + process.stdout.write(chunk.message.content); +} +``` + +### Chat with image +```javascript +const response = await ollama.chat({ + model: 'llava', + messages: [ + { + role: 'user', + content: 'What's in this image?', + images: ['...'] + } + ] +}); +console.log(response.message.content); +``` + +## Notes or Considerations +- Images in messages can be provided as base64 encoded strings or file paths. +- The `stream` option allows for real-time responses, which is useful for long-running conversations. +- When using tools, ensure they are properly defined in the `tools` array of the request. +- The `keep_alive` option can be used to optimize performance for multiple requests to the same model. +- Error handling should be implemented to manage potential issues with the AI model or network connectivity. \ No newline at end of file diff --git a/docs/create.md b/docs/create.md new file mode 100644 index 000000000..fc98bc140 --- /dev/null +++ b/docs/create.md @@ -0,0 +1,64 @@ +# create Documentation + +## Brief Description +The `create` method creates a new model from a stream of data or a modelfile. + +## Usage +To use the `create` method, you need to import the Ollama class and instantiate it. Then you can call the `create` method on the instance. + +```javascript +import { Ollama } from 'ollama' + +const ollama = new Ollama() +``` + +## Parameters +The `create` method accepts a `CreateRequest` object with the following properties: + +- `model` (string, required): The name of the model to create. +- `path` (string, optional): The path to the modelfile. +- `modelfile` (string, optional): The content of the modelfile. +- `stream` (boolean, optional): Whether to stream the response. +- `quantize` (string, optional): The quantization level for the model. + +Note: You must provide either `path` or `modelfile`, but not both. + +## Return Value +The `create` method returns a Promise that resolves to either: + +- A `ProgressResponse` object if `stream` is false or not specified. +- An `AbortableAsyncIterator` if `stream` is true. + +## Examples + +1. Creating a model from a modelfile path: + +```javascript +const response = await ollama.create({ + model: 'my-new-model', + path: '/path/to/modelfile' +}) +console.log(response) +``` + +2. Creating a model with streaming progress: + +```javascript +const stream = await ollama.create({ + model: 'my-streaming-model', + modelfile: 'FROM llama2\n\nSYSTEM You are a helpful assistant.', + stream: true +}) + +for await (const chunk of stream) { + console.log(chunk.status) +} +``` + +## Notes or Considerations + +- If you provide a `path`, the method will read the modelfile content and parse it before sending the request. +- The method supports automatic parsing of `FROM` and `ADAPTER` commands in the modelfile, replacing them with corresponding blob hashes if the files exist. +- When using `stream: true`, you can abort the operation by calling the `abort()` method on the returned `AbortableAsyncIterator`. +- The `create` method may throw an error if neither `path` nor `modelfile` is provided. +- Be cautious when using large modelfiles, as they may consume significant resources during the creation process. \ No newline at end of file diff --git a/docs/dev-docs-vscode-extension-core-features-and-use-cases.md b/docs/dev-docs-vscode-extension-core-features-and-use-cases.md new file mode 100644 index 000000000..5658a1b3d --- /dev/null +++ b/docs/dev-docs-vscode-extension-core-features-and-use-cases.md @@ -0,0 +1,57 @@ + + + # Dev-Docs VS Code Extension: Core Features and Use Cases + +Dev-Docs is a powerful VS Code extension designed to streamline and enhance the documentation process for developers. Here's an overview of its core features and use cases for different developer roles: + +## Core Features + +1. AI-Powered Documentation Generation +2. Context-Aware Documentation +3. External and Internal Documentation Management +4. Version Control Integration +5. Customizable Documentation Workflows +6. API Documentation Generation +7. Missing Documentation Detection +8. Documentation Auditing +9. Interactive Q&A with Your Codebase + +## Use Cases for Different Developer Roles + +### For Individual Developers + +1. **Rapid Documentation Creation**: Quickly generate documentation for your code using AI-assisted tools. +2. **Code Understanding**: Use the "Ask Dev-Docs A Question" feature to understand complex parts of the codebase. +3. **Personal Knowledge Base**: Create and maintain a personal documentation repository for your projects. + +### For Team Leaders and Project Managers + +1. **Onboarding Acceleration**: Generate comprehensive project overviews and architecture documentation to help new team members get up to speed quickly. +2. **Documentation Standardization**: Enforce consistent documentation practices across the team using customizable templates and AI-generated content. +3. **Project Health Monitoring**: Use the documentation auditing feature to identify areas of the codebase that need better documentation. + +### For Open Source Maintainers + +1. **Community Documentation**: Easily create and maintain user-facing documentation for your open-source projects. +2. **Contribution Guidelines**: Generate and keep updated contribution guidelines and project structure documentation. +3. **API References**: Automatically generate and update API documentation as your project evolves. + +### For Technical Writers + +1. **Content Generation Assistance**: Use AI-powered features to generate initial drafts of technical documentation. +2. **Documentation Gap Analysis**: Identify missing documentation and generate suggestions for new content. +3. **Integration with Existing Workflows**: Seamlessly integrate Dev-Docs into existing documentation processes and version control systems. + +### For QA Engineers + +1. **Test Documentation**: Generate documentation for test cases and testing procedures directly from the codebase. +2. **Feature Documentation Review**: Use the generated documentation to cross-reference with actual implemented features. + +### For DevOps Engineers + +1. **Infrastructure Documentation**: Generate and maintain documentation for deployment processes and infrastructure setup. +2. **Configuration Management**: Document configuration files and environment variables with context-aware features. + +By leveraging these features, Dev-Docs empowers developers across different roles to create, maintain, and improve documentation efficiently, leading to better code understanding, improved collaboration, and streamlined development processes. + + \ No newline at end of file diff --git a/docs/encodeImage.md b/docs/encodeImage.md new file mode 100644 index 000000000..95f8418dc --- /dev/null +++ b/docs/encodeImage.md @@ -0,0 +1,33 @@ +# encodeImage Documentation + +## Brief Description +The `encodeImage` method converts image data to a base64-encoded string, supporting both Uint8Array and string inputs. + +## Usage +This method is used internally by the Ollama class to prepare image data for API requests. It's not typically called directly by users. + +## Parameters +- `image` (Uint8Array | string): The image data to encode. Can be a Uint8Array of raw image data or a string (potentially already base64 encoded). + +## Return Value +- `Promise`: A Promise that resolves to the base64-encoded image string. + +## Examples + +```javascript +const ollama = new Ollama(); + +// Example with a Uint8Array +const imageData = new Uint8Array([/* ... */]); // Raw image data +const encodedImage = await ollama.encodeImage(imageData); + +// Example with a string (potentially already base64 encoded) +const base64String = "..."; +const encodedImage = await ollama.encodeImage(base64String); +``` + +## Notes or Considerations +- This method is primarily used internally by other Ollama methods that handle image inputs. +- If a string is provided, the method assumes it might already be base64 encoded and returns it as-is. +- For Uint8Array inputs, the method performs the base64 encoding. +- This method is asynchronous and returns a Promise, so remember to use `await` or `.then()` when calling it. \ No newline at end of file diff --git a/docs/generate.md b/docs/generate.md new file mode 100644 index 000000000..8d06a457e --- /dev/null +++ b/docs/generate.md @@ -0,0 +1,58 @@ +# generate Documentation + +## Brief Description +The `generate` method creates a response from a text prompt using a specified AI model. + +## Usage +To use `generate`, you need to create an instance of the Ollama class and call the `generate` method with the appropriate parameters. + +```javascript +import { Ollama } from 'ollama' + +const ollama = new Ollama() +const response = await ollama.generate(request) +``` + +## Parameters +The `generate` method accepts a single parameter: + +- `request` (Required): An object of type `GenerateRequest` with the following properties: + - `model` (Required): String - The name of the model to use. + - `prompt` (Required): String - The input text to generate a response from. + - `stream` (Optional): Boolean - Whether to stream the response or not. + - `options` (Optional): Object - Additional options for generation (e.g., temperature, top_k, etc.). + +## Return Value +The `generate` method returns a Promise that resolves to either: +- A `GenerateResponse` object if `stream` is false or not specified. +- An `AbortableAsyncIterator` if `stream` is true. + +## Examples + +### Basic usage: +```javascript +const response = await ollama.generate({ + model: 'llama2', + prompt: 'Tell me a joke about programming' +}) +console.log(response.response) +``` + +### Streaming response: +```javascript +const stream = await ollama.generate({ + model: 'llama2', + prompt: 'Write a short story', + stream: true +}) + +for await (const chunk of stream) { + console.log(chunk.response) +} +``` + +## Notes or Considerations +- The `generate` method can handle images as part of the input. If `images` are provided in the request, they will be automatically encoded. +- Streaming allows for real-time processing of the generated response, which can be useful for long-form content or interactive applications. +- The specific options available in the `options` object may vary depending on the model being used. +- Error handling should be implemented when using this method, as network issues or invalid requests may occur. \ No newline at end of file diff --git a/docs/pull.md b/docs/pull.md new file mode 100644 index 000000000..e5be1cb4a --- /dev/null +++ b/docs/pull.md @@ -0,0 +1,52 @@ +# pull Documentation + +## Brief Description +The `pull` method downloads a model from the Ollama registry, with the option to stream the progress. + +## Usage +To use the `pull` method, you need to create an instance of the Ollama class and call the `pull` method with a `PullRequest` object. + +```javascript +import Ollama from 'ollama' + +const ollama = new Ollama() +const response = await ollama.pull({ model: 'modelname' }) +``` + +## Parameters +The `pull` method accepts a `PullRequest` object with the following properties: + +- `model` (string, required): The name of the model to pull from the Ollama registry. +- `insecure` (boolean, optional): Whether to allow insecure connections when pulling the model. +- `stream` (boolean, optional): If set to `true`, the method will return a stream of progress responses. + +## Return Value +The `pull` method returns a Promise that resolves to either: + +- A `ProgressResponse` object if `stream` is `false` or not specified. +- An `AbortableAsyncIterator` if `stream` is `true`. + +The `ProgressResponse` object contains information about the pull progress, including status, digest, total, and completed values. + +## Examples + +### Basic usage: +```javascript +const response = await ollama.pull({ model: 'llama2' }) +console.log(response.status) +``` + +### Streaming progress: +```javascript +const stream = await ollama.pull({ model: 'llama2', stream: true }) +for await (const chunk of stream) { + console.log(`Progress: ${chunk.completed}/${chunk.total}`) +} +``` + +## Notes or Considerations +- The `pull` method allows you to download models from the Ollama registry to your local environment. +- When using the streaming option, you can track the progress of the download in real-time. +- If you need to cancel an ongoing pull operation, you can use the `abort()` method on the returned `AbortableAsyncIterator`. +- Ensure you have a stable internet connection when pulling large models. +- The `insecure` option should be used with caution and only when necessary, as it may pose security risks. \ No newline at end of file diff --git a/docs/push.md b/docs/push.md new file mode 100644 index 000000000..affbd1d0a --- /dev/null +++ b/docs/push.md @@ -0,0 +1,46 @@ +# push Documentation + +## Brief Description +The `push` method pushes a model to the Ollama registry, allowing for optional streaming of the progress. + +## Usage +To use the `push` method, you need to create an instance of the Ollama class and then call the `push` method with the required parameters. + +```javascript +import Ollama from 'ollama' + +const ollama = new Ollama() +``` + +## Parameters +- `request` (object, required): An object containing the following properties: + - `model` (string, required): The name of the model to push. + - `stream` (boolean, optional): If set to `true`, the method will return a stream of progress responses. + - `insecure` (boolean, optional): If set to `true`, allows insecure connections for pushing the model. + +## Return Value +The `push` method returns a Promise that resolves to either: +- A `ProgressResponse` object if `stream` is `false` or not specified. +- An `AbortableAsyncIterator` if `stream` is `true`, which yields progress responses. + +## Examples + +### Basic usage: +```javascript +const result = await ollama.push({ model: 'my-model' }) +console.log(result) +``` + +### Streaming progress: +```javascript +const stream = await ollama.push({ model: 'my-model', stream: true }) +for await (const progress of stream) { + console.log(`Push progress: ${progress.status}`) +} +``` + +## Notes or Considerations +- Ensure you have the necessary permissions to push models to the Ollama registry. +- The `insecure` option should be used with caution, as it may compromise the security of the model transfer. +- When using the streaming option, remember to handle potential errors and the end of the stream appropriately. +- The push operation may take some time depending on the size of the model and your network speed. \ No newline at end of file diff --git a/docs/quick-start-guide.md b/docs/quick-start-guide.md new file mode 100644 index 000000000..14015edec --- /dev/null +++ b/docs/quick-start-guide.md @@ -0,0 +1,57 @@ +# Dev-Docs Quick Start Guide + +## 1. Install the VS Code Extension + +Install the [Dev-Docs VS Code extension](https://marketplace.visualstudio.com/items?itemName=dev-docs.dev-docs) from the Visual Studio Code Marketplace. + +## 2. Set Up Your Repository + +1. Open your project in VS Code +2. Click the Dev-Docs icon in the Activity Bar +3. Click "Setup my repo" +4. Click "Generate Context" to create initial documentation + +## 3. Generate Documentation + +### From VS Code: +1. Right-click in a code file +2. Select "Generate Documentation" +3. Or use the shortcut: + - Mac: `Shift + Command + D` + - Windows/Linux: `Shift + Ctrl + D` + +### From GitHub: +1. Install the Dev-Docs GitHub App +2. Configure your `dev-docs.json` file: + +```json +{ + "gitHubApp": { + "workflows": ["generateDocs"] + } +} +``` + +3. Commit and push changes to trigger automatic doc generation + +## 4. Customize Generation + +Edit `dev-docs.json` to customize AI-powered doc generation: + +```json +{ + "ai": { + "internalTypeFilters": ["class", "method", "function"], + "contextPrompt": "Generate comprehensive API documentation", + "defaultLength": "3-5 Sentences" + } +} +``` + +## 5. View and Edit Documentation + +1. Check the `docs` folder for generated Markdown files +2. Use the web editor to make changes and add content +3. Leverage AI features like "Generate Content from Existing Content" + +For more details, see the [full documentation](https://dev-docs.io/docs). \ No newline at end of file diff --git a/docs/troubleshooting.md b/docs/troubleshooting.md new file mode 100644 index 000000000..a856caf33 --- /dev/null +++ b/docs/troubleshooting.md @@ -0,0 +1,49 @@ +# Troubleshooting Guide + +## Common Issues and Solutions + +### 1. API Key Not Working + +If your API key is not being recognized: + +- Ensure you have copied the full API key without any extra spaces +- Check that you have the correct permissions enabled for your API key +- Try regenerating a new API key in your account settings + +### 2. Documentation Not Generating + +If documentation is not being generated: + +- Verify that your dev-docs.json file is properly configured +- Check that you have selected the correct files/folders to document +- Ensure you have an active internet connection +- Try restarting the VS Code extension + +### 3. AI Generation Errors + +If you encounter errors during AI-assisted generation: + +- Check your OpenAI API key and usage limits +- Try reducing the amount of context provided +- Break up large generation tasks into smaller chunks +- Wait a few minutes and try again if the AI service is overloaded + +### 4. GitHub Integration Issues + +For problems with GitHub integration: + +- Confirm your GitHub Personal Access Token has the necessary permissions +- Ensure the GitHub App is properly installed on your repository +- Check that your repository URL is correctly specified in settings +- Try disconnecting and reconnecting your GitHub account + +### 5. Markdown Rendering Problems + +If markdown is not rendering properly: + +- Validate your markdown syntax for any errors +- Check for unsupported markdown extensions +- Ensure all referenced images/assets exist and have correct paths +- Try viewing the markdown in a different renderer to isolate the issue + +If you continue to experience issues after trying these solutions, please contact our support team for further assistance. \ No newline at end of file