refactor(ivy): Update @publicApi to @codeGenApi on ivy instructions (#29820)

- Removes `@publicApi` annotation from ivy instructions
- Adds new `@codeGenApi` annotation to ivy instructions
- Updates ts_api_guardian to support the new annotation properly

PR Close #29820
This commit is contained in:
Ben Lesh 2019-04-10 13:45:26 -07:00 committed by Igor Minar
parent def73a6728
commit ddadb8e22c
32 changed files with 142 additions and 127 deletions

View File

@ -39,7 +39,7 @@ let _renderCompCount = 0;
* }); * });
* } * }
* ``` * ```
* @publicApi * @codeGenApi
*/ */
export function ΔdefineComponent<T>(componentDefinition: { export function ΔdefineComponent<T>(componentDefinition: {
/** /**
@ -305,7 +305,7 @@ export function ΔdefineComponent<T>(componentDefinition: {
} }
/** /**
* @publicApi * @codeGenApi
*/ */
export function ΔsetComponentScope( export function ΔsetComponentScope(
type: ComponentType<any>, directives: Type<any>[], pipes: Type<any>[]): void { type: ComponentType<any>, directives: Type<any>[], pipes: Type<any>[]): void {
@ -332,7 +332,7 @@ export function extractPipeDef(type: PipeType<any>): PipeDef<any> {
} }
/** /**
* @publicApi * @codeGenApi
*/ */
export function ΔdefineNgModule<T>(def: { export function ΔdefineNgModule<T>(def: {
/** Token representing the module. Used by DI. */ /** Token representing the module. Used by DI. */
@ -376,7 +376,7 @@ export function ΔdefineNgModule<T>(def: {
* marked pure to tree-shake it from the bundle, allowing for all referenced declarations * marked pure to tree-shake it from the bundle, allowing for all referenced declarations
* to become eligible for tree-shaking as well. * to become eligible for tree-shaking as well.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔsetNgModuleScope(type: any, scope: { export function ΔsetNgModuleScope(type: any, scope: {
/** List of components, directives, and pipes declared by this module. */ /** List of components, directives, and pipes declared by this module. */
@ -488,7 +488,7 @@ function invertObject<T>(
* *
* @param baseDefinition The base definition parameters * @param baseDefinition The base definition parameters
* *
* @publicApi * @codeGenApi
*/ */
export function ΔdefineBase<T>(baseDefinition: { export function ΔdefineBase<T>(baseDefinition: {
/** /**
@ -570,7 +570,7 @@ export function ΔdefineBase<T>(baseDefinition: {
* } * }
* ``` * ```
* *
* @publicApi * @codeGenApi
*/ */
export const ΔdefineDirective = ΔdefineComponent as any as<T>(directiveDefinition: { export const ΔdefineDirective = ΔdefineComponent as any as<T>(directiveDefinition: {
/** /**
@ -688,7 +688,7 @@ export const ΔdefineDirective = ΔdefineComponent as any as<T>(directiveDefinit
* ``` * ```
* @param pipeDef Pipe definition generated by the compiler * @param pipeDef Pipe definition generated by the compiler
* *
* @publicApi * @codeGenApi
*/ */
export function ΔdefinePipe<T>(pipeDef: { export function ΔdefinePipe<T>(pipeDef: {
/** Name of the pipe. Used for matching pipes in template to pipe defs. */ /** Name of the pipe. Used for matching pipes in template to pipe defs. */

View File

@ -635,7 +635,7 @@ export class NodeInjector implements Injector {
} }
/** /**
* @publicApi * @codeGenApi
*/ */
export function ΔgetFactoryOf<T>(type: Type<any>): ((type: Type<T>| null) => T)|null { export function ΔgetFactoryOf<T>(type: Type<any>): ((type: Type<T>| null) => T)|null {
const typeAny = type as any; const typeAny = type as any;
@ -648,7 +648,7 @@ export function ΔgetFactoryOf<T>(type: Type<any>): ((type: Type<T>| null) => T)
} }
/** /**
* @publicApi * @codeGenApi
*/ */
export function ΔgetInheritedFactory<T>(type: Type<any>): (type: Type<T>) => T { export function ΔgetInheritedFactory<T>(type: Type<any>): (type: Type<T>) => T {
const proto = Object.getPrototypeOf(type.prototype).constructor as Type<any>; const proto = Object.getPrototypeOf(type.prototype).constructor as Type<any>;

View File

@ -24,7 +24,7 @@ function getSuperType(type: Type<any>): Type<any>&
* Merges the definition from a super class to a sub class. * Merges the definition from a super class to a sub class.
* @param definition The definition that is a SubClass of another directive of component * @param definition The definition that is a SubClass of another directive of component
* *
* @publicApi * @codeGenApi
*/ */
export function ΔInheritDefinitionFeature(definition: DirectiveDef<any>| ComponentDef<any>): void { export function ΔInheritDefinitionFeature(definition: DirectiveDef<any>| ComponentDef<any>): void {
let superType = getSuperType(definition.type); let superType = getSuperType(definition.type);

View File

@ -39,7 +39,7 @@ type OnChangesExpando = OnChanges & {
* }); * });
* ``` * ```
* *
* @publicApi * @codeGenApi
*/ */
export function ΔNgOnChangesFeature<T>(): DirectiveDefFeature { export function ΔNgOnChangesFeature<T>(): DirectiveDefFeature {
// This option ensures that the ngOnChanges lifecycle hook will be inherited // This option ensures that the ngOnChanges lifecycle hook will be inherited

View File

@ -37,7 +37,7 @@ import {DirectiveDef} from '../interfaces/definition';
* *
* @param definition * @param definition
* *
* @publicApi * @codeGenApi
*/ */
export function ΔProvidersFeature<T>(providers: Provider[], viewProviders: Provider[] = []) { export function ΔProvidersFeature<T>(providers: Provider[], viewProviders: Provider[] = []) {
return (definition: DirectiveDef<T>) => { return (definition: DirectiveDef<T>) => {

View File

@ -347,7 +347,7 @@ const parentIndexStack: number[] = [];
* @param message The translation message. * @param message The translation message.
* @param subTemplateIndex Optional sub-template index in the `message`. * @param subTemplateIndex Optional sub-template index in the `message`.
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18nStart(index: number, message: string, subTemplateIndex?: number): void { export function Δi18nStart(index: number, message: string, subTemplateIndex?: number): void {
const tView = getLView()[TVIEW]; const tView = getLView()[TVIEW];
@ -534,7 +534,7 @@ function appendI18nNode(tNode: TNode, parentTNode: TNode, previousTNode: TNode |
* *
* @returns Transformed string that can be consumed by i18nStart instruction * @returns Transformed string that can be consumed by i18nStart instruction
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18nPostprocess( export function Δi18nPostprocess(
message: string, replacements: {[key: string]: (string | string[])} = {}): string { message: string, replacements: {[key: string]: (string | string[])} = {}): string {
@ -630,7 +630,7 @@ export function Δi18nPostprocess(
* Translates a translation block marked by `i18nStart` and `i18nEnd`. It inserts the text/ICU nodes * Translates a translation block marked by `i18nStart` and `i18nEnd`. It inserts the text/ICU nodes
* into the render tree, moves the placeholder nodes and removes the deleted nodes. * into the render tree, moves the placeholder nodes and removes the deleted nodes.
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18nEnd(): void { export function Δi18nEnd(): void {
const tView = getLView()[TVIEW]; const tView = getLView()[TVIEW];
@ -919,7 +919,7 @@ function removeNode(index: number, viewData: LView) {
* @param message The translation message. * @param message The translation message.
* @param subTemplateIndex Optional sub-template index in the `message`. * @param subTemplateIndex Optional sub-template index in the `message`.
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18n(index: number, message: string, subTemplateIndex?: number): void { export function Δi18n(index: number, message: string, subTemplateIndex?: number): void {
Δi18nStart(index, message, subTemplateIndex); Δi18nStart(index, message, subTemplateIndex);
@ -932,7 +932,7 @@ export function Δi18n(index: number, message: string, subTemplateIndex?: number
* @param index A unique index in the static block * @param index A unique index in the static block
* @param values * @param values
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18nAttributes(index: number, values: string[]): void { export function Δi18nAttributes(index: number, values: string[]): void {
const tView = getLView()[TVIEW]; const tView = getLView()[TVIEW];
@ -984,7 +984,7 @@ let shiftsCounter = 0;
* *
* @param expression The binding's new value or NO_CHANGE * @param expression The binding's new value or NO_CHANGE
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18nExp<T>(expression: T | NO_CHANGE): void { export function Δi18nExp<T>(expression: T | NO_CHANGE): void {
if (expression !== NO_CHANGE) { if (expression !== NO_CHANGE) {
@ -999,7 +999,7 @@ export function Δi18nExp<T>(expression: T | NO_CHANGE): void {
* @param index Index of either {@link i18nStart} (translation block) or {@link i18nAttributes} * @param index Index of either {@link i18nStart} (translation block) or {@link i18nAttributes}
* (i18n attribute) on which it should update the content. * (i18n attribute) on which it should update the content.
* *
* @publicApi * @codeGenApi
*/ */
export function Δi18nApply(index: number) { export function Δi18nApply(index: number) {
if (shiftsCounter) { if (shiftsCounter) {

View File

@ -17,7 +17,7 @@ import {NO_CHANGE} from '../tokens';
* *
* @param count Amount of vars to be allocated * @param count Amount of vars to be allocated
* *
* @publicApi * @codeGenApi
*/ */
export function ΔallocHostVars(count: number): void { export function ΔallocHostVars(count: number): void {
const lView = getLView(); const lView = getLView();

View File

@ -28,7 +28,7 @@ import {addToViewTree, createDirectivesAndLocals, createLContainer, createNodeAt
* *
* @param index The index of the container in the data array * @param index The index of the container in the data array
* *
* @publicApi * @codeGenApi
*/ */
export function Δcontainer(index: number): void { export function Δcontainer(index: number): void {
const tNode = containerInternal(index, null, null); const tNode = containerInternal(index, null, null);
@ -57,7 +57,7 @@ export function Δcontainer(index: number): void {
* @param localRefExtractor A function which extracts local-refs values from the template. * @param localRefExtractor A function which extracts local-refs values from the template.
* Defaults to the current element associated with the local-ref. * Defaults to the current element associated with the local-ref.
* *
* @publicApi * @codeGenApi
*/ */
export function Δtemplate( export function Δtemplate(
index: number, templateFn: ComponentTemplate<any>| null, consts: number, vars: number, index: number, templateFn: ComponentTemplate<any>| null, consts: number, vars: number,
@ -85,7 +85,7 @@ export function Δtemplate(
* *
* @param index The index of the container in the data array * @param index The index of the container in the data array
* *
* @publicApi * @codeGenApi
*/ */
export function ΔcontainerRefreshStart(index: number): void { export function ΔcontainerRefreshStart(index: number): void {
const lView = getLView(); const lView = getLView();
@ -108,7 +108,7 @@ export function ΔcontainerRefreshStart(index: number): void {
* *
* Marking the end of LContainer is the time when to child views get inserted or removed. * Marking the end of LContainer is the time when to child views get inserted or removed.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔcontainerRefreshEnd(): void { export function ΔcontainerRefreshEnd(): void {
let previousOrParentTNode = getPreviousOrParentTNode(); let previousOrParentTNode = getPreviousOrParentTNode();

View File

@ -33,7 +33,7 @@ import {getLView, getPreviousOrParentTNode} from '../state';
* @param flags Injection flags * @param flags Injection flags
* @returns the value from the injector or `null` when not found * @returns the value from the injector or `null` when not found
* *
* @publicApi * @codeGenApi
*/ */
export function ΔdirectiveInject<T>(token: Type<T>| InjectionToken<T>): T; export function ΔdirectiveInject<T>(token: Type<T>| InjectionToken<T>): T;
export function ΔdirectiveInject<T>(token: Type<T>| InjectionToken<T>, flags: InjectFlags): T; export function ΔdirectiveInject<T>(token: Type<T>| InjectionToken<T>, flags: InjectFlags): T;
@ -48,7 +48,7 @@ export function ΔdirectiveInject<T>(
/** /**
* Facade for the attribute injection from DI. * Facade for the attribute injection from DI.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔinjectAttribute(attrNameToInject: string): string|null { export function ΔinjectAttribute(attrNameToInject: string): string|null {
return injectAttributeImpl(getPreviousOrParentTNode(), attrNameToInject); return injectAttributeImpl(getPreviousOrParentTNode(), attrNameToInject);

View File

@ -42,7 +42,7 @@ import {getActiveDirectiveStylingIndex} from './styling';
* hold an attribute name and elements with an odd index hold an attribute value, ex.: * hold an attribute name and elements with an odd index hold an attribute value, ex.:
* ['id', 'warning5', 'class', 'alert'] * ['id', 'warning5', 'class', 'alert']
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementStart( export function ΔelementStart(
index: number, name: string, attrs?: TAttributes | null, localRefs?: string[] | null): void { index: number, name: string, attrs?: TAttributes | null, localRefs?: string[] | null): void {
@ -127,7 +127,7 @@ export function ΔelementStart(
/** /**
* Mark the end of the element. * Mark the end of the element.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementEnd(): void { export function ΔelementEnd(): void {
let previousOrParentTNode = getPreviousOrParentTNode(); let previousOrParentTNode = getPreviousOrParentTNode();
@ -179,7 +179,7 @@ export function ΔelementEnd(): void {
* element on creation. Use [AttributeMarker] to denote the meaning of this array. * element on creation. Use [AttributeMarker] to denote the meaning of this array.
* @param localRefs A set of local reference bindings on the element. * @param localRefs A set of local reference bindings on the element.
* *
* @publicApi * @codeGenApi
*/ */
export function Δelement( export function Δelement(
index: number, name: string, attrs?: TAttributes | null, localRefs?: string[] | null): void { index: number, name: string, attrs?: TAttributes | null, localRefs?: string[] | null): void {
@ -198,7 +198,7 @@ export function Δelement(
* @param sanitizer An optional function used to sanitize the value. * @param sanitizer An optional function used to sanitize the value.
* @param namespace Optional namespace to use when setting the attribute. * @param namespace Optional namespace to use when setting the attribute.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementAttribute( export function ΔelementAttribute(
index: number, name: string, value: any, sanitizer?: SanitizerFn | null, index: number, name: string, value: any, sanitizer?: SanitizerFn | null,
@ -266,7 +266,7 @@ export function ΔelementAttribute(
* @param attrs An array of static values (attributes, classes and styles) with the correct marker * @param attrs An array of static values (attributes, classes and styles) with the correct marker
* values. * values.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementHostAttrs(attrs: TAttributes) { export function ΔelementHostAttrs(attrs: TAttributes) {
const hostElementIndex = getSelectedIndex(); const hostElementIndex = getSelectedIndex();

View File

@ -29,7 +29,7 @@ import {createDirectivesAndLocals, createNodeAtIndex, executeContentQueries, set
* the DOM (as a comment node can't have attributes). Attributes are here only for directive * the DOM (as a comment node can't have attributes). Attributes are here only for directive
* matching purposes and setting initial inputs of directives. * matching purposes and setting initial inputs of directives.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementContainerStart( export function ΔelementContainerStart(
index: number, attrs?: TAttributes | null, localRefs?: string[] | null): void { index: number, attrs?: TAttributes | null, localRefs?: string[] | null): void {
@ -70,7 +70,7 @@ export function ΔelementContainerStart(
/** /**
* Mark the end of the <ng-container>. * Mark the end of the <ng-container>.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementContainerEnd(): void { export function ΔelementContainerEnd(): void {
let previousOrParentTNode = getPreviousOrParentTNode(); let previousOrParentTNode = getPreviousOrParentTNode();

View File

@ -24,7 +24,7 @@ import {assignTViewNodeToLView, createLView, createTView, refreshDescendantViews
* @param viewBlockId The ID of this view * @param viewBlockId The ID of this view
* @return boolean Whether or not this view is in creation mode * @return boolean Whether or not this view is in creation mode
* *
* @publicApi * @codeGenApi
*/ */
export function ΔembeddedViewStart(viewBlockId: number, consts: number, vars: number): RenderFlags { export function ΔembeddedViewStart(viewBlockId: number, consts: number, vars: number): RenderFlags {
const lView = getLView(); const lView = getLView();
@ -127,7 +127,7 @@ function scanForView(lContainer: LContainer, startIdx: number, viewBlockId: numb
/** /**
* Marks the end of an embedded view. * Marks the end of an embedded view.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔembeddedViewEnd(): void { export function ΔembeddedViewEnd(): void {
const lView = getLView(); const lView = getLView();

View File

@ -15,7 +15,7 @@ import {getLView} from '../state';
* of the current view and restore it when listeners are invoked. This allows * of the current view and restore it when listeners are invoked. This allows
* walking the declaration view tree in listeners to get vars from parent views. * walking the declaration view tree in listeners to get vars from parent views.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔgetCurrentView(): OpaqueViewState { export function ΔgetCurrentView(): OpaqueViewState {
return getLView() as any as OpaqueViewState; return getLView() as any as OpaqueViewState;

View File

@ -29,7 +29,7 @@ import {BindingDirection, generatePropertyAliases, getCleanup, handleError, load
* @param eventTargetResolver Function that returns global target information in case this listener * @param eventTargetResolver Function that returns global target information in case this listener
* should be attached to a global object like window, document or body * should be attached to a global object like window, document or body
* *
* @publicApi * @codeGenApi
*/ */
export function Δlistener( export function Δlistener(
eventName: string, listenerFn: (e?: any) => any, useCapture = false, eventName: string, listenerFn: (e?: any) => any, useCapture = false,
@ -56,7 +56,7 @@ export function Δlistener(
* @param eventTargetResolver Function that returns global target information in case this listener * @param eventTargetResolver Function that returns global target information in case this listener
* should be attached to a global object like window, document or body * should be attached to a global object like window, document or body
* *
* @publicApi * @codeGenApi
*/ */
export function ΔcomponentHostSyntheticListener<T>( export function ΔcomponentHostSyntheticListener<T>(
eventName: string, listenerFn: (e?: any) => any, useCapture = false, eventName: string, listenerFn: (e?: any) => any, useCapture = false,

View File

@ -17,7 +17,7 @@ import {nextContextImpl} from '../state';
* @param level The relative level of the view from which to grab context compared to contextVewData * @param level The relative level of the view from which to grab context compared to contextVewData
* @returns context * @returns context
* *
* @publicApi * @codeGenApi
*/ */
export function ΔnextContext<T = any>(level: number = 1): T { export function ΔnextContext<T = any>(level: number = 1): T {
return nextContextImpl(level); return nextContextImpl(level);

View File

@ -37,7 +37,7 @@ import {createNodeAtIndex} from './shared';
* @param selectors A collection of parsed CSS selectors * @param selectors A collection of parsed CSS selectors
* @param rawSelectors A collection of CSS selectors in the raw, un-parsed form * @param rawSelectors A collection of CSS selectors in the raw, un-parsed form
* *
* @publicApi * @codeGenApi
*/ */
export function ΔprojectionDef(selectors?: CssSelectorList[]): void { export function ΔprojectionDef(selectors?: CssSelectorList[]): void {
const componentNode = findComponentView(getLView())[T_HOST] as TElementNode; const componentNode = findComponentView(getLView())[T_HOST] as TElementNode;
@ -76,7 +76,7 @@ export function ΔprojectionDef(selectors?: CssSelectorList[]): void {
* - 0 when the selector is `*` (or unspecified as this is the default value), * - 0 when the selector is `*` (or unspecified as this is the default value),
* - 1 based index of the selector from the {@link projectionDef} * - 1 based index of the selector from the {@link projectionDef}
* *
* @publicApi * @codeGenApi
*/ */
export function Δprojection( export function Δprojection(
nodeIndex: number, selectorIndex: number = 0, attrs?: TAttributes): void { nodeIndex: number, selectorIndex: number = 0, attrs?: TAttributes): void {

View File

@ -32,7 +32,7 @@ import {TsickleIssue1009, elementPropertyInternal, loadComponentRenderer, storeB
* @returns This function returns itself so that it may be chained * @returns This function returns itself so that it may be chained
* (e.g. `property('name', ctx.name)('title', ctx.title)`) * (e.g. `property('name', ctx.name)('title', ctx.title)`)
* *
* @publicApi * @codeGenApi
*/ */
export function Δproperty<T>( export function Δproperty<T>(
propName: string, value: T, sanitizer?: SanitizerFn | null, propName: string, value: T, sanitizer?: SanitizerFn | null,
@ -48,7 +48,7 @@ export function Δproperty<T>(
* *
* @param value Value to diff * @param value Value to diff
* *
* @publicApi * @codeGenApi
*/ */
export function Δbind<T>(value: T): T|NO_CHANGE { export function Δbind<T>(value: T): T|NO_CHANGE {
const lView = getLView(); const lView = getLView();
@ -73,7 +73,7 @@ export function Δbind<T>(value: T): T|NO_CHANGE {
* @param nativeOnly Whether or not we should only set native properties and skip input check * @param nativeOnly Whether or not we should only set native properties and skip input check
* (this is necessary for host property bindings) * (this is necessary for host property bindings)
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementProperty<T>( export function ΔelementProperty<T>(
index: number, propName: string, value: T | NO_CHANGE, sanitizer?: SanitizerFn | null, index: number, propName: string, value: T | NO_CHANGE, sanitizer?: SanitizerFn | null,
@ -102,7 +102,7 @@ export function ΔelementProperty<T>(
* @param nativeOnly Whether or not we should only set native properties and skip input check * @param nativeOnly Whether or not we should only set native properties and skip input check
* (this is necessary for host property bindings) * (this is necessary for host property bindings)
* *
* @publicApi * @codeGenApi
*/ */
export function ΔcomponentHostSyntheticProperty<T>( export function ΔcomponentHostSyntheticProperty<T>(
index: number, propName: string, value: T | NO_CHANGE, sanitizer?: SanitizerFn | null, index: number, propName: string, value: T | NO_CHANGE, sanitizer?: SanitizerFn | null,

View File

@ -27,7 +27,7 @@ import {TsickleIssue1009, elementPropertyInternal, storeBindingMetadata} from '.
* *
* Returns the concatenated string when any of the arguments changes, `NO_CHANGE` otherwise. * Returns the concatenated string when any of the arguments changes, `NO_CHANGE` otherwise.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔinterpolationV(values: any[]): string|NO_CHANGE { export function ΔinterpolationV(values: any[]): string|NO_CHANGE {
ngDevMode && assertLessThan(2, values.length, 'should have at least 3 values'); ngDevMode && assertLessThan(2, values.length, 'should have at least 3 values');
@ -72,7 +72,7 @@ export function ΔinterpolationV(values: any[]): string|NO_CHANGE {
* @param v0 value checked for change. * @param v0 value checked for change.
* @param suffix static value used for concatenation only. * @param suffix static value used for concatenation only.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation1(prefix: string, v0: any, suffix: string): string|NO_CHANGE { export function Δinterpolation1(prefix: string, v0: any, suffix: string): string|NO_CHANGE {
const lView = getLView(); const lView = getLView();
@ -84,7 +84,7 @@ export function Δinterpolation1(prefix: string, v0: any, suffix: string): strin
/** /**
* Creates an interpolation binding with 2 expressions. * Creates an interpolation binding with 2 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation2( export function Δinterpolation2(
prefix: string, v0: any, i0: string, v1: any, suffix: string): string|NO_CHANGE { prefix: string, v0: any, i0: string, v1: any, suffix: string): string|NO_CHANGE {
@ -105,7 +105,7 @@ export function Δinterpolation2(
/** /**
* Creates an interpolation binding with 3 expressions. * Creates an interpolation binding with 3 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation3( export function Δinterpolation3(
prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, suffix: string): string| prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, suffix: string): string|
@ -131,7 +131,7 @@ export function Δinterpolation3(
/** /**
* Create an interpolation binding with 4 expressions. * Create an interpolation binding with 4 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation4( export function Δinterpolation4(
prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any, prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any,
@ -159,7 +159,7 @@ export function Δinterpolation4(
/** /**
* Creates an interpolation binding with 5 expressions. * Creates an interpolation binding with 5 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation5( export function Δinterpolation5(
prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any, prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any,
@ -189,7 +189,7 @@ export function Δinterpolation5(
/** /**
* Creates an interpolation binding with 6 expressions. * Creates an interpolation binding with 6 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation6( export function Δinterpolation6(
prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any, prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any,
@ -220,7 +220,7 @@ export function Δinterpolation6(
/** /**
* Creates an interpolation binding with 7 expressions. * Creates an interpolation binding with 7 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation7( export function Δinterpolation7(
prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any, prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any,
@ -254,7 +254,7 @@ export function Δinterpolation7(
/** /**
* Creates an interpolation binding with 8 expressions. * Creates an interpolation binding with 8 expressions.
* *
* @publicApi * @codeGenApi
*/ */
export function Δinterpolation8( export function Δinterpolation8(
prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any, prefix: string, v0: any, i0: string, v1: any, i1: string, v2: any, i2: string, v3: any,

View File

@ -29,7 +29,7 @@ import {getCheckNoChangesMode, getLView, setSelectedIndex} from '../state';
* ``` * ```
* @param index the index of the item to act on with the following instructions * @param index the index of the item to act on with the following instructions
* *
* @publicApi * @codeGenApi
*/ */
export function Δselect(index: number): void { export function Δselect(index: number): void {
ngDevMode && assertGreaterThan(index, -1, 'Invalid index'); ngDevMode && assertGreaterThan(index, -1, 'Invalid index');

View File

@ -31,7 +31,7 @@ export function store<T>(index: number, value: T): void {
* *
* @param index The index of the local ref in contextViewData. * @param index The index of the local ref in contextViewData.
* *
* @publicApi * @codeGenApi
*/ */
export function Δreference<T>(index: number) { export function Δreference<T>(index: number) {
const contextLView = getContextLView(); const contextLView = getContextLView();
@ -41,7 +41,7 @@ export function Δreference<T>(index: number) {
/** /**
* Retrieves a value from current `viewData`. * Retrieves a value from current `viewData`.
* *
* @publicApi * @codeGenApi
*/ */
export function Δload<T>(index: number): T { export function Δload<T>(index: number): T {
return loadInternal<T>(getLView(), index); return loadInternal<T>(getLView(), index);

View File

@ -62,7 +62,7 @@ import {scheduleTick, setInputsForProperty} from './shared';
* @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
* style values that are applied to the element (during rendering). * style values that are applied to the element (during rendering).
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementStyling( export function ΔelementStyling(
classBindingNames?: string[] | null, styleBindingNames?: string[] | null, classBindingNames?: string[] | null, styleBindingNames?: string[] | null,
@ -104,7 +104,7 @@ export function ΔelementStyling(
* will not be used if the same property is assigned in another directive or * will not be used if the same property is assigned in another directive or
* on the element directly. * on the element directly.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementHostStyling( export function ΔelementHostStyling(
classBindingNames?: string[] | null, styleBindingNames?: string[] | null, classBindingNames?: string[] | null, styleBindingNames?: string[] | null,
@ -164,7 +164,7 @@ function initElementStyling(
* @param forceOverride Whether or not to update the styling value immediately * @param forceOverride Whether or not to update the styling value immediately
* (despite the other bindings possibly having priority) * (despite the other bindings possibly having priority)
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementStyleProp( export function ΔelementStyleProp(
index: number, styleIndex: number, value: string | number | String | PlayerFactory | null, index: number, styleIndex: number, value: string | number | String | PlayerFactory | null,
@ -198,7 +198,7 @@ export function ΔelementStyleProp(
* @param forceOverride Whether or not to update the styling value immediately * @param forceOverride Whether or not to update the styling value immediately
* (despite the other bindings possibly having priority) * (despite the other bindings possibly having priority)
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementHostStyleProp( export function ΔelementHostStyleProp(
styleIndex: number, value: string | number | String | PlayerFactory | null, styleIndex: number, value: string | number | String | PlayerFactory | null,
@ -251,7 +251,7 @@ function resolveStylePropValue(
* @param forceOverride Whether or not this value will be applied regardless * @param forceOverride Whether or not this value will be applied regardless
* of where it is being set within the styling priority structure. * of where it is being set within the styling priority structure.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementClassProp( export function ΔelementClassProp(
index: number, classIndex: number, value: boolean | PlayerFactory, index: number, classIndex: number, value: boolean | PlayerFactory,
@ -281,7 +281,7 @@ export function ΔelementClassProp(
* @param forceOverride Whether or not this value will be applied regardless * @param forceOverride Whether or not this value will be applied regardless
* of where it is being set within the stylings priority structure. * of where it is being set within the stylings priority structure.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementHostClassProp( export function ΔelementHostClassProp(
classIndex: number, value: boolean | PlayerFactory, forceOverride?: boolean): void { classIndex: number, value: boolean | PlayerFactory, forceOverride?: boolean): void {
@ -324,7 +324,7 @@ function booleanOrNull(value: any): boolean|null {
* Any missing styles (that have already been applied to the element beforehand) will be * Any missing styles (that have already been applied to the element beforehand) will be
* removed (unset) from the element's styling. * removed (unset) from the element's styling.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementStylingMap( export function ΔelementStylingMap(
index: number, classes: {[key: string]: any} | string | NO_CHANGE | null, index: number, classes: {[key: string]: any} | string | NO_CHANGE | null,
@ -377,7 +377,7 @@ export function ΔelementStylingMap(
* Any missing styles (that have already been applied to the element beforehand) will be * Any missing styles (that have already been applied to the element beforehand) will be
* removed (unset) from the element's styling. * removed (unset) from the element's styling.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementHostStylingMap( export function ΔelementHostStylingMap(
classes: {[key: string]: any} | string | NO_CHANGE | null, classes: {[key: string]: any} | string | NO_CHANGE | null,
@ -403,7 +403,7 @@ export function ΔelementHostStylingMap(
* *
* @param index Index of the element's with which styling is associated. * @param index Index of the element's with which styling is associated.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementStylingApply(index: number): void { export function ΔelementStylingApply(index: number): void {
elementStylingApplyInternal(DEFAULT_TEMPLATE_DIRECTIVE_INDEX, index); elementStylingApplyInternal(DEFAULT_TEMPLATE_DIRECTIVE_INDEX, index);
@ -417,7 +417,7 @@ export function ΔelementStylingApply(index: number): void {
* been run and will only apply styling to the host element if any * been run and will only apply styling to the host element if any
* styling bindings have been updated. * styling bindings have been updated.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔelementHostStylingApply(): void { export function ΔelementHostStylingApply(): void {
elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex()); elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex());

View File

@ -22,7 +22,7 @@ import {createNodeAtIndex} from './shared';
* @param index Index of the node in the data array * @param index Index of the node in the data array
* @param value Value to write. This value will be stringified. * @param value Value to write. This value will be stringified.
* *
* @publicApi * @codeGenApi
*/ */
export function Δtext(index: number, value?: any): void { export function Δtext(index: number, value?: any): void {
const lView = getLView(); const lView = getLView();
@ -45,7 +45,7 @@ export function Δtext(index: number, value?: any): void {
* @param index Index of the node in the data array. * @param index Index of the node in the data array.
* @param value Stringified value to write. * @param value Stringified value to write.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔtextBinding<T>(index: number, value: T | NO_CHANGE): void { export function ΔtextBinding<T>(index: number, value: T | NO_CHANGE): void {
if (value !== NO_CHANGE) { if (value !== NO_CHANGE) {

View File

@ -86,7 +86,7 @@ export const enum DirectiveDefFlags {ContentQuery = 0b10}
export interface PipeType<T> extends Type<T> { ngPipeDef: never; } export interface PipeType<T> extends Type<T> { ngPipeDef: never; }
/** /**
* @publicApi * @codeGenApi
*/ */
export type ΔDirectiveDefWithMeta< export type ΔDirectiveDefWithMeta<
T, Selector extends string, ExportAs extends string[], InputMap extends{[key: string]: string}, T, Selector extends string, ExportAs extends string[], InputMap extends{[key: string]: string},
@ -101,7 +101,7 @@ export type ΔDirectiveDefWithMeta<
* *
* See: {@link defineBase} * See: {@link defineBase}
* *
* @publicApi * @codeGenApi
*/ */
export interface ΔBaseDef<T> { export interface ΔBaseDef<T> {
/** /**
@ -200,7 +200,7 @@ export interface DirectiveDef<T> extends ΔBaseDef<T> {
} }
/** /**
* @publicApi * @codeGenApi
*/ */
export type ΔComponentDefWithMeta< export type ΔComponentDefWithMeta<
T, Selector extends String, ExportAs extends string[], InputMap extends{[key: string]: string}, T, Selector extends String, ExportAs extends string[], InputMap extends{[key: string]: string},
@ -347,7 +347,7 @@ export interface PipeDef<T> {
} }
/** /**
* @publicApi * @codeGenApi
*/ */
export type ΔPipeDefWithMeta<T, Name extends string> = PipeDef<T>; export type ΔPipeDefWithMeta<T, Name extends string> = PipeDef<T>;

View File

@ -25,7 +25,7 @@ import {NO_CHANGE} from './tokens';
* @param pipeName The name of the pipe * @param pipeName The name of the pipe
* @returns T the instance of the pipe. * @returns T the instance of the pipe.
* *
* @publicApi * @codeGenApi
*/ */
export function Δpipe(index: number, pipeName: string): any { export function Δpipe(index: number, pipeName: string): any {
const tView = getLView()[TVIEW]; const tView = getLView()[TVIEW];
@ -79,7 +79,7 @@ function getPipeDef(name: string, registry: PipeDefList | null): PipeDef<any> {
* @param slotOffset the offset in the reserved slot space * @param slotOffset the offset in the reserved slot space
* @param v1 1st argument to {@link PipeTransform#transform}. * @param v1 1st argument to {@link PipeTransform#transform}.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpipeBind1(index: number, slotOffset: number, v1: any): any { export function ΔpipeBind1(index: number, slotOffset: number, v1: any): any {
const pipeInstance = Δload<PipeTransform>(index); const pipeInstance = Δload<PipeTransform>(index);
@ -99,7 +99,7 @@ export function ΔpipeBind1(index: number, slotOffset: number, v1: any): any {
* @param v1 1st argument to {@link PipeTransform#transform}. * @param v1 1st argument to {@link PipeTransform#transform}.
* @param v2 2nd argument to {@link PipeTransform#transform}. * @param v2 2nd argument to {@link PipeTransform#transform}.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpipeBind2(index: number, slotOffset: number, v1: any, v2: any): any { export function ΔpipeBind2(index: number, slotOffset: number, v1: any, v2: any): any {
const pipeInstance = Δload<PipeTransform>(index); const pipeInstance = Δload<PipeTransform>(index);
@ -120,7 +120,7 @@ export function ΔpipeBind2(index: number, slotOffset: number, v1: any, v2: any)
* @param v2 2nd argument to {@link PipeTransform#transform}. * @param v2 2nd argument to {@link PipeTransform#transform}.
* @param v3 4rd argument to {@link PipeTransform#transform}. * @param v3 4rd argument to {@link PipeTransform#transform}.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpipeBind3(index: number, slotOffset: number, v1: any, v2: any, v3: any): any { export function ΔpipeBind3(index: number, slotOffset: number, v1: any, v2: any, v3: any): any {
const pipeInstance = Δload<PipeTransform>(index); const pipeInstance = Δload<PipeTransform>(index);
@ -142,7 +142,7 @@ export function ΔpipeBind3(index: number, slotOffset: number, v1: any, v2: any,
* @param v3 3rd argument to {@link PipeTransform#transform}. * @param v3 3rd argument to {@link PipeTransform#transform}.
* @param v4 4th argument to {@link PipeTransform#transform}. * @param v4 4th argument to {@link PipeTransform#transform}.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpipeBind4( export function ΔpipeBind4(
index: number, slotOffset: number, v1: any, v2: any, v3: any, v4: any): any { index: number, slotOffset: number, v1: any, v2: any, v3: any, v4: any): any {
@ -163,7 +163,7 @@ export function ΔpipeBind4(
* @param slotOffset the offset in the reserved slot space * @param slotOffset the offset in the reserved slot space
* @param values Array of arguments to pass to {@link PipeTransform#transform} method. * @param values Array of arguments to pass to {@link PipeTransform#transform} method.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpipeBindV(index: number, slotOffset: number, values: any[]): any { export function ΔpipeBindV(index: number, slotOffset: number, values: any[]): any {
const pipeInstance = Δload<PipeTransform>(index); const pipeInstance = Δload<PipeTransform>(index);

View File

@ -38,7 +38,7 @@ import {getBindingRoot, getLView, isCreationMode} from './state';
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns value * @returns value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction0<T>(slotOffset: number, pureFn: () => T, thisArg?: any): T { export function ΔpureFunction0<T>(slotOffset: number, pureFn: () => T, thisArg?: any): T {
// TODO(kara): use bindingRoot instead of bindingStartIndex when implementing host bindings // TODO(kara): use bindingRoot instead of bindingStartIndex when implementing host bindings
@ -59,7 +59,7 @@ export function ΔpureFunction0<T>(slotOffset: number, pureFn: () => T, thisArg?
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction1( export function ΔpureFunction1(
slotOffset: number, pureFn: (v: any) => any, exp: any, thisArg?: any): any { slotOffset: number, pureFn: (v: any) => any, exp: any, thisArg?: any): any {
@ -82,7 +82,7 @@ export function ΔpureFunction1(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction2( export function ΔpureFunction2(
slotOffset: number, pureFn: (v1: any, v2: any) => any, exp1: any, exp2: any, slotOffset: number, pureFn: (v1: any, v2: any) => any, exp1: any, exp2: any,
@ -109,7 +109,7 @@ export function ΔpureFunction2(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction3( export function ΔpureFunction3(
slotOffset: number, pureFn: (v1: any, v2: any, v3: any) => any, exp1: any, exp2: any, exp3: any, slotOffset: number, pureFn: (v1: any, v2: any, v3: any) => any, exp1: any, exp2: any, exp3: any,
@ -137,7 +137,7 @@ export function ΔpureFunction3(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction4( export function ΔpureFunction4(
slotOffset: number, pureFn: (v1: any, v2: any, v3: any, v4: any) => any, exp1: any, exp2: any, slotOffset: number, pureFn: (v1: any, v2: any, v3: any, v4: any) => any, exp1: any, exp2: any,
@ -166,7 +166,7 @@ export function ΔpureFunction4(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction5( export function ΔpureFunction5(
slotOffset: number, pureFn: (v1: any, v2: any, v3: any, v4: any, v5: any) => any, exp1: any, slotOffset: number, pureFn: (v1: any, v2: any, v3: any, v4: any, v5: any) => any, exp1: any,
@ -197,7 +197,7 @@ export function ΔpureFunction5(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction6( export function ΔpureFunction6(
slotOffset: number, pureFn: (v1: any, v2: any, v3: any, v4: any, v5: any, v6: any) => any, slotOffset: number, pureFn: (v1: any, v2: any, v3: any, v4: any, v5: any, v6: any) => any,
@ -230,7 +230,7 @@ export function ΔpureFunction6(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction7( export function ΔpureFunction7(
slotOffset: number, slotOffset: number,
@ -265,7 +265,7 @@ export function ΔpureFunction7(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunction8( export function ΔpureFunction8(
slotOffset: number, slotOffset: number,
@ -297,7 +297,7 @@ export function ΔpureFunction8(
* @param thisArg Optional calling context of pureFn * @param thisArg Optional calling context of pureFn
* @returns Updated or cached value * @returns Updated or cached value
* *
* @publicApi * @codeGenApi
*/ */
export function ΔpureFunctionV( export function ΔpureFunctionV(
slotOffset: number, pureFn: (...v: any[]) => any, exps: any[], thisArg?: any): any { slotOffset: number, pureFn: (...v: any[]) => any, exps: any[], thisArg?: any): any {

View File

@ -370,7 +370,7 @@ export function query<T>(
* @returns `true` if a query got dirty during change detection or if this is a static query * @returns `true` if a query got dirty during change detection or if this is a static query
* resolving in creation mode, `false` otherwise. * resolving in creation mode, `false` otherwise.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔqueryRefresh(queryList: QueryList<any>): boolean { export function ΔqueryRefresh(queryList: QueryList<any>): boolean {
const queryListImpl = (queryList as any as QueryList_<any>); const queryListImpl = (queryList as any as QueryList_<any>);
@ -392,7 +392,7 @@ export function ΔqueryRefresh(queryList: QueryList<any>): boolean {
* @param descend Whether or not to descend into children * @param descend Whether or not to descend into children
* @param read What to save in the query * @param read What to save in the query
* *
* @publicApi * @codeGenApi
*/ */
export function ΔstaticViewQuery<T>( export function ΔstaticViewQuery<T>(
// TODO(FW-486): "read" should be an AbstractType // TODO(FW-486): "read" should be an AbstractType
@ -413,7 +413,7 @@ export function ΔstaticViewQuery<T>(
* @param read What to save in the query * @param read What to save in the query
* @returns QueryList<T> * @returns QueryList<T>
* *
* @publicApi * @codeGenApi
*/ */
export function ΔviewQuery<T>( export function ΔviewQuery<T>(
// TODO(FW-486): "read" should be an AbstractType // TODO(FW-486): "read" should be an AbstractType
@ -433,7 +433,7 @@ export function ΔviewQuery<T>(
/** /**
* Loads current View Query and moves the pointer/index to the next View Query in LView. * Loads current View Query and moves the pointer/index to the next View Query in LView.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔloadViewQuery<T>(): T { export function ΔloadViewQuery<T>(): T {
const index = getCurrentQueryIndex(); const index = getCurrentQueryIndex();
@ -451,7 +451,7 @@ export function ΔloadViewQuery<T>(): T {
* @param read What to save in the query * @param read What to save in the query
* @returns QueryList<T> * @returns QueryList<T>
* *
* @publicApi * @codeGenApi
*/ */
export function ΔcontentQuery<T>( export function ΔcontentQuery<T>(
directiveIndex: number, predicate: Type<any>| string[], descend: boolean, directiveIndex: number, predicate: Type<any>| string[], descend: boolean,
@ -482,7 +482,7 @@ export function ΔcontentQuery<T>(
* @param read What to save in the query * @param read What to save in the query
* @returns QueryList<T> * @returns QueryList<T>
* *
* @publicApi * @codeGenApi
*/ */
export function ΔstaticContentQuery<T>( export function ΔstaticContentQuery<T>(
directiveIndex: number, predicate: Type<any>| string[], descend: boolean, directiveIndex: number, predicate: Type<any>| string[], descend: boolean,
@ -498,7 +498,7 @@ export function ΔstaticContentQuery<T>(
/** /**
* *
* @publicApi * @codeGenApi
*/ */
export function ΔloadContentQuery<T>(): QueryList<T> { export function ΔloadContentQuery<T>(): QueryList<T> {
const lView = getLView(); const lView = getLView();

View File

@ -90,7 +90,7 @@ export function getBindingsEnabled(): boolean {
* </div> * </div>
* ``` * ```
* *
* @publicApi * @codeGenApi
*/ */
export function ΔenableBindings(): void { export function ΔenableBindings(): void {
bindingsEnabled = true; bindingsEnabled = true;
@ -113,7 +113,7 @@ export function ΔenableBindings(): void {
* </div> * </div>
* ``` * ```
* *
* @publicApi * @codeGenApi
*/ */
export function ΔdisableBindings(): void { export function ΔdisableBindings(): void {
bindingsEnabled = false; bindingsEnabled = false;
@ -267,7 +267,7 @@ export function getActiveDirectiveSuperClassDepth() {
* *
* @param viewToRestore The OpaqueViewState instance to restore. * @param viewToRestore The OpaqueViewState instance to restore.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔrestoreView(viewToRestore: OpaqueViewState) { export function ΔrestoreView(viewToRestore: OpaqueViewState) {
contextLView = viewToRestore as any as LView; contextLView = viewToRestore as any as LView;
@ -490,7 +490,7 @@ let _currentNamespace: string|null = null;
/** /**
* Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state. * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔnamespaceSVG() { export function ΔnamespaceSVG() {
_currentNamespace = 'http://www.w3.org/2000/svg'; _currentNamespace = 'http://www.w3.org/2000/svg';
@ -499,7 +499,7 @@ export function ΔnamespaceSVG() {
/** /**
* Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state. * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔnamespaceMathML() { export function ΔnamespaceMathML() {
_currentNamespace = 'http://www.w3.org/1998/MathML/'; _currentNamespace = 'http://www.w3.org/1998/MathML/';
@ -509,7 +509,7 @@ export function ΔnamespaceMathML() {
* Sets the namespace used to create elements no `null`, which forces element creation to use * Sets the namespace used to create elements no `null`, which forces element creation to use
* `createElement` rather than `createElementNS`. * `createElement` rather than `createElementNS`.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔnamespaceHTML() { export function ΔnamespaceHTML() {
_currentNamespace = null; _currentNamespace = null;

View File

@ -43,7 +43,7 @@ export const defaultScheduler =
/** /**
* *
* @publicApi * @codeGenApi
*/ */
export function ΔresolveWindow(element: RElement & {ownerDocument: Document}) { export function ΔresolveWindow(element: RElement & {ownerDocument: Document}) {
return {name: 'window', target: element.ownerDocument.defaultView}; return {name: 'window', target: element.ownerDocument.defaultView};
@ -51,7 +51,7 @@ export function ΔresolveWindow(element: RElement & {ownerDocument: Document}) {
/** /**
* *
* @publicApi * @codeGenApi
*/ */
export function ΔresolveDocument(element: RElement & {ownerDocument: Document}) { export function ΔresolveDocument(element: RElement & {ownerDocument: Document}) {
return {name: 'document', target: element.ownerDocument}; return {name: 'document', target: element.ownerDocument};
@ -59,7 +59,7 @@ export function ΔresolveDocument(element: RElement & {ownerDocument: Document})
/** /**
* *
* @publicApi * @codeGenApi
*/ */
export function ΔresolveBody(element: RElement & {ownerDocument: Document}) { export function ΔresolveBody(element: RElement & {ownerDocument: Document}) {
return {name: 'body', target: element.ownerDocument.body}; return {name: 'body', target: element.ownerDocument.body};

View File

@ -20,7 +20,7 @@ import {createTemplateRef} from './view_engine_compatibility';
* Retrieves `TemplateRef` instance from `Injector` when a local reference is placed on the * Retrieves `TemplateRef` instance from `Injector` when a local reference is placed on the
* `<ng-template>` element. * `<ng-template>` element.
* *
* @publicApi * @codeGenApi
*/ */
export function ΔtemplateRefExtractor(tNode: TNode, currentView: LView) { export function ΔtemplateRefExtractor(tNode: TNode, currentView: LView) {
return createTemplateRef(ViewEngine_TemplateRef, ViewEngine_ElementRef, tNode, currentView); return createTemplateRef(ViewEngine_TemplateRef, ViewEngine_ElementRef, tNode, currentView);

View File

@ -30,18 +30,18 @@ export function startCli() {
// Angular project tag rules unless specified explicitly through a given option. // Angular project tag rules unless specified explicitly through a given option.
if (argv['useAngularTagRules']) { if (argv['useAngularTagRules']) {
options.exportTags = { options.exportTags = {
required: ['publicApi'], requireAtLeastOne: ['publicApi', 'codeGenApi'],
banned: ['experimental'], banned: ['experimental'],
toCopy: ['deprecated'] toCopy: ['deprecated']
}; };
options.memberTags = { options.memberTags = {
required: [], requireAtLeastOne: [],
banned: ['experimental', 'publicApi'], banned: ['experimental', 'publicApi', 'codeGenApi'],
toCopy: ['deprecated'] toCopy: ['deprecated']
}; };
options.paramTags = { options.paramTags = {
required: [], requireAtLeastOne: [],
banned: ['experimental', 'publicApi'], banned: ['experimental', 'publicApi', 'codeGenApi'],
toCopy: ['deprecated'] toCopy: ['deprecated']
}; };
} }

View File

@ -17,9 +17,10 @@ const baseTsOptions: ts.CompilerOptions = {
export interface JsDocTagOptions { export interface JsDocTagOptions {
/** /**
* An array of names of jsdoc tags that must exist. * An array of names of jsdoc tags, one of which must exist. If no tags are provided, there are no
* required tags.
*/ */
required?: string[]; requireAtLeastOne?: string[];
/** /**
* An array of names of jsdoc tags that must not exist. * An array of names of jsdoc tags that must not exist.
@ -316,15 +317,16 @@ class ResolvedDeclarationEmitter {
private processJsDocTags(node: ts.Node, tagOptions: JsDocTagOptions) { private processJsDocTags(node: ts.Node, tagOptions: JsDocTagOptions) {
const jsDocTags = getJsDocTags(node); const jsDocTags = getJsDocTags(node);
const missingRequiredTags = const requireAtLeastOne = tagOptions.requireAtLeastOne;
tagOptions.required.filter(requiredTag => jsDocTags.every(tag => tag !== requiredTag)); const isMissingAnyRequiredTag = requireAtLeastOne != null && requireAtLeastOne.length > 0 &&
if (missingRequiredTags.length) { jsDocTags.every(tag => requireAtLeastOne.indexOf(tag) === -1);
if (isMissingAnyRequiredTag) {
this.diagnostics.push({ this.diagnostics.push({
type: 'error', type: 'error',
message: createErrorMessage( message: createErrorMessage(
node, 'Required jsdoc tags - ' + node, 'Required jsdoc tags - One of the tags: ' +
missingRequiredTags.map(tag => `"@${tag}"`).join(', ') + requireAtLeastOne.map(tag => `"@${tag}"`).join(', ') +
` - are missing on ${getName(node)}.`) ` - must exist on ${getName(node)}.`)
}); });
} }
const bannedTagsFound = const bannedTagsFound =
@ -436,7 +438,7 @@ function hasModifier(node: ts.Node, modifierKind: ts.SyntaxKind): boolean {
} }
function applyDefaultTagOptions(tagOptions: JsDocTagOptions | undefined): JsDocTagOptions { function applyDefaultTagOptions(tagOptions: JsDocTagOptions | undefined): JsDocTagOptions {
return {required: [], banned: [], toCopy: [], ...tagOptions}; return {requireAtLeastOne: [], banned: [], toCopy: [], ...tagOptions};
} }
function getName(node: any) { function getName(node: any) {

View File

@ -531,8 +531,8 @@ describe('unit test', () => {
`; `;
checkThrows( checkThrows(
{'file.d.ts': input}, {'file.d.ts': input},
'file.d.ts(2,1): error: Required jsdoc tags - "@stable" - are missing on `A`.', 'file.d.ts(2,1): error: Required jsdoc tags - One of the tags: "@stable" - must exist on `A`.',
{exportTags: {required: ['stable']}}); {exportTags: {requireAtLeastOne: ['stable']}});
}); });
it('should throw on missing required jsdoc tags on fields', () => { it('should throw on missing required jsdoc tags on fields', () => {
@ -544,8 +544,8 @@ describe('unit test', () => {
`; `;
checkThrows( checkThrows(
{'file.d.ts': input}, {'file.d.ts': input},
'file.d.ts(3,3): error: Required jsdoc tags - "@stable" - are missing on `value`.', 'file.d.ts(3,3): error: Required jsdoc tags - One of the tags: "@stable" - must exist on `value`.',
{memberTags: {required: ['stable']}}); {memberTags: {requireAtLeastOne: ['stable']}});
}); });
it('should throw on missing required jsdoc tags on parameters', () => { it('should throw on missing required jsdoc tags on parameters', () => {
@ -557,8 +557,21 @@ describe('unit test', () => {
`; `;
checkThrows( checkThrows(
{'file.d.ts': input}, {'file.d.ts': input},
'file.d.ts(3,7): error: Required jsdoc tags - "@stable" - are missing on `param`.', 'file.d.ts(3,7): error: Required jsdoc tags - One of the tags: "@stable" - must exist on `param`.',
{paramTags: {required: ['stable']}}); {paramTags: {requireAtLeastOne: ['stable']}});
});
it('should require at least one of the requireOnOf tags', () => {
const input = `
/** @experimental */
export declare class A {
foo(param: number): void;
}
`;
checkThrows(
{'file.d.ts': input},
'file.d.ts(3,7): error: Required jsdoc tags - One of the tags: "@stable", "@foo", "@bar" - must exist on `param`.',
{paramTags: {requireAtLeastOne: ['stable', 'foo', 'bar']}});
}); });
}); });