diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS new file mode 100644 index 00000000..dbd44b4a --- /dev/null +++ b/.github/CODEOWNERS @@ -0,0 +1 @@ +*.ts @coderabbitai/typescript-reviewers diff --git a/.github/workflows/node.js.yaml b/.github/workflows/node.js.yaml new file mode 100644 index 00000000..ca205b40 --- /dev/null +++ b/.github/workflows/node.js.yaml @@ -0,0 +1,24 @@ +name: Node.js CI + +on: + push: + branches: main + pull_request: + branches: main + +jobs: + test: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + - uses: pnpm/action-setup@v4 + with: + version: latest + - uses: actions/setup-node@v4 + with: + node-version: latest + cache: pnpm + - run: pnpm install --frozen-lockfile --strict-peer-dependencies + - run: pnpm run build + - run: pnpm run lint diff --git a/.markdownlint-cli2.yaml b/.markdownlint-cli2.yaml new file mode 100644 index 00000000..7d4928b0 --- /dev/null +++ b/.markdownlint-cli2.yaml @@ -0,0 +1 @@ +gitignore: true diff --git a/.markdownlint.json b/.markdownlint.json deleted file mode 100644 index 0715438c..00000000 --- a/.markdownlint.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "default": true, - "MD013": false, - "MD051": false, - "MD033": false, - "MD024": { - "siblings_only": true - } -} diff --git a/.markdownlint.yaml b/.markdownlint.yaml new file mode 100644 index 00000000..4acc2ef4 --- /dev/null +++ b/.markdownlint.yaml @@ -0,0 +1,8 @@ +default: true +first-line-heading: false +line-length: false +link-fragments: false +no-duplicate-heading: + siblings_only: true +no-inline-html: false +single-title: false diff --git a/.markdownlintrc b/.markdownlintrc deleted file mode 120000 index db8c7ef1..00000000 --- a/.markdownlintrc +++ /dev/null @@ -1 +0,0 @@ -.markdownlint.json \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 120000 index 00000000..1cf57d4c --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1 @@ +./docs/changelog.md \ No newline at end of file diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 8897a10d..6494fa7c 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -24,25 +24,30 @@ There are various ways you can contribute: 1. **Fork** the repository to your GitHub account by visiting [CodeRabbit Docs GitHub repo](https://github.com/coderabbitai/coderabbit-docs). 2. **Clone** your fork locally: + ```shell git clone git@github.com:YOUR_USERNAME/coderabbit-docs.git + ``` + 3. Create a new branch: -```shell -git checkout -b your_username/feature_description -``` + + ```shell + git checkout -b your_username/feature_description + ``` 4. Implement the changes then commit and push the changes from your working branch: -```shell -git commit -m "docs: add explanation about [section]" -git push origin your_username/feature_description -``` + + ```shell + git commit -m "docs: add explanation about [section]" + git push origin your_username/feature_description + ``` ## Commit Message Format 💬 We require all commits in this repository to adhere to the following commit message format. -``` +```txt : (#) [optional body] @@ -52,7 +57,9 @@ This format is based on [Conventional Commits](https://www.conventionalcommits.o Please refer to the Conventional Commits specification for more details. ## Keeping your Fork Up-to-Date 🆕 + To keep your fork updated with the latest changes from the upstream repository: + ```shell git remote add upstream https://github.com/coderabbitai/coderabbit-docs.git git fetch upstream @@ -64,4 +71,4 @@ git rebase upstream/main - Work on **one issue at a time** to avoid confusion. - If you need help, post in the `#support` channel on Discord. - Test your changes locally before submitting a PR. -- While AI is cool, minimize its use for `direct team communication`. We value concise, genuine exchanges over scripted messages. \ No newline at end of file +- While AI is cool, minimize its use for _direct team communication_. We value concise, genuine exchanges over scripted messages. diff --git a/README.md b/README.md index 65686176..775bcadb 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,7 @@ Welcome to the official docs for [**CodeRabbit**](https://coderabbit.ai), the co [![Twitter Follow](https://img.shields.io/twitter/follow/coderabbitai?style=social)](https://twitter.com/coderabbitai) [![Discord](https://img.shields.io/discord/invite-code?color=7289DA&label=Discord&logo=discord&logoColor=green)](https://discord.com/invite/GsXnASn26c) [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)](https://github.com/coderabbitai/coderabbit-docs/pulls) +[![Node.js CI](https://github.com/coderabbitai/coderabbit-docs/actions/workflows/node.js.yaml/badge.svg)](https://github.com/coderabbitai/coderabbit-docs/actions/workflows/node.js.yaml) ## About CodeRabbit @@ -155,28 +156,28 @@ CodeRabbit uses the following order of precedence for configuration: 1. Clone this repository: -```bash -git clone https://github.com/coderabbit-ai/coderabbit-docs.git -cd coderabbit-docs -``` + ```sh + git clone https://github.com/coderabbit-ai/coderabbit-docs.git + cd coderabbit-docs + ``` 2. Install dependencies: -```bash -pnpm install -``` + ```sh + pnpm install + ``` 3. Start the development server: -```bash -pnpm start -``` + ```sh + pnpm start + ``` -This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server. + This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server. ## Project Structure -``` +```sh coderabbit-docs/ ├── blog/ ├── docs/ @@ -192,7 +193,7 @@ coderabbit-docs/ ## Local Development -``` +```sh docusaurus start ``` @@ -200,7 +201,7 @@ This command starts a local development server and opens up a browser window. ## Building for Production -``` +```sh docusaurus build ``` diff --git a/docs/Future Development.md b/docs/Future Development.md index 1f003b37..50dcc836 100644 --- a/docs/Future Development.md +++ b/docs/Future Development.md @@ -4,60 +4,60 @@ sidebar_label: Future Development description: Learn how CodeRabbit works in a pull request review. --- -# Future Developments +# Future Developments We are actively iterating and refining CodeRabbit, and this is a sneak peek into the upcoming milestones and releases. We are focused on making the Applied AI review better than the median manual review. In addition to that, we are looking at a holistic user experience with various integrations and types of reviews. -## Applied AI Improvements +## Applied AI Improvements -We are actively trying to make the application of Generative AI more useful , relevant , meaningful for the coder and reviewer journey. Our immediate focus is +We are actively trying to make the application of Generative AI more useful , relevant , meaningful for the coder and reviewer journey. Our immediate focus is -### Accuracy and Conciseness Enhancements +### Accuracy and Conciseness Enhancements -- Refining knowledge base context understanding -- Implementing advanced summarization techniques -- Implementing a knowledge base feature library +- Refining knowledge base context understanding +- Implementing advanced summarization techniques +- Implementing a knowledge base feature library ### Learning Refinements -- We have made significant improvement of the learning Enhancing reinforcement learning based on the user feedback +- We have made significant improvement of the learning Enhancing reinforcement learning based on the user feedback -## New Feature Enhancements +## New Feature Enhancements -### Expanded Integrations +### Expanded Integrations We are integrating various tool chains to enable coders and reviewers to have a consistent experience irrespective of the tools. The immediate tools would be: -- **Circle CI** -- **Jenkins** +- **Circle CI** +- **Jenkins** -### Communication Tool Integrations +### Communication Tool Integrations Communication and the user experience of review via various communication tools are going to be key. We will start with integrations to Slack and Microsoft Teams and will be diving into the design engineering of these flows further: -- **Slack**: Real-time notifications and interactive discussions -- **Microsoft Teams**: Code review conversations within Microsoft ecosystem +- **Slack**: Real-time notifications and interactive discussions +- **Microsoft Teams**: Code review conversations within Microsoft ecosystem -### Enhanced Review Capabilities +### Enhanced Review Capabilities These are additional capabilities that can also be reviewed in the same PR to accelerate the coder and reviewer journey. This includes pipeline failure analysis and resolution, as well as vulnerability assessment. -#### Pipeline Failure Analysis +#### Pipeline Failure Analysis - Automated analysis of CI/CD pipeline failures - AI-driven suggestions for resolving issues - Historical tracking of pipeline performance -### Finishing Touches +### Finishing Touches Finishing touches are about experience that often take developers time away from what they like doing best - coding. But adding finishing touches is crucial and should follow the ontology and taxonomy. We will start by looking into Docstring and expand to various areas to solve pain points for coders and reviewers. #### 1. DocString Review -- Automated checks for docstring presence and quality -- AI-powered suggestions for improving documentation -- Resolving Doc-string conflicts in a following PR +- Automated checks for docstring presence and quality +- AI-powered suggestions for improving documentation +- Resolving Doc-string conflicts in a following PR -> Disclaimer: any product roadmap features mentioned below are only meant to outline -> our general product direction. This documentation is for informational purposes +> Disclaimer: any product roadmap features mentioned below are only meant to outline +> our general product direction. This documentation is for informational purposes > only and may not be incorporated into any contract. diff --git a/docs/about/features.md b/docs/about/features.md index 77589260..80ea221e 100644 --- a/docs/about/features.md +++ b/docs/about/features.md @@ -24,7 +24,7 @@ changes. ### 2. Code Review feedback {#code-review-feedback} **Code review** feedback is posted as review comments on the lines of the code that -changed for each file. +changed for each file. > Code suggestions are given in a Diff format, which either be copied or committed within the pull request with a single click. @@ -85,7 +85,7 @@ changes. ### 7. Learnings {#learnings} - **CodeRabbit** learns from user chat interactions to gain tribal knowledge on your -repositories and organization. +repositories and organization. - **CodeRabbit** will apply and update these learnings in future reviews. diff --git a/docs/about/pricing.md b/docs/about/pricing.md index c788d59a..16cebf2d 100644 --- a/docs/about/pricing.md +++ b/docs/about/pricing.md @@ -22,6 +22,7 @@ Find all the information you need about CodeRabbit's plans and how to manage you --- ## Open Source + :::note CodeRabbit Pro is free for all Open Source projects. ::: diff --git a/docs/about/support.md b/docs/about/support.md index e5e15b1c..398951a0 100644 --- a/docs/about/support.md +++ b/docs/about/support.md @@ -8,7 +8,7 @@ Welcome to CodeRabbit Support. Please refer to the following sections for contacting our support team. Our support team will respond back as soon as possible. -## Discord Server +## Discord Server All CodeRabbit users have access to the [CodeRabbit Discord Server](http://discord.gg/coderabbit), where you can ask questions or see what others are doing with CodeRabbit. You will find CodeRabbit users and members of the CodeRabbit team actively engaged. @@ -20,24 +20,24 @@ For assistance from our support team, click the help icon located in the bottom Complete the support ticket by providing your name, email, a description of your issue, and attaching any necessary files. If you are reporting a bug, please provide the GitHub or GitLab organization name. - ![How to Open a Support Ticket-CodeRabbit ](/img/about/cr_support_help_light.png#gh-light-mode-only) ![How to Open a Support Ticket-CodeRabbit ](/img/about/cr_support_help_dark.png#gh-dark-mode-only) :::note -If you are a paying user and cannot access the support ticket form in the CodeRabbit UI for some reason, you can contact CodeRabbit support at the following email address: support@coderabbit.ai. +If you are a paying user and cannot access the support ticket form in the CodeRabbit UI for some reason, you can contact CodeRabbit support at the following email address: [support@coderabbit.ai](mailto:support@coderabbit.ai). ::: ## Customer Responsibilities -> To ensure efficient resolution of issues, customers are expected to +> To ensure efficient resolution of issues, customers are expected to 1. Provide detailed information about the issue. 2. Cooperate with the Support team during troubleshooting. 3. Utilize available self-service resources/docs for basic inquiries. ## Etiquette -Regardless of the method or location through which CodeRabbit provides Support, communication should be professional and respectful. Any communication that is deemed objectionable by CodeRabbit staff is not tolerated. This includes but is not limited to any communication that is abusive or contains profane language. + +Regardless of the method or location through which CodeRabbit provides Support, communication should be professional and respectful. Any communication that is deemed objectionable by CodeRabbit staff is not tolerated. This includes but is not limited to any communication that is abusive or contains profane language. > CodeRabbit reserves the right to terminate Support Services in the event of any such objectionable communication. diff --git a/docs/changelog.md b/docs/changelog.md index 71ec406d..70b6337b 100644 --- a/docs/changelog.md +++ b/docs/changelog.md @@ -6,17 +6,17 @@ sidebar_position: 9 --- ## October 30, 2024 -### Microsoft Teams Integration & Bitbucket Support -Our integration capabilities just got a major upgrade with Microsoft Teams and Bitbucket support. - -- Microsoft Teams integration is with scheduled reporting system and direct notification pipeline to keep your team informed. +### Microsoft Teams Integration & Bitbucket Support -- We've also launched Bitbucket Data Center support with Pull Request integration, offering core review functionality, Pull Request summaries, and direct inline comments for applying review suggestions +Our integration capabilities just got a major upgrade with Microsoft Teams and Bitbucket support. +- Microsoft Teams integration is with scheduled reporting system and direct notification pipeline to keep your team informed. +- We've also launched Bitbucket Data Center support with Pull Request integration, offering core review functionality, Pull Request summaries, and direct inline comments for applying review suggestions ## October 22, 2024 + ### Security and SAST Remediation Improvements - Enabling comprehensive security analysis directly from context within GitHub Checks @@ -26,6 +26,7 @@ Our integration capabilities just got a major upgrade with Microsoft Teams and B - CodeRabbit now automatically detects Semgrep rulesets from default `semgrep.yml` or `semgrep.config.yml` files, eliminating the need for manual configuration ## September 9, 2024 + ### Related PRs and Label suggestions - Possibly related PRs: The walkthrough comment now includes a list of potentially related PRs to help you recall the past context @@ -34,11 +35,13 @@ Our integration capabilities just got a major upgrade with Microsoft Teams and B > Note: Possibly related PRs, automatic label suggestions based on past PRs, learnings, and possibly related issues require data opt-in (enabled by default). ## August 15, 2024 -### New Dashboard + +### New Dashboard We're excited to share our updated dashboard, designed to give you better insights into CodeRabbit review metrics. What's new: + - Flexible Time Selector: Choose different periods to analyze your data - Useful Context: See how learnings, tools, and path instructions are used in reviews - New Visuals: Check out the bar, line, and stats charts for a better understanding @@ -48,11 +51,13 @@ What's new: These updates are here to help you get more from the dashboard. Take a look today! ## July 31, 2024 + ### Promote members to admin You can now promote members in your organization to admins within CodeRabbit. Admins will be able to manage the subscription and the seats for that organization. ## July 16, 2024 + ### New Features and Improvements #### Learnings Page @@ -62,6 +67,7 @@ We're thrilled to announce the new "Learnings" page! Users can now interact with #### Reports (Beta) Page Introducing the beta release of "Reports"! Generate recurring summaries of team performance and PR reviews with features like: + - Scheduling regular report generation - Specifying parameters such as repository, team, user, or label - Selecting report types (Daily Stand-Up, Sprint Report, Release Notes, Custom) @@ -74,6 +80,7 @@ You can now choose whether to auto-generate sequence diagrams in PR Walkthroughs #### Enhanced Tool Settings & New Analysis Tools We've refined the default settings to be less noisy and more actionable. Additionally, we've added new static analysis and security tools: + - Yamllint A linter for YAML files - Gitleaks A lightweight, open-source secret scanner to prevent security breaches - Checkov Scans infrastructure as code for misconfigurations before they become security issues @@ -83,42 +90,55 @@ We've refined the default settings to be less noisy and more actionable. Additio The GitLab integration now offers more flexibility and security. Users can use Personal Access Tokens (PATs) from within their organization to post reviews. This enhancement ensures reviews are posted with appropriate organizational context and permissions, improving traceability and security. ## May 28, 2024 + ### New Features and Improvements #### Sequence Diagrams + CodeRabbit now generates sequence diagrams of code changes, enhancing reviewers' ability to understand the flow of control. #### Auto-Generate PR Titles + Users will now find a new option called auto_title_placeholder and will default to `@coderabbitai` title. This option allows users to put a placeholder title and have CodeRabbit auto-generate one for them when the review process kicks in. #### New Commands + We have introduced new commands for interacting with CodeRabbit, detailed under the "Tips" section of a review walkthrough: + - `@coderabbitai full review`: Conducts a full review from scratch, covering all files again - `@coderabbitai summary`: Regenerates the summary of the PR - `@coderabbitai configuration`: Displays the current CodeRabbit configuration for the repository #### Improved Handling of Closed PRs + We have been observing that many PRs get closed quickly and CodeRabbit continues to review them. PRs get closed quickly for various reasons - changes are too small, the author is confident (perhaps, overly?), or the changes were unnecessary. With this improvement, we now stop the review process midway if we detect that the PR has been closed. ## May 23, 2024 + ### New Features and Improvements #### Review Settings + Users can now select between "Chill" and "Assertive" review tones to tailor feedback styles according to their preferences. The "Assertive" profile posts more comments and nitpicks the code more aggressively, while the "Chill" profile is more relaxed and posts fewer comments. #### More Static Analysis Support + We are continually expanding our support for static analysis tools. We have added support for biome, hadolint, and ast-grep. Update the settings in your .coderabbit.yaml file or head over to the settings page to enable or disable the tools you want to use. #### Tone Settings + Users can now customize CodeRabbit to review code in the style of their favorite characters or personalities. Here are some of our favorite examples: + - Mr. T: "You must talk like Mr. T in all your code reviews. I pity the fool who doesn't!" - Pirate: "Arr, matey! Ye must talk like a pirate in all yer code reviews. Yarrr!" - Snarky Ex-Girlfriend: "You must talk like a snarky ex-girlfriend in all your code reviews. You're welcome." #### Revamped Settings Page + We have redesigned the settings page for a more intuitive layout, enabling users to find and adjust settings quickly. This change was long-time coming; it not only improves the user experience but also allows our development team to add more settings in the future with ease. Going forward, the changes to .coderabbit.yaml will be reflected in the settings page, and vice versa. ## April 18, 2024 + ### Static Analyzers and Linters Integration CodeRabbit now runs static analyzers, linters and provides one-click fixes for the issues identified. AI helps reduce the false positives and focus on the critical findings. CodeRabbit will respect the existing configuration files of these tools if they already exist in the project. For example, if your project already uses ruff and has a ruff.toml file at the root of the project, that will be used. In cases where project configurations are not found, CodeRabbit defaults will be used. Currently, CodeRabbit runs markdownlint, shellcheck, ruff, and languagetool. We will continue to add more tools. The default configuration can be changed through the .coderabbit.yaml file. @@ -126,36 +146,43 @@ CodeRabbit now runs static analyzers, linters and provides one-click fixes for t Are there any specific tools you'd like us to add? Let us know. We'd love to hear your suggestions! ## April 1, 2024 + ### GDPR Compliance Excited to announce that CodeRabbit is now GDPR compliant in accordance with EU regulations! ## March 12, 2024 + ### GitHub Check Fixes CodeRabbit now offers fixes for GitHub Check failures on pull requests. With this change, Check Runs on GitHub that add Annotations to Pull Requests will be used. For example, popular GitHub Actions published by reviewdog (action-golangci-lint, action-staticcheck, action-eslint) and super-linter among many others have the ability to report issues on Pull Requests as annotations. Checks that output logs will be supported shortly. CodeRabbit GitHub App requires permission to read Checks for this feature to work. To enable this, please grant the necessary permissions by visiting the CodeRabbit GitHub app settings under [installation](https://github.com/settings/installations). Support for GitLab will follow. ## March 11, 2024 + ### SOC 2 Type II Compliance -Excited to announce that CodeRabbit is now GDPR compliant in accordance with EU regulations! +CodeRabbit is now SOC 2 Type II compliant to ensure top-tier security, availability, integrity, and privacy for our users. ## March 2, 2024 + ### Enhanced Markdown Review CodeRabbit now offers a more comprehensive review of the markdown changes. In addition to the AI suggestions, we do a thorough check for spelling, grammar, word choice, language style, as well as improvements in paraphrasing and punctuation. ## January 17, 2024 + ### Self-hosted GitLab Integration CodeRabbit now offers integration for self-hosted GitLab. Refer to the [setup instructions](https://docs.coderabbit.ai/integrations/self-hosted-gitlab). ## January 2, 2024 + ### Deep Insights Feature Release Working as recursive autonomous agent, CodeRabbit uses shell scripts to perform complex operations on the entire codebase, verifying changes and providing deeper insights. Here are some uses cases: + - Want to defer implementing the CodeRabbit suggestion to a later time? Ask the bot the create an issue - Generate unit tests - comment `@coderabbitai generate unit tests` for the src/utils.ts - In PR comments, ask the bot to gather insights on your repository including latest commits, frequently changed files, recent contributors etc @@ -164,55 +191,68 @@ Here are some uses cases: Really excited to see how this feature gets used, especially with access to the CLI commands. There are some suggestions in the pull request tips but we are looking forward to seeing additional use cases of how developers use this feature. Please consider sharing your experiences. ## December 18, 2023 + ### Request Changes Workflow Enable Request Changes review workflow for CodeRabbit reviews via .coderabbit.yaml Yaml field request_changes_workflow (default: false). When enabled, review comments are posted as request changes and CodeRabbit review will be marked approved once all the review comments are resolved. ## December 5, 2023 + ### Multiple Features Release #### Learnings + CodeRabbit can now learn from your conversations to fine-tune your reviews. If you encounter inaccurate feedback or something not relevant to your codebase, just let the bot know, and it will remember the context for the future. We understand that coding practices and standards evolve over time. Using the chat, you can inform the bot, and it will remove any existing learnings that are no longer relevant. This feature does not work, if you have opted out of data storage. #### Codebase Verification + Verifies the reference of the changes on the overall codebase and identifies missing changes. #### Jira and Linear Integrations + You can now integrate Jira and Linear into CodeRabbit. This would be used for additional context while reviewing pull requests. If you use any of these systems, we recommend you integrate CodeRabbit. We will be adding more integrations over time. #### Related Issues + Identifies all issues affected by the code changes. This helps understand the impact on the overall product. It also assists in identifying duplicate issues or the impact on any other existing issues. This feature does not work, if you have opted out of data. ## November 5, 2023 + ### Issue Validation CodeRabbit review can now assess the pull request changes against the linked GitHub or GitLab issue. Integration with other workflow systems including Jira and Linear is under development. ## November 1, 2023 + ### Committable Suggestions Review comments can now post committable suggestions that can be committed within the pull request with a single click. ## October 28, 2023 + ### Resolve Command Use `@coderabbitai resolve` to mark all the CodeRabbit review comments as resolved all at once. ## October 23, 2023 + ### CodeRabbit Commands Introducing additional CodeRabbit commands for managing code reviews: + - Pause Reviews: Use `@coderabbitai pause` in a PR comment to halt ongoing reviews - Resume Reviews: Enter `@coderabbitai resume` in a PR comment to continue paused reviews - On-Demand Reviews: Disable automatic reviews for your repository to switch to on-demand reviews. Use `@coderabbitai review` in a PR comment. This command will override all review filters that might be set up in the repository settings and will initiate a one-time review - Help Command: You can at any time post `@coderabbitai help` in a PR comment to get the list of all valid commands ## October 12, 2023 + ### YML File Customization CodeRabbit customizations made easy! You can now customize CodeRabbit using a YML file from your repository. To learn more, refer to our comprehensive documentation on customizing CodeRabbit. ## September 21, 2023 + ### Path-Based Review Instructions This section explains how to add custom code review instructions for the entire project or specific file paths in your project using glob patterns. Developers can provide tailored review guidelines based on the file paths. These instructions are needed only if you want the reviewer to follow specific instructions besides the standard review. @@ -220,17 +260,19 @@ This section explains how to add custom code review instructions for the entire Adding file path prompts allows developers to specify custom instructions for different parts of the codebase. For example, you may want to enforce style guide by file types or directories. Sample Usage: -``` + +```yaml path: **/*.js instructions: Review the javascript code against the google javascript style guide and point out any mismatches ``` -``` +```yaml path: tests/**.* instructions: Review the following unit test code written using the Mocha test library. Ensure that: The code adheres to best practices associated with Mocha. Descriptive test names are used to clearly convey the intent of each test. ``` > Note: +> > - Paths accept glob patterns > - Instructions generally work well for specific additional instructions. However, they are not that effective if you are instructing AI not to do something > - Test the review feedback on pull requests and tailor as necessary diff --git a/docs/guides/review-instructions.md b/docs/guides/review-instructions.md index 8ffa2cb4..791a4e50 100644 --- a/docs/guides/review-instructions.md +++ b/docs/guides/review-instructions.md @@ -17,7 +17,7 @@ This section explains how to add custom code review instructions for the entire project or specific file paths in your project using glob patterns. Developers can provide tailored review guidelines based on the file paths. These instructions are needed only if you want CodeRabbit to follow specific -instructions besides the standard review. +instructions besides the standard review. >For example, you may want to enforce a style guide by file types or directories. diff --git a/docs/introduction.md b/docs/introduction.md index c42558e5..1484af95 100644 --- a/docs/introduction.md +++ b/docs/introduction.md @@ -52,12 +52,12 @@ However, opting out may reduce the level of personalized review feedback. :::tip For open source projects CodeRabbit Pro is **_FREE_**, forever. + - No credit card required - Unlimited public repositories + :::
Start reviewing PR Now
- - diff --git a/docs/platforms/azure-devops.md b/docs/platforms/azure-devops.md index 0751217b..99302194 100644 --- a/docs/platforms/azure-devops.md +++ b/docs/platforms/azure-devops.md @@ -21,14 +21,14 @@ DevOps. consent requests. Please forward these requests to your administrator for approval. -:::warning + :::warning -If you are an administrator, you may approve the applications directly. If not, -please contact your administrator to request approval for the applications. + If you are an administrator, you may approve the applications directly. If not, + please contact your administrator to request approval for the applications. -::: + ::: -![azure devops apps consent](/img/integrations/azure_apps_consent_page.png) + ![azure devops apps consent](/img/integrations/azure_apps_consent_page.png) 3. Once your administrator has approved the applications, click "Continue." 4. You will be redirected to the "Onboarding" page, where you can select the diff --git a/docs/tools/semgrep.md b/docs/tools/semgrep.md index f3d027eb..3098082a 100644 --- a/docs/tools/semgrep.md +++ b/docs/tools/semgrep.md @@ -22,13 +22,11 @@ Semgrep supports the following config files: project's `.coderabbit.yaml` file or setting the "Review → Tools → Semgrep → Config File" field in CodeRabbit's settings page. -> Due to licensing CodeRabbit does not ship with the -> [community-created Semgrep rules](https://github.com/returntocorp/semgrep-rules), -> but you're free to use these in your own `semgrep.yml` config file. +Due to licensing, CodeRabbit does not ship with the [community-created Semgrep rules](https://github.com/returntocorp/semgrep-rules), but you're free to use these in your own `semgrep.yml` config file. -> **NOTE: CodeRabbit will only run Semgrep if your repository contains a Semgrep -> config file. This config must use the default file names or you must define -> the path to this file in the `.coderabbit.yaml` or config UI.** +:::note +CodeRabbit will only run Semgrep if your repository contains a Semgrep config file. This config must use the default file names or you must define the path to this file in the `.coderabbit.yaml` or config UI. +::: ## Links diff --git a/docs/tools/tools.md b/docs/tools/tools.md index 7b5f78ab..42c415bf 100644 --- a/docs/tools/tools.md +++ b/docs/tools/tools.md @@ -89,4 +89,3 @@ Remove extraneous f prefix [Cppcheck]: ./cppcheck.md [CircleCi]: ./circleci.md [Semgrep]: ./semgrep.md - diff --git a/package.json b/package.json index b3fd3b38..07520c20 100644 --- a/package.json +++ b/package.json @@ -1,5 +1,5 @@ { - "name": "coderabbit-docs", + "name": "@coderabbitai/coderabbit-docs", "version": "0.0.0", "private": true, "scripts": { @@ -10,9 +10,11 @@ "deploy": "docusaurus deploy", "clear": "docusaurus clear", "serve": "docusaurus serve", + "lint": "markdownlint-cli2 \"**/*.md\"", + "lint:fix": "markdownlint-cli2 \"**/*.md\" --fix", "write-translations": "docusaurus write-translations", "write-heading-ids": "docusaurus write-heading-ids", - "typecheck": "tsc" + "typecheck": "tsc --noEmit" }, "dependencies": { "@docusaurus/core": "^3.1.1", @@ -32,14 +34,19 @@ }, "devDependencies": { "@docusaurus/module-type-aliases": "^3.1.1", + "@docusaurus/theme-classic": "^3.5.2", "@docusaurus/tsconfig": "^3.1.1", "@docusaurus/types": "^3.1.1", "@types/js-yaml": "^4.0.9", + "@types/node": "^22.8.4", "@types/react": "^18.3.4", "ace-builds": "^1.36.1", "ajv": "^8.17.1", "js-yaml": "^4.1.0", + "markdownlint-cli2": "^0.14.0", + "prettier": "^3.3.3", "react": "^18.3.1", + "sitemap": "^8.0.0", "typescript": "~5.2.2" }, "browserslist": { diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 4714d9b2..669ce02d 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -54,6 +54,9 @@ importers: '@docusaurus/module-type-aliases': specifier: ^3.1.1 version: 3.5.2(acorn@8.14.0)(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/theme-classic': + specifier: ^3.5.2 + version: 3.5.2(@types/react@18.3.12)(acorn@8.14.0)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) '@docusaurus/tsconfig': specifier: ^3.1.1 version: 3.5.2 @@ -63,6 +66,9 @@ importers: '@types/js-yaml': specifier: ^4.0.9 version: 4.0.9 + '@types/node': + specifier: ^22.8.4 + version: 22.8.4 '@types/react': specifier: ^18.3.4 version: 18.3.12 @@ -75,9 +81,18 @@ importers: js-yaml: specifier: ^4.1.0 version: 4.1.0 + markdownlint-cli2: + specifier: ^0.14.0 + version: 0.14.0 + prettier: + specifier: ^3.3.3 + version: 3.3.3 react: specifier: ^18.3.1 version: 18.3.1 + sitemap: + specifier: ^8.0.0 + version: 8.0.0 typescript: specifier: ~5.2.2 version: 5.2.2 @@ -1021,6 +1036,10 @@ packages: resolution: {integrity: sha512-TV7t8GKYaJWsn00tFDqBw8+Uqmr8A0fRU1tvTQhyZzGv0sJCGRQL3JGMI3ucuKo3XIZdUP+Lx7/gh2t3lewy7g==} engines: {node: '>=14.16'} + '@sindresorhus/merge-streams@2.3.0': + resolution: {integrity: sha512-LtoMMhxAlorcGhmFYI+LhPgbPZCkgP6ra1YL604EeF6U98pLlQ3iWIGMdWSC+vWmPBWBNgmDBAhnAobLROJmwg==} + engines: {node: '>=18'} + '@slorber/remark-comment@1.0.0': resolution: {integrity: sha512-RCE24n7jsOj1M0UPvIQCHTe7fI0sFL4S2nwKVWwHyVr/wI/H8GosgsJGyhnsZoGFnD/P2hLf1mSbrrgSLN93NA==} @@ -2417,6 +2436,10 @@ packages: resolution: {integrity: sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + globby@14.0.2: + resolution: {integrity: sha512-s3Fq41ZVh7vbbe2PN3nrW7yC7U7MFVc5c98/iTl9c2GawNMKx/J648KQRW6WKkuU8GIbbh2IXfIRQjOZnXcTnw==} + engines: {node: '>=18'} + gopd@1.0.1: resolution: {integrity: sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==} @@ -2842,6 +2865,9 @@ packages: jsonc-parser@2.2.1: resolution: {integrity: sha512-o6/yDBYccGvTz1+QFevz6l6OBZ2+fMVu2JZ9CIhzsYRX4mjaK5IyX9eldUdCmga16zlgQxyrj5pt9kzuj2C02w==} + jsonc-parser@3.3.1: + resolution: {integrity: sha512-HUgH65KyejrUFPvHFPbqOY0rsFip3Bo5wb4ngvdi1EpCYWUQDC5V+Y7mZws+DLkr4M//zQJoanu1SP+87Dv1oQ==} + jsonfile@6.1.0: resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==} @@ -2878,6 +2904,9 @@ packages: lines-and-columns@1.2.4: resolution: {integrity: sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==} + linkify-it@5.0.0: + resolution: {integrity: sha512-5aHCbzQRADcdP+ATqnDuhhJ/MRIqDkZX5pyjFHRRysS8vZ5AbqGEoFIb6pYHPZ+L/OC2Lc+xT8uHVVR5CAK/wQ==} + loader-runner@4.3.0: resolution: {integrity: sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==} engines: {node: '>=6.11.5'} @@ -2944,9 +2973,31 @@ packages: resolution: {integrity: sha512-o5vL7aDWatOTX8LzaS1WMoaoxIiLRQJuIKKe2wAw6IeULDHaqbiqiggmx+pKvZDb1Sj+pE46Sn1T7lCqfFtg1Q==} engines: {node: '>=16'} + markdown-it@14.1.0: + resolution: {integrity: sha512-a54IwgWPaeBCAAsv13YgmALOF1elABB08FxO9i+r4VFk5Vl4pKokRPeX8u5TCgSsPi6ec1otfLjdOpVcgbpshg==} + hasBin: true + markdown-table@3.0.4: resolution: {integrity: sha512-wiYz4+JrLyb/DqW2hkFJxP7Vd7JuTDm77fvbM8VfEQdmSMqcImWeeRbHwZjBjIFki/VaMK2BhFi7oUUZeM5bqw==} + markdownlint-cli2-formatter-default@0.0.5: + resolution: {integrity: sha512-4XKTwQ5m1+Txo2kuQ3Jgpo/KmnG+X90dWt4acufg6HVGadTUG5hzHF/wssp9b5MBYOMCnZ9RMPaU//uHsszF8Q==} + peerDependencies: + markdownlint-cli2: '>=0.0.4' + + markdownlint-cli2@0.14.0: + resolution: {integrity: sha512-2cqdWy56frU2FTpbuGb83mEWWYuUIYv6xS8RVEoUAuKNw/hXPar2UYGpuzUhlFMngE8Omaz4RBH52MzfRbGshw==} + engines: {node: '>=18'} + hasBin: true + + markdownlint-micromark@0.1.10: + resolution: {integrity: sha512-no5ZfdqAdWGxftCLlySHSgddEjyW4kui4z7amQcGsSKfYC5v/ou+8mIQVyg9KQMeEZLNtz9OPDTj7nnTnoR4FQ==} + engines: {node: '>=18'} + + markdownlint@0.35.0: + resolution: {integrity: sha512-wgp8yesWjFBL7bycA3hxwHRdsZGJhjhyP1dSxKVKrza0EPFYtn+mHtkVy6dvP1kGSjovyG5B8yNP6Frj0UFUJg==} + engines: {node: '>=18'} + mdast-util-directive@3.0.0: resolution: {integrity: sha512-JUpYOqKI4mM3sZcNxmF/ox04XYFFkNwr0CFlrQIkCwbvH0xzMCqkMqAde9wRd80VAhaUrwFwKm2nxretdT1h7Q==} @@ -3007,6 +3058,9 @@ packages: mdn-data@2.0.30: resolution: {integrity: sha512-GaqWWShW4kv/G9IEucWScBx9G1/vsFZZJUO+tD26M8J8z3Kw5RDQjaoZe03YAClgeS/SWPOcb4nkFBTEi5DUEA==} + mdurl@2.0.0: + resolution: {integrity: sha512-Lf+9+2r+Tdp5wXDXC4PcIBjTDtq4UKjCPMQhKIuzpJNW0b96kVqSwW0bT7FhRSfmAiFYgP+SCRvdrDozfh0U5w==} + media-typer@0.3.0: resolution: {integrity: sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==} engines: {node: '>= 0.6'} @@ -3456,6 +3510,10 @@ packages: resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==} engines: {node: '>=8'} + path-type@5.0.0: + resolution: {integrity: sha512-5HviZNaZcfqP95rwpv+1HDgUamezbqdSYTyzjTvwtJSnIH+3vnbmWsItli8OFEndS984VT55M3jduxZbX351gg==} + engines: {node: '>=12'} + picocolors@1.1.1: resolution: {integrity: sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==} @@ -3743,6 +3801,11 @@ packages: resolution: {integrity: sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==} engines: {node: ^10 || ^12 || >=14} + prettier@3.3.3: + resolution: {integrity: sha512-i2tDNA0O5IrMO757lfrdQZCc2jPNDVntV0m/+4whiDfWaTKfMNgR7Qz0NAeGz/nRqF4m5/6CLzbP4/liHt12Ew==} + engines: {node: '>=14'} + hasBin: true + pretty-error@4.0.0: resolution: {integrity: sha512-AoJ5YMAcXKYxKhuJGdcvse+Voc6v1RgnsR3nWcYU7q4t6z0Q6T86sv5Zq8VIRbOWWFpvdGE83LtdSMNd+6Y0xw==} @@ -3779,6 +3842,10 @@ packages: resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==} engines: {node: '>= 0.10'} + punycode.js@2.3.1: + resolution: {integrity: sha512-uxFIHU0YlHYhDQtV4R9J6a52SLx28BCjT+4ieh7IGbgwVJWO+km431c4yRlREUAsAmt/uMjQUyQHNEPf0M39CA==} + engines: {node: '>=6'} + punycode@2.3.1: resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==} engines: {node: '>=6'} @@ -4191,6 +4258,11 @@ packages: engines: {node: '>=12.0.0', npm: '>=5.6.0'} hasBin: true + sitemap@8.0.0: + resolution: {integrity: sha512-+AbdxhM9kJsHtruUF39bwS/B0Fytw6Fr1o4ZAIAEqA6cke2xcoO2GleBw9Zw7nRzILVEgz7zBM5GiTJjie1G9A==} + engines: {node: '>=14.0.0', npm: '>=6.0.0'} + hasBin: true + skin-tone@2.0.0: resolution: {integrity: sha512-kUMbT1oBJCpgrnKoSr0o6wPtvRWT9W9UKvGLwfJYO2WuahZRHOpEyL1ckyMGgMWh0UdpmaoFqKKD29WTomNEGA==} engines: {node: '>=8'} @@ -4203,6 +4275,10 @@ packages: resolution: {integrity: sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==} engines: {node: '>=12'} + slash@5.1.0: + resolution: {integrity: sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg==} + engines: {node: '>=14.16'} + snake-case@3.0.4: resolution: {integrity: sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==} @@ -4435,6 +4511,9 @@ packages: engines: {node: '>=14.17'} hasBin: true + uc.micro@2.1.0: + resolution: {integrity: sha512-ARDJmphmdvUk6Glw7y9DQ2bFkKBHwQHLi2lsaH6PPmz/Ka9sFOBsBluozhDltWmnv9u/cF6Rt87znRTPV+yp/A==} + undici-types@6.19.8: resolution: {integrity: sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==} @@ -4458,6 +4537,10 @@ packages: resolution: {integrity: sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==} engines: {node: '>=4'} + unicorn-magic@0.1.0: + resolution: {integrity: sha512-lRfVq8fE8gz6QMBuDM6a+LO3IAzTi05H6gCVaUpir2E1Rwpo4ZUog45KpNXKC/Mn3Yb9UDuHumeFTo9iV/D9FQ==} + engines: {node: '>=18'} + unified@11.0.5: resolution: {integrity: sha512-xKvGhPWw3k84Qjh8bI3ZeJjqnyadK+GEFtazSfZv/rKeTkTjOJho6mFqh2SM96iIcZokxiOpg78GazTSg8+KHA==} @@ -6436,6 +6519,8 @@ snapshots: '@sindresorhus/is@5.6.0': {} + '@sindresorhus/merge-streams@2.3.0': {} + '@slorber/remark-comment@1.0.0': dependencies: micromark-factory-space: 1.1.0 @@ -6713,7 +6798,7 @@ snapshots: '@types/sax@1.2.7': dependencies: - '@types/node': 17.0.45 + '@types/node': 22.8.4 '@types/send@0.17.4': dependencies: @@ -8003,6 +8088,15 @@ snapshots: merge2: 1.4.1 slash: 4.0.0 + globby@14.0.2: + dependencies: + '@sindresorhus/merge-streams': 2.3.0 + fast-glob: 3.3.2 + ignore: 5.3.2 + path-type: 5.0.0 + slash: 5.1.0 + unicorn-magic: 0.1.0 + gopd@1.0.1: dependencies: get-intrinsic: 1.2.4 @@ -8473,6 +8567,8 @@ snapshots: jsonc-parser@2.2.1: {} + jsonc-parser@3.3.1: {} + jsonfile@6.1.0: dependencies: universalify: 2.0.1 @@ -8504,6 +8600,10 @@ snapshots: lines-and-columns@1.2.4: {} + linkify-it@5.0.0: + dependencies: + uc.micro: 2.1.0 + loader-runner@4.3.0: {} loader-utils@2.0.4: @@ -8559,8 +8659,37 @@ snapshots: markdown-extensions@2.0.0: {} + markdown-it@14.1.0: + dependencies: + argparse: 2.0.1 + entities: 4.5.0 + linkify-it: 5.0.0 + mdurl: 2.0.0 + punycode.js: 2.3.1 + uc.micro: 2.1.0 + markdown-table@3.0.4: {} + markdownlint-cli2-formatter-default@0.0.5(markdownlint-cli2@0.14.0): + dependencies: + markdownlint-cli2: 0.14.0 + + markdownlint-cli2@0.14.0: + dependencies: + globby: 14.0.2 + js-yaml: 4.1.0 + jsonc-parser: 3.3.1 + markdownlint: 0.35.0 + markdownlint-cli2-formatter-default: 0.0.5(markdownlint-cli2@0.14.0) + micromatch: 4.0.8 + + markdownlint-micromark@0.1.10: {} + + markdownlint@0.35.0: + dependencies: + markdown-it: 14.1.0 + markdownlint-micromark: 0.1.10 + mdast-util-directive@3.0.0: dependencies: '@types/mdast': 4.0.4 @@ -8752,6 +8881,8 @@ snapshots: mdn-data@2.0.30: {} + mdurl@2.0.0: {} + media-typer@0.3.0: {} memfs@3.5.3: @@ -9332,6 +9463,8 @@ snapshots: path-type@4.0.0: {} + path-type@5.0.0: {} + picocolors@1.1.1: {} picomatch@2.3.1: {} @@ -9588,6 +9721,8 @@ snapshots: picocolors: 1.1.1 source-map-js: 1.2.1 + prettier@3.3.3: {} + pretty-error@4.0.0: dependencies: lodash: 4.17.21 @@ -9625,6 +9760,8 @@ snapshots: forwarded: 0.2.0 ipaddr.js: 1.9.1 + punycode.js@2.3.1: {} + punycode@2.3.1: {} pupa@3.1.0: @@ -10189,6 +10326,13 @@ snapshots: arg: 5.0.2 sax: 1.4.1 + sitemap@8.0.0: + dependencies: + '@types/node': 17.0.45 + '@types/sax': 1.2.7 + arg: 5.0.2 + sax: 1.4.1 + skin-tone@2.0.0: dependencies: unicode-emoji-modifier-base: 1.0.0 @@ -10197,6 +10341,8 @@ snapshots: slash@4.0.0: {} + slash@5.1.0: {} + snake-case@3.0.4: dependencies: dot-case: 3.0.4 @@ -10441,6 +10587,8 @@ snapshots: typescript@5.2.2: {} + uc.micro@2.1.0: {} + undici-types@6.19.8: {} unicode-canonical-property-names-ecmascript@2.0.1: {} @@ -10456,6 +10604,8 @@ snapshots: unicode-property-aliases-ecmascript@2.1.0: {} + unicorn-magic@0.1.0: {} + unified@11.0.5: dependencies: '@types/unist': 3.0.3