| <?xml version='1.0' encoding='UTF-8'?> |
| <!-- Schema file written by PDE --> |
| <schema targetNamespace="org.eclipse.cdt.ui" xmlns="http://www.w3.org/2001/XMLSchema"> |
| |
| <include schemaLocation="schema://org.eclipse.core.expressions/schema/expressionLanguage.exsd"/> |
| |
| <annotation> |
| <appInfo> |
| <meta.schema plugin="org.eclipse.cdt.ui" id="quickFixProcessors" name="Quick Fix Processor"/> |
| </appInfo> |
| <documentation> |
| This extension point allows users to add a Quick Fix processor to offer new Quick Fixes on C/C++ problems. |
| <p> |
| The extension can specify which problem marker types it can handle. It will only get problems of these types to process. |
| </p> |
| <p> |
| This extension point supports the <code>enablement</code> tag. Properties to test on are: |
| <dl> |
| <li>translationUnit: type ITranslationUnit; the translation unit the quick assist is applied on</li> |
| <li>projectNatures: type Collection; all project natures of the current project</li> |
| </dl> |
| </p> |
| </documentation> |
| </annotation> |
| |
| <element name="extension"> |
| <annotation> |
| <appInfo> |
| <meta.element /> |
| </appInfo> |
| </annotation> |
| <complexType> |
| <sequence> |
| <element ref="quickFixProcessor" minOccurs="1" maxOccurs="unbounded"/> |
| </sequence> |
| <attribute name="point" type="string" use="required"> |
| <annotation> |
| <documentation> |
| a fully qualified identifier of the target extension point |
| </documentation> |
| </annotation> |
| </attribute> |
| <attribute name="id" type="string"> |
| <annotation> |
| <documentation> |
| an optional identifier of the extension instance |
| </documentation> |
| </annotation> |
| </attribute> |
| <attribute name="name" type="string"> |
| <annotation> |
| <documentation> |
| an optional name of the extension instance |
| </documentation> |
| <appInfo> |
| <meta.attribute translatable="true"/> |
| </appInfo> |
| </annotation> |
| </attribute> |
| </complexType> |
| </element> |
| |
| <element name="quickFixProcessor"> |
| <complexType> |
| <sequence> |
| <element ref="enablement" minOccurs="0" maxOccurs="1"/> |
| <element ref="handledMarkerTypes" minOccurs="0" maxOccurs="unbounded"/> |
| </sequence> |
| <attribute name="id" type="string" use="required"> |
| <annotation> |
| <documentation> |
| A unique identifier for the Quick Fix processor. |
| </documentation> |
| <appInfo> |
| <meta.attribute kind="identifier"/> |
| </appInfo> |
| </annotation> |
| </attribute> |
| <attribute name="name" type="string"> |
| <annotation> |
| <documentation> |
| A localized name of the Quick Fix processor. |
| </documentation> |
| <appInfo> |
| <meta.attribute translatable="true"/> |
| </appInfo> |
| </annotation> |
| </attribute> |
| <attribute name="class" type="string" use="required"> |
| <annotation> |
| <documentation> |
| The name of the class that implements this Quick Fix processor. The |
| class must be public and implement |
| <samp>org.eclipse.cdt.ui.text.IQuickFixProcessor</samp> |
| with a public 0-argument constructor. |
| </documentation> |
| <appInfo> |
| <meta.attribute kind="java" basedOn="org.eclipse.cdt.ui.text.IQuickFixProcessor"/> |
| </appInfo> |
| </annotation> |
| </attribute> |
| </complexType> |
| </element> |
| |
| <element name="handledMarkerTypes"> |
| <annotation> |
| <documentation> |
| Specifies the marker types of the problems this quick fix processor can handle. |
| If no handled marker type are specified, the processor will get problems of types org.eclipse.cdt.core.problem, org.eclipse.cdt.core.buildpath_problem and org.eclipse.cdt.core.task. |
| </documentation> |
| </annotation> |
| <complexType> |
| <sequence> |
| <element ref="markerType" minOccurs="1" maxOccurs="unbounded"/> |
| </sequence> |
| </complexType> |
| </element> |
| |
| <element name="markerType"> |
| <complexType> |
| <attribute name="id" type="string" use="required"> |
| <annotation> |
| <documentation> |
| The marker type id of the marker that can be handled by this processor. |
| </documentation> |
| <appInfo> |
| <meta.attribute kind="identifier"/> |
| </appInfo> |
| </annotation> |
| </attribute> |
| </complexType> |
| </element> |
| |
| <annotation> |
| <appInfo> |
| <meta.section type="since"/> |
| </appInfo> |
| <documentation> |
| 4.1 |
| </documentation> |
| </annotation> |
| |
| <annotation> |
| <appInfo> |
| <meta.section type="examples"/> |
| </appInfo> |
| <documentation> |
| The following is an example of a Quick Fix processor contribution: |
| <p> |
| <pre> |
| <extension point="org.eclipse.cdt.ui.quickFixProcessors"> |
| <quickFixProcessor |
| id="AdvancedQuickFixProcessor" |
| name="Advanced Quick Fix Processor" |
| class="com.example.AdvancedQuickFixProcessor"> |
| <handledMarkerTypes> |
| <markerType id="org.eclipse.myplugin.audits"/> |
| </handledMarkerTypes> |
| <enablement> |
| <with variable="projectNatures"> |
| <iterate operator="or"> |
| <equals value="org.eclipse.cdt.core.cnature"/> |
| </iterate> |
| </with> |
| </enablement> |
| </quickFixProcessor> |
| </extension> |
| </pre> |
| </p> |
| </documentation> |
| </annotation> |
| |
| <annotation> |
| <appInfo> |
| <meta.section type="apiInfo"/> |
| </appInfo> |
| <documentation> |
| The contributed class must implement <code>org.eclipse.cdt.ui.text.IQuickFixProcessor</code> |
| </documentation> |
| </annotation> |
| |
| |
| <annotation> |
| <appInfo> |
| <meta.section type="copyright"/> |
| </appInfo> |
| <documentation> |
| Copyright (c) 2001, 2007 IBM Corporation and others.<br> |
| This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0 which accompanies this distribution, and is available at <a href="http://www.eclipse.org/legal/epl-2.0/">https://www.eclipse.org/legal/epl-2.0/ |
| t; |
| t;SPDX-License-Identifier: EPL-2.0</a> |
| </documentation> |
| </annotation> |
| |
| </schema> |