1
0
mirror of https://github.com/rkd77/elinks.git synced 2024-12-04 14:46:47 -05:00

[spidermonkey] convert keyCode to dom_string

This commit is contained in:
Witold Filipczyk 2024-05-12 12:11:26 +02:00
parent c45fa86605
commit 4439f4e976
8 changed files with 160 additions and 8 deletions

View File

@ -377,6 +377,29 @@ CORESTRING_DOM_VALUE(text_javascript, "text/javascript");
CORESTRING_DOM_VALUE(http_equiv, "http-equiv"); CORESTRING_DOM_VALUE(http_equiv, "http-equiv");
CORESTRING_DOM_VALUE(html_namespace, "http://www.w3.org/1999/xhtml"); CORESTRING_DOM_VALUE(html_namespace, "http://www.w3.org/1999/xhtml");
/* keyboardEvent keys */
CORESTRING_DOM_STRING(Enter);
CORESTRING_DOM_STRING(Insert);
CORESTRING_DOM_STRING(ArrowLeft);
CORESTRING_DOM_STRING(ArrowRight);
CORESTRING_DOM_STRING(ArrowUp);
CORESTRING_DOM_STRING(ArrowDown);
CORESTRING_DOM_STRING(Backspace);
CORESTRING_DOM_STRING(Tab);
CORESTRING_DOM_STRING(Delete);
CORESTRING_DOM_STRING(F1);
CORESTRING_DOM_STRING(F2);
CORESTRING_DOM_STRING(F3);
CORESTRING_DOM_STRING(F4);
CORESTRING_DOM_STRING(F5);
CORESTRING_DOM_STRING(F6);
CORESTRING_DOM_STRING(F7);
CORESTRING_DOM_STRING(F8);
CORESTRING_DOM_STRING(F9);
CORESTRING_DOM_STRING(F10);
CORESTRING_DOM_STRING(F11);
CORESTRING_DOM_STRING(F12);
//CORESTRING_NSURL(about_blank, "about:blank"); //CORESTRING_NSURL(about_blank, "about:blank");
//CORESTRING_NSURL(about_query_ssl, "about:query/ssl"); //CORESTRING_NSURL(about_query_ssl, "about:query/ssl");
//CORESTRING_NSURL(about_query_auth, "about:query/auth"); //CORESTRING_NSURL(about_query_auth, "about:query/auth");

View File

@ -16,6 +16,7 @@
#include "cache/cache.h" #include "cache/cache.h"
#include "document/document.h" #include "document/document.h"
#include "document/libdom/corestrings.h"
#include "document/libdom/doc.h" #include "document/libdom/doc.h"
#include "intl/charsets.h" #include "intl/charsets.h"
#include "util/string.h" #include "util/string.h"
@ -104,3 +105,109 @@ add_lowercase_to_string(struct string *buf, const char *str, int len)
add_bytes_to_string(buf, tmp, len); add_bytes_to_string(buf, tmp, len);
mem_free(tmp); mem_free(tmp);
} }
bool
convert_key_to_dom_string(term_event_key_T key, dom_string **res)
{
bool is_special = key <= 0x001F || (0x007F <= key && key <= 0x009F);
dom_string *dom_key = NULL;
dom_exception exc;
if (is_special) {
switch (key) {
case KBD_ENTER:
dom_key = dom_string_ref(corestring_dom_Enter);
break;
case KBD_LEFT:
dom_key = dom_string_ref(corestring_dom_ArrowLeft);
break;
case KBD_RIGHT:
dom_key = dom_string_ref(corestring_dom_ArrowRight);
break;
case KBD_UP:
dom_key = dom_string_ref(corestring_dom_ArrowUp);
break;
case KBD_DOWN:
dom_key = dom_string_ref(corestring_dom_ArrowDown);
break;
case KBD_PAGE_UP:
dom_key = dom_string_ref(corestring_dom_PageUp);
break;
case KBD_PAGE_DOWN:
dom_key = dom_string_ref(corestring_dom_PageDown);
break;
case KBD_HOME:
dom_key = dom_string_ref(corestring_dom_Home);
break;
case KBD_END:
dom_key = dom_string_ref(corestring_dom_End);
break;
case KBD_ESC:
dom_key = dom_string_ref(corestring_dom_Escape);
break;
case KBD_BS: // Backspace
dom_key = dom_string_ref(corestring_dom_Backspace);
break;
case KBD_TAB: // Tab
dom_key = dom_string_ref(corestring_dom_Tab);
break;
case KBD_INS: // Insert
dom_key = dom_string_ref(corestring_dom_Insert);
break;
case KBD_DEL: // Delete
dom_key = dom_string_ref(corestring_dom_Delete);
break;
case KBD_F1: // F1
dom_key = dom_string_ref(corestring_dom_F1);
break;
case KBD_F2: // F2
dom_key = dom_string_ref(corestring_dom_F2);
break;
case KBD_F3: // F3
dom_key = dom_string_ref(corestring_dom_F3);
break;
case KBD_F4: // F4
dom_key = dom_string_ref(corestring_dom_F4);
break;
case KBD_F5: // F5
dom_key = dom_string_ref(corestring_dom_F5);
break;
case KBD_F6: // F6
dom_key = dom_string_ref(corestring_dom_F6);
break;
case KBD_F7: // F7
dom_key = dom_string_ref(corestring_dom_F7);
break;
case KBD_F8: // F8
dom_key = dom_string_ref(corestring_dom_F8);
break;
case KBD_F9: // F9
dom_key = dom_string_ref(corestring_dom_F9);
break;
case KBD_F10: // F10
dom_key = dom_string_ref(corestring_dom_F10);
break;
case KBD_F11: // F11
dom_key = dom_string_ref(corestring_dom_F11);
break;
case KBD_F12: // F12
dom_key = dom_string_ref(corestring_dom_F12);
break;
default:
dom_key = NULL;
break;
}
} else {
char *utf8 = encode_utf8(key);
if (utf8) {
exc = dom_string_create((const uint8_t *)utf8, strlen(utf8), &dom_key);
if (exc != DOM_NO_ERR) {
return false;
}
}
}
*res = dom_key;
return true;
}

View File

@ -1,6 +1,9 @@
#ifndef EL__DOCUMENT_LIBDOM_DOC_H #ifndef EL__DOCUMENT_LIBDOM_DOC_H
#define EL__DOCUMENT_LIBDOM_DOC_H #define EL__DOCUMENT_LIBDOM_DOC_H
#include <dom/dom.h>
#include "terminal/kbd.h"
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
@ -13,6 +16,7 @@ void *document_parse(struct document *document, struct string *source);
void free_document(void *doc); void free_document(void *doc);
void *el_match_selector(const char *selector, void *node); void *el_match_selector(const char *selector, void *node);
void add_lowercase_to_string(struct string *buf, const char *str, int len); void add_lowercase_to_string(struct string *buf, const char *str, int len);
bool convert_key_to_dom_string(term_event_key_T key, dom_string **res);
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -6,6 +6,8 @@
#include "elinks.h" #include "elinks.h"
#include "ecmascript/libdom/dom.h"
#include "dialogs/status.h" #include "dialogs/status.h"
#include "document/document.h" #include "document/document.h"
#include "document/libdom/doc.h" #include "document/libdom/doc.h"
@ -593,3 +595,4 @@ walk_tree_query_append(dom_node *root, dom_node *node, const char *selector, int
} while (child != NULL); /* No more children */ } while (child != NULL); /* No more children */
} }
} }

View File

@ -4,6 +4,7 @@
#include "document/document.h" #include "document/document.h"
#include "ecmascript/libdom/dom.h" #include "ecmascript/libdom/dom.h"
#include "main/module.h" #include "main/module.h"
#include "terminal/kbd.h"
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {

View File

@ -9,6 +9,8 @@
#include "elinks.h" #include "elinks.h"
#include "ecmascript/libdom/dom.h"
#include "config/home.h" #include "config/home.h"
#include "config/options.h" #include "config/options.h"
#include "dialogs/status.h" #include "dialogs/status.h"

View File

@ -10,6 +10,7 @@
#include "elinks.h" #include "elinks.h"
#include "ecmascript/libdom/dom.h"
#include "document/libdom/doc.h" #include "document/libdom/doc.h"
#include "ecmascript/ecmascript.h" #include "ecmascript/ecmascript.h"
#include "ecmascript/libdom/parse.h" #include "ecmascript/libdom/parse.h"

View File

@ -14,6 +14,8 @@
#include <js/BigInt.h> #include <js/BigInt.h>
#include <js/Conversions.h> #include <js/Conversions.h>
#include "ecmascript/libdom/dom.h"
#include "bfu/dialog.h" #include "bfu/dialog.h"
#include "cache/cache.h" #include "cache/cache.h"
#include "cookies/cookies.h" #include "cookies/cookies.h"
@ -22,9 +24,9 @@
#include "document/html/frames.h" #include "document/html/frames.h"
#include "document/document.h" #include "document/document.h"
#include "document/forms.h" #include "document/forms.h"
#include "document/libdom/doc.h"
#include "document/view.h" #include "document/view.h"
#include "ecmascript/ecmascript.h" #include "ecmascript/ecmascript.h"
#include "ecmascript/libdom/dom.h"
#include "ecmascript/spidermonkey.h" #include "ecmascript/spidermonkey.h"
#include "ecmascript/spidermonkey/heartbeat.h" #include "ecmascript/spidermonkey/heartbeat.h"
#include "ecmascript/spidermonkey/keyboard.h" #include "ecmascript/spidermonkey/keyboard.h"
@ -72,7 +74,7 @@ static bool keyboardEvent_get_property_type(JSContext *ctx, unsigned int argc, J
static bool keyboardEvent_preventDefault(JSContext *ctx, unsigned int argc, JS::Value *vp); static bool keyboardEvent_preventDefault(JSContext *ctx, unsigned int argc, JS::Value *vp);
static unicode_val_T keyCode; static term_event_key_T keyCode;
static void static void
keyboardEvent_finalize(JS::GCContext *op, JSObject *keyb_obj) keyboardEvent_finalize(JS::GCContext *op, JSObject *keyb_obj)
@ -463,16 +465,25 @@ get_keyboardEvent(JSContext *ctx, struct term_event *ev)
if (exc != DOM_NO_ERR) { if (exc != DOM_NO_ERR) {
return NULL; return NULL;
} }
keyCode = get_kbd_key(ev); term_event_key_T keyCode = get_kbd_key(ev);
if (keyCode == KBD_ENTER) { dom_string *dom_key = NULL;
keyCode = 13; convert_key_to_dom_string(keyCode, &dom_key);
}
exc = dom_keyboard_event_init(keyb, NULL, false, false, dom_string *keydown = NULL;
NULL, NULL, NULL, DOM_KEY_LOCATION_STANDARD, exc = dom_string_create("keydown", strlen("keydown"), &keydown);
exc = dom_keyboard_event_init(keyb, keydown, false, false,
NULL, dom_key, NULL, DOM_KEY_LOCATION_STANDARD,
false, false, false, false, false, false, false, false,
false, false); false, false);
if (dom_key) {
dom_string_unref(dom_key);
}
if (keydown) {
dom_string_unref(keydown);
}
// keyb->keyCode = keyCode; // keyb->keyCode = keyCode;
JS::SetReservedSlot(k, 0, JS::PrivateValue(keyb)); JS::SetReservedSlot(k, 0, JS::PrivateValue(keyb));