Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Download Text Mode buffer #1181

Open
RixInGithub opened this issue Nov 10, 2024 · 3 comments
Open

feat: Download Text Mode buffer #1181

RixInGithub opened this issue Nov 10, 2024 · 3 comments

Comments

@RixInGithub
Copy link

RixInGithub commented Nov 10, 2024

So, I am making my own mini textual bootloader OS.
Problem is, I'm making a sort of Command Prompt to test my assembly skills.
How it works, is when built, it launches a https://copy.sh/v86/?profile=custom&fda.url=... type of link. (I read the source, fda.url is the URL for the floppy image for which I use a Base64 Data URL)

I'm currently testing what ASCII value do the keys I input print out. For normal letters or numbers, this is self-explanatory. However, for something like the Enter key, Meta (⊞ for Windows and ⌘ for Mac) key, Ctrl key, Escape, so on, this isn't so explainable. So, I tested the Enter key first. It moved my cursor a bit, which is weird, and probably some compilation-to-WASM bug, granted, but I wanted to see what ASCII value does Enter give off. Turns out, I won't know until I can download the textual output the emulator has, including the special characters that seem to move the cursor around.

So that's why I'm requesting a way to download the buffer from Text Mode as a .TXT (or a .BIN (possibly)).

It would be much more useful than just for devs like me. What if someone painted amazing ASCII art in their emulator, only for a bummer to appear as you can only screenshot for now? Sure, saving as an image is more convenient, but at least add a dropdown to either save as an image or a text file.

And of course, make it only enabled only when Text Mode, Graphics can't be downloaded as text (unless the and/or chars with a bit of ANSI colors)

Thanks for reading, I hope you all like my suggestion to further improve your awesome WASM emulator, and I really like the whole idea of compiling binaries to WASM.

edit: found the char for enter key, it's just \r. the reason carriage return moves is still unknown to me tho.

@chschnell
Copy link
Contributor

chschnell commented Nov 10, 2024

V86 emulates a VGA graphics card.

In VGA text mode, applications can use predefined font bitmaps from the VGA BIOS, or they can upload their own font bitmaps into VGA RAM. See here and scroll down to see a couple of screenshots made in text mode with user-defined fonts.

So if the guest application uploads its own font bitmaps in VGA text mode it is generally impossible to copy precisely unless you take a screenshot. In the text mode you use (which uses the browser's fonts instead of the VGA fonts) such font bitmaps can also not be displayed, that is why graphical text mode was added recently.

In theory you'd be free to define your own font bitmap and accompanying 8-bit code page (preferably using glyphs in your font bitmap that are defined somewhere in the Unicode standard).

But there are internationally standardized 8-bit codepages to make this interoperable. Predefined VGA BIOS fonts typically match the widely used code page CP437 (DOS Latin US). Other encodings (like the European CP850) come with their own font bitmaps as part of the operating system.

I have a collection of standardized code page mappings for V86 here, it is still work-in-progress but it works.

The screen's current text bytes are lineary stored in VGA RAM and can easily be copied into the browser's clipboard. But since text in VGA RAM is 8-bit encoded you need to apply the codepage-to-Unicode mapping here in order to properly copy text out of the VM.

To illustrate, here an example screenshot while I had the FreeDOS text editor open with a German poem (note the diacritics and special characters), code page is CP850, graphical text mode:

freedos-edit-wiesel

And here is the Unicode text I copied from the same screen to clipboard using the proper Unicode mapping (all diacritics and graphical characters are mapped correctly):

┌ ­                            FreeDOS Edit 0.9a                             ↓↑┐
│   File  Edit  Search  Utilities  Options  Window  Help                       │
│┌ ­                                test.txt                                ↓↕┐│
││Das ästhetische Wiesel                                                      ▲│
││                                                                            ▓│
││Ein Wiesel                                                                  ░│
││saß auf einem Kiesel                                                        ░│
││inmitten Bachgeriesel.                                                      ░│
││                                                                            ░│
││Wißt ihr,                                                                   ░│
││weshalb?                                                                    ░│
││                                                                            ░│
││Das Mondkalb                                                                ░│
││verriet es mir                                                              ░│
││im stillen:                                                                 ░│
││Das raffinier-                                                              ░│
││te Tier                                                                     ░│
││                                                                            ░│
││                                                                            ░│
││                                                                            ░│
││                                                                            ░│
││                                                                            ░│
││                                                                            ▼│
│└◄▓░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░►┘│
└ F1=Help ¦                           * INS   Line:   15  Col:   1 │ 16:46:29  ♦

Further reading:

So to summarize, it is kinda work-in-progress and the building blocks are there, it only needs to be properly integrated.

If you want you can try your image in my V86 embedding (built around V86 at the core), there you can switch between the two text modes, select a code page and are able to copy to clipboard (through the menu). You can also copy from clipboard, but that's a whole different story.

@copy
Copy link
Owner

copy commented Nov 30, 2024

A PR would be welcome.

@RixInGithub
Copy link
Author

As far as I've searched the characters printed out go through an ArrayBuffer and then displayed. Problem is, I don't really know where to add new event listeners for new controls and also what scope does the array buffer have. (I'm not the biggest OS nerd, I still don't know what ASCII value does Enter give off. :P)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants