mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-17 18:44:45 +02:00
Chore: Automatically build migration index
This commit is contained in:
parent
9aa7240d5e
commit
a281163353
@ -781,6 +781,7 @@ packages/lib/services/database/migrations/42.js
|
|||||||
packages/lib/services/database/migrations/43.js
|
packages/lib/services/database/migrations/43.js
|
||||||
packages/lib/services/database/migrations/44.js
|
packages/lib/services/database/migrations/44.js
|
||||||
packages/lib/services/database/migrations/45.js
|
packages/lib/services/database/migrations/45.js
|
||||||
|
packages/lib/services/database/migrations/index.js
|
||||||
packages/lib/services/database/sqlStringToLines.js
|
packages/lib/services/database/sqlStringToLines.js
|
||||||
packages/lib/services/database/types.js
|
packages/lib/services/database/types.js
|
||||||
packages/lib/services/debug/populateDatabase.js
|
packages/lib/services/debug/populateDatabase.js
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -761,6 +761,7 @@ packages/lib/services/database/migrations/42.js
|
|||||||
packages/lib/services/database/migrations/43.js
|
packages/lib/services/database/migrations/43.js
|
||||||
packages/lib/services/database/migrations/44.js
|
packages/lib/services/database/migrations/44.js
|
||||||
packages/lib/services/database/migrations/45.js
|
packages/lib/services/database/migrations/45.js
|
||||||
|
packages/lib/services/database/migrations/index.js
|
||||||
packages/lib/services/database/sqlStringToLines.js
|
packages/lib/services/database/sqlStringToLines.js
|
||||||
packages/lib/services/database/types.js
|
packages/lib/services/database/types.js
|
||||||
packages/lib/services/debug/populateDatabase.js
|
packages/lib/services/debug/populateDatabase.js
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"buildApiDoc": "yarn workspace joplin start apidoc ../../readme/api/references/rest_api.md",
|
"buildApiDoc": "yarn workspace joplin start apidoc ../../readme/api/references/rest_api.md",
|
||||||
"buildCommandIndex": "node packages/tools/gulp/tasks/buildCommandIndexRun.js",
|
"buildScriptIndexes": "node packages/tools/gulp/tasks/buildScriptIndexesRun.js",
|
||||||
"buildParallel": "yarn workspaces foreach --verbose --interlaced --parallel --jobs 2 --topological run build && yarn run tsc",
|
"buildParallel": "yarn workspaces foreach --verbose --interlaced --parallel --jobs 2 --topological run build && yarn run tsc",
|
||||||
"buildPluginDoc": "cd packages/generate-plugin-doc && yarn run buildPluginDoc_",
|
"buildPluginDoc": "cd packages/generate-plugin-doc && yarn run buildPluginDoc_",
|
||||||
"buildSequential": "yarn workspaces foreach --verbose --interlaced --topological run build && yarn run tsc",
|
"buildSequential": "yarn workspaces foreach --verbose --interlaced --topological run build && yarn run tsc",
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as copyDevCommand from './copyDevCommand';
|
import * as copyDevCommand from './copyDevCommand';
|
||||||
import * as editProfileConfig from './editProfileConfig';
|
import * as editProfileConfig from './editProfileConfig';
|
||||||
import * as exportFolders from './exportFolders';
|
import * as exportFolders from './exportFolders';
|
||||||
@ -36,4 +36,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as addProfile from './addProfile';
|
import * as addProfile from './addProfile';
|
||||||
import * as commandPalette from './commandPalette';
|
import * as commandPalette from './commandPalette';
|
||||||
import * as deleteFolder from './deleteFolder';
|
import * as deleteFolder from './deleteFolder';
|
||||||
@ -92,4 +92,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as focusElementNoteBody from './focusElementNoteBody';
|
import * as focusElementNoteBody from './focusElementNoteBody';
|
||||||
import * as focusElementNoteTitle from './focusElementNoteTitle';
|
import * as focusElementNoteTitle from './focusElementNoteTitle';
|
||||||
import * as pasteAsText from './pasteAsText';
|
import * as pasteAsText from './pasteAsText';
|
||||||
@ -14,4 +14,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as focusElementNoteList from './focusElementNoteList';
|
import * as focusElementNoteList from './focusElementNoteList';
|
||||||
|
|
||||||
const index:any[] = [
|
const index:any[] = [
|
||||||
@ -6,4 +6,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as focusSearch from './focusSearch';
|
import * as focusSearch from './focusSearch';
|
||||||
|
|
||||||
const index:any[] = [
|
const index:any[] = [
|
||||||
@ -6,4 +6,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as focusElementSideBar from './focusElementSideBar';
|
import * as focusElementSideBar from './focusElementSideBar';
|
||||||
|
|
||||||
const index:any[] = [
|
const index:any[] = [
|
||||||
@ -6,4 +6,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
@ -39,7 +39,7 @@ const tasks = {
|
|||||||
},
|
},
|
||||||
tsc: require('@joplin/tools/gulp/tasks/tsc'),
|
tsc: require('@joplin/tools/gulp/tasks/tsc'),
|
||||||
updateIgnoredTypeScriptBuild: require('@joplin/tools/gulp/tasks/updateIgnoredTypeScriptBuild'),
|
updateIgnoredTypeScriptBuild: require('@joplin/tools/gulp/tasks/updateIgnoredTypeScriptBuild'),
|
||||||
buildCommandIndex: require('@joplin/tools/gulp/tasks/buildCommandIndex'),
|
buildScriptIndexes: require('@joplin/tools/gulp/tasks/buildScriptIndexes'),
|
||||||
compileSass: {
|
compileSass: {
|
||||||
fn: async () => {
|
fn: async () => {
|
||||||
await compileSass(
|
await compileSass(
|
||||||
@ -58,7 +58,7 @@ const buildBeforeStartParallel = [
|
|||||||
'copyPluginAssets',
|
'copyPluginAssets',
|
||||||
'copyApplicationAssets',
|
'copyApplicationAssets',
|
||||||
'updateIgnoredTypeScriptBuild',
|
'updateIgnoredTypeScriptBuild',
|
||||||
'buildCommandIndex',
|
'buildScriptIndexes',
|
||||||
'compileSass',
|
'compileSass',
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -1,13 +1,10 @@
|
|||||||
import Resource from './models/Resource';
|
import Resource from './models/Resource';
|
||||||
import shim from './shim';
|
import shim from './shim';
|
||||||
import Database from './database';
|
import Database from './database';
|
||||||
import migration42 from './services/database/migrations/42';
|
import { SqlQuery } from './services/database/types';
|
||||||
import migration43 from './services/database/migrations/43';
|
|
||||||
import migration44 from './services/database/migrations/44';
|
|
||||||
import migration45 from './services/database/migrations/45';
|
|
||||||
import { SqlQuery, Migration } from './services/database/types';
|
|
||||||
import addMigrationFile from './services/database/addMigrationFile';
|
import addMigrationFile from './services/database/addMigrationFile';
|
||||||
import sqlStringToLines from './services/database/sqlStringToLines';
|
import sqlStringToLines from './services/database/sqlStringToLines';
|
||||||
|
import migrations from './services/database/migrations';
|
||||||
|
|
||||||
const { sprintf } = require('sprintf-js');
|
const { sprintf } = require('sprintf-js');
|
||||||
|
|
||||||
@ -125,13 +122,6 @@ CREATE TABLE version (
|
|||||||
INSERT INTO version (version) VALUES (1);
|
INSERT INTO version (version) VALUES (1);
|
||||||
`;
|
`;
|
||||||
|
|
||||||
const migrations: Migration[] = [
|
|
||||||
migration42,
|
|
||||||
migration43,
|
|
||||||
migration44,
|
|
||||||
migration45,
|
|
||||||
];
|
|
||||||
|
|
||||||
export interface TableField {
|
export interface TableField {
|
||||||
name: string;
|
name: string;
|
||||||
type: number;
|
type: number;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
import * as historyBackward from './historyBackward';
|
import * as historyBackward from './historyBackward';
|
||||||
import * as historyForward from './historyForward';
|
import * as historyForward from './historyForward';
|
||||||
import * as openMasterPasswordDialog from './openMasterPasswordDialog';
|
import * as openMasterPasswordDialog from './openMasterPasswordDialog';
|
||||||
@ -12,4 +12,4 @@ const index:any[] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
// AUTO-GENERATED using `gulp buildCommandIndex`
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
17
packages/lib/services/database/migrations/index.ts
Normal file
17
packages/lib/services/database/migrations/index.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
||||||
|
import migration42 from './42';
|
||||||
|
import migration43 from './43';
|
||||||
|
import migration44 from './44';
|
||||||
|
import migration45 from './45';
|
||||||
|
|
||||||
|
import { Migration } from '../types';
|
||||||
|
|
||||||
|
const index: Migration[] = [
|
||||||
|
migration42,
|
||||||
|
migration43,
|
||||||
|
migration44,
|
||||||
|
migration45,
|
||||||
|
];
|
||||||
|
|
||||||
|
export default index;
|
||||||
|
// AUTO-GENERATED using `gulp buildScriptIndexes`
|
@ -1,11 +1,18 @@
|
|||||||
|
// Takes a directory of TypeScript files and generate an index from it.
|
||||||
|
|
||||||
const utils = require('../utils');
|
const utils = require('../utils');
|
||||||
const glob = require('glob');
|
const glob = require('glob');
|
||||||
const rootDir = utils.rootDir();
|
const rootDir = utils.rootDir();
|
||||||
|
|
||||||
async function processDirectory(dir) {
|
async function processDirectory(dir, indexFilePath = null, typeScriptType = null, imports = null, importNameTemplate = null, exportNameTemplate = null) {
|
||||||
|
if (!indexFilePath) indexFilePath = `${dir}/index.ts`;
|
||||||
|
if (!typeScriptType) typeScriptType = 'any';
|
||||||
|
if (!importNameTemplate) importNameTemplate = '* as FILE_NAME';
|
||||||
|
if (!exportNameTemplate) exportNameTemplate = 'FILE_NAME';
|
||||||
|
|
||||||
const tsFiles = glob.sync('{**/*.ts,**/*.tsx}', {
|
const tsFiles = glob.sync('{**/*.ts,**/*.tsx}', {
|
||||||
cwd: dir,
|
cwd: dir,
|
||||||
}).filter(f => f !== 'index.ts');
|
}).filter(f => `${dir}/${f}` !== indexFilePath);
|
||||||
|
|
||||||
tsFiles.sort();
|
tsFiles.sort();
|
||||||
|
|
||||||
@ -13,16 +20,21 @@ async function processDirectory(dir) {
|
|||||||
|
|
||||||
for (const tsFile of tsFiles) {
|
for (const tsFile of tsFiles) {
|
||||||
const f = utils.getFilename(tsFile);
|
const f = utils.getFilename(tsFile);
|
||||||
fileContent.push(`import * as ${f} from './${f}';`);
|
fileContent.push(`import ${importNameTemplate.replace(/FILE_NAME/g, f)} from './${f}';`);
|
||||||
}
|
}
|
||||||
|
|
||||||
fileContent.push('');
|
fileContent.push('');
|
||||||
|
|
||||||
fileContent.push('const index:any[] = [');
|
if (imports) {
|
||||||
|
fileContent.push(imports);
|
||||||
|
fileContent.push('');
|
||||||
|
}
|
||||||
|
|
||||||
|
fileContent.push(`const index:${typeScriptType}[] = [`);
|
||||||
|
|
||||||
for (const tsFile of tsFiles) {
|
for (const tsFile of tsFiles) {
|
||||||
const f = utils.getFilename(tsFile);
|
const f = utils.getFilename(tsFile);
|
||||||
fileContent.push(`\t${f},`);
|
fileContent.push(`\t${exportNameTemplate.replace(/FILE_NAME/g, f)},`);
|
||||||
}
|
}
|
||||||
|
|
||||||
fileContent.push('];');
|
fileContent.push('];');
|
||||||
@ -31,13 +43,11 @@ async function processDirectory(dir) {
|
|||||||
|
|
||||||
fileContent.push('export default index;');
|
fileContent.push('export default index;');
|
||||||
|
|
||||||
const destFile = `${dir}/index.ts`;
|
console.info(`Generating ${indexFilePath}...`);
|
||||||
|
|
||||||
console.info(`Generating ${destFile}...`);
|
|
||||||
|
|
||||||
await utils.insertContentIntoFile(
|
await utils.insertContentIntoFile(
|
||||||
destFile,
|
indexFilePath,
|
||||||
'// AUTO-GENERATED using `gulp buildCommandIndex`',
|
'// AUTO-GENERATED using `gulp buildScriptIndexes`',
|
||||||
fileContent.join('\n'),
|
fileContent.join('\n'),
|
||||||
true,
|
true,
|
||||||
);
|
);
|
||||||
@ -53,5 +63,14 @@ module.exports = {
|
|||||||
await processDirectory(`${rootDir}/packages/app-desktop/gui/NoteListControls/commands`);
|
await processDirectory(`${rootDir}/packages/app-desktop/gui/NoteListControls/commands`);
|
||||||
await processDirectory(`${rootDir}/packages/app-desktop/gui/Sidebar/commands`);
|
await processDirectory(`${rootDir}/packages/app-desktop/gui/Sidebar/commands`);
|
||||||
await processDirectory(`${rootDir}/packages/lib/commands`);
|
await processDirectory(`${rootDir}/packages/lib/commands`);
|
||||||
|
|
||||||
|
await processDirectory(
|
||||||
|
`${rootDir}/packages/lib/services/database/migrations`,
|
||||||
|
null,
|
||||||
|
'Migration',
|
||||||
|
'import { Migration } from \'../types\';',
|
||||||
|
'migrationFILE_NAME',
|
||||||
|
'migrationFILE_NAME',
|
||||||
|
);
|
||||||
},
|
},
|
||||||
};
|
};
|
@ -1,6 +1,6 @@
|
|||||||
// Allow running that task "buildCommandIndex" without gulp
|
// Allow running that task "buildScriptIndexes" without gulp
|
||||||
|
|
||||||
const task = require('./buildCommandIndex.js');
|
const task = require('./buildScriptIndexes.js');
|
||||||
|
|
||||||
const main = async () => {
|
const main = async () => {
|
||||||
await task.fn();
|
await task.fn();
|
Loading…
x
Reference in New Issue
Block a user