Skip to content

template-tools/template-sync

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

npm License bundlejs downloads GitHub Issues Build Status Styled with prettier Commitizen friendly Known Vulnerabilities Coverage Status

template-sync

Keep repository in sync with its template.

Generates pull requests to bring a repository back in sync with its template.

So by making changes to the template and applying template-sync the target project will be updated accoring to the template.

Works with github and bitbucket.

This is the engine for cli operation please see template-tools/template-sync-cli

Merges contents from template branch into destination branch handling some special cases for:

generated pull request

Some templates

API

Table of Contents

Context

Extends LogLevelMixin(class _Context {})

Context prepared to execute one branch.

Parameters

Properties

targetBranch

Type: (Branch | String)

initialize

Returns Promise<(Context | undefined)>

execute

Generate Pull Requests.

Returns AsyncIterable<PullRequest>

commits

Generate all commits from the template entry merges.

Returns AsyncIterable<Commit>

executeBranch

Generate Pull Requests.

Returns AsyncIterable<PullRequest> the actual PRs

pullRequestBranch

Type: String

sortedKeys

order in which json keys are written

exportsConditionOrder

Order in which exports are searched

Package

Extends Merger

Merger for package.json

properties

Deliver some key properties.

  • name
  • version
  • description
  • main

Parameters

  • entry ContentEntry

Returns Promise<Object>

Merger

Mergable content

properties

Deliver some key properties.

Parameters

  • entry ContentEntry

Returns Promise<Object> extracted properties

commits

Generate commits as result of merging two entries.

Parameters

  • context
  • destinationEntry
  • sourceEntry
  • options

Returns AsyncIterable<Commit>

Merger

Type: Object

Properties

properties

Deliver some key properties.

Parameters

  • entry ContentEntry

Returns Promise<Object> extracted properties

commits

Generate commits as result of merging two entries.

Parameters

  • context
  • destinationEntry
  • sourceEntry
  • options

Returns AsyncIterable<Commit>

Readme

Extends Merger

Injects badges into README.md.

MergeLineSet

Extends Merger

Replace

Extends Merger

Always overwrite entry from template

INI

Extends Merger

Merge ini entries

Skip

Extends Merger

Does not generate destination entry

Delete

Extends Merger

Delete entry.

EntryMerger

Type: Object

Properties

Template

Extends LogLevelMixin(class {})

Parameters

Properties

  • context Conext
  • sources Set<string>
  • toBeRemovedSources Set<string>
  • mergers Array<Merger>
  • branches Set<Branch> all used branches direct and inherited
  • keyBranches Set<Branch> branches used to define the template

shortKey

Used to identify generated branch.

Returns string short template key

entryMerger

Find a suitable merger for each entry

Parameters

  • entries Iterator<ContentEntry>

Returns Iterator<[ContentEntry, Merger]>

mergerFor

Find a suitable merger

Parameters

Returns Merger

_templateFrom

Load all templates and collects the entries.

Parameters

  • sources string branch names
  • inheritencePath Array<Branch> who was requesting us (optional, default [])

Returns Object package as merged from sources

updateUsedBy

Updates usedBy section of the template branch.

Parameters

  • targetBranch Branch template to be updated
  • templateSources Array<string> original branch identifiers (even with deletion hints)
  • options Object as passed to commitIntoPullRequest

Returns AsyncIterator<PullRequest>

templateFor

Load a template.

Parameters

ReplaceIfEmpty

Extends Merger

Overwrites none existing entries from template.

normalizeTemplateSources

Remove duplicate sources. Sources staring with '-' will be removed

Parameters

Returns Array<string> normalized sources

jspath

Parameters

  • object
  • path
  • cb

actions2message

Parameters

Returns any actions as one string lines ordered by scope

actions2messages

Parameters

install

With npm do:

npm install -g @template-tools/sync-cli

license

BSD-2-Clause