2021-01-23 23:29:11 +01:00
|
|
|
set(PROCESS_DEBUG ON)
|
|
|
|
set(SCHEDULER_DEBUG ON)
|
|
|
|
set(SCHEDULER_RUNNABLE_DEBUG ON)
|
|
|
|
set(THREAD_DEBUG ON)
|
|
|
|
set(LOCK_DEBUG ON)
|
|
|
|
set(SIGNAL_DEBUG ON)
|
|
|
|
set(BMP_DEBUG ON)
|
|
|
|
set(WAITBLOCK_DEBUG ON)
|
|
|
|
set(WAITQUEUE_DEBUG ON)
|
|
|
|
set(MULTIPROCESSOR_DEBUG ON)
|
|
|
|
set(ACPI_DEBUG ON)
|
|
|
|
set(PAGE_FAULT_DEBUG ON)
|
|
|
|
set(CONTEXT_SWITCH_DEBUG ON)
|
|
|
|
set(SMP_DEBUG ON)
|
|
|
|
set(BXVGA_DEBUG ON)
|
|
|
|
set(PS2MOUSE_DEBUG ON)
|
2021-04-02 23:21:35 +03:00
|
|
|
set(MOUSE_DEBUG ON)
|
2021-01-23 23:29:11 +01:00
|
|
|
set(VMWARE_BACKDOOR_DEBUG ON)
|
|
|
|
set(FILEDESCRIPTION_DEBUG ON)
|
|
|
|
set(PROCFS_DEBUG ON)
|
|
|
|
set(VFS_DEBUG ON)
|
2021-01-02 19:53:05 +02:00
|
|
|
set(VIRTIO_DEBUG ON)
|
2021-01-23 23:29:11 +01:00
|
|
|
set(IOAPIC_DEBUG ON)
|
|
|
|
set(IRQ_DEBUG ON)
|
|
|
|
set(INTERRUPT_DEBUG ON)
|
|
|
|
set(E1000_DEBUG ON)
|
|
|
|
set(IPV4_SOCKET_DEBUG ON)
|
|
|
|
set(LOCAL_SOCKET_DEBUG ON)
|
|
|
|
set(SOCKET_DEBUG ON)
|
|
|
|
set(TCP_SOCKET_DEBUG ON)
|
|
|
|
set(PCI_DEBUG ON)
|
|
|
|
set(PATA_DEBUG ON)
|
2021-02-26 06:25:45 +02:00
|
|
|
set(AHCI_DEBUG ON)
|
2021-01-23 23:29:11 +01:00
|
|
|
set(IO_DEBUG ON)
|
|
|
|
set(FORK_DEBUG ON)
|
|
|
|
set(POLL_SELECT_DEBUG ON)
|
|
|
|
set(HPET_DEBUG ON)
|
|
|
|
set(HPET_COMPARATOR_DEBUG ON)
|
|
|
|
set(MASTERPTY_DEBUG ON)
|
|
|
|
set(SLAVEPTY_DEBUG ON)
|
|
|
|
set(PTMX_DEBUG ON)
|
|
|
|
set(TTY_DEBUG ON)
|
|
|
|
set(CONTIGUOUS_VMOBJECT_DEBUG ON)
|
|
|
|
set(VRA_DEBUG ON)
|
|
|
|
set(COPY_DEBUG ON)
|
|
|
|
set(CURSOR_TOOL_DEBUG ON)
|
|
|
|
set(FILE_CONTENT_DEBUG ON)
|
|
|
|
set(GZIP_DEBUG ON)
|
|
|
|
set(CNETWORKJOB_DEBUG ON)
|
|
|
|
set(CSOCKET_DEBUG ON)
|
2021-02-21 18:44:17 +02:00
|
|
|
set(CSS_LOADER_DEBUG ON)
|
2021-01-23 23:29:11 +01:00
|
|
|
set(SAFE_SYSCALL_DEBUG ON)
|
|
|
|
set(GHASH_PROCESS_DEBUG ON)
|
|
|
|
set(NT_DEBUG ON)
|
|
|
|
set(CRYPTO_DEBUG ON)
|
|
|
|
set(DWARF_DEBUG ON)
|
|
|
|
set(HUNKS_DEBUG ON)
|
|
|
|
set(JOB_DEBUG ON)
|
|
|
|
set(GIF_DEBUG ON)
|
|
|
|
set(JPG_DEBUG ON)
|
|
|
|
set(EMOJI_DEBUG ON)
|
|
|
|
set(FILL_PATH_DEBUG ON)
|
|
|
|
set(PNG_DEBUG ON)
|
|
|
|
set(PORTABLE_IMAGE_LOADER_DEBUG ON)
|
|
|
|
set(SYNTAX_HIGHLIGHTING_DEBUG ON)
|
|
|
|
set(KEYBOARD_SHORTCUTS_DEBUG ON)
|
2021-03-11 15:38:35 +01:00
|
|
|
set(KMALLOC_DEBUG ON)
|
2021-05-14 04:09:06 -07:00
|
|
|
set(KMALLOC_VERIFY_NO_SPINLOCK_HELD ON)
|
2021-01-23 23:29:11 +01:00
|
|
|
set(MARKDOWN_DEBUG ON)
|
|
|
|
set(REGEX_DEBUG ON)
|
|
|
|
set(TLS_DEBUG ON)
|
|
|
|
set(SPAM_DEBUG ON)
|
2021-04-18 17:34:17 -04:00
|
|
|
set(SQL_DEBUG ON)
|
2021-01-23 23:29:11 +01:00
|
|
|
set(PARSER_DEBUG ON)
|
|
|
|
set(TOKENIZER_TRACE_DEBUG ON)
|
|
|
|
set(IMAGE_LOADER_DEBUG ON)
|
|
|
|
set(RESOURCE_DEBUG ON)
|
|
|
|
set(CACHE_DEBUG ON)
|
|
|
|
set(DHCPV4_DEBUG ON)
|
|
|
|
set(DHCPV4CLIENT_DEBUG ON)
|
|
|
|
set(IMAGE_DECODER_DEBUG ON)
|
|
|
|
set(SYSTEM_MENU_DEBUG ON)
|
|
|
|
set(SYSTEMSERVER_DEBUG ON)
|
|
|
|
set(SERVICE_DEBUG ON)
|
|
|
|
set(COMPOSE_DEBUG ON)
|
|
|
|
set(MINIMIZE_ANIMATION_DEBUG ON)
|
|
|
|
set(OCCLUSIONS_DEBUG ON)
|
|
|
|
set(MENUS_DEBUG ON)
|
|
|
|
set(WSSCREEN_DEBUG ON)
|
|
|
|
set(WINDOWMANAGER_DEBUG ON)
|
|
|
|
set(RESIZE_DEBUG ON)
|
|
|
|
set(MOVE_DEBUG ON)
|
|
|
|
set(DOUBLECLICK_DEBUG ON)
|
|
|
|
set(DISASM_DUMP_DEBUG ON)
|
|
|
|
set(PATH_DEBUG ON)
|
|
|
|
set(LOCK_TRACE_DEBUG ON)
|
|
|
|
set(LOCK_RESTORE_DEBUG ON)
|
|
|
|
set(FUTEXQUEUE_DEBUG ON)
|
|
|
|
set(FUTEX_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
set(UHCI_DEBUG ON)
|
|
|
|
set(APIC_DEBUG ON)
|
|
|
|
set(APIC_SMP_DEBUG ON)
|
|
|
|
set(ARP_DEBUG ON)
|
|
|
|
set(AWAVLOADER_DEBUG ON)
|
|
|
|
set(BBFS_DEBUG ON)
|
|
|
|
set(CALLBACK_MACHINE_DEBUG ON)
|
|
|
|
set(CHTTPJOB_DEBUG ON)
|
|
|
|
set(COMMIT_DEBUG ON)
|
|
|
|
set(AUTOCOMPLETE_DEBUG ON)
|
|
|
|
set(CPP_LANGUAGE_SERVER_DEBUG ON)
|
|
|
|
set(DIFF_DEBUG ON)
|
|
|
|
set(HIGHLIGHT_FOCUSED_FRAME_DEBUG ON)
|
|
|
|
set(ITEM_RECTS_DEBUG ON)
|
|
|
|
set(SH_LANGUAGE_SERVER_DEBUG ON)
|
|
|
|
set(TEXTEDITOR_DEBUG ON)
|
|
|
|
set(DEFERRED_INVOKE_DEBUG ON)
|
|
|
|
set(DYNAMIC_LOAD_DEBUG ON)
|
|
|
|
set(EDITOR_DEBUG ON)
|
|
|
|
set(ELF_IMAGE_DEBUG ON)
|
|
|
|
set(ETHERNET_DEBUG ON)
|
|
|
|
set(ETHERNET_VERY_DEBUG ON)
|
|
|
|
set(EVENT_DEBUG ON)
|
|
|
|
set(EVENTLOOP_DEBUG ON)
|
|
|
|
set(EXEC_DEBUG ON)
|
|
|
|
set(EXT2_DEBUG ON)
|
2021-03-11 19:22:13 +01:00
|
|
|
set(EXT2_BLOCKLIST_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
set(EXT2_VERY_DEBUG ON)
|
|
|
|
set(GEMINI_DEBUG ON)
|
|
|
|
set(GEMINIJOB_DEBUG ON)
|
|
|
|
set(GENERATE_DEBUG_CODE ON)
|
|
|
|
set(GLOBAL_DTORS_DEBUG ON)
|
|
|
|
set(HEAP_DEBUG ON)
|
|
|
|
set(HEX_DEBUG ON)
|
2021-01-28 20:31:20 +00:00
|
|
|
set(HTML_SCRIPT_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
set(HTTPSJOB_DEBUG ON)
|
|
|
|
set(ICMP_DEBUG ON)
|
|
|
|
set(ICO_DEBUG ON)
|
|
|
|
set(IPV4_DEBUG ON)
|
|
|
|
set(IRC_DEBUG ON)
|
|
|
|
set(KEYBOARD_DEBUG ON)
|
|
|
|
set(LEXER_DEBUG ON)
|
|
|
|
set(LOOKUPSERVER_DEBUG ON)
|
|
|
|
set(MALLOC_DEBUG ON)
|
|
|
|
set(MBR_DEBUG ON)
|
|
|
|
set(MEMORY_DEBUG ON)
|
|
|
|
set(MENU_DEBUG ON)
|
|
|
|
set(NETWORK_TASK_DEBUG ON)
|
|
|
|
set(OBJECT_DEBUG ON)
|
|
|
|
set(OFFD_DEBUG ON)
|
LibJS: Add initial support for Promises
Almost a year after first working on this, it's finally done: an
implementation of Promises for LibJS! :^)
The core functionality is working and closely following the spec [1].
I mostly took the pseudo code and transformed it into C++ - if you read
and understand it, you will know how the spec implements Promises; and
if you read the spec first, the code will look very familiar.
Implemented functions are:
- Promise() constructor
- Promise.prototype.then()
- Promise.prototype.catch()
- Promise.prototype.finally()
- Promise.resolve()
- Promise.reject()
For the tests I added a new function to test-js's global object,
runQueuedPromiseJobs(), which calls vm.run_queued_promise_jobs().
By design, queued jobs normally only run after the script was fully
executed, making it improssible to test handlers in individual test()
calls by default [2].
Subsequent commits include integrations into LibWeb and js(1) -
pretty-printing, running queued promise jobs when necessary.
This has an unusual amount of dbgln() statements, all hidden behind the
PROMISE_DEBUG flag - I'm leaving them in for now as they've been very
useful while debugging this, things can get quite complex with so many
asynchronously executed functions.
I've not extensively explored use of these APIs for promise-based
functionality in LibWeb (fetch(), Notification.requestPermission()
etc.), but we'll get there in due time.
[1]: https://tc39.es/ecma262/#sec-promise-objects
[2]: https://tc39.es/ecma262/#sec-jobs-and-job-queues
2021-04-01 22:13:29 +02:00
|
|
|
set(PROMISE_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
set(PTHREAD_DEBUG ON)
|
|
|
|
set(REACHABLE_DEBUG ON)
|
|
|
|
set(ROUTING_DEBUG ON)
|
2021-01-30 16:00:57 +01:00
|
|
|
set(NE2000_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
set(RTL8139_DEBUG ON)
|
|
|
|
set(SB16_DEBUG ON)
|
|
|
|
set(SH_DEBUG ON)
|
|
|
|
set(STORAGE_DEVICE_DEBUG ON)
|
|
|
|
set(TCP_DEBUG ON)
|
|
|
|
set(TERMCAP_DEBUG ON)
|
|
|
|
set(TERMINAL_DEBUG ON)
|
2021-05-08 20:37:43 +02:00
|
|
|
set(ESCAPE_SEQUENCE_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
set(UCI_DEBUG ON)
|
|
|
|
set(UDP_DEBUG ON)
|
|
|
|
set(UHCI_VERBOSE_DEBUG ON)
|
|
|
|
set(UPDATE_COALESCING_DEBUG ON)
|
|
|
|
set(VOLATILE_PAGE_RANGES_DEBUG ON)
|
|
|
|
set(WSMESSAGELOOP_DEBUG ON)
|
|
|
|
set(GPT_DEBUG ON)
|
2021-01-23 16:47:20 +02:00
|
|
|
set(CPP_DEBUG ON)
|
2021-01-23 16:55:19 +02:00
|
|
|
set(DEBUG_CPP_LANGUAGE_SERVER ON)
|
|
|
|
set(DEBUG_AUTOCOMPLETE ON)
|
2021-02-08 20:40:58 +01:00
|
|
|
set(FILE_WATCHER_DEBUG ON)
|
2021-02-11 22:43:18 +01:00
|
|
|
set(SYSCALL_1_DEBUG ON)
|
2021-02-14 14:50:42 +03:30
|
|
|
set(RSA_PARSE_DEBUG ON)
|
2021-02-20 21:33:13 +03:30
|
|
|
set(LINE_EDITOR_DEBUG ON)
|
2021-03-02 09:40:10 +03:30
|
|
|
set(LANGUAGE_SERVER_DEBUG ON)
|
2021-01-06 22:58:01 +11:00
|
|
|
set(GL_DEBUG ON)
|
2021-04-26 12:48:13 +04:30
|
|
|
set(WASM_BINPARSER_DEBUG ON)
|
2021-05-08 14:57:49 -07:00
|
|
|
set(PDF_DEBUG ON)
|
2021-05-15 22:12:22 -04:00
|
|
|
set(SOLITAIRE_DEBUG ON)
|
2021-01-24 15:28:26 +01:00
|
|
|
|
|
|
|
# False positive: DEBUG is a flag but it works differently.
|
|
|
|
# set(DEBUG ON)
|
2021-02-13 12:46:22 +01:00
|
|
|
# False positive: DT_DEBUG is a flag, but for a bitset, not a feature.
|
|
|
|
# set(DT_DEBUG ON)
|
|
|
|
# False positive: GUI_DND_DEBUG is a flag, but passed as an envvar.
|
|
|
|
# set(GUI_DND_DEBUG ON)
|
|
|
|
# False positive: GUI_FOCUS_DEBUG is a flag, but passed as an envvar.
|
|
|
|
# set(GUI_FOCUS_DEBUG ON)
|
2020-12-21 10:48:32 -07:00
|
|
|
# False positive: LOG_DEBUG is a flag, but for a bitset, not a feature.
|
2021-01-24 15:28:26 +01:00
|
|
|
# set(LOG_DEBUG ON)
|
2021-02-13 12:46:22 +01:00
|
|
|
# False positive: UHCI_USBCMD_SOFTWARE_DEBUG is a flag, but for a bitset, not a feature.
|
|
|
|
# set(UHCI_USBCMD_SOFTWARE_DEBUG ON)
|
2021-04-16 14:42:13 -04:00
|
|
|
# False positive: DEBUG_CONTROL_REGISTER represents a specification constant.
|
|
|
|
# set(DEBUG_CONTROL_REGISTER ON)
|
|
|
|
# False positive: DEBUG_STATUS_REGISTER represents a specification constant.
|
|
|
|
# set(DEBUG_STATUS_REGISTER ON)
|
|
|
|
# False positive: DEFINE_DEBUG_REGISTER is used to define read/write methods for debug registers.
|
|
|
|
# set(DEFINE_DEBUG_REGISTER ON)
|
2021-01-18 17:25:44 +01:00
|
|
|
# Clogs up build: The WrapperGenerator stuff is run at compile time.
|
2021-01-24 15:28:26 +01:00
|
|
|
# set(WRAPPER_GENERATOR_DEBUG ON)
|