mirror of
https://github.com/HifiExperiments/overte.git
synced 2025-06-21 18:29:10 +02:00
Merge pull request #14854 from danteruiz/quest-default
Case 21037: Allow the script engine to use FileSeclector when loading scriopts
This commit is contained in:
commit
3ee412faf7
3 changed files with 126 additions and 0 deletions
|
@ -16,6 +16,7 @@
|
||||||
#include <SettingHandle.h>
|
#include <SettingHandle.h>
|
||||||
#include <UserActivityLogger.h>
|
#include <UserActivityLogger.h>
|
||||||
#include <PathUtils.h>
|
#include <PathUtils.h>
|
||||||
|
#include <shared/FileUtils.h>
|
||||||
|
|
||||||
#include "ScriptEngine.h"
|
#include "ScriptEngine.h"
|
||||||
#include "ScriptEngineLogging.h"
|
#include "ScriptEngineLogging.h"
|
||||||
|
@ -476,6 +477,8 @@ ScriptEnginePointer ScriptEngines::loadScript(const QUrl& scriptFilename, bool i
|
||||||
scriptUrl = normalizeScriptURL(scriptFilename);
|
scriptUrl = normalizeScriptURL(scriptFilename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scriptUrl = QUrl(FileUtils::selectFile(scriptUrl.toString()));
|
||||||
|
|
||||||
auto scriptEngine = getScriptEngine(scriptUrl);
|
auto scriptEngine = getScriptEngine(scriptUrl);
|
||||||
if (scriptEngine && !scriptEngine->isStopping()) {
|
if (scriptEngine && !scriptEngine->isStopping()) {
|
||||||
return scriptEngine;
|
return scriptEngine;
|
||||||
|
|
|
@ -30,6 +30,11 @@ const QStringList& FileUtils::getFileSelectors() {
|
||||||
static std::once_flag once;
|
static std::once_flag once;
|
||||||
static QStringList extraSelectors;
|
static QStringList extraSelectors;
|
||||||
std::call_once(once, [] {
|
std::call_once(once, [] {
|
||||||
|
|
||||||
|
#if defined(Q_OS_ANDROID)
|
||||||
|
//extraSelectors << "android_" HIFI_ANDROID_APP;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(USE_GLES)
|
#if defined(USE_GLES)
|
||||||
extraSelectors << "gles";
|
extraSelectors << "gles";
|
||||||
#endif
|
#endif
|
||||||
|
|
118
scripts/+android_questInterface/defaultScripts.js
Normal file
118
scripts/+android_questInterface/defaultScripts.js
Normal file
|
@ -0,0 +1,118 @@
|
||||||
|
"use strict";
|
||||||
|
/* jslint vars: true, plusplus: true */
|
||||||
|
|
||||||
|
//
|
||||||
|
// defaultScripts.js
|
||||||
|
// examples
|
||||||
|
//
|
||||||
|
// Copyright 2014 High Fidelity, Inc.
|
||||||
|
//
|
||||||
|
// Distributed under the Apache License, Version 2.0.
|
||||||
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||||
|
//
|
||||||
|
|
||||||
|
var DEFAULT_SCRIPTS_COMBINED = [
|
||||||
|
"system/request-service.js",
|
||||||
|
"system/progress.js",
|
||||||
|
//"system/away.js",
|
||||||
|
"system/hmd.js",
|
||||||
|
"system/menu.js",
|
||||||
|
"system/bubble.js",
|
||||||
|
"system/pal.js", // "system/mod.js", // older UX, if you prefer
|
||||||
|
"system/avatarapp.js",
|
||||||
|
"system/makeUserConnection.js",
|
||||||
|
"system/tablet-goto.js",
|
||||||
|
"system/notifications.js",
|
||||||
|
"system/commerce/wallet.js",
|
||||||
|
"system/dialTone.js",
|
||||||
|
"system/firstPersonHMD.js",
|
||||||
|
"system/tablet-ui/tabletUI.js",
|
||||||
|
"system/miniTablet.js"
|
||||||
|
];
|
||||||
|
var DEFAULT_SCRIPTS_SEPARATE = [
|
||||||
|
"system/controllers/controllerScripts.js",
|
||||||
|
//"system/chat.js"
|
||||||
|
];
|
||||||
|
|
||||||
|
if (Window.interstitialModeEnabled) {
|
||||||
|
// Insert interstitial scripts at front so that they're started first.
|
||||||
|
DEFAULT_SCRIPTS_COMBINED.splice(0, 0, "system/interstitialPage.js", "system/redirectOverlays.js");
|
||||||
|
}
|
||||||
|
|
||||||
|
// add a menu item for debugging
|
||||||
|
var MENU_CATEGORY = "Developer > Scripting";
|
||||||
|
var MENU_ITEM = "Debug defaultScripts.js";
|
||||||
|
|
||||||
|
var SETTINGS_KEY = '_debugDefaultScriptsIsChecked';
|
||||||
|
var previousSetting = Settings.getValue(SETTINGS_KEY);
|
||||||
|
|
||||||
|
if (previousSetting === '' || previousSetting === false || previousSetting === 'false') {
|
||||||
|
previousSetting = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (previousSetting === true || previousSetting === 'true') {
|
||||||
|
previousSetting = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Menu.menuExists(MENU_CATEGORY) && !Menu.menuItemExists(MENU_CATEGORY, MENU_ITEM)) {
|
||||||
|
Menu.addMenuItem({
|
||||||
|
menuName: MENU_CATEGORY,
|
||||||
|
menuItemName: MENU_ITEM,
|
||||||
|
isCheckable: true,
|
||||||
|
isChecked: previousSetting,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadSeparateDefaults() {
|
||||||
|
for (var i in DEFAULT_SCRIPTS_SEPARATE) {
|
||||||
|
Script.load(DEFAULT_SCRIPTS_SEPARATE[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function runDefaultsTogether() {
|
||||||
|
for (var i in DEFAULT_SCRIPTS_COMBINED) {
|
||||||
|
Script.include(DEFAULT_SCRIPTS_COMBINED[i]);
|
||||||
|
}
|
||||||
|
loadSeparateDefaults();
|
||||||
|
}
|
||||||
|
|
||||||
|
function runDefaultsSeparately() {
|
||||||
|
for (var i in DEFAULT_SCRIPTS_COMBINED) {
|
||||||
|
Script.load(DEFAULT_SCRIPTS_COMBINED[i]);
|
||||||
|
}
|
||||||
|
loadSeparateDefaults();
|
||||||
|
}
|
||||||
|
|
||||||
|
// start all scripts
|
||||||
|
if (Menu.isOptionChecked(MENU_ITEM)) {
|
||||||
|
// we're debugging individual default scripts
|
||||||
|
// so we load each into its own ScriptEngine instance
|
||||||
|
runDefaultsSeparately();
|
||||||
|
} else {
|
||||||
|
// include all default scripts into this ScriptEngine
|
||||||
|
runDefaultsTogether();
|
||||||
|
}
|
||||||
|
|
||||||
|
function menuItemEvent(menuItem) {
|
||||||
|
if (menuItem === MENU_ITEM) {
|
||||||
|
var isChecked = Menu.isOptionChecked(MENU_ITEM);
|
||||||
|
if (isChecked === true) {
|
||||||
|
Settings.setValue(SETTINGS_KEY, true);
|
||||||
|
} else if (isChecked === false) {
|
||||||
|
Settings.setValue(SETTINGS_KEY, false);
|
||||||
|
}
|
||||||
|
Menu.triggerOption("Reload All Scripts");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeMenuItem() {
|
||||||
|
if (!Menu.isOptionChecked(MENU_ITEM)) {
|
||||||
|
Menu.removeMenuItem(MENU_CATEGORY, MENU_ITEM);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Script.scriptEnding.connect(function() {
|
||||||
|
removeMenuItem();
|
||||||
|
});
|
||||||
|
|
||||||
|
Menu.menuItemEvent.connect(menuItemEvent);
|
Loading…
Reference in a new issue