Skip to content

Commit

Permalink
#106 New method, getIncludeUrl(), that allows you to retrieve the com…
Browse files Browse the repository at this point in the history
…piled URL of a given resource

[skip ci]
  • Loading branch information
DominicWatson committed May 19, 2014
1 parent 241c568 commit f7819e7
Show file tree
Hide file tree
Showing 3 changed files with 74 additions and 1 deletion.
35 changes: 34 additions & 1 deletion org/cfstatic/CfStatic.cfc
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,33 @@
</cfscript>
</cffunction>

<cffunction name="getIncludeUrl" access="public" returntype="string" output="false" hint="I am the getIncludeUrl() method. I return the URL of the compiled asset for the given path.">
<cfargument name="type" type="string" required="true" hint="Either 'js' or 'css'. the type of include for which to fetch the URL." />
<cfargument name="resource" type="string" required="true" hint="A url path, relative to the base static url, specifiying a static file or entire static package. e.g. '/css/core/layout.css' to include a single file, or '/css/core/' to include all files in the core css package." />
<cfargument name="throwOnMissing" type="boolean" required="false" default="#_getThrowOnMissingInclude()#" hint="If set to true and the resource does not exist, an informative error will be thrown. Defaults to false (no error will be thrown)" />
<cfargument name="debugMode" type="boolean" required="false" default="#_isDebugOnForRequest()#" hint="Whether or not to render the source files (as opposed to the compiled files). You should use the debug url parameter (see cfstatic config options) rather than manually setting this argument, but it is included here should you need it." />

<cfscript>
var include = _appendFileTypesToSpecialIncludes( resource );

if ( arguments.throwOnMissing and not _resourceExists( arguments.resource ) ) {
$throw( type="cfstatic.missing.include", message="CfStatic include() error: The requested include, [#arguments.resource#], does not exist." );
}

renderCache = _getRenderedIncludeCache( type, debugMode )._urls;

if ( StructKeyExists( renderCache, resource ) ) {
return renderCache[ resource ];
}

if ( throwOnMissing ) {
$throw( type="cfstatic.missing.include", message="CfStatic getIncludeUrl() error: The requested include, [#arguments.resource#], does not exist." );
}

return "";
</cfscript>
</cffunction>

<!--- private methods --->
<cffunction name="_setProperties" access="private" returntype="void" output="false">
<cfargument name="staticDirectory" type="string" required="true" hint="Full path to the directoy in which static files reside" />
Expand Down Expand Up @@ -986,6 +1013,11 @@
_renderedIncludeCache.css['_ordered'] = ArrayNew(1);
_renderedIncludeCache.debug.js['_ordered'] = ArrayNew(1);
_renderedIncludeCache.debug.css['_ordered'] = ArrayNew(1);

_renderedIncludeCache.js['_urls'] = StructNew();
_renderedIncludeCache.css['_urls'] = StructNew();
_renderedIncludeCache.debug.js['_urls'] = StructNew();
_renderedIncludeCache.debug.css['_urls'] = StructNew();
</cfscript>
</cffunction>

Expand All @@ -1003,8 +1035,9 @@
node = _renderedIncludeCache[ type ];
}

ArrayAppend( node['_ordered'], rendered );
ArrayAppend( node[ '_ordered' ], rendered );
node[ path ] = ArrayLen( node['_ordered'] );
node[ '_urls' ][ path ] = $extractUrlFromRenderedInclude( rendered );
</cfscript>
</cffunction>

Expand Down
15 changes: 15 additions & 0 deletions org/cfstatic/util/Base.cfc
Original file line number Diff line number Diff line change
Expand Up @@ -182,6 +182,21 @@
<cfreturn $renderIeConditional( '<script type="text/javascript" src="#src#"></script>', ieConditional ) & $newline() />
</cffunction>

<cffunction name="$extractUrlFromRenderedInclude" access="private" returntype="string" output="false">
<cfargument name="renderedInclude" type="string" required="true" />

<cfscript>
var regex = '^.*?(href|src)="(.*?)".*$';
var replaced = ReReplaceNoCase( renderedInclude, regex, "\2" );

if ( replaced == renderedInclude ) {
return "";
}

return replaced;
</cfscript>
</cffunction>

<cffunction name="$generateCacheBuster" access="private" returntype="string" output="false" hint="I return a cachebuster string for a given date">
<cfargument name="dateLastModified" type="date" required="false" default="#Now()#" />

Expand Down
25 changes: 25 additions & 0 deletions tests/integration/org/cfstatic/CfStaticTest.cfc
Original file line number Diff line number Diff line change
Expand Up @@ -1064,6 +1064,26 @@
</cfscript>
</cffunction>

<cffunction name="t43_getIncludeUrl_shouldReturnUrlOfSpecifiedAsset" returntype="void">
<cfscript>
var expected = "/mystaticurl/min/someFolder.min.css";
var actual = "";

rootDir &= 'goodFiles/standardFolders/';

cfstatic.init(
staticDirectory = rootDir
, staticUrl = "/mystaticurl"
, debugKey = "doNotLetMxUnitDebugScrewTests"
);

actual = cfstatic.getIncludeUrl( "css", "/someFolder/" );
actual = _removeCheckSumFromFileNames( actual );

super.assertEquals( expected, actual );
</cfscript>
</cffunction>

<!--- private helpers --->
<cffunction name="_getResourcePath" access="private" returntype="string" output="false">
<cfreturn '/tests/integration/resources/' />
Expand Down Expand Up @@ -1099,6 +1119,11 @@
</cfif>
</cfloop>
</cfif>

<!--- state cache file --->
<cfif FileExists( rootDir & "/.cfstaticstatecache" )>
<cffile action="delete" file="#rootDir#/.cfstaticstatecache" />
</cfif>
</cffunction>

<cffunction name="_assertFoldersAreEqual" access="private" returntype="void" output="false">
Expand Down

0 comments on commit f7819e7

Please sign in to comment.