[ 
https://issues.apache.org/jira/browse/FELIX-3844?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Richard S. Hall resolved FELIX-3844.
------------------------------------

    Resolution: Fixed
      Assignee: Richard S. Hall

I really think we should move our OS aliases to configuration properties, but I 
don't have time to do that right now so I am applying this patch (i'll open an 
issue for future work). Please close if you are satisfied. Thanks.
                
> Native bundles cannot be installed on Windows 8 and Windows Server 2012
> -----------------------------------------------------------------------
>
>                 Key: FELIX-3844
>                 URL: https://issues.apache.org/jira/browse/FELIX-3844
>             Project: Felix
>          Issue Type: Bug
>          Components: Framework
>    Affects Versions: framework-4.0.3
>            Reporter: Nicolas Roduit
>            Assignee: Richard S. Hall
>              Labels: patch
>             Fix For: framework-4.2.0
>
>
> "osname=win32" in the Bundle-NativeCode entry doe not work, this exception is 
> thrown:org.osgi.framework.BundleException: Unresolved constraint in bundle 
> native-lib-windows-x86 [6]: No matching native libraries found.
> This osname alias needs to be added to the felix framework. I made some 
> changes according to the OSGI specifications at 
> http://www.osgi.org/Specifications/Reference .
> Here is the patch:
> Index: 
> src/main/java/org/apache/felix/framework/util/manifestparser/R4LibraryClause.java
> ===================================================================
> --- 
> src/main/java/org/apache/felix/framework/util/manifestparser/R4LibraryClause.java
>  (revision 1431008)
> +++ 
> src/main/java/org/apache/felix/framework/util/manifestparser/R4LibraryClause.java
>  (working copy)
> @@ -140,11 +140,13 @@
>              || currentOSName.equals("windowsnt")
>              || currentOSName.equals("windows2000")
>              || currentOSName.equals("windows2003")
> -            || currentOSName.equals("windows2008")
> +            || currentOSName.equals("windowsserver2008")
>              || currentOSName.equals("windowsxp")
>              || currentOSName.equals("windowsce")
>              || currentOSName.equals("windowsvista")
> -            || currentOSName.equals("windows7"));
> +            || currentOSName.equals("windows7")
> +            || currentOSName.equals("windows8")
> +            || currentOSName.equals("windowsserver2012"));
>  
>          for (int i = 0; (osnames != null) && (i < osnames.length); i++)
>          {
> @@ -381,7 +383,11 @@
>              }
>              else if (value.indexOf("2008") >= 0)
>              {
> -                os = "windows2008";
> +                os = "windowsserver2008";
> +            }
> +            else if (value.indexOf("2012") >= 0)
> +            {
> +                os = "windowsserver2012";
>              }
>              else if (value.indexOf("xp") >= 0)
>              {
> @@ -396,10 +402,15 @@
>                  os = "windowsvista";
>              }
>              // will need better test here if any future Windows version has 
> a 7 in it!
> -            else if (value.indexOf("7") >= 0)
> +            else if (value.indexOf(" 7") >= 0 || value.equals("win7"))
>              {
>                  os = "windows7";
>              }
> +            else if (value.indexOf(" 8") >= 0 || value.equals("win8"))
> +            {
> +                os = "windows8";
> +            }
> +
>              return os;
>          }
>          else if (value.startsWith("linux"))

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to