Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create one hash per "group" of assets (eg. for Retina/hidpi pairs) #15

Open
steveluscher opened this issue Sep 23, 2013 · 5 comments
Open

Comments

@steveluscher
Copy link

There's a technique in the wild where you can use an in-browser HTML preprocessor to replace instances of "foo.png" with "foo@2x.png" depending on the client's display resolution. It's pretty awesome. It works like this (just imagine a string replacement on src rather than whatever's going on in that example).

Of course, asset hashing breaks this. There's no replacement I can perform on 3d15f.foo.png to end up with 5a1f6.foo@2x.png.

What's your opinion of a feature that would allow you to hash assets as a group? I would love it if grunt-rev would allow me to specify that files matching the pattern *.png and *@2x.png belong to a group of files that should all share the same hash.

Thoughts?

@harperrg
Copy link

I agree on this one, would love to see a solution for it.

@farneman
Copy link

farneman commented Feb 6, 2014

I'd like to see this feature to. In my case I'm using svgeezy to replace svg image with a png in browsers that don't support svg (IE8, etc). svgeezy works by looking up the svg filename/path and then looking for a file with the same path/name but a png extension. It would be great to be able tos et some sort of group or matching option to give the svg and png versions of a file the same hash.

@mblarsen
Copy link

mblarsen commented Mar 4, 2014

I've made a pull-request that implements this feature. https://github.com/TinyCarrier/grunt-rev

You can use like this (package.json):

"devDependencies": {
  "grunt": "~0.4.2",
  "grunt-rev": "https://github.com/TinyCarrier/grunt-rev/tarball/7c763020e311cf68ec69961b22cae4ec2f9fa3c4"
}

Here is an example usage for the alt-feature:

...
rev: {
  options: {
    alt: {
      pattern: 'tmp/*@2x.{jpg,gif,png,webp}',
      identifier: '@2x'
    }
  },
  src: ['tmp/*.png']
},
...

This produces a reved file any files identified by '@2x' will get the same hash prefix. For example:

Open-Source-Logo.png
Open-Source-Logo@2x.png

... becomes:

3d0793d5.Open-Source-Logo.png
3d0793d5.Open-Source-Logo@2x.png

... despite they are different images with different hashes.

You can specify alt as an object or an array of objects.

@steveluscher
Copy link
Author

Moving my comments to the pull request! #21

@mblarsen
Copy link

mblarsen commented Mar 9, 2014

Check #21 which implements this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants