Skip to main content

Anoying XSLT Error

Had a nasty error in using an XSLT today. I was attempting to perform a transform but before I got that far, I kept getting an error, specifically when trying to set the stylesheet property of the xsl template object.
dim xslt, xmltempl
set xslt = Server.CreateObject("Msxml2.FreeThreadedDOMDocument")
xslt.async = false
xslt.load Server.MapPath("my.xsl")
set xmltempl = Server.CreateObject("Msxml2.XSLTemplate")
set xmltempl.stylesheet = xslt
The error I kept getting was "The system cannot locate the object specified" and I kept getting it right at the last line. I would then use my debugger to browse the xslt object and see that all the xml for that stylesheet was loading just fine as expected. I was very confused and spent a considerable amount of time trying to fix it.
Thankfully a colleague had a suggestion and to make a potentially long story short, the issue was that the xslt I was trying to import was trying to include a file that didn't exist. Unfortunately, MSXML wasn't very verbose in complaining about the error and the transform was actually happening server-side so I didn't get to see a failed HTTP request in Fiddler.
I originally tried searching for this error but results were sparse at best. That's why I'm adding this to my blog. Hopefully it will be properly indexed by search engines and that one person who ends up having the same problem as I will stumble upon this post and their answer will be solved :) .

Comments

Popular posts from this blog

IE Caches a Lot

Cross post from my employer's development blog: http://rootinc.github.io/2016/03/09/ie-caches/

In developing a page, I decided to do things a bit differently on the server. By doing an explicit check on the HTTP request headers, I can detect server-side if a request to the server is coming via XHR (Ajax) or a standard page load. I can then serve different content based on the request type. So, I can use the same URL for retrieving the initial HTML page and the raw JSON data associated with that page. Express makes this pretty easy:
if (req.xhr){      return res.json(await this.usersData());    }    else {      return res.view('users', await this.usersData());    }
I’m not sure if it’s technically more RESTful than having separate URL routes for data and HTML, but it felt like it made sense. The URL is referring to the same data, and based on a header, I want to determine how it is represented, but the data doesn’t change so why should the URL? This also makes it possible to d…

Quick Deepstream.io Setup Using JSPM

Cross post from my employer's development blog: http://rootinc.github.io/2016/02/12/deepstream-jspm/
Want to use JSPM rather than Bower for running the Deepstream.io example? Follow these steps. This is basically a duplicate of the [Getting Started tutorial][tutorial] on the [Deepstream.io website][website] but using a really simple JSPM setup. This is a very crude guide where I list everything I had to do to get things running.

Create an empty project folder npm install deepstream.io Copy server code verbatim from the Getting Started guide jspm install npm:deepstream.io-client-js Hit enter for all the prompts from JSPM

We’re going to modify the client side code a little bit. We have native support for ES6 compiling with JSPM/Babel so we can import the Deepstream client directly:

import deepstream from 'deepstream.io-client-js'; let ds = deepstream( 'localhost:6020' ).login();

let record = ds.record.getRecord( 'someUser' );

let input = document.querySelector( 'inp…

Atari E3 2004 PAL digital press kit

Making note of some old swag. The Atari E3 2004 PAL digital press kit. See video for details.