GithubHelp home page GithubHelp logo

felixrieseberg / windows95 Goto Github PK

View Code? Open in Web Editor NEW
22.1K 22.1K 1.3K 4.05 MB

๐Ÿ’ฉ๐Ÿš€ Windows 95 in Electron. Runs on macOS, Linux, and Windows.

License: Other

JavaScript 15.06% HTML 0.89% Dockerfile 1.93% TypeScript 74.73% Shell 1.49% PowerShell 0.45% Less 5.46%

windows95's Introduction

windows95

This is Windows 95, running in an Electron app. Yes, it's the full thing. I'm sorry.

Downloads


Windows
32-bit ๐Ÿ’ฟ Installer | ๐Ÿ“ฆ Standalone Zip
64-bit ๐Ÿ’ฟ Installer | ๐Ÿ“ฆ Standalone Zip
ARM64 ๐Ÿ’ฟ Installer | ๐Ÿ“ฆ Standalone Zip
โ“ Don't know what kind of chip you have? Hit start, enter "processor" for info.

macOS
Intel Processor ๐Ÿ“ฆ Standalone Zip
Apple M1 Processor ๐Ÿ“ฆ Standalone Zip
โ“ Don't know what kind of chip you have? Learn more at apple.com.

Linux
64-bit ๐Ÿ’ฟ rpm | ๐Ÿ’ฟ deb
ARM64 ๐Ÿ’ฟ rpm | ๐Ÿ’ฟ deb
ARMv7 (armhf) ๐Ÿ’ฟ rpm | ๐Ÿ’ฟ deb

Screenshot

Does it work?

Yes! Quite well, actually - on macOS, Windows, and Linux. Bear in mind that this is written entirely in JavaScript, so please adjust your expectations.

Should this have been a native app?

Absolutely.

Does it run Doom (or my other favorite game)?

You'll likely be better off with an actual virtualization app, but the short answer is yes. Thanks to @DisplacedGamers I can recommend that you switch to a resolution of 640x480 @ 256 colors before starting DOS games - just like in the good ol' days.

Credits

99% of the work was done over at v86 by Copy aka Fabian Hemmer and his contributors.

Contributing

Before you can run this from source, you'll need the disk image. It's not part of the repository, but you can grab it using the Show Disk Image button from the packaged release, which does include the disk image. You can find that button in the Modify C: Drive section.

Unpack the images folder into the src folder, creating this layout:

- /images/windows95.img
- /images/default-state.bin
- /assets/...
- /bios/...
- /docs/...

Once you've done so, run npm install and npm start to run your local build.

If you want to tinker with the image or make a new one, check out the QEMU docs.

Other Questions

License

This project is provided for educational purposes only. It is not affiliated with and has not been approved by Microsoft.

windows95's People

Contributors

argan avatar benwiley4000 avatar dependabot[bot] avatar felixrieseberg avatar fjbecerra avatar hmsjy2017 avatar jacobq avatar jankeromnes avatar kant avatar maacarbo avatar malept avatar petervatistas avatar pf94 avatar samuell avatar shanselman avatar toolboc avatar weirdo1312 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

windows95's Issues

There is an error after open command line. It was crashed and in the following, after reload, this windows can not start working

โš ๏ธ Thank you for reporting an issue!

Before we go any further, understand that I probably won't be able to fullfil feature requests.
Feel free to report what feature you'd love to see, just don't get angry when I don't have
time to implement it ๐Ÿ™‡โ€โ™‚๏ธ

I will however gladly help you make a pull request if you're willing to play with Javascript!

Internet Explorer issues due to missing TCP/IP

Internet Explorer would work if the TCP/IP stack would have been installed. Installing it requires the Win95 disk though :-/

Could this be implemented? Might give the whole project a useful sense ;-)

  • Max

Windows XP Support

I appears that the only version to run on Windows is
windows95-1.1.0-setup-x64.exe

Perhaps you could make available an X86 version to run on Windows XP?

Thank you.

Region

Hi.
Cool work.
I report this bug: when i want to change of region (country), windows 95 freeze (surely the restart).
I'm on windows 10.
Regards
GravuTrad

Increased Hard Drive Space!

133 MB of spcae is not enough for my applications. If you don't want to increase the space of the C drive, allow the user to create another 2 GB disk image, a D drive to install their applications there

Is it possible to run Office 2003

โš ๏ธ Thank you for reporting an issue!

Before we go any further, understand that I probably won't be able to fullfil feature requests.
Feel free to report what feature you'd love to see, just don't get angry when I don't have
time to implement it ๐Ÿ™‡โ€โ™‚๏ธ

I will however gladly help you make a pull request if you're willing to play with Javascript!

The performance is too good

I suggest adding a new feature that will actually slow that thing down, in order to simulate a real-life windows system

Scaling/HiDPI support

I am using a 4k monitor with x2 scaling. The canvas with Windows doesn't seem to scale or align properly, it just gets centered.
2018-08-24-210024_1927x1289_scrot

If I manually override the scaling with --high-dpi-support=1 --force-device-scale-factor=1, it works as expected:
2018-08-24-210453_1290x874_scrot

start button is not displayed

I downroaded all asset but I can't find start button. It is may be my fault that I can't find it, please tell me how to do.

npm run make error

On Pop!_OS 18.04 (based on Ubuntu 18.04):

โœ– Making for target: rpm - On platform: linux - For arch: x64

An unhandled error has occurred inside Forge:
An error occured while making for target: rpm
Error executing command (spawn rpmbuild ENOENT): 
rpmbuild -bb /tmp/electron-118723-1021-6kvhff.t153q/windows95_1.0.0_x86_64/SPECS/windows95.spec --target x86_64

Error: Error executing command (spawn rpmbuild ENOENT): 
rpmbuild -bb /tmp/electron-118723-1021-6kvhff.t153q/windows95_1.0.0_x86_64/SPECS/windows95.spec --target x86_64

    at ChildProcess.<anonymous> (/home/aral/sandbox/windows95/node_modules/electron-installer-redhat/src/installer.js:55:23)
    at emitTwo (events.js:126:13)
    at ChildProcess.emit (events.js:214:7)
    at maybeClose (internal/child_process.js:925:16)
    at Socket.stream.socket.on (internal/child_process.js:346:11)
    at emitOne (events.js:116:13)
    at Socket.emit (events.js:211:7)
    at Pipe._handle.close [as _onclose] (net.js:557:12)
npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! [email protected] make: `electron-forge make`
npm ERR! Exit status 1
npm ERR! 
npm ERR! Failed at the [email protected] make script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.

npm ERR! A complete log of this run can be found in:
npm ERR!     /home/aral/.npm/_logs/2018-08-23T22_21_53_600Z-debug.log

npm run start does work but app fails with no bootable image found.

Whatโ€™s the expected way to run this? (And thanks for the late-night chuckles) :)

No network adapter

Is it possible to get networking functional so that we can get this machine online?

Personal note: Amazing project, well done!

System can't recover after freeze/machine reset

I clicked on your twitter handle and for some reason the windows 95 machine froze, and stayed frozen even after I quit and rebooted the machine. So I hit the button to clear the state, and now every time I restart I get this:

SeaBIOS (version rel-1.10.0-39-g3fdabae-dirty-20170530_144256-nyu)              
Booting from Floppy...                                                          
Boot failed: could not read the boot disk                                       
                                                                                
Booting from Hard Disk...                                                       
Boot failed: could not read the boot disk                                       
                                                                                
No bootable device.  Retrying in 60 seconds.

As a workaround, it would be nice to know how to clear all app data from my system.

Cannot access storage

It cannot access storage devices on linux. The app got freezed when I clicked on my drive. I force closed the app but still facing seem freezed window after app restart.

Windows95 running on MacOS (10.13.6) freezes when trying to access Floppy A:

I was trying a few things, went to My Computer, selected "Floppy Drive A:" The Win95 app froze. Mac OS was fine, but couldn't do anything inside the Win95 app.

Restarted the app, same screen. Deleted all instances of the app on my Mac. Opened the zip file again and ran the app, same screen.
Went into Activity Monitor dropped three processes related to the app, same screen.

screen shot 2018-08-23 at 5 29 54 pm

Restarted the Mac. All was fine with the Mac but Win95 app had same screen.
Re-downloaded the original zip file. Still, the exact same screen.

There's something persistent.

Existence

The very fact that you are attempting to run Windows 95 within Electron concerns me. An OS that runs just fine with 32MiB of RAM should not be on a platform that is known to use copious amounts of RAM.

Native Mouse Pointer vs. Windows95 Mouse Pointer

somehow I managed to have two mouse pointers (the native macOS one and the virtual windows95 one):

img_5823

the relative movements of the simulated mouse pointer was still correct though.

Running macOS Mojave 10.14 Beta (18A371a).

Ubuntu 16 shows an all white screen

All I see after installing the app on Ubuntu 16 is the boot screen, followed by an all white screen.

I also see the following error being logged:

Error: async hook stack has become corrupted (actual: 3061531, expected: 0)
 1: node::Environment::AsyncHooks::pop_async_id(double) [/usr/lib/windows95/libnode.so]
 2: node::InternalCallbackScope::Close() [/usr/lib/windows95/libnode.so]
 3: node::InternalCallbackScope::~InternalCallbackScope() [/usr/lib/windows95/libnode.so]
 4: node::InternalMakeCallback(node::Environment*, v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*, node::async_context) [/usr/lib/windows95/libnode.so]
 5: node::MakeCallback(v8::Isolate*, v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*, node::async_context) [/usr/lib/windows95/libnode.so]
 6: node::Environment::CheckImmediate(uv_check_s*) [/usr/lib/windows95/libnode.so]
 7: 0x7f421c42a474 [/usr/lib/windows95/libnode.so]
 8: uv_run [/usr/lib/windows95/libnode.so]
 9: atom::NodeBindings::UvRunOnce() [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.a
sar --node-integration=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --ena
ble-compositor-image-animations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
10: 0x3ed1ba4 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
11: 0x46c8762 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
12: 0x3ed1ba4 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
13: 0x3e61d9e [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
14: 0x3e62407 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
15: 0x3e6297a [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
16: 0x3e54575 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
17: 0x164d2b8 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
18: 0x1523f39 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
19: 0x1524f58 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
20: 0x330cbc4 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
21: 0x15258f4 [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration
=true --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-a
nimations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
22: main [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration=true
 --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-animat
ions --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]
23: __libc_start_main [/lib/x86_64-linux-gnu/libc.so.6]
24: _start [/usr/lib/windows95/windows95 --type=renderer --no-sandbox --service-pipe-token=5A43982E12DB14DB0CF42B4A93A91182 --lang=de --app-path=/usr/lib/windows95/resources/app.asar --node-integration=tr
ue --webview-tag=true --no-sandbox --preload=/usr/lib/windows95/resources/app.asar/src/preload.js --context-id=1 --num-raster-threads=2 --enable-main-frame-before-activation --enable-compositor-image-anim
ations --service-request-channel-token=5A43982E12DB14DB0CF42B4A93A91182 --renderer-client-id=5 --shared-files=v8_context_snapshot_data:100,v8_natives_data:101]

Rebooting breaks the state

I'm not able to figure out why, but rebooting just gets the state stuck. I'm trying to install software that requires a reboot and keep getting hungup at that point.

Expansion a space on HDD

โš ๏ธ Thank you for reporting an issue!

Before we go any further, understand that I probably won't be able to fullfil feature requests.
Feel free to report what feature you'd love to see, just don't get angry when I don't have
time to implement it ๐Ÿ™‡โ€โ™‚๏ธ

I will however gladly help you make a pull request if you're willing to play with Javascript!

No startup chime? :)

Just a request for maybe hopefully someday implementing the lovely Windows 95 startup chime!

Wolfenstein 3D

Hello ๐Ÿ‘‹, how can I install Wolfenstein 3d on this windows 95?

Ability to Install Netscape Navigator

Would be awesome to run good 'ole Netscape. Can I get some up-vote love?

Have the installer on the desktop as a temptation for those interested in running it.

ReadME erroneous

Sorry, this might be dumb, but the README has the install instructions under Contributing

Don't close after Shutdown

It works and it have great performance to start but after Shutdown it doesn't close the App and it keep Lock mouse Then only Alt + Tab for Force close it.

Windows 10 Pro build 18219

Hitting escape releases the mouse... and closes whatever window you have open

I forgot this is what the escape key used to do... so annoying! Maybe:

  1. Use a different keyboard shortcut to release the mouse from the app
    or
  2. Preempt Windows using the event and stop capture propagation. Maybe if the user really needs to hit escape inside of Windows they can use a special keyboard shortcut.

Installation failed on Windows 10, 1803 build 17134

2018-04-02 03:01:38> Program: Starting install, writing to C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-04-02 03:01:38> Program: About to install to: C:\Users\UserAccountName\AppData\Local\Postman
2018-04-02 03:01:38> CheckForUpdateImpl: Couldn't write out staging user ID, this user probably shouldn't get beta anything: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\Postman\packages\.betaId'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.StreamWriter.CreateFile(String path, Boolean append, Boolean checkHost)
   at System.IO.StreamWriter..ctor(String path, Boolean append, Encoding encoding, Int32 bufferSize, Boolean checkHost)
   at System.IO.File.InternalWriteAllText(String path, String contents, Encoding encoding, Boolean checkHost)
   at System.IO.File.WriteAllText(String path, String contents, Encoding encoding)
   at Squirrel.UpdateManager.CheckForUpdateImpl.getOrCreateStagedUserId()
2018-04-02 03:01:38> CheckForUpdateImpl: Failed to load local releases, starting from scratch: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\Postman\packages\RELEASES'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share)
   at Squirrel.Utility.LoadLocalReleases(String localReleaseFile)
   at Squirrel.UpdateManager.CheckForUpdateImpl.<CheckForUpdate>d__2.MoveNext()
2018-04-02 03:01:38> CheckForUpdateImpl: Reading RELEASES file from C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-04-02 03:01:38> CheckForUpdateImpl: First run or local directory is corrupt, starting from scratch
2018-04-02 03:01:38> ApplyReleasesImpl: Writing files to app directory: C:\Users\UserAccountName\AppData\Local\Postman\app-6.0.10
2018-04-02 03:01:41> ApplyReleasesImpl: Squirrel Enabled Apps: [C:\Users\UserAccountName\AppData\Local\Postman\app-6.0.10\Postman.exe]
2018-04-02 03:01:45> ApplyReleasesImpl: Starting fixPinnedExecutables
2018-04-02 03:01:45> ApplyReleasesImpl: Examining Pin: File Explorer.lnk
2018-04-02 03:01:45> ApplyReleasesImpl: Examining Pin: Magnify.lnk
2018-04-02 03:01:45> ApplyReleasesImpl: Fixing up tray icons
2018-04-02 03:01:45> ApplyReleasesImpl: cleanDeadVersions: for version 6.0.10
2018-04-02 03:01:45> ApplyReleasesImpl: cleanDeadVersions: exclude folder app-6.0.10
2018-04-02 03:01:46> InstallHelperImpl: Couldn't write uninstall icon, don't care: System.Net.WebException: Could not find a part of the path 'C:\Users\Postman\buildkite-agent\builds\postman-ci-agent-windows-1\postman\electron-package-and-deploy\resources\postman-prod.ico'. ---> System.Net.WebException: Could not find a part of the path 'C:\Users\Postman\buildkite-agent\builds\postman-ci-agent-windows-1\postman\electron-package-and-deploy\resources\postman-prod.ico'. ---> System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\Postman\buildkite-agent\builds\postman-ci-agent-windows-1\postman\electron-package-and-deploy\resources\postman-prod.ico'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy)
   at System.Net.FileWebStream..ctor(FileWebRequest request, String path, FileMode mode, FileAccess access, FileShare sharing, Int32 length, Boolean async)
   at System.Net.FileWebResponse..ctor(FileWebRequest request, Uri uri, FileAccess access, Boolean asyncHint)
   --- End of inner exception stack trace ---
   at System.Net.FileWebResponse..ctor(FileWebRequest request, Uri uri, FileAccess access, Boolean asyncHint)
   at System.Net.FileWebRequest.GetResponseCallback(Object state)
   --- End of inner exception stack trace ---
   at System.Net.FileWebRequest.EndGetResponse(IAsyncResult asyncResult)
   at System.Net.WebClient.GetWebResponse(WebRequest request, IAsyncResult result)
   at System.Net.WebClient.DownloadBitsResponseCallback(IAsyncResult result)
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.InstallHelperImpl.<CreateUninstallerRegistryEntry>d__5.MoveNext()
2018-08-24 01:45:13> Program: Starting Squirrel Updater: --install .
2018-08-24 01:45:13> Program: Starting install, writing to C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-08-24 01:45:13> Program: About to install to: C:\Users\UserAccountName\AppData\Local\windows98
2018-08-24 01:45:13> CheckForUpdateImpl: Couldn't write out staging user ID, this user probably shouldn't get beta anything: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\windows98\packages\.betaId'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.StreamWriter.CreateFile(String path, Boolean append, Boolean checkHost)
   at System.IO.StreamWriter..ctor(String path, Boolean append, Encoding encoding, Int32 bufferSize, Boolean checkHost)
   at System.IO.File.InternalWriteAllText(String path, String contents, Encoding encoding, Boolean checkHost)
   at System.IO.File.WriteAllText(String path, String contents, Encoding encoding)
   at Squirrel.UpdateManager.CheckForUpdateImpl.getOrCreateStagedUserId()
2018-08-24 01:45:13> CheckForUpdateImpl: Failed to load local releases, starting from scratch: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\windows98\packages\RELEASES'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share)
   at Squirrel.Utility.LoadLocalReleases(String localReleaseFile)
   at Squirrel.UpdateManager.CheckForUpdateImpl.<CheckForUpdate>d__2.MoveNext()
2018-08-24 01:45:13> CheckForUpdateImpl: Reading RELEASES file from C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-08-24 01:45:13> CheckForUpdateImpl: First run or local directory is corrupt, starting from scratch
2018-08-24 01:45:13> ApplyReleasesImpl: Writing files to app directory: C:\Users\UserAccountName\AppData\Local\windows98\app-1.0.0
2018-08-24 01:45:23> IEnableLogger: Failed to install package to app dir: System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
2018-08-24 01:45:23> Unhandled exception: System.AggregateException: One or more errors occurred. ---> System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<ApplyReleases>d__2.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.<FullInstall>d__10.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.Update.Program.<Install>d__4.MoveNext()
   --- End of inner exception stack trace ---
   at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean includeTaskCanceledExceptions)
   at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
   at System.Threading.Tasks.Task.Wait()
   at Squirrel.Update.Program.executeCommandLine(String[] args)
   at Squirrel.Update.Program.main(String[] args)
---> (Inner Exception #0) System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<ApplyReleases>d__2.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.<FullInstall>d__10.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.Update.Program.<Install>d__4.MoveNext()<---

2018-08-24 01:48:42> Program: Starting Squirrel Updater: --install .
2018-08-24 01:48:42> Program: Starting install, writing to C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-08-24 01:48:42> Program: About to install to: C:\Users\UserAccountName\AppData\Local\windows98
2018-08-24 01:48:42> Program: Install path C:\Users\UserAccountName\AppData\Local\windows98 already exists, burning it to the ground
2018-08-24 01:48:43> CheckForUpdateImpl: Couldn't write out staging user ID, this user probably shouldn't get beta anything: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\windows98\packages\.betaId'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.StreamWriter.CreateFile(String path, Boolean append, Boolean checkHost)
   at System.IO.StreamWriter..ctor(String path, Boolean append, Encoding encoding, Int32 bufferSize, Boolean checkHost)
   at System.IO.File.InternalWriteAllText(String path, String contents, Encoding encoding, Boolean checkHost)
   at System.IO.File.WriteAllText(String path, String contents, Encoding encoding)
   at Squirrel.UpdateManager.CheckForUpdateImpl.getOrCreateStagedUserId()
2018-08-24 01:48:43> CheckForUpdateImpl: Failed to load local releases, starting from scratch: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\windows98\packages\RELEASES'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share)
   at Squirrel.Utility.LoadLocalReleases(String localReleaseFile)
   at Squirrel.UpdateManager.CheckForUpdateImpl.<CheckForUpdate>d__2.MoveNext()
2018-08-24 01:48:43> CheckForUpdateImpl: Reading RELEASES file from C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-08-24 01:48:43> CheckForUpdateImpl: First run or local directory is corrupt, starting from scratch
2018-08-24 01:48:43> ApplyReleasesImpl: Writing files to app directory: C:\Users\UserAccountName\AppData\Local\windows98\app-1.0.0
2018-08-24 01:48:51> IEnableLogger: Failed to install package to app dir: System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
2018-08-24 01:48:51> Unhandled exception: System.AggregateException: One or more errors occurred. ---> System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<ApplyReleases>d__2.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.<FullInstall>d__10.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.Update.Program.<Install>d__4.MoveNext()
   --- End of inner exception stack trace ---
   at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean includeTaskCanceledExceptions)
   at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
   at System.Threading.Tasks.Task.Wait()
   at Squirrel.Update.Program.executeCommandLine(String[] args)
   at Squirrel.Update.Program.main(String[] args)
---> (Inner Exception #0) System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<ApplyReleases>d__2.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.<FullInstall>d__10.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.Update.Program.<Install>d__4.MoveNext()<---

2018-08-24 01:49:19> Program: Starting Squirrel Updater: --install . --rerunningWithoutUAC
2018-08-24 01:49:20> Program: Starting install, writing to C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-08-24 01:49:20> Program: About to install to: C:\Users\UserAccountName\AppData\Local\windows98
2018-08-24 01:49:20> Program: Install path C:\Users\UserAccountName\AppData\Local\windows98 already exists, burning it to the ground
2018-08-24 01:49:20> CheckForUpdateImpl: Couldn't write out staging user ID, this user probably shouldn't get beta anything: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\windows98\packages\.betaId'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.StreamWriter.CreateFile(String path, Boolean append, Boolean checkHost)
   at System.IO.StreamWriter..ctor(String path, Boolean append, Encoding encoding, Int32 bufferSize, Boolean checkHost)
   at System.IO.File.InternalWriteAllText(String path, String contents, Encoding encoding, Boolean checkHost)
   at System.IO.File.WriteAllText(String path, String contents, Encoding encoding)
   at Squirrel.UpdateManager.CheckForUpdateImpl.getOrCreateStagedUserId()
2018-08-24 01:49:20> CheckForUpdateImpl: Failed to load local releases, starting from scratch: System.IO.DirectoryNotFoundException: Could not find a part of the path 'C:\Users\UserAccountName\AppData\Local\windows98\packages\RELEASES'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share)
   at Squirrel.Utility.LoadLocalReleases(String localReleaseFile)
   at Squirrel.UpdateManager.CheckForUpdateImpl.<CheckForUpdate>d__2.MoveNext()
2018-08-24 01:49:20> CheckForUpdateImpl: Reading RELEASES file from C:\Users\UserAccountName\AppData\Local\SquirrelTemp
2018-08-24 01:49:20> CheckForUpdateImpl: First run or local directory is corrupt, starting from scratch
2018-08-24 01:49:21> ApplyReleasesImpl: Writing files to app directory: C:\Users\UserAccountName\AppData\Local\windows98\app-1.0.0
2018-08-24 01:49:27> IEnableLogger: Failed to install package to app dir: System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
2018-08-24 01:49:27> Unhandled exception: System.AggregateException: One or more errors occurred. ---> System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<ApplyReleases>d__2.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.<FullInstall>d__10.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.Update.Program.<Install>d__4.MoveNext()
   --- End of inner exception stack trace ---
   at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean includeTaskCanceledExceptions)
   at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
   at System.Threading.Tasks.Task.Wait()
   at Squirrel.Update.Program.executeCommandLine(String[] args)
   at Squirrel.Update.Program.main(String[] args)
---> (Inner Exception #0) System.ArgumentException: WriteEntryTo or OpenEntryStream can only be called once.
   at SharpCompress.Readers.AbstractReader`2.WriteEntryTo(Stream writableStream)
   at SharpCompress.Readers.IReaderExtensions.WriteEntryToFile(IReader reader, String destinationFileName, ExtractionOptions options)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_2.<ExtractZipForInstall>b__1()
   at Squirrel.Utility.<>c__DisplayClass8_0.<Retry>b__0()
   at Squirrel.Utility.Retry[T](Func`1 block, Int32 retries)
   at Squirrel.Utility.Retry(Action block, Int32 retries)
   at Squirrel.ReleasePackage.<>c__DisplayClass15_0.<ExtractZipForInstall>b__0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task.Execute()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<>c__DisplayClass7_0.<<installPackageToAppDir>b__0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.Utility.<LogIfThrows>d__43`1.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.UpdateManager.ApplyReleasesImpl.<ApplyReleases>d__2.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Squirrel.UpdateManager.<FullInstall>d__10.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
   at Squirrel.Update.Program.<Install>d__4.MoveNext()<---

Will there be appimage format?

โš ๏ธ Thank you for reporting an issue!

Before we go any further, understand that I probably won't be able to fullfil feature requests.
Feel free to report what feature you'd love to see, just don't get angry when I don't have
time to implement it ๐Ÿ™‡โ€โ™‚๏ธ

I will however gladly help you make a pull request if you're willing to play with Javascript!

Missing viruses

Hello.

I'm genuinely amazed (but not that much surprised) one could actually emulate a x86 CPU close enough to run that good ol' Windows 95. That's quite the achivement to see that after years of taking jabs at browsers becoming close to VMs, they ended up as such.

I guess the next step is adding viruses? I mean, I'm a fan of Danooct1 and his videos about the world of old-timer viruses, and to see them evolving in their natural virtualized state a bit like this xkcd could be a fun way to showcase them online, I guess?

Amazing work, nonetheless. Have a nice day and ood luck with your future projects!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.