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

Calls to CombresLink are case sensitive - could this be changed? #48

Open
peterlukerow opened this issue Aug 25, 2017 · 2 comments
Open

Comments

@peterlukerow
Copy link

peterlukerow commented Aug 25, 2017

In my MVC project I have dynamic call like this in my Razor view:
@(Html.CombresLink("publicCss" + Model.PublicSkinName))

The string passed in might resolve to "publicCssFubar", for example.
If however the resource name in my Combres.xml config is called "publicCssFuBar" - notice the capitial B - then the example of "publicCssFubar" will fail with the exception of "Resource set 'publicCssFubar' cannot be found" in Combres.WebExtensions.GetResourceSet(string setName) +65"

Could it be changed to be case insensitive?

I'm using the nuGet package which says I'm on v2.2.2.5 of combres.mvc. I checked the version history since that release and there doesn't appear to be any indication of this being changed.

@buunguyen
Copy link
Owner

It is possible to change but it will be breaking change (because people might be relying on case sensitivity) and I'm not sure it's worth it. Isn't it possible to change your combres config or the variable?

@peterlukerow
Copy link
Author

peterlukerow commented Aug 29, 2017

The problem for me is that my project is sold as a product and installed multiple times on different hosts and thus is configured by multiple different people and not under my control. When it breaks it just causes an exception in my product that results in a call to my colleagues who deal with support who then need to check the logs.

It would seem someone would have to be a bit masochistic to need/want to define 2 resource sets with the same name that differ only by case given that there is no compiler checking in this scenario, however I understand the desire not to want to introduce any compatibility issues.

How about adding a nameSensitivity attribute to <resourceSets> which has a default of true? This would then maintain the existing functionality but when set to false would treat name attributes as case insensitive?

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

2 participants