scaffolding

This commit is contained in:
2024-11-12 16:22:30 +02:00
parent 7180cfeb7f
commit c2245d92b3
9 changed files with 345 additions and 2 deletions
+55
View File
@@ -0,0 +1,55 @@
const fs = require('fs');
function getType(t){
return (t?.type.names[0] || '').replace(/^Array\.\<(.*)\>$/, '$1*')
}
function graft(childNodes, parentLongname) {
let result = '';
childNodes.filter(({memberof}) => memberof === parentLongname)
.forEach(element => {
if (element.kind === 'function') {
result += `${getType(element.returns?.[0]) || 'void'} ${element.name}(${ element.params?.map(p=>
`/* ${p.description || ''} */ ${getType(p)} ${p.name}`
).join(', ') || ''});\n`;
}
else if (element.kind === 'member') {
result += `/* ${element.description || ''} */ ${getType(element)} ${element.name};`
}
else if (element.kind === 'class') {
result+= `/** ${element.classdesc || ''} */\nclass ${element.name}{\n public: \n`;
result += graft(childNodes, element.longname);
result+= '\n};\n';
}
});
return result;
}
/**
@param {TAFFY} data
@param {object} opts
*/
exports.publish = (data, {destination, query}) => {
let docs;
data({undocumented: true}).remove();
docs = data().get(); // <-- an array of Doclet objects
fs.promises.writeFile('./result.json', JSON.stringify(docs), {encoding:'utf-8'})
let result = graft(docs);
console.log(result)
if (destination === 'console') {
if (query && query.format === 'xml') {
//console.log( xml.parse('xs:schema', root) );
}
else {
//console.log( require('jsdoc/util/dumper').dump(root) );
}
}
else {
console.log('This template only supports output to the console. Use the option "-d console" when you run JSDoc.');
}
};
+102
View File
@@ -0,0 +1,102 @@
/**
* Games manager class
*/
class GamesManager{
name = 'games';
/**
* Class initializer
* @param {App} app Class initializer
*/
init(app){
const {db} = app;
/**
* Creates a new game definition
* @param {Context} ctx Request context
* @param {Game} data the game description
*/
this.create = async function(ctx, data){
}
/**
* Reads game definition by ID
* @param {Number} id game ID
* @returns {Game}
*/
this.read = async function(id){
}
/**
* Updates game definition
* @param {Context} ctx Request context
* @param {Game} data the game description
*/
this.update = async function(ctx, data){
}
/**
* Removes game by ID
* @param {Number} id game definition ID
*/
this.remove = async function(id){
}
/**
* Returns a set of games by given criteria
* @param {Query} query criteria
* @returns {Game[]}
*/
this.list = async function(query){
}
}
/**
* Class starter
* @param {App} app The application
*/
async start(app){
}
}
/**
* Game entity
*/
class Game {
/**
* Game name
* @type string
*/
name = null;
/**
* Game formal description
* @type GameDefinition
*/
definition = {
/**
*
*/
levels:[
{
name: 'Level 1',
environment: null,
objects:[
{
id: 15
}
]
}
]
};
}
export { GamesManager }
+82
View File
@@ -0,0 +1,82 @@
/**
* Rules manager class
*/
class RulesManager{
name = 'rules';
/**
* Class initializer
* @param {App} app Class initializer
*/
init(app){
const {db} = app;
/**
* Creates a new rule
* @param {Context} ctx Request context
* @param {Rule} data the rule
*/
this.create = async function(ctx, data){
}
/**
* Reads rule by ID
* @param {Number} id rule ID
* @returns {Rule}
*/
this.read = async function(id){
}
/**
* Updates rule
* @param {Context} ctx Request context
* @param {Rule} data the rule
*/
this.update = async function(ctx, data){
}
/**
* Removes rule by ID
* @param {Number} id rule ID
*/
this.remove = async function(id){
}
/**
* Returns a set of rules by given criteria
* @param {Query} query criteria
* @returns {Rule[]}
*/
this.list = async function(query){
}
}
/**
* Class starter
* @param {App} app The application
*/
async start(app){
}
}
/**
* Rule entity
*/
class Rule {
/**
* Rule name
* @type string
*/
name = null;
}
export { RulesManager }
+82
View File
@@ -0,0 +1,82 @@
/**
* Scenarios manager class
*/
class ScenariosManager{
name = 'scenarios';
/**
* Class initializer
* @param {App} app Class initializer
*/
init(app){
const {db} = app;
/**
* Creates a new scenario
* @param {Context} ctx Request context
* @param {Scenario} data the scenario
*/
this.create = async function(ctx, data){
}
/**
* Reads scenario by ID
* @param {Number} id scenario ID
* @returns {Scenario}
*/
this.read = async function(id){
}
/**
* Updates scenario
* @param {Context} ctx Request context
* @param {Scenario} data the scenario
*/
this.update = async function(ctx, data){
}
/**
* Removes scenario by ID
* @param {Number} id scenario ID
*/
this.remove = async function(id){
}
/**
* Returns a set of scenarios by given criteria
* @param {Query} query criteria
* @returns {Scenario[]}
*/
this.list = async function(query){
}
}
/**
* Class starter
* @param {App} app The application
*/
async start(app){
}
}
/**
* Scenario entity
*/
class Scenario {
/**
* Scenario name
* @type string
*/
name = null;
}
export { ScenariosManager }
@@ -0,0 +1,13 @@
import express from 'express';
class GamesController{
name = 'gamesApi'
route = '/api/game'
init(app){
const router = express.Router();
}
}
export { GamesController }
+2 -2
View File
@@ -9,7 +9,7 @@
<v-list> <v-list>
<v-list-item to="/game-objects/add">Нов игрови обект</v-list-item> <v-list-item to="/game-objects/add">Нов игрови обект</v-list-item>
<v-list-item>Нов сценарий</v-list-item> <v-list-item>Нов сценарий</v-list-item>
<v-list-item>Нова игра</v-list-item> <v-list-item to="/games/add">Нова игра</v-list-item>
</v-list> </v-list>
</v-menu> </v-menu>
</v-app-bar> </v-app-bar>
@@ -24,7 +24,7 @@
<v-list-item prepend-icon="mdi-receipt-text-edit-outline" :title="$l.gameScenarios"></v-list-item> <v-list-item prepend-icon="mdi-receipt-text-edit-outline" :title="$l.gameScenarios"></v-list-item>
<v-list-item prepend-icon="mdi-cogs" :title="$l.gameRules"></v-list-item> <v-list-item prepend-icon="mdi-cogs" :title="$l.gameRules"></v-list-item>
<v-divider></v-divider> <v-divider></v-divider>
<v-list-item prepend-icon="mdi-controller" :title="$l.games"></v-list-item> <v-list-item prepend-icon="mdi-controller" :title="$l.games" to="/games/list"></v-list-item>
</v-list> </v-list>
<v-divider></v-divider> <v-divider></v-divider>
<v-list nav> <v-list nav>
+9
View File
@@ -0,0 +1,9 @@
<template>
</template>
<script>
export default {
}
</script>