Как я могу включить файлы с Gjs Gnome Javascript
Я понимаю, что могу импортировать файлы достаточно легко, но я пытаюсь создать какую-то структуру плагинов. Я хотел бы иметь возможность сканировать папку и загружать каждый файл Javascript.
С помощью Seed JS я могу использовать Seed.include() для оценки файла, как если бы он был включен в файл в момент вызова include. ( ссылка)
Gnome Javascript (Gjs) имеет эквивалентную функцию?
3 ответа
Есть нить об этой проблеме, парень, по-видимому, жалуется, что это на самом деле не работает. Я не знаю, стоит ли пытаться, потому что в любом случае такой подход - отстой - он слишком громоздкий, на мой взгляд.
Так что я просто поделюсь тем, что я сделал в своем расширении gnome.
TL; DR: используйте Node + Webpack, чтобы иметь хорошую систему модулей и доступ к огромной библиотеке модулей.
- Прежде всего, я установил Node + npm, потому что вместе они дают вам достаточно функциональную систему модулей. Бонус - вы можете использовать общедоступные модули NPM, если они не используют Node API.
- Я создал
package.json
файл, вот он:
{
"name": "blah",
"version": "0.0.1",
"description": "blah",
"scripts": {
"watch": "nodemon --exec 'npm run build'",
"build": "webpack"
},
"author": "me",
"license": "ISC",
"devDependencies": {
"nodemon": "^1.11.0",
"webpack": "^2.2.1"
},
"dependencies": {
"string-format": "^0.5.0"
}
}
- Далее я создал свой
webpack.config.js
файл:
var path = require('path');
module.exports = {
entry: {
main: './src/main.js',
ui: './src/ui.js'
},
output: {
filename: '[name].js',
path: path.resolve(__dirname),
libraryTarget: 'var',
library: '[name]'
},
resolve: {
modules: [
path.resolve('./src'),
'node_modules'
]
},
externals: {
'gnome': 'global',
'lang': 'imports.lang',
'gi/meta': 'imports.gi.Meta',
'gi/shell': 'imports.gi.Shell',
'ui/main': 'imports.ui.main',
'ui/popupMenu': 'imports.ui.popupMenu',
'ui/panelMenu': 'imports.ui.panelMenu',
'gi/atk': 'imports.gi.Atk',
'gi/st': 'imports.gi.St',
'gi/gtk': 'imports.gi.Gtk',
'gi/gdk': 'imports.gi.Gdk',
'gi/gobject': 'imports.gi.GObject',
'gi/gio': 'imports.gi.Gio',
'gi/soup': 'imports.gi.Soup',
'gi/glib': 'imports.gi.GLib',
'gi/clutter': 'imports.gi.Clutter',
'misc/config': 'imports.misc.config',
'me': 'imports.misc.extensionUtils.getCurrentExtension()'
}
};
Так что теперь я использую систему модулей Node и могу просто требовать, чтобы мои вещи были в файлах. Тогда я бегу npm run build
и webpack дает мне один хороший жесткий файл, который я могу запустить со всем необходимым внутри.
Есть пример файла:
const Lang = require('lang')
const Gdk = require('gi/gdk')
const parser = require('./parser')
const modifier = require('./modifier')
const rules = [
parser((state, result) => {
const name = result.string
const rule = new RegExp('^[a-zA-Z0-9]+$')
return name && rule.test(name)
}, '', true),
modifier(Gdk.ModifierType.SUPER_MASK, 'super', false),
modifier(Gdk.ModifierType.MOD1_MASK, 'alt', false),
modifier(Gdk.ModifierType.CONTROL_MASK, 'control', false),
// this makes sure that we have at least one modifier enabled
modifier(Gdk.ModifierType.MODIFIER_MASK, false, true)
]
module.exports = function(state, keyval) {
const result = {
valid: false,
string: '',
}
if(state[0] && keyval[0]) {
result.valid = true,
result.string = Gdk.keyval_name(keyval[1])
rules.forEach((rule) => {
result = rule(state[1], result)
})
}
return result
}
Вы можете добавить новую запись в imports.searchPath
:
$ mkdir -p ~/gjs/dynmodules/
$ touch ~/gjs/dynmodules/hello.js
imports.searchPath.push("/home/ole/gjs")
hello = imports.dynmodules.hello;
Вы можете загрузить содержимое файла в строку и eval()
это получить тот же эффект.
У вас есть конкретная причина, почему вы не можете использовать импорт, чтобы получить то, что вы хотите в структуре плагина? Вы также можете сканировать каталог и импортировать каждый файл JS. Это предотвратит сброс плагинов произвольных значений в ваше глобальное пространство имен.