diff --git a/editor/extension.ts b/editor/extension.ts index c18dfcdb..266d86d4 100644 --- a/editor/extension.ts +++ b/editor/extension.ts @@ -31,89 +31,87 @@ namespace pxt.editor { class DAPWrapper { cortexM: DapJS.CortexM + packetIo: HF2.PacketIO; constructor(h: HF2.PacketIO) { - let pbuf = new U.PromiseBuffer() + this.packetIo = h; + let pbuf = new U.PromiseBuffer(); let sendMany = (cmds: Uint8Array[]) => { - return h.talksAsync(cmds.map(c => ({ cmd: 0, data: c }))) + return h.talksAsync(cmds.map(c => ({ cmd: 0, data: c }))); } if (!h.talksAsync) - sendMany = null + sendMany = null; let dev = new DapJS.DAP({ write: writeAsync, - close: closeAsync, + close: this.disconnectAsync, read: readAsync, sendMany: sendMany - }) - this.cortexM = new DapJS.CortexM(dev) + }); + this.cortexM = new DapJS.CortexM(dev); h.onData = buf => { - pbuf.push(buf) + pbuf.push(buf); } function writeAsync(data: ArrayBuffer) { - h.sendPacketAsync(new Uint8Array(data)) - return Promise.resolve() + h.sendPacketAsync(new Uint8Array(data)); + return Promise.resolve(); } function readAsync() { - return pbuf.shiftAsync() - } - - function closeAsync() { - return h.disconnectAsync() + return pbuf.shiftAsync(); } } reconnectAsync(first: boolean) { - return this.cortexM.init() + return this.cortexM.init(); + } + + disconnectAsync() { + return this.packetIo.disconnectAsync(); } } + let previousDapWrapper: DAPWrapper; function dapAsync() { - return pxt.HF2.mkPacketIOAsync() + return Promise.resolve() + .then(() => { + if (previousDapWrapper) { + return previousDapWrapper.disconnectAsync() + .finally(() => { + previousDapWrapper = null; + }); + } + return Promise.resolve(); + }) + .then(() => pxt.HF2.mkPacketIOAsync()) .then(h => { let w = new DAPWrapper(h) + previousDapWrapper = w; return w.reconnectAsync(true) .then(() => w) }) } - let noHID = false - - let initPromise: Promise function initAsync() { - if (initPromise) - return initPromise - let canHID = false if (U.isNodeJS) { canHID = true } else { const forceHexDownload = /forceHexDownload/i.test(window.location.href); - if (Cloud.isLocalHost() && Cloud.localToken && !forceHexDownload) + const isUwp = !!(window as any).Windows; + if (Cloud.isLocalHost() && Cloud.localToken && !forceHexDownload || isUwp) canHID = true } - if (noHID) - canHID = false - if (canHID) { - initPromise = dapAsync() - .catch(err => { - initPromise = null - noHID = true - return Promise.reject(err) - }) + return dapAsync(); } else { - noHID = true - initPromise = Promise.reject(new Error("no HID")) + return Promise.reject(new Error("no HID")) } - - return initPromise } function pageAlignBlocks(blocks: UF2.Block[], pageSize: number) { @@ -234,13 +232,8 @@ namespace pxt.editor { } startTime = 0 - - if (noHID) return saveHexAsync() - let wrap: DAPWrapper - log("init") - let logV = (msg: string) => { } //let logV = log @@ -339,11 +332,7 @@ namespace pxt.editor { }) }) .catch(e => { - // if we failed to initalize, retry - if (noHID) - return saveHexAsync() - else - return Promise.reject(e) + return saveHexAsync(); }) } @@ -371,16 +360,16 @@ namespace pxt.editor { }, name: data.meta.name }) }, { - id: "td", - canImport: data => data.meta.cloudId == "microbit.co.uk" && data.meta.editor == "touchdevelop", - importAsync: (project, data) => - project.createProjectAsync({ - filesOverride: { "main.blocks": "", "main.ts": " " }, - name: data.meta.name - }) - .then(() => project.convertTouchDevelopToTypeScriptAsync(data.source)) - .then(text => project.overrideTypescriptFile(text)) - }] + id: "td", + canImport: data => data.meta.cloudId == "microbit.co.uk" && data.meta.editor == "touchdevelop", + importAsync: (project, data) => + project.createProjectAsync({ + filesOverride: { "main.blocks": "", "main.ts": " " }, + name: data.meta.name + }) + .then(() => project.convertTouchDevelopToTypeScriptAsync(data.source)) + .then(text => project.overrideTypescriptFile(text)) + }] }; pxt.commands.deployCoreAsync = deployCoreAsync; return Promise.resolve(res); diff --git a/pxtarget.json b/pxtarget.json index 4aae702e..54e39fa6 100644 --- a/pxtarget.json +++ b/pxtarget.json @@ -70,6 +70,14 @@ "device_print_message.message": "text" } } + ], + "hidSelectors": [ + { + "usagePage": "0xFF00", + "usageId": "0x0001", + "vid": "0x0d28", + "pid": "0x0204" + } ] }, "runtime": { diff --git a/pxtwapp/.gitignore b/pxtwapp/.gitignore new file mode 100644 index 00000000..7ade57d0 --- /dev/null +++ b/pxtwapp/.gitignore @@ -0,0 +1,295 @@ +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. +## +## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore + +# User-specific files +*.suo +*.user +*.userosscache +*.sln.docstates + +# User-specific files (MonoDevelop/Xamarin Studio) +*.userprefs + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +x64/ +x86/ +bld/ +[Bb]in/ +[Oo]bj/ +[Ll]og/ + +# Visual Studio 2015 cache/options directory +.vs/ +# Uncomment if you have tasks that create the project's static files in wwwroot +#wwwroot/ + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +# NUNIT +*.VisualState.xml +TestResult.xml + +# Build Results of an ATL Project +[Dd]ebugPS/ +[Rr]eleasePS/ +dlldata.c + +# Benchmark Results +BenchmarkDotNet.Artifacts/ + +# .NET Core +project.lock.json +project.fragment.lock.json +artifacts/ +**/Properties/launchSettings.json + +*_i.c +*_p.c +*_i.h +*.ilk +*.meta +*.obj +*.pch +*.pdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*.log +*.vspscc +*.vssscc +.builds +*.pidb +*.svclog +*.scc + +# Chutzpah Test files +_Chutzpah* + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opendb +*.opensdf +*.sdf +*.cachefile +*.VC.db +*.VC.VC.opendb + +# Visual Studio profiler +*.psess +*.vsp +*.vspx +*.sap + +# TFS 2012 Local Workspace +$tf/ + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper +*.DotSettings.user + +# JustCode is a .NET coding add-in +.JustCode + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# Visual Studio code coverage results +*.coverage +*.coveragexml + +# NCrunch +_NCrunch_* +.*crunch*.local.xml +nCrunchTemp_* + +# MightyMoose +*.mm.* +AutoTest.Net/ + +# Web workbench (sass) +.sass-cache/ + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.[Pp]ublish.xml +*.azurePubxml +# TODO: Comment the next line if you want to checkin your web deploy settings +# but database connection strings (with potential passwords) will be unencrypted +*.pubxml +*.publishproj + +# Microsoft Azure Web App publish settings. Comment the next line if you want to +# checkin your Azure Web App publish settings, but sensitive information contained +# in these scripts will be unencrypted +PublishScripts/ + +# NuGet Packages +*.nupkg +# The packages folder can be ignored because of Package Restore +**/packages/* +# except build/, which is used as an MSBuild target. +!**/packages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/packages/repositories.config +# NuGet v3's project.json files produces more ignorable files +*.nuget.props +*.nuget.targets + +# Microsoft Azure Build Output +csx/ +*.build.csdef + +# Microsoft Azure Emulator +ecf/ +rcf/ + +# Windows Store app package directories and files +AppPackages/ +BundleArtifacts/ +Package.StoreAssociation.xml +_pkginfo.txt +*.appx + +# Visual Studio cache files +# files ending in .cache can be ignored +*.[Cc]ache +# but keep track of directories ending in .cache +!*.[Cc]ache/ + +# Others +ClientBin/ +~$* +*~ +*.dbmdl +*.dbproj.schemaview +*.jfm +*.pfx +*.publishsettings +orleans.codegen.cs + +# Since there are multiple workflows, uncomment next line to ignore bower_components +# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) +#bower_components/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file +# to a newer Visual Studio version. Backup files are not needed, +# because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm + +# SQL Server files +*.mdf +*.ldf +*.ndf + +# Business Intelligence projects +*.rdl.data +*.bim.layout +*.bim_*.settings + +# Microsoft Fakes +FakesAssemblies/ + +# GhostDoc plugin setting file +*.GhostDoc.xml + +# Node.js Tools for Visual Studio +.ntvs_analysis.dat +node_modules/ + +# Typescript v1 declaration files +typings/ + +# Visual Studio 6 build log +*.plg + +# Visual Studio 6 workspace options file +*.opt + +# Visual Studio 6 auto-generated workspace file (contains which files were open etc.) +*.vbw + +# Visual Studio LightSwitch build output +**/*.HTMLClient/GeneratedArtifacts +**/*.DesktopClient/GeneratedArtifacts +**/*.DesktopClient/ModelManifest.xml +**/*.Server/GeneratedArtifacts +**/*.Server/ModelManifest.xml +_Pvt_Extensions + +# Paket dependency manager +.paket/paket.exe +paket-files/ + +# FAKE - F# Make +.fake/ + +# JetBrains Rider +.idea/ +*.sln.iml + +# CodeRush +.cr/ + +# Python Tools for Visual Studio (PTVS) +__pycache__/ +*.pyc + +# Cake - Uncomment if you are using it +# tools/** +# !tools/packages.config + +# Tabs Studio +*.tss + +# Telerik's JustMock configuration file +*.jmconfig + +# BizTalk build output +*.btp.cs +*.btm.cs +*.odx.cs +*.xsd.cs \ No newline at end of file diff --git a/pxtwapp/pxtwapp.sln b/pxtwapp/pxtwapp.sln new file mode 100644 index 00000000..a4f95a62 --- /dev/null +++ b/pxtwapp/pxtwapp.sln @@ -0,0 +1,48 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 15 +VisualStudioVersion = 15.0.26430.15 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{262852C6-CD72-467D-83FE-5EEB1973A190}") = "pxtwapp", "pxtwapp\pxtwapp.jsproj", "{34E8CDE2-3991-414E-BB19-BFF4BD5E031A}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Debug|ARM = Debug|ARM + Debug|x64 = Debug|x64 + Debug|x86 = Debug|x86 + Release|Any CPU = Release|Any CPU + Release|ARM = Release|ARM + Release|x64 = Release|x64 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|Any CPU.Build.0 = Debug|Any CPU + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|Any CPU.Deploy.0 = Debug|Any CPU + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|ARM.ActiveCfg = Debug|ARM + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|ARM.Build.0 = Debug|ARM + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|ARM.Deploy.0 = Debug|ARM + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|x64.ActiveCfg = Debug|x64 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|x64.Build.0 = Debug|x64 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|x64.Deploy.0 = Debug|x64 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|x86.ActiveCfg = Debug|x86 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|x86.Build.0 = Debug|x86 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Debug|x86.Deploy.0 = Debug|x86 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|Any CPU.ActiveCfg = Release|Any CPU + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|Any CPU.Build.0 = Release|Any CPU + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|Any CPU.Deploy.0 = Release|Any CPU + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|ARM.ActiveCfg = Release|ARM + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|ARM.Build.0 = Release|ARM + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|ARM.Deploy.0 = Release|ARM + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|x64.ActiveCfg = Release|x64 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|x64.Build.0 = Release|x64 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|x64.Deploy.0 = Release|x64 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|x86.ActiveCfg = Release|x86 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|x86.Build.0 = Release|x86 + {34E8CDE2-3991-414E-BB19-BFF4BD5E031A}.Release|x86.Deploy.0 = Release|x86 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/pxtwapp/pxtwapp/images/SmallTile.scale-200.png b/pxtwapp/pxtwapp/images/SmallTile.scale-200.png new file mode 100644 index 00000000..ece0f13d Binary files /dev/null and b/pxtwapp/pxtwapp/images/SmallTile.scale-200.png differ diff --git a/pxtwapp/pxtwapp/images/SplashScreen.scale-200.png b/pxtwapp/pxtwapp/images/SplashScreen.scale-200.png new file mode 100644 index 00000000..04e2edea Binary files /dev/null and b/pxtwapp/pxtwapp/images/SplashScreen.scale-200.png differ diff --git a/pxtwapp/pxtwapp/images/Square150x150Logo.scale-200.png b/pxtwapp/pxtwapp/images/Square150x150Logo.scale-200.png new file mode 100644 index 00000000..ba7825e4 Binary files /dev/null and b/pxtwapp/pxtwapp/images/Square150x150Logo.scale-200.png differ diff --git a/pxtwapp/pxtwapp/images/Square44x44Logo.altform-unplated_targetsize-48.png b/pxtwapp/pxtwapp/images/Square44x44Logo.altform-unplated_targetsize-48.png new file mode 100644 index 00000000..95fbcbba Binary files /dev/null and b/pxtwapp/pxtwapp/images/Square44x44Logo.altform-unplated_targetsize-48.png differ diff --git a/pxtwapp/pxtwapp/images/Square44x44Logo.scale-200.png b/pxtwapp/pxtwapp/images/Square44x44Logo.scale-200.png new file mode 100644 index 00000000..9718ecf2 Binary files /dev/null and b/pxtwapp/pxtwapp/images/Square44x44Logo.scale-200.png differ diff --git a/pxtwapp/pxtwapp/images/Square44x44Logo.targetsize-48.png b/pxtwapp/pxtwapp/images/Square44x44Logo.targetsize-48.png new file mode 100644 index 00000000..9c282d89 Binary files /dev/null and b/pxtwapp/pxtwapp/images/Square44x44Logo.targetsize-48.png differ diff --git a/pxtwapp/pxtwapp/images/Wide310x150Logo.scale-200.png b/pxtwapp/pxtwapp/images/Wide310x150Logo.scale-200.png new file mode 100644 index 00000000..dbcd6e25 Binary files /dev/null and b/pxtwapp/pxtwapp/images/Wide310x150Logo.scale-200.png differ diff --git a/pxtwapp/pxtwapp/images/logo.png b/pxtwapp/pxtwapp/images/logo.png new file mode 100644 index 00000000..8b21b4a5 Binary files /dev/null and b/pxtwapp/pxtwapp/images/logo.png differ diff --git a/pxtwapp/pxtwapp/images/storelogo.scale-200.png b/pxtwapp/pxtwapp/images/storelogo.scale-200.png new file mode 100644 index 00000000..d576c75e Binary files /dev/null and b/pxtwapp/pxtwapp/images/storelogo.scale-200.png differ diff --git a/pxtwapp/pxtwapp/msapp-error.css b/pxtwapp/pxtwapp/msapp-error.css new file mode 100644 index 00000000..8b478344 --- /dev/null +++ b/pxtwapp/pxtwapp/msapp-error.css @@ -0,0 +1,40 @@ +body { + margin: 10px; + background-color: #4C4B4D; + color: #FFFFFF; + font-family: 'Open Sans', 'Helvetica Neue', Arial, Helvetica, sans-serif; +} + +.paramName { + font-size: 10px; + font-weight: bold; +} + +.paramValue { + font-size: 10px; + padding-left: 10px; +} + +.param { + margin-bottom: 8px; +} + +#retryButton { + box-shadow: 0px 0em 0px 0px rgba(34, 36, 38, 0.15) inset; + outline: none; + border: none; + vertical-align: baseline; + padding: 0.78571429em 1.5em 0.78571429em; + text-transform: none; + font-weight: bold; + font-style: normal; + text-align: center; + text-decoration: none; + border-radius: 0.28571429rem; + background-color: #FB48C7; + margin: 15px 10px 100px 10px; + width: 80px; + height: 35px; + font-size: 15px; + color: #FFFFFF; +} diff --git a/pxtwapp/pxtwapp/msapp-error.html b/pxtwapp/pxtwapp/msapp-error.html new file mode 100644 index 00000000..33303cf1 --- /dev/null +++ b/pxtwapp/pxtwapp/msapp-error.html @@ -0,0 +1,24 @@ + + + + Oops! + + + + +

Oops! Please connect to the Internet.

+ +
+ URL: + +
+
+ HTTP status: + +
+
+ Failure name: + +
+ + diff --git a/pxtwapp/pxtwapp/msapp-error.js b/pxtwapp/pxtwapp/msapp-error.js new file mode 100644 index 00000000..ef5e2bef --- /dev/null +++ b/pxtwapp/pxtwapp/msapp-error.js @@ -0,0 +1,47 @@ +(function () { + var validParameterNames = ["httpStatus", "failureName", "failureUrl"]; + + function parseQueryParameters() { + var query = location.search.slice(1); + return query.split("&").reduce(function (queryParameters, rawPair) { + var pair = rawPair.split("=").map(decodeURIComponent); + queryParameters[pair[0]] = pair[1]; + return queryParameters; + }, {}); + } + + function initialize() { + var queryParameters = parseQueryParameters(); + var url = queryParameters["failureUrl"]; + var retryButton = document.getElementById("retryButton"); + + if (url) { + retryButton.addEventListener("click", (e) => { + window.location.href = url; + }); + } else { + retryButton.style.display = none; + } + + validParameterNames.forEach(function (parameterName) { + var parameterValue = queryParameters[parameterName]; + + if (parameterValue) { + document.getElementById(parameterName + "Value").textContent = parameterValue; + } else { + document.getElementById(parameterName).remove(); + } + }); + } + + function updateOnlineStatus(e) { + var queryParameters = parseQueryParameters(); + var url = queryParameters["failureUrl"]; + if (url) { + window.location.href = url; + } + } + + window.addEventListener("online", updateOnlineStatus); + document.addEventListener("DOMContentLoaded", initialize); +}()); diff --git a/pxtwapp/pxtwapp/package.appxmanifest b/pxtwapp/pxtwapp/package.appxmanifest new file mode 100644 index 00000000..8551fb37 --- /dev/null +++ b/pxtwapp/pxtwapp/package.appxmanifest @@ -0,0 +1,60 @@ + + + + + + Microsoft MakeCode for micro:bit + micro:bit + images\storelogo.png + + + + + + + + + + + + + + + + + + + + + + + + + Microsoft MakeCode binary file + + .hex + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pxtwapp/pxtwapp/pxtwapp.jsproj b/pxtwapp/pxtwapp/pxtwapp.jsproj new file mode 100644 index 00000000..075e1e95 --- /dev/null +++ b/pxtwapp/pxtwapp/pxtwapp.jsproj @@ -0,0 +1,87 @@ + + + + + Debug + AnyCPU + + + Debug + ARM + + + Debug + x64 + + + Debug + x86 + + + Release + AnyCPU + + + Release + ARM + true + + + Release + x64 + true + + + Release + x86 + true + + + + 34e8cde2-3991-414e-bb19-bff4bd5e031a + + + + 14.0 + + + + + UAP + 10.0.15063.0 + 10.0.10240.0 + $(VersionNumberMajor).$(VersionNumberMinor) + en-US + pxtwapp_TemporaryKey.pfx + + + + Designer + + + + + + + + + + + + + + + + + + \ No newline at end of file