qmk_firmware/assets/support_deprecation_policy.md.ETZSQpOy.js

16 lines
5.2 KiB
JavaScript
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import { _ as _export_sfc, c as createElementBlock, o as openBlock, a8 as createStaticVNode } from "./chunks/framework.B9AX-CPi.js";
const __pageData = JSON.parse('{"title":"Feature support policies","description":"","frontmatter":{},"headers":[],"relativePath":"support_deprecation_policy.md","filePath":"support_deprecation_policy.md","lastUpdated":null}');
const _sfc_main = { name: "support_deprecation_policy.md" };
const _hoisted_1 = /* @__PURE__ */ createStaticVNode('<h1 id="feature-support-policies" tabindex="-1">Feature support policies <a class="header-anchor" href="#feature-support-policies" aria-label="Permalink to &quot;Feature support policies&quot;"></a></h1><h2 id="system-constraints" tabindex="-1">System Constraints <a class="header-anchor" href="#system-constraints" aria-label="Permalink to &quot;System Constraints&quot;"></a></h2><p>In general, feature development is encouraged to support as many hardware configurations as possible. Depending on system constraints this may not always be achievable, and is usually bound by microcontroller flash and RAM capabilities.</p><p>The most frequently-hit constraint is the amount of code that can be flashed onto an ATmega32U4 -- users almost always need to pick and choose included functionality due to the size constraints.</p><div class="warning custom-block"><p class="custom-block-title">WARNING</p><p><a href="./squeezing_avr">Squeezing AVR</a> has some steps that users can take in order to minimise the overall firmware size, which in some cases enables the ability for users to include other desired features.</p></div><h2 id="deprecation-removal-policy" tabindex="-1">Deprecation &amp; Removal Policy <a class="header-anchor" href="#deprecation-removal-policy" aria-label="Permalink to &quot;Deprecation &amp; Removal Policy&quot;"></a></h2><p>QMK Firmware strives for innovation wherever possible. With ongoing feature development and other improvements made to the codebase, sometimes the retirement of outdated, under-utilised, or limited-value functionality is selected for deprecation and subsequent removal.</p><p>The intent behind feature deprecation is to maintain and/or improve quality. As a result, perpetually supporting under-utilised features would negatively impact the QMK team&#39;s ability to improve other areas of QMK Firmware.</p><p>There may be several motivations behind the deprecation or removal of functionality (keeping in mind that this list is not exhaustive):</p><ul><li>Better alternatives have already been implemented</li><li>Lack of adherence to standards</li><li>Poor support from code owners or upstream maintainers</li><li>Poor design</li><li>Hardware constraints</li><li>Minimal use within the QMK Firmware repository</li><li>Copyright disputes</li><li>Bit-rot</li></ul><p>When a feature is selected for deprecation, future changes to that area will cease to be developed by the QMK team, and Pull Requests submitted against those areas will be declined.</p><div class="tip custom-block"><p class="custom-block-title">TIP</p><p>As QMK does not gather metrics from its users, the only way the QMK team can gauge the level of usage is to refer to the main QMK Firmware repository -- searching through forks is not practical due to the sheer number of them.</p></div><h3 id="how-much-advance-notice-will-be-given" tabindex="-1">How much advance notice will be given? <a class="header-anchor" href="#how-much-advance-notice-will-be-given" aria-label="Permalink to &quot;How much advance notice will be given?&quot;"></a></h3><p>Disregarding emergencies or other high-risk concerns, deprecation of large features or entire subsystems within QMK will be communicated on the <code>develop</code> branch at least one breaking changes cycle (3 months) before removal. Advance notice may be extended for higher impact features, and is at the discretion of the QMK team.</p><p>Smaller features may be removed within a breaking changes cycle, and will generally be based on the level of use within the repository. Features with minimal use may be selected for removal at any time on the <code>develop</code> branch.</p><p>Third-party software libraries leveraged by QMK are generally forked to mitigate disappearance upstream. If the upstream repository is removed, it will generally be replaced when practical, or dependent features will be removed as per the normal deprecation policy.</p><h3 id="how-will-deprecation-be-communicated" tabindex="-1">How will deprecation be communicated? <a class="header-anchor" href="#how-will-deprecation-be-communicated" aria-label="Permalink to &quot;How will deprecation be communicated?&quot;"></a></h3><p>Every breaking changes merge from <code>develop</code> into <code>master</code> is accompanied by a changelog document -- intended and completed deprecations will be communicated here.</p><p>In addition, wherever possible warnings will be issued during firmware compilation when deprecated features are still being used.</p>', 19);
const _hoisted_20 = [
_hoisted_1
];
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
return openBlock(), createElementBlock("div", null, _hoisted_20);
}
const support_deprecation_policy = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
export {
__pageData,
support_deprecation_policy as default
};