@atomist/sdm
Version:
Atomist Software Delivery Machine SDK
48 lines (41 loc) • 2.09 kB
text/typescript
/*
* Copyright © 2019 Atomist, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { EditResult } from "@atomist/automation-client/lib/operations/edit/projectEditor";
import { Project } from "@atomist/automation-client/lib/project/Project";
import { NoParameters } from "@atomist/automation-client/lib/SmartParameters";
import { PushAwareParametersInvocation } from "./PushAwareParametersInvocation";
export type TransformResult = EditResult;
export type TransformReturnable = Project | TransformResult | void;
/**
* Function that can transform a project. Mixing HandlerContextMethods into second
* parameter, and third parameter are only for backward compatibility.
* New code should use (Project, Command ParametersInvocation).
* Projects are naturally mutable.
*/
export type CodeTransform<P = NoParameters> = (p: Project,
papi: PushAwareParametersInvocation<P>,
params?: P) => Promise<TransformReturnable>;
/**
* Compatible with CodeTransform but returns TransformResult.
* At the cost of greater ceremony, guarantees the return of more information.
*/
export type ExplicitCodeTransform<P = NoParameters> = (p: Project,
papi: PushAwareParametersInvocation<P>,
params?: P) => Promise<TransformResult>;
/**
* One or many CodeTransforms
*/
export type CodeTransformOrTransforms<PARAMS> = CodeTransform<PARAMS> | Array<CodeTransform<PARAMS>>;