|  |  |  |  | 
Search filtering on the name is done in the backend for efficiency reasons. This can be added into the compiled backend if this is not possible in any new backend design.
Filter options are:
| Option | Description | 
|---|---|
| installedor~installed | If the package is currently installed.
              Packages returned with the ~installedfilter set
              are available in remote software sources. | 
| develor~devel | Development packages are typically not required for normal operation and typically have the suffixes -devel, -dgb and -static. | 
| guior~gui | GUI programs typically depend on gtk, libkde or libxfce. | 
| applicationor~application | Packages that provide desktop files and are probably applications. | 
| freeor~free | Free software. The package contains only software and other content that is available under a free license. See the Fedora wiki for a list of licenses that are considered free. If a license cannot be determined from the package metadata, or the status of the license is not known, the package will be marked as 'non-free'. | 
| visibleor~visible | Repositories may want to specify if a package should be visible in an application chooser. This is only really useful for embedded environments where the package list is manually chosen. | 
| supportedor~supported | If the package is supported by the distribution or retailer or is a unsupported third party package. | 
| basenameor~basename | The basename filter will only return results according to the
              package basename.
              This is useful if you are searching for pm-utils and you only
              want to show the main pm-utils package, not any of the -develor-debuginfoor-commonsuffixes in the UI.
              The basename is normally the original name of the source package. | 
| newestor~newest | 
                The newest filter will only return the newest package available.
                This is useful if you are searching for  
                NOTE:
                The  | 
| archor~arch | The arch filter will only return the packages that match the exact architecture of the system, for instance only showing x86_64 packages on a AMD Turion 64. This would mean that x86_64 packages could be filtered from non-native 32-bit packages. This allows the used to choose non-native packages if a multi-lib policy is allowed. | 
| sourceor~source | The source filter will only return source packages. These are typically useful when rebuilding other packages. | 
So valid options would be:
| Option | Description | 
|---|---|
| none | All packages installed or available with no filtering | 
| devel;~installed | All non-installed development packages | 
| installed;~devel | All installed non-development packages | 
| gui;~installed;~devel | All non-installed, non-devel gui programs | 
        When outputting a list of packages, it's important to remove the available
        package if the same version is installed.
        This is required, as the user may do SearchName("kernel",filter="none")
        and only want to return results that can be operated on.
        For instance, suppose we have installed:
      
| kernel-2.6.29.4-167 (installed) | 
| kernel-2.6.29.5-191 (installed) | 
And in the remote software sources we have:
| kernel-2.6.29.4-167 (fedora) | 
| kernel-2.6.29.5-191 (fedora-updates) | 
| kernel-2.6.30.1-203 (fedora-updates) | 
        If we do Resolve("kernel",filter="none") we should expect:
      
| kernel-2.6.29.4-167 (installed) | 
| kernel-2.6.29.5-191 (installed) | 
| kernel-2.6.30.1-203 (fedora-updates) | 
        If the kernel-2.6.29.4-167 (fedora) result was returned,
        this will be in the list of results, and is a valid install target.
        The user will get very confused why 2.6.29.4-167 is both
        installed and not installed.
      
Suppose we have installed:
| kernel-2.6.29.4-167 (installed) | 
| kernel-2.6.29.5-191 (installed) | 
In the remote software sources we have:
| kernel-2.6.29.4-167 (fedora) | 
| kernel-2.6.29.5-191 (fedora-updates) | 
| kernel-2.6.30.1-203 (fedora-updates) | 
        If we do Resolve("kernel",filter="none") we should expect:
      
| kernel-2.6.29.4-167 (installed) | 
| kernel-2.6.29.5-191 (installed) | 
| kernel-2.6.30.1-203 (fedora-updates) | 
        If we do Resolve("kernel",filter="installed") we should expect:
      
| kernel-2.6.29.4-167 (installed) | 
| kernel-2.6.29.5-191 (installed) | 
        If we do Resolve("kernel",filter="~installed") we should expect:
      
| kernel-2.6.30.1-203 (fedora-updates) | 
        If we do Resolve("kernel",filter="newest;installed") we should expect:
      
| kernel-2.6.29.5-191 (installed) | 
        If we do Resolve("kernel",filter="newest") we should expect:
      
| kernel-2.6.29.5-191 (installed) | 
| kernel-2.6.30.1-203 (fedora-updates) |