---
title: "url(for:asLocalizedFor:)"
framework: backgroundassets
role: symbol
role_heading: Instance Method
path: "backgroundassets/assetpackmanager/url(for:aslocalizedfor:)"
---

# url(for:asLocalizedFor:)

Returns a URL for the specified relative path.

## Declaration

```swift
nonisolated func url(for path: FilePath, asLocalizedFor language: Locale.Language) throws -> URL
```

## Parameters

- `path`: The relative path.
- `language`: The language that the framework uses to limit the search within localized asset packs.

## Mentioned in

Reducing download and storage demands with localized asset packs

## Return Value

Return Value The URL to the item.

## Discussion

Discussion warning: Don’t persist the returned URL beyond the lifetime of the current process. note: This method will return a well formed URL even if no item exists at the specified relative path in any relevant asset pack, in which case any attempts to get its contents—whether it’s a file or a directory—will fail. All asset packs share the same namespace, so you can treat the overall collection of downloaded asset packs as if it were a single root directory that contains all of your subdirectories and asset files, regardless of the specific asset pack in which any particular file resides. Unlike contents(at:asLocalizedFor:options:) and descriptor(for:asLocalizedFor:), this method supports retrieving entire directories—including packages—in which case it merges the corresponding slices of the shared logical directory from all downloaded asset packs that are localized in the specified language and that contain such slices. If there’s a path collision across multiple such asset packs, then it’s undefined from which asset pack an individual file will be resolved. warning: This method is less efficient than contents(at:asLocalizedFor:options:) and descriptor(for:asLocalizedFor:); use those methods when possible. In particular, this method shouldn’t be used to get the URL to the root of the shared asset-pack namespace. Don’t use this method to block the main thread. This method is most useful if you intentionally induce a file-path collision across multiple differently localized asset packs. For example, you may include an English-localized version of Videos/Introduction.m4v in an en asset pack, a Hebrew-localized version of Videos/Introduction.m4v in a he asset pack, and an American Spanish–localized version of Videos/Introduction.m4v in an es-US asset pack. If you offer split-language functionality to users, then you may want to download two or more of those asset packs on the same device. In that scenario, the specific choice of item the URL to which url(for:) returns would be undefined. With this method, merely passing a Locale.Language instance to the language parameter is sufficient to resolve the ambiguity. url(for:) is more suitable in most other situations. note: Language matching considers implicit script and region tags per Unicode’s Common Locale Data Repository. For example, en is equivalent to en-US and en-Latn-US but not en-CA. note: When the path isn’t relative or when some other error occurs while finding the requested item.

## See Also

### Accessing asset contents

- [contents(at:searchingInAssetPackWithID:options:)](backgroundassets/assetpackmanager/contents(at:searchinginassetpackwithid:options:).md)
- [contents(at:asLocalizedFor:options:)](backgroundassets/assetpackmanager/contents(at:aslocalizedfor:options:).md)
- [descriptor(for:searchingInAssetPackWithID:)](backgroundassets/assetpackmanager/descriptor(for:searchinginassetpackwithid:).md)
- [descriptor(for:asLocalizedFor:)](backgroundassets/assetpackmanager/descriptor(for:aslocalizedfor:).md)
- [url(for:)](backgroundassets/assetpackmanager/url(for:).md)
