SerenityOS / serenity

The Serenity Operating System 🐞
https://serenityos.org
BSD 2-Clause "Simplified" License
30.63k stars 3.19k forks source link

Spreadsheet: Some (?) JS errors crash Spreadsheet #14042

Closed kleinesfilmroellchen closed 2 years ago

kleinesfilmroellchen commented 2 years ago

To reproduce:

spreadsheet file contents

``` [{"name":"Calculation","rows":6,"cells":{"K4":{"kind":"Formula","source":"D4*A3/F4","value":"249.62158203125","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"B0":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"K6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"F5": {"kind":"Formula","source":"481*1024","value":"492544","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"I3":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"E4":{"kind":"LiteralString","value":"94","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"E3":{"kind":"LiteralString","value":"187","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"A2":{"kind":"LiteralString","value":"Amount of data (bytes)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterLeft"},"conditional_formats":[],"evaluated_formats":{}},"B6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"J3":{"kind":"Formula","source":"H3*A3/F3/1000","value":"3678826.222500000149011","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"C3":{"kind":"LiteralString","value":"83","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"D2": {"kind":"LiteralString","value":"Height (mm)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"B3":{"kind":"LiteralString","value":"Hollerith punch cards","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"B2":{"kind":"LiteralString","value":"Medium","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"B5":{"kind":"LiteralString","value":"large floppys","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"B4": {"kind":"LiteralString","value":"small floppys","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"K3":{"kind":"Formula","source":"D3*A3/F3","value":"237022.5","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"H6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"C2":{"kind":"LiteralString","value":"Width (mm)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"G3": {"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"G2":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"F4":{"kind":"Formula","source":"1440*1024","value":"1474560","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"E6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"J5":{"kind":"Formula","source":"H5*A3/F5/1000","value":"12629.502744932431596","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"J9": {"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"J6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"E7":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"A3":{"kind":"LiteralString","value":"111540000","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterLeft"},"conditional_formats":[],"evaluated_formats":{}},"K5":{"kind":"Formula","source":"D5*A3/F5","value":"747.307854729729683","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"H4":{"kind":"Formula","source":"C4*D4*E4","value":"27918","type":"Identity","type_metadata": {"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"I2":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"J2":{"kind":"LiteralString","value":"SerenityOS volume (cm³)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"A1":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"E2":{"kind":"LiteralString","value":"Length (mm)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"D6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"F3":{"kind":"LiteralString","value":"80","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"H5":{"kind":"Formula","source":"C5*D5*E5","value":"55770","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"D4": {"kind":"LiteralString","value":"3.3","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"C5":{"kind":"LiteralString","value":"130","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"C6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"B1":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"C1": {"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"A4":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"F2":{"kind":"LiteralString","value":"Capacity (bytes)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"D3":{"kind":"LiteralString","value":"0.17","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"F6":{"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"K2":{"kind":"LiteralString","value":"SerenityOS height (mm)","type":"Identity","type_metadata": {"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"C4":{"kind":"LiteralString","value":"90","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"J4":{"kind":"Formula","source":"H4*A3/F4/1000","value":"2111.798583984375","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"H2":{"kind":"LiteralString","value":"Volume (mm³)","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"A0":{"kind":"LiteralString","value":"Calculations for how much volume SerenityOS takes up in physical containers","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"H3":{"kind":"Formula","source":"C3*D3*E3","value":"2638.570000000000163","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"G4": {"kind":"LiteralString","value":"","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"E5":{"kind":"LiteralString","value":"130","type":"Numeric","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}},"D5":{"kind":"LiteralString","value":"3.3","type":"Identity","type_metadata":{"length":-1,"format":null,"alignment":"CenterRight"},"conditional_formats":[],"evaluated_formats":{}}}}] ```

cc @alimpfard

kleinesfilmroellchen commented 2 years ago

Appears to be fixed now, can't reproduce.