Hacker News new | past | comments | ask | show | jobs | submit login
Open-Sourcing Windows Calculator (windows.com)
194 points by Shinkirou 13 days ago | hide | past | web | favorite | 174 comments





https://github.com/Microsoft/calculator#data--telemetry

"This project collects usage data and sends it to Microsoft to help improve our products and services. Read our privacy statement to learn more. Telemetry is disabled in development builds by default, and can be enabled with the SEND_TELEMETRY build flag."

Even on a simple calculator.



That's some pretty boring information overall.

One which might be cause for concern is LogInvalidInputPasted() specifically because pastedExpression is included in the Telemetry Event.

I also have questions on LogConversionResult(). Why is that recording NetworkAccessBehavior or the raw conversion values? Wouldn't knowing the FromUnit/ToUnit be enough to know how much something is being used?


Conversion between currencies requires access to the API that provides conversion rates.

I presume that LogConversionResult() logs the result of a currency conversion that has already accessed Micrisoft's API. So why does Microsoft need to know the results of my calculations? The function in question isn't GetCurrencyRate().

> might be cause for concern

Only "might"? If you just accidentally paste your password to the calculator...


Why have all the single-use constant strings instead of using the corresponding literals in-place? It’s additional lines of code and doesn't help readability/maintainability (there's already one unused const - EVENT_NAME_HIDE_IF_SHOWN). Additionally, the code mixes string literals with constants:

    fields.AddString(L"AddSubtractMode", isAddMode ? L"Add" : L"Subtract");
    LogTelemetryEvent(EVENT_NAME_DATE_ADD_SUBTRACT_USED, fields);
But then it doesn't use constants where it might make sense, when a string is used more than once. e.g. the literal string "WindowId" is used a dozen times.

Separately, I question whether anyone looking at the telemetry on the backend. In my experience, developers add this stuff because they think it will be useful, then it never or rarely gets looked at. A telemetry event here, a telemetry event there, pretty soon you're talking real bandwidth.


So nothing really nefarious then.

Well it must include your IP address too, and they know the time and date is was received. And then it gets bundled with the rest of the data they collected.

I don't even want them knowing when I'm using my computer.

“What gets measured gets managed.”


Errant pasted data sounds like a bad thing to log.

Because it is a simple calculator. Now think about what they might be collecting from the rest of the system.

All the concerning privacy issues with Facebook or any other company should be seen rigorously by its users. Telemetry at OS Level is one of the worst offending practices IMO.


You don't have to imagine, you can view the data for yourself: https://docs.microsoft.com/en-us/windows/privacy/diagnostic-...

If we're expected to trust the party spying on us to reveal exactly the extent to which they spy on us via their proprietary, closed-source spying data viewer tool, then we deserve exactly whatever the fuck it is we end up getting.

If they cheated on the documentation matching the binary to try and sneak in more telemetry, the backlash would be phenomenal. I don't know if Twitter could handle that kind of load =]

It's always good to trust but verify, although here the the safeguard is pretty strong.


It doesn't always have to be explicitly intentional as you described, but the simple fact is that they are incentivized to gather this data and they will not, in fact, suffer major repercussions commensurate with the amount of data that is collected/gathered. Look at all of the penalties that have been levied at all the other data breaches and how negatively affected those business were. [1]

[1] Very little to not at all.


"MAIL_FOLDER_LIST_EXPANDED", "REFRESH_INBOX_BUTTON_USED", ... :P

‘’’In a brightly lit but still somehow nefarious meeting room two devs discuss their latest findings: Dev1: “These users searching for ‘transfer bank savings’ also have a 15% chance of pasting these long invalid numbers into the calculator. Look at all of them.” Dev2: “Odd those look like bank accounts numbers...” Dev3: “I think we may have an early retirement opportunity...” ‘’’

You raise valid issue, but that issue has nothing to do with the telemetry itself, but with the brokeness of US banking system. Essentially everywhere else the bank account number is simply an public address that you can use to send money there and nothing else.

So microsoft should just ignore all the lessons that we've learned over and over about being data driven?

> Even on a simple calculator.

Why not? If they're paying people to build this software, they presumably want to make it good. With this data, they can learn all kinds of things to help improve future versions: when/why is it crashing, what features are people using most/least, are there patterns of clicks that suggest people are mis-understanding or mis-clicking certain features, etc, etc.

edit: Another one that's often useful is looking at different usage patterns across countries. For example, if nobody in Israel is using COSINE, then there's likely a problem with the right-to-left internationalization that you should fix.


Virtually all of the complaints Microsoft receives about telemetry could be addressed by simply allowing people a global way to turn all telemetry for Microsoft apps off. If you want to support the improvement of apps by allowing this form of telemetry, you can leave it enabled. If you consider it a violation of your privacy, you should be able to easily turn it off.

There's a lack of user control and a lack of transparency. Even if you are a Windows 10 Enterprise user (lucky you, you can turn off system telemetry, unlike the plebes who run Windows 10 Professional), and you turn off telemetry for Windows as a whole, does that include the Calculator or not? Maybe it does. It's really unclear to most people.


If they're paying people to build this software, they presumably want to make it good.

I find it more likely that the real answer is they're trying to "maximize shareholder value." If Microsoft wanted to make good software, there are several thousand other things it could do other than collecting information on people using a calculator.


> Why not? If they're paying people to build this software, ...

Even from people who Do Not Want their data collected for this purpose?


Basically every Android and IOS app you use collects telemetry (which you usually cannot disable) for UX purposes but suddenly when Microsoft does it it's a Big Deal. I don't see the issue with refining UX using anonymous data if it improves the product for the end users. Every high quality commercial app does this.

F-Droid maintains a repository of open-source only android apps, and either doesn't allow apps that has telemetry or at least flags apps which may have such anti-features:

https://f-droid.org/en/packages/


Basically every Android and IOS app you use collects telemetry

So it's OK, then. Jimmy jumped off a bridge, so it's OK if Johnny does it, too. No harm done!

but suddenly when Microsoft does it it's a Big Deal

No, it's a big deal because Microsoft feels entitled to collect information about people using... wait for it... a calculator.

using anonymous data

It's not anonymous. We know it's going to at least get a timestamp and IP address.

I don't see the issue with refining UX

Neither do I. Do it by bringing people in and testing the program on them, the way it was done for decades before "telemetry" became one of those SV euphemisms.

Every high quality commercial app does this.

No. They don't.


Is this data actually anonymous? I can't find anything saying so.

Apple does not collect data at anywhere near this granularity, e.g. which buttons were pressed.


You can effectively disable telemetry in Android by getting Blokada from F-droid

Can it run on regular Android?

You don't need to root your phone to run Blokada, if that's what you're asking... I installed it sometime last year and as of right now, it claims to have blocked 595944 requests.

I had an interview last year with the Windows and Devices Group. On the day of the interview, I was told it would be with people that work on telemetry.

One interviewer told me that keystrokes were being measured by conhost.exe. Not just for internal testing. He clarified that it was done on customer machines. It wasn't clear if they collected individual key presses because we were discussing something you could infer by knowing keystroke timing.

Windows 10 is the most prolific malware in the world.


Speaking as the engineering lead owning conhost.exe: I can't find anything in our code that would trace user input, or data effectively derived from user input, to even a local event stream.

There are a couple instances where we trace API call timings, but only that of API calls initiated by an attached console application.


Open the code up then..

I highly doubt he is the one who has the power to make that happen.

When are we going to see unlimited command line buffers :)?

Hey, I work on the commandline team too - We can't give out exact timelines for anything we work on, but I can tell you that it's pretty high up on the backlog. It's closer now than it's ever been, that's for sure.

That is such an outrageous claim I had to check for myself.

From looking at conhost.exe in IDA Pro, there are some references to telemetry in a function HandleKeyEvent: https://i.imgur.com/MwaBLcW.jpg

But looking more closely it's just used to increase some counters when Ctrl+C or Ctrl+V are used: https://i.imgur.com/29e2qLD.png

There is another one for Ctrl+A elsewhere in the function as well.

Seems these are for when clipboard operations happen, there is other telemetry nearby for when key activity causes a paste: https://i.imgur.com/xONKrGJ.png

So Microsoft are indeed collecting keystroke telemetry in conhost.exe, but it's just some boring old counters to measure clipboard usage.


But how can that be when "... the engineering lead owning conhost.exe: I can't find anything in our code that would trace user input, or data effectively derived from user input, to even a local event stream."

I mean, I suppose that the key sequences around copy/paste are technically user input. Those events get processed into telemetry as to whether they were done in processed or raw input mode, and whether Quick Edit was engaged at the time.

Additional telemetry points include whether the "Find" dialog is being used (explicitly, whether "find next" has been clicked, and how long the search string is -- no other user-generated search content is included in event logs), when a process detaches from the console, and when the window is resized.



Sorry. This is a subthread on the Console and conhost.exe, and I don’t consider myself qualified to talk about Calculator’s telemetry points.

I think this disassembly supports their assertion. The number of times a user copies and pastes isn't in itself input to the console, just a metric of some out of band events.

it's just some boring old counters to measure clipboard usage.

Today. After the next (forced?) upgrade...?


Built-in applications are great opportunities to dogfood new platform features. I'm speculating, but calculator may have added telemetry as a way of testing the relevant SDKs, APIs, data visualization systems, etc, not necessarily because a PM a Microsoft somewhere actually cares what percentage of users press the "multiply" button.

It's not dogfooding if you unleash it on the public.

Surely Microsoft has an accountant or two on staff. Let them test it in-house.


Well, not unless they consider their users to be dogs.

This seems to be the reason they put the telemetry in. They were solving a bug related to the time calculation feature. And, needed to discover if any customers had issues after the change was made.

https://github.com/Microsoft/calculator/blob/057401f5f2b4bb1...


On my windows machine I use Windows 10 Firewall Control (and outbound LittleSnitch type thing .. except crappy). I don't think it was calculator, but there was some other basic Microsoft app that wanted to make an outbound connection. I remember thinking, "WTF?! Why would this need to connect to the Internet ever." .. maybe it was calc. Is this telemetry currently enabled on the released version or is it only in the OSS code?

I'm not sure if I should be disturbed or amused by Microsoft putting telemetry in (at this rate) literally every one of its products.

Like, what the hell do they even track? I guess the obvious ones are things like application crashes, but now I'm curious if they have the data on the most common calculations, folks' favorite numbers, etc.


I'm pretty sure I've entered 58008 in every calculator I've ever touched. That's probably in my Microsoft file somewhere...

And I'm sure your ads are targeted accordingly ;)

The Scientific/Math/Programmer expanded calculators have a bunch of features. Maybe they can test how often the "cube root" button is used versus Arcsinh or something.

This is actually pretty relevant because TI has been goofing up the cube root function in its calculators for decades.

How is that telemetry relevant? The bug needs to be fixed no matter how many people use it.

TI doesn’t think anyone actually uses it in a nontrivial manner.

I have a hard time believing this and can't find any details online. Source please?

I should specify I mean the ones they market to middle and high schools , TI-89, Nspire, and etc

Is there a bug in there?

TI will tell you, “It’s a feature.” Play around with the cube root of negative real fractions ( with even and odd denominators) and integers (starting with -1) and see what you find.

I mean, I guess it would be cool to know what kind of operations people are doing most often? Maybe you send different ads to people who only use addition/subtraction than people who use sin / cos?

or target people who use large numbers with financial planning ads, for example?

Not like I'm going anywhere with this, just morbidly curious but...this is spoken (typed) in parody/jest, right?

Don't give them ideas. ;)

i can't even tell anymore...

Are there that many rich physicists?

What would you imagine with differentiate +/- people to sin users?

Telemetry is not used for ads, but since it is open-source you can check and get a pretty good idea what they actually send.

Here is the list of events, the jokes seem pretty on point to me: https://github.com/Microsoft/calculator/blob/057401f5f2b4bb1...

A small selection:

    constexpr auto EVENT_NAME_INVALID_INPUT_PASTED = L"InvalidInputPasted";
    constexpr auto EVENT_NAME_VALID_INPUT_PASTED = L"ValidInputPasted";
    constexpr auto EVENT_NAME_BITFLIP_PANE_CLICKED = L"BitFlipPaneClicked";
    constexpr auto EVENT_NAME_BITFLIP_BUTTONS_USED = L"BitFlipToggleButtonUsed";
    constexpr auto EVENT_NAME_ANGLE_BUTTONS_USED = L"AngleButtonUsedInSession";
    constexpr auto EVENT_NAME_HYP_BUTTON_USED = L"HypButtonUsedInSession";
    constexpr auto EVENT_NAME_FUNCTION_USAGE = L"FunctionUsageInSession";
    constexpr auto EVENT_NAME_BITLENGTH_BUTTON_USED = L"BitLengthButtonUsed";
Do you have a source for "not used for ads"?

How can you be sure it's not used for ads, their privacy statement says they do[1]:

"You provide some of this data directly, and we get some of it by collecting data about your interactions, use, and experiences with our products."

"Microsoft uses the data we collect to provide you with rich, interactive experiences. In particular, we use data to:

...

Advertise and market to you, which includes sending promotional communications, targeting advertising, and presenting you with relevant offers."

[1] https://privacy.microsoft.com/en-US/privacystatement


You're looking for: https://privacy.microsoft.com/en-gb/privacystatement#mainadv... (data seems different on the US site?)

TL;DR: AdvertisingID handles ad tracking in windows and can be opted out of during install, in settings and globally on your account. AFAIK you can also wipe any previously tracked data. AID tracking is unrelated to telemetry.

Telemetry does not contribute to advertising at all unless "tailored experiences" is enabled in settings, and even then the data is mostly used for Microsoft to suggest features and fixes for problems.


> Telemetry is disabled in development builds by default

So it's not ideal from a privacy perspective to have to worry about usage telemetry in a calculator. But at least there is the silver lining of having telemetry disabled by default _somewhere_, even if it is only for dev builds.


To be fair, it's a nightmare looking at reports that are all clogged up with crashes and whatever from your developers making messes at their desks running non-release code.

Obviously one option is just a dev build flag in your telemetry payload, but I can see the logic in just turning it off altogether.


There is always the HN beloved ChromeOS as alternative.

I'm just surprised it's opt-in for dev builds.

Developers use software in weird ways. I've written scripts to hit buttons thousands of times for hours on end. It makes sense that they don't want developers' janky experiments polluting data used to drive design decisions.

Then why the hell do .NET Core dev utilities have opt-out, and sometimes mandatory, telemetry?

The label "developer" is relative. Any given product wants to exclude telemetry from developers developing the product itself. There's no need to exclude telemetry from developers using the product like a user. The point is to exclude developers running the software in weird ways to debug it. Not just to exclude anyone that calls themselves a developer.

This is cool, but I really wish they'd release the source for the original Notepad. No real reason other than "this software was really important to me when I was a kid".

As it stands, though, Calculator is not something I've particularly cared about in the Windows world; pretty much anyone here could write a simple calculator app in an afternoon.

Still, I am glad MS is slowly becoming more OSS-friendly; I doubt anyone installs Windows specifically for the calculator app, so as a result, why the hell not open-source it?


Part of the Windows 2000 source code leaked and it included Notepad. I don't think it's changed much since then as it's pretty much a wrapper around the Win32 widget with a few features like changing the font, printing, etc.

The only place where I found it where it is publicly "browseable" -> http://www.codeforge.com/article/148667


It seems they updated a couple of things in Notepad (Unix eol, text size, ..) https://hn.algolia.com/?query=windows%20notepad&sort=byDate&...

"Original" is the issue there. They're far more likely to open source a modern UWP app, written with current best practices in mind, rather than a 20 year old C app with untold terrors hiding in the codebase. If they ever rework Notepad into a UWP app, I suspect that would be open sourced, as I expect many newer Windows components to be.

IIRC Notepad source code is in a Windows SDK. Probably an old one, but it only started to be actively maintained quite recently (and even then: only very lightly), so the source code you can get will likely cover most of its lifespan for now.

I'm not sure the source of notepad is that much interesting, though. I mean, yeah, nice to have out of curiosity, maybe, but I'm not sure I would get anything from looking at it. I'm even more interested by monstrosities like historical version of conhost, or of cmd, because it is both simultaneously horrendous and bizarrely not extremely buggy (probably was debugged by some kind of brute force effort, then... :p )

Although a version of the Notepad source under a free software licence would at least permit to strip it of the new ridiculous shits, like "Search with Bing" and maybe some spying features.


I have this kind of masochistic fantasy of rewriting Notepad directly in a modern language. No new features, an identical port in Scheme or something.

I feel like that would be trivial with a clean room reimplementation. There's just not that much functionality to clone.

For me (and for a lot of other people) what I wish they would release as open source is VB6.

There are a ton of good reasons why this is unlikely to ever happen, though (third-party licenses mainly).

There are a ton of VB6 applications out there running, and Microsoft so far has continued to keep the runtime around, but that won't always be the case.

When it is finally EOL'd, people aren't going to be happy at all about it...


Accepting some pull requests on notepad would be nice....

I might try to commit to this.

I've always found the "App" version of Calculator lacking compare to its Win32 predecessor. In particular History. On the old Calculator you could double-click the history and edit the equation, and get a new result, no go on the App.

Plus the Programmer UI, while being more powerful is actually harder to use since the information is now split between two screens rather than one.

Oh and you cannot paste in currency ($10) is now invalid. The old one just stripped the currency symbols.


I use this: https://winaero.com/blog/get-calculator-from-windows-8-and-w...

I don't know if it has the features you're missing, I use it because I don't like the look and feel of the new apps.


Very nice, and it even has a chocolatey package via choco install oldcalc so I can do my [Windows]+R calc and have the Win8 calculator open, very nice indeed!

I don't like the fact that the new calculator always seems to be the wrong size, when using different DPI monitors. I don't need calc to take up 90% of the screen and I don't want to have to resize it. There's no real need for that. Agreed on the history missing functionality, that has annoyed me too.

I worked on a win32 application for my first job out of college. My boss told me "want to learn win32 and c++, go program a windows calculator clone." It was a great project to get started and I did learn a lot. Now I have something to compare my work to ha

Yes I realize this calculator is now a universal windows app, I couldn’t edit cause noprocast locked me out after posting. Reguardless, building a calculator is still a great way to learn a new UI framework. I could see that this would have been a great resource for me as a new engineer (if building a universal windows app).

This calculator is not written using Win32.

(Why the downvotes?)


I didn't downvote you, but it comes across like you were trying to nitpick someone by pointing out a detail that isn't relevant to what they were saying.

One of my pet peeves when engaging in technical discussions!

In this case I think it's valid because the old calculator from windows 8 and below (before the app version) is sometimes called win32calc.

It's still useful for comparing the C++ parts. Could even be useful for learning how modern UWP XAML compares to classic Win32 approaches in C++.

I guess people downvoting you think it's obvious.

Can someone explain why it launches so slowly?

It's 2019, I have a multi-gigahertz processor, it's a calculator app, and it takes a few seconds to launch!


All the layers of more and more abstractions. What used to be a simple app with a few dependencies is now multi-team project requiring almost a virtual machine to run.

The "help wanted" label on some of the GitHub issues[0] is interesting to me. Presumably there are Microsoft employees who are being paid to work on Calculator, are they trying to crowd-source their jobs? I should convince my company to open source the project I am working on so I can offload some of my work too ;)

[0]: https://github.com/Microsoft/calculator/issues?q=is%3Aissue+...


It's something of a GitHub-wide standard/best-practice to have a "help wanted" or "probably easy" or "good first issue" label:

https://help.github.com/en/articles/helping-new-contributors...

It's the Open Source issue tracker equivalent of the "Welcome mat". It doesn't necessarily mean that Microsoft's employees here need help, but it certainly shows that they welcome it.

(Which is a very useful indicator for engagement and shows presumably some stake in actually continuing to develop Calculator out in the open, as opposed it being a one time or rarely-if-ever code drop.)


maybe it become so complex that it's hard to maintain so they seek the community to maintain it for them for free so they can focus on selling the OS it runs on. ;)

speaking from experience working in a truck repair shop, I quit using calculator in windows as it was rather unreliable. if im calculating inner diameter or outer diameter for a part, or doing tooth math for machining a new bull gear, ive often encountered wildly different values in calculator from what a machinists handbook tells me. Ive even had an old-timer warn me about different depth and feed rate calculations that calculator has never done right. This is simple shop math, but i think we're calling it trigonometry these days.

https://blogs.windows.com/windowsexperience/2018/04/04/annou...


This is an issue with any math-related tool in general, including the specialized software, where bugs are much much more sophisticated. Most App Store/Microsoft Store/Google Play apps can't be trusted even for simple square root and trigonometry calculations.

I know it's totally overkill, but I use Mathematica for even simple arithmetic computations. I assume that the developers have ironed most of the obvious bugs.

I think Mathematica uses the GNU multiple precision arithmetic (gmp) library itself in many cases.

> doing tooth math for machining a new bull gear, ive often encountered wildly different values in calculator from what a machinists handbook tells me

Please some example, I'm curious, as Microsoft claims that they use the "infinite" precision library there.


In case anyone is wondering what telemetry is collected: https://github.com/Microsoft/calculator/blob/master/src/Calc...

Awesome seeing another component of Windows (albeit a small one) shifting to open source. My hope is that over time, more and more components will end up open source as they get updated and rewritten.

This is their whole plan. They are testing the waters with this. Soon all of Windows will be open source.

And we still have to pay for it

What does that have to do with anything?

MS goes on to open source the famous and non interesting parts of its products.

What's next? Notepad, Ms Paint?

Shall we see anything bigger than VS Code?


"Microsoft open sources MSPaint.exe"

two weeks later

"Show HN: I added transparency support to MSPaint"

two (more) weeks later

"Adobe shares plummet as users cancel their subscriptions to Creative Cloud by the thousands, analysts baffled"


I know you joke, but in case someone has been unaware, there's Paint.NET[1], which is somewhere between MSPaint-on-steroids and Photoshop-lite.

In 7.5MB, it offers most of the features casual users need from a graphics program: layers, transparency, curves, etc. - all in a footprint (and startup time) comparable to that of MSPaint.

[1]https://www.getpaint.net/


You joke, but Paint actually has a very rudimentary support of transparency: https://www.wikihow.tech/Make-a-Background-Transparent-in-Pa...

I wouldn't even call that 'rudimentary' transparency support, since you're still relying on a background color to select an area of your image.

What I'm talking about is actual RGB alpha channel support

https://en.wikipedia.org/wiki/RGBA_color_space

But what you have here is still a neat function of MSPaint.exe


Be careful Transparent Selection also has a nasty bug.

- Rectangular Select part of an image

- Move it one pixel or more

- With Transparent Selection enabled Rotate -> Rotate 90 Degrees

This is the result: https://i.imgur.com/HlAkHM1.png

If you disable Transparent Selection it works as expected. I reported this to Microsoft twice over the last ten years, no fix yet...


As an aside, this very proposed scenario makes me wonder how many users with more casual image editing requirements PaintDotNet has taken from Photoshop.

The real question is: if Microsoft's Paint gets alpha channel support, what happens to GNU Gimp? :P

> Shall we see anything bigger than VS Code?

.NET framework?


That has no use, as you can almost certainly not install and use it anywhere. .NET framework is an OS component you probably don't want to mess with. And Microsoft neither, given they only innovate in .NET Core nowadays.

OK, .NET core then. The point is the same.

> open source the famous and non interesting parts of its products.

I appreciate you're probably referring to things such as the Windows kernel (just for an example), but this reads like an oxymoron. :)


I would love to see mshtml/trident spun off. While it is not the most modern design, of course, it does have some advantages for embedding and extending with everything having native COM interfaces.

Whoa, it appears to be written in C++/CLI. I wonder how much Windows code also is, and how it impacts maintainability.

I was trying to figure out if it was C++/CLI or C++/CX (I don't do enough Windows dev to know at a glance...). I was hoping it was C++/WinRT – I'm interested in seeing the new language projection in action.

It's C++/CX.

For an example of OS code that uses C++/WinRT, check out the native UI controls library, WinUI: https://github.com/Microsoft/microsoft-ui-xaml


Apparently C++/WinRt was only introduced in Windows 1803 [1], a few years after original Win 10. Interesting to learn that it was originally developed by an independent developer, who was then brought into Microsoft to continue work on it. C++/WinRt uses standard c++.

[1] https://en.wikipedia.org/wiki/C%2B%2B/WinRT


Thank you. I was trying to figure out what language this is, because there's some weird syntax in the .h and .cpp files that I don't recognize as C++.

It's C++/CX, which uses some of the same syntax but targets WinRT instead of .NET.

The history is truncated on GitHub. (first real commit is https://github.com/Microsoft/calculator/commit/c13b8a099eea1... ) They're using GitHub to merge PRs now.

Was this source previously in the Windows repository? Has all development moved to GitHub? If it was in the Windows repo, are they mirroring it back?

Do they still have the old history? There are multiple ways to deal with this in git (grafts, replacements) I wonder if they're using anything like this to get full history, internally.


Kinda shocking how large the codebase is for such a simple app

That's enterprise development for you. 49% boilerplate, 49% tests, and 2% actual code.


This is the most trivial program on the entire OS. Hooray for Microsoft, I guess.

Most trivial? Not by a long shot. What about WINVER?

Not windows, but `true` has to take the cake for the most trivial program, the portion of my comment after the second : is a valid implementation:

GO.COM for CP/M and DOS was similarly trivial. A 0-byte program, the effect of which was to cause the previously run program (which was still in memory at 0100h) to start again.

Is true a program? I thought it was a command built into the shell.

Most shells optimize it to avoid the overhead of spawning a process for something as trivial as that. But yes, it's an actual binary even so, just in case - try `which true`.

https://www.gnu.org/software/coreutils/manual/html_node/true...



It’s /usr/bin/true on Mac, and the OpenBSD source for it is at https://github.com/openbsd/src/blob/master/usr.bin/true/true... .

I don't know what I expected.

I wouldn't call the arbitrary-precision may engine in that trivial, per se.

it is a good first step, now they just gotta keep walking down this line

Nice to hear that.

I like to calculate stuff from time to time, so I use the default OS calculator app a lot.

The Windows one is actually pretty decent, except maybe for the shortcuts - e.g. raising to the power is under "y" for some reason.

Ubuntu/Linux(es) has by far the best one. The shortcuts are obvious and the whole expression is visible at all times.

The one for macOS is surprisingly lacking.


I think that function has been bound to y for decades by now. No reason to change muscle memory, even when rewriting the UI.

How many threads for a calculator? My Task Manager says 20.

This is going to be great for ReactOS, they're even open sourcing more of their UI components.

Now if the would open solitaire, that would be huge.

I can’t believe the core of it is still some C code from ’95 called “Ratpack”: https://github.com/Microsoft/calculator/tree/master/src/Calc... over which they added a whole bunch of enterprise fluff.

> I can’t believe the core of it is still some C code from ’95

Why?

https://en.wikipedia.org/wiki/NumPy

"Internally, both MATLAB and NumPy rely on BLAS and LAPACK for efficient linear algebra computations."

As far as I know BLAS and LAPACK are still based on the decades old FORTRAN code.


This is really cool! I thought the open sourcing of Winfile was cool too.

I hope they continue down this road. I doubt we'll see the NT Kernel on GitHub in my life time... but, one can dream.



The NT 4.0 source code is probably stupidly interesting and I'm sure there's much to be learned, but... Source code leaking is not the same as something getting open sourced. It's illegal, and it doesn't foster collaboration in the same way. And plus, even as fascinating as NT 4.0 is, it'd be neat to see more recent stuff too.

Is this the version with floating point precision errors?

My favorite calculator was the PowerToy Calculator back in the Windows XP days.

Does anyone have a suggestion for a replace on Windows 10?


Finally I can have it run in a size that does not take up 3/4th of my screen by default.

I hope cmd.exe is next so that we can learn how to build terminals the ms way

Is this for the old school cool calc.exe or the new Calculator Windows 10 app?

I see xaml there, does that mean this is WPF even though it's c++ ?

That's XAML but not WPF.

XAML is just a markup language, it's used across multiple frameworks and languages.

This particular technology is called UWP, it's mostly rebranded WinRT.

Historically, XAML was also used in Silverlight, both desktop/web, WinCE, and Windows Phone.


Well, the constructs used in the xaml appear to be very similar between uwp and wpf. You still have controltemplates, datatemplates, and dependency properties, so there is a lot in common more than just syntax.

The syntax and controls are indeed very similar.

If you know any XAML, you’ll have zero issues using the rest of them. Speaking from experience, I started with Silverlight a decade ago, had no problems switching to others.

But the underlying tech is very different. Early Silverlight rendered on CPU, WPF is based on DirectX 9, UWP uses Direct3D 11. Silverlight and WPF are .NET based, WinRT and UWP are not, they’re 100% native code, exposed to .NET through COM interop.


thanks

While I applaud this, and I'm generally positive about Microsoft's new stance regarding open source, I wonder whether they ever have, or ever will, apologise for having made remarks like "Linux is communism". They caused a lot of damage. It feels a bit disingenuous to just pretend now that nothing happened.

I don't know what a single sentence, said in 2000 by a person who has not been at an organization since 2014 has to do with said organization in 2019.

Kind of like the people who comment "embrace, extend, extinguish" on every Micro$oft article, forgetting that the one person to who the phrase has been directly attributed (by a third party who was paraphrasing) resigned from Microsoft 19 years ago and when obliquely referenced (like during lawsuits) the documents used as exhibits in the lawsuits all date from the mid-90s.

It kind of makes me roll my eyes, like people ask "did you know coca cola used to have COCAINE in it?"


In the 50s, Alan Turing was convicted for being gay. Much later, in 2013, the UK government issued a posthumous pardon [0]. I'm pretty sure nobody in the 2013 government was in the government in 1950, but AFAIK this was widely seen as a good thing, an admission that what the institution that is the UK government, although not the same people, had made a mistake.

I think this applies in exactly the same way to the wrongs of corporations. Out of decency, if not out of being consistent with the idea of treating them as legal persons.

[0] https://www.bbc.co.uk/news/technology-25495315


They will not. I can't find the link at the moment but I read an article about 6 months or so ago where, iirc, Steve Balmer and Satya Nadella where talking about Microsoft's open source plans and some of the history and made a remark that fighting open source "was the correct business choice at the time."

>having made remarks like "Linux is communism".

what?



So they are gonna open source everything so that the community can contribute to it and still charge us for using it. Cleaver move Microsoft



Applications are open for YC Summer 2019

Guidelines | FAQ | Support | API | Security | Lists | Bookmarklet | Legal | Apply to YC | Contact

Search: