如何使用Gjs Gnome Javascript包含文件



我知道我可以很容易地导入文件,但我正在尝试制作某种插件结构。我希望能够扫描文件夹并加载每个Javascript文件。

使用Seed JS,我可以使用Seed.include()来评估文件,就好像它在调用include时包含在文件中一样。(参考)

Gnome Javascript(Gjs)有等效的功能吗?

有一个关于这个问题的线索,这个家伙显然抱怨它实际上不起作用。我不知道是否值得尝试,因为无论如何,这种方法都很糟糕——在我看来太麻烦了。

所以我只分享我在gnome扩展中所做的事情。

TL;DR:使用Node+Webpack可以拥有良好的模块系统,并可以访问庞大的模块库。

  • 首先,我安装了Node+npm,因为它们一起为您提供了功能强大的模块系统。奖金-如果公共NPM模块不使用任何节点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文件。这将防止插件将任意值转储到全局命名空间中。

相关内容

  • 没有找到相关文章

最新更新