Cambridge Alexa Devs Meetup
I recently attended the inaugural meetup of the Cambridge Alexa Developers Group held at Amazon’s Cambridge office. The group was set up by Bob Harris and Rich Merrett, who both gave talks on building Alexa skills and SSML.
David Low, Amazon’s Head of Solutions Architects, also gave a talk about how to best create a skill by working out its user value:
One particlarly interesting thing covered was a formula for working out whether a skill will be a “killer skill”:
Cusomter value | × | Contexts | × | Frequency | × | Multipliers |
Complexity | × | Friction |
The higher the output of this formula, the higher the likelihood that a skill will be succesful.
While this talk wasn’t recorded, he has given a similar talk before that was.
NDC London 2018
Last week I attended NDC London. It’s not the first time that I’ve been, but it is the first time I’ve done the workshops that run alongside the main conference.
I attended the “Identity & Access Control for modern Applications and APIs using ASP.NET Core 2” workshop hosted by Dominick Baier and Brock Allen. This was a two day workshop consisting of a mixture of presentation, discussion, and hands-on labs. It dived deep into the security aspects of modern ASP.Net applications, specifically the application itself and its APIs. The first day focused on how external authentication (via OAuth 2.0 and OpenID Connect) could be used to save having to implement authentication yourself in your application. The second day took this further and focused on how to secure an API that you may have in an application so that you can call it server-to-server, from mobile applications, or from JavaScript applications.
The remaining three days of the conference was in the form of talks. Like I’ve done before, I sketchnoted many of the sessions that I attended.
What Is Programming Anyway?
The Power Of Technical Decisions
You Build It, You Run It
An Introduction To Kotlin
Composite UIs: The Microservices Last Mile
Designing For Speech
Jewelbots: How To Get More Girls Coding
Who Needs Dashboards?
Pilot Decision Management
A Developer’s Guide To Machine Learning
CSP XXP STS PKP CAA ETC…
Web Apps Can’t Do That, Can They?
These are the other talks I attended but didn’t sketchnote:
C# 7.0
C# 7.1 and 7.2: The Releases You Didn’t Know You Had
The Psychology Of Social Engineering
The Modern Cloud
The Hello World Show Live
hosted by Heather Downing and Spencer Schneidenbach
Tips And Tricks With Azure
Why I’m Not Leaving .Net
DDD North 7
I recently attended DDD North 7 in Bradford. I’ve been wanting to take up sketchnoting for a while now, but have never gotten round to doing it, so when Ian Johnson (go check out his sketchnotes - they are great) prompted me to take my sketchbook and pens with me, I reluctantly obliged. I’m so glad I did though as I really enjoyed doing them, and I feel it had the effect of me being able to recall much more of the content of each talk. I tweeted the sketchnotes after each session and got a great response from both the speakers and attendees.
Here are the sketchnotes I did during the day.
Microservices: What I’ve Learned After A Year Of Building A System
Spot The Difference: Automating Visual Regression Testing
Married To The Mob (Programming)
How To Parse A File
Alexa, Open Sneezaroo…
Setting a culture for all threads in an application
If you do any kind of globalisation in your applications, you will probably already be familiar with the Thread.CurrentCulture
and Thread.CurrentUICulture
properties that can be used to set a culture on the thread so that .Net knows to load the correct resources and to format numbers and dates properly.
A big downside to using approach this is that the culture is only set on the current thread, meaning that any new threads created will be using the default culture for the application (which is tied to the regional settings of the operation system). This wasn’t too much of a problem years ago when multi-threading was not used widely, but in modern application development it is virtually impossible to avoid using multiple threads (e.g. Task Parallel Library), especially when trying to make use of modern multi-core hardware. You would have to manually set the culture when spawning new threads to ensure that the correct culture was being used - a real pain and a common cause of bugs.
.Net 4.5 comes to the rescue with the introduction of two new properties:
CultureInfo.DefaultThreadCurrentCulture
CultureInfo.DefaultThreadCurrentUICulture
A culture can be set using properties that will then be used for all threads in the whole application domain, meaning that you can set the correct culture at application start up and all threads will use that culture. By default, these properties are set to null meaning that the pre-4.5 behaviour will still hold and that the system culture will be used by default.
The MSDN docs for CultureInfo.DefaultThreadCurrentCulture
and CultureInfo.DefaultThreadCurrentUICulture
provide more details.
Alternatives to .Net Reflector
RedGate recently announced that from the next version of Reflector (v7), they will charge $35 for a licence. Since the announcement a few weeks ago, there has been quite a backlash against the decision from the .Net community, mainly because RedGate have put a time-bomb in the currently-free version so that it will expire at the end of May 2011. In response to this announcement, several alternatives to Reflector have surfaced - some free, some commercial. The list below outlines all of the alternatives, some of which have been around for many years.
-
JetBrains ReSharper (commercial + free)
Within a day of the announcement, JetBrains put out a teaser suggesting that a decompiler was in the works. Two weeks later, they announced that the next version of ReSharper will have an integrated decompiler akin to reflector, along with a free standalone version to be released later in the year. -
Telerik JustCode (commercial)
Just as JetBrains put out a teaser, Telerik followed suit and showed a decompilation feature that will be in the next version of their JustCode tool. -
ldasm (free)
This tool comes bundled with the Windows SDK Tools (that get installed as part of Visual Studio). It is purely an IL disassembler, and so cannot decompile to C#. -
ILSpy (free)
The team behind SharpDevelop have been working hard on ILSpy and have already released a major milestone of v1 of their decompiler. It can decompile to C#. -
Cecil Studio (free)
This is a Windows forms UI based on the Mono Cecil library. It has already been around for a few years. -
MonoReflector (free)
This is a WPF UI based on the Mono Cecil library. -
MonoDevelop Assembly Browser (free)
Released for the first time in version 2.0 of MonoDevelop (currently at v2.4.2). -
Salamander .Net Decompiler (commercial)
This is part of a larger tool called .Net Explorer. -
Dis# (commercial)
This tool has been around for a while, but is not often mentioned. It is not as polished as Reflector and does not support never versions of .Net, but has some nice features not seen anywhere else. Once such feature is to rename the decompiled variables within the tool to give them a more meaningful name. -
Spices .Net Decompiler (commercial)
As well as decompiling to IL, C#, J#, C++ and Delphi.Net, this tool has a feature to build code flow diagrams from the decompiled source to show the execution flow. -
Decompiler.NET (commercial)
This is s decompiler combined with an obfuscator, language translator and refactoring tool that integrates with Visual Studio. -
Keep Decompiling Free
This website popped up recently with nothing more than a teaser to get more information when it is available. -
RedGate Reflector (commercial)
Of course, there is still the current king of them all, albeit in a now charged-for format. Still well worth the $35.
Which of these will turn out to be the best/most successful to take Reflector’s throne is yet to play out, but there seems to be a healthy interest from both the community and commercial aspects in making a replacement.