[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-7133":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":19,"stars90d":16,"forks30d":16,"starsTrendScore":20,"compositeScore":21,"rankGlobal":10,"rankLanguage":10,"license":22,"archived":23,"fork":23,"defaultBranch":24,"hasWiki":25,"hasPages":23,"topics":26,"createdAt":10,"pushedAt":10,"updatedAt":38,"readmeContent":39,"aiSummary":40,"trendingCount":16,"starSnapshotCount":16,"syncStatus":18,"lastSyncTime":41,"discoverSource":42},7133,"LicensePlist","mono0926\u002FLicensePlist","mono0926","A license list generator of all your dependencies for iOS applications","https:\u002F\u002Fwww.slideshare.net\u002Fmono0926\u002Flicenseplist-a-license-list-generator-of-all-your-dependencies-for-ios-applications",null,"Swift",2526,155,19,39,0,1,2,7,4,28.58,"MIT License",false,"main",true,[27,28,29,30,31,32,33,34,35,36,37],"automation","cli","commandline","ios","license","license-management","licenses","productivity","settings","swift-package-manager","xcode","2026-06-12 02:01:35","\u003Cimg src=\"LicensePlist.png\" width=\"200\" height=\"200\" alt=\"LicensePlist Logo\"> LicensePlist\n======================================\n\n![platforms](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fplatforms-iOS-333333.svg)\n[![GitHub license](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Flicense-MIT-lightgrey.svg)](https:\u002F\u002Fraw.githubusercontent.com\u002Fmono0926\u002FNativePopup\u002Fmaster\u002FLICENSE)\n[![Language: Swift 5.3](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fswift-5.3-4BC51D.svg?style=flat)](https:\u002F\u002Fdeveloper.apple.com\u002Fswift)\n[![Swift Package Manager compatible](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FSwift%20Package%20Manager-compatible-brightgreen.svg)](https:\u002F\u002Fgithub.com\u002Fapple\u002Fswift-package-manager)\n\n[![Lint](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Factions\u002Fworkflows\u002Flint.yml\u002Fbadge.svg)](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Factions\u002Fworkflows\u002Flint.yml)\n[![Test](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Factions\u002Fworkflows\u002Ftest.yml\u002Fbadge.svg)](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Factions\u002Fworkflows\u002Ftest.yml)\n\n`LicensePlist` is a command-line tool that automatically generates a Plist of all your dependencies, including files added manually(specified by [YAML config file](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FTests\u002FLicensePlistTests\u002FResources\u002Flicense_plist.yml)) or using `Carthage` or `CocoaPods`. All these licenses then show up in the Settings app.\n\n![Flow](Screenshots\u002Fflow.png)\n\n![Demo](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FResource\u002Fraw\u002Fmaster\u002FLicensePlist\u002FLicensePlist.gif)\n\n| App Setting Root          | License List              | License Detail              |\n| ------------------------- | ------------------------- | --------------------------- |\n| ![](Screenshots\u002Froot.png) | ![](Screenshots\u002Flist.png) | ![](Screenshots\u002Fdetail.png) |\n\n## Installation\n\n> **Warning**  \n> SPM(Swift Package Manager) are not supported.\n\n### CocoaPods (Recommended)\n\n```\npod 'LicensePlist'\n# Installation path: `${PODS_ROOT}\u002FLicensePlist\u002Flicense-plist`\n```\n\n### Homebrew (Also Recommended)\n\n```sh\nbrew install licenseplist\n```\n\n### Mint (Also Recommended)\n```sh\nmint run mono0926\u002FLicensePlist\n```\n\n### Xcode project - SPM\n\nIn Project Settings, on the tab \"Package Dependencies\", click \"+\" and add `https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist`.\n\nClick \"Add Package\" without selecting any package products.\n\n### Download the executable binary from [Releases](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Freleases)\n\nDownload from [Releases](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Freleases), then copy to `\u002Fusr\u002Flocal\u002Fbin\u002Flicense-plist` etc.\n\nOr you can also download the latest binary and install it with a one-liner.\n\n```sh\ncurl -fsSL https:\u002F\u002Fraw.githubusercontent.com\u002Fmono0926\u002FLicensePlist\u002Fmaster\u002Finstall.sh | sh\n```\n\n### From Source\n\nClone the master branch of the repository, then run `make install`.\n\n```sh\ngit clone https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist.git\nmake install\n```\n\n## Usage\n\n1. When you are in the directory that contains your `Cartfile` or `Pods`, simply execute `license-plist`.\n2. `com.mono0926.LicensePlist.Output` directory will be generated.\n3. Move the files in the output directory into your app's `Settings.bundle`.\n    - [Settings.bundle's sample is here](Settings.bundle.zip)\n    - The point is to [specify `com.mono0926.LicensePlist` as license list file on your `Root.plist`](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FSettings.bundle\u002FRoot.plist#L19).\n\n```\nSettings.bundle\n├── Root.plist\n├── com.mono0926.LicensePlist\n│   ├── APIKit.plist\n│   ├── Alamofire.plist\n│   └── EditDistance.plist\n├── com.mono0926.LicensePlist.plist\n├── en.lproj\n│   └── Root.strings\n└── ja.lproj\n    └── Root.strings\n```\n\n### Options\n\nYou can see options by `license-plist --help`.\n\n#### `--cartfile-path`\n\n- Default: `Cartfile`\n\n#### `--mintfile-path`\n\n- Default: `Mintfile`\n\n#### `--nestfile-path`\n\n- Default: `nestfile.yaml`\n\n#### `--pods-path`\n\n- Default: `Pods`\n\n#### `--package-path`\n\n- Default: `Package.swift`\n- `LicensePlist` tries to find `YourProjectName.xcodeproj\u002Fproject.xcworkspace\u002Fxcshareddata\u002Fswiftpm\u002FPackage.resolved` and `YourProjectName.xcworkspace\u002Fxcshareddata\u002Fswiftpm\u002FPackage.resolved`, then uses new one.\n\n#### `--package-paths`\n\n- Support for multiple `Package.swift`\n- Example: `license-plist --package-paths \u002Fpath\u002Fto\u002Fpackage1\u002FPackage.swift \u002Fpath\u002Fto\u002Fpackage2\u002FPackage.swift`\n\n#### `--package-sources-path`\n\n- Default: None.\n- The directory with cloned Swift package sources. If specified `LicensePlist` uses cloned files instead of GitHub API. For more information, see parameter `-clonedSourcePackagesDirPath` of [xcodebuild](https:\u002F\u002Fdeveloper.apple.com\u002Flibrary\u002Farchive\u002Ftechnotes\u002Ftn2339\u002F_index.html).\n- Example: `license-plist --package-sources-path .\u002FSourcePackages`\n\n#### `--xcodeproj-path`\n\n- Default: `\"*.xcodeproj\"`\n- By specifiying the path to the `.xcodeproj` `LicensePlist` will attempt to load the `Package.resolved` from that Xcode project. If you specify `somedir\u002F*.xcodeproj` then `LicensePlist` will load from the first `xcodeproj` it finds in `somedir`.\n\n#### `--xcworkspace-path`\n\n- Default: `\"*.xcworkspace\"`\n- By specifying the path to the `.xcworkspace` `LicensePlist` will load the `Package.resolved` from that Xcode workspace. If you specify `somedir\u002F*.xcworkspace` then `LicensePlist` will load from the first `xcworkspace` it finds in `somedir`.\n- `--xcworkspace-path` supersedes any provided `--xcodeproj-path`.\n\n#### `--output-path`\n\n- Default: `com.mono0926.LicensePlist.Output`\n- Recommended: `--output-path YOUR_PRODUCT_DIR\u002FSettings.bundle`\n\n#### `--github-token`\n\n- Default: None.\n- LicensePlist uses GitHub API, so sometimes API limit errors occur. You can avoid those errors by specifying a GitHub token.\n- [You can generate a token here](https:\u002F\u002Fgithub.com\u002Fsettings\u002Ftokens\u002Fnew)\n    - `repo` scope is needed.\n- You can also pass the GitHub token via the `LICENSE_PLIST_GITHUB_TOKEN` environment variable.\n\n#### `--config-path`\n\n- Default: `license_plist.yml`\n- You can specify GitHub libraries(introduced by hand) and excluded libraries\n    - [Example is here](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FTests\u002FLicensePlistTests\u002FResources\u002Flicense_plist.yml)\n    - See [Configuration](#Configuration) for more information\n\n#### `--prefix`\n\n- Default: `com.mono0926.LicensePlist`\n- You can specify output file names instead of default one.\n\n#### `--html-path`\n\n- Default: None.\n- If this path is specified, a html acknowledgements file will be generated.\n  - [Example is here](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FAssets\u002Facknowledgements.html)\n\n#### `--markdown-path`\n\n- Default: None.\n- If this path is specified, a markdown acknowledgements file will be generated.\n  - [Example is here](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FAssets\u002Facknowledgements.md)\n\n#### `--csv-path`\n\n- Default: None.\n- If this path is specified, a csv acknowledgements file will be generated.\n  - [Example is here](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FAssets\u002Facknowledgements.csv)\n\n#### `--license-file-names`\n\n- Default: `LICENSE, LICENSE.*`.\n- License file name variants for cloned Swift packages. \n  - Case insensitive. \n  - Supports any non-empty path extensions if `FILENAME.*` is specified.\n  - Used only in combination with `--package-sources-path`.\n\n#### `--force`\n\n- Default: false\n- `LicensePlist` saves latest result summary, so if there are no changes, the program interrupts.\n    - In this case, **execution time is less than 100ms for the most case**, so **you can run `LicensePlist` at `Run Script Phase` every time** 🎉\n- You can run all the way anyway, by using `--force` flag.\n\n#### `--add-version-numbers`\n\n- Default: false\n- When the library name is `SomeLibrary`, by adding `--add-version-numbers` flag, the name will be changed to `SomeLibrary (X.Y.Z)`.\n    - `X.Y.Z` is parsed from CocoaPods and Cartfile information, and GitHub libraries specified at [Config YAML](https:\u002F\u002Fgithub.com\u002Fmono0926\u002FLicensePlist\u002Fblob\u002Fmaster\u002FTests\u002FLicensePlistTests\u002FResources\u002Flicense_plist.yml) also support this flag.\n\n\u003Cimg src=\"Screenshots\u002Flist_version.png\" width=\"320\" height=\"568\" alt=\"License list with versions\">\n\n#### `--add-sources`\n\n- Default: false\n- Adds the source of the library to the output if there is one. The source for GitHub and CocoaPods libraries is generated. Manual libraries use the optional source field.\n\n#### `--suppress-opening-directory`\n\n- Default: false\n- Only when the files are created or updated, the terminal or the finder opens. By adding `--suppress-opening-directory` flag, this behavior is suppressed.\n- Automatically enabled if `--sandbox-mode` is specified.\n\n#### `--single-page`\n\n- Default: false\n- All licenses are listed on a single page, not separated pages.\n\n#### `--fail-if-missing-license`\n\n- Default: false\n- If there is even one package for which a license cannot be found, LicensePlist returns exit code 1.\n\n#### `--silence-mode` \u002F `--verbose`\n\n- By adding the `--silence-mode` flag, the logger's output will not print.\n- The logger's output will be more detailed than the average log level by adding the `--verbose` flag.\n- LicencePlist uses the latter option if you simultaneously set the `--silence-mode` option and the `--verbose` option.\n- Default: average log level\n\n#### `--no-color` \u002F `--color`\n\n- The logger's output is printed in monochrome by adding the `--no-color` flag. If any escape characters in CI\u002FCD log bother you, the `--no-color` option will help.\n- By adding the `--color` flag, LicensePlist will always print the logger's output in color.\n- LicencePlist uses the latter option if you simultaneously set the `--no-color` option and the `--color` option.\n- If neither option is specified, LicensePlist will look for the `NO_COLOR` environment variable. If you set the `NO_COLOR` environment variable to `\"1\"`, LicensePlist runs without colors.\n- Default: auto - LicensePlist decides its color mode depending on the terminal type.\n\n#### `--sandbox-mode` \u002F `--no-sandbox-mode`\n\n- Default: false\n- Enables or disables the \"sandbox\" mode.\n- In the sandbox mode, LicensePlist avoids network requests. That means Swift package licenses can not be fetched with GitHub API. To parse Swift package licenses `--package-sources-path` must be specified.\n\n\n### Integrate into build - run script\n\nAdd a `Run Script Phase` to `Build Phases`:\n\n```sh\nif [ $CONFIGURATION = \"Debug\" ]; then\ncd $SRCROOT\n\u002Fusr\u002Flocal\u002Fbin\u002Flicense-plist --output-path $PRODUCT_NAME\u002FSettings.bundle --github-token YOUR_GITHUB_TOKEN\nfi\n```\n\n![Run Script Phase](Screenshots\u002Frun_script_phase.png)\n\nAlternatively, if you've installed LicensePlist via CocoaPods the script should look like this:\n\n```sh\nif [ $CONFIGURATION = \"Debug\" ]; then\n${PODS_ROOT}\u002FLicensePlist\u002Flicense-plist --output-path $PRODUCT_NAME\u002FSettings.bundle --github-token YOUR_GITHUB_TOKEN\nfi\n```\n\n### Integrate into build - build tool plugin\n\n_LicensePlist build tool plugins requires [Swift package installation](#xcode-project---spm)._\n\n![Choose package plugins](Screenshots\u002Fchoose_plugin.png)\n\nSelect your target, on the tab \"Build Phases\", in the section \"Run Build Tool Plug-ins\", click \"+\" and add `LicensePlistBuildTool`.\n\n![Run build tool plug-ins](Screenshots\u002Frun_build_tool_plugins.png)\n\nIn the case of using the build tool plugin, define all the settings in `license_plist.yml` at the root of your project.\n\n`license_plist.yml` example:\n```yml\noptions:\n  xcworkspacePath: \"*.xcworkspace\"\n  prefix: Acknowledgements\n  singlePage: true\n```\n\n**Important**: to process Swift Package licenses, the config must include one of the following parameters:\n- `xcworkspacePath`,\n- `xcodeprojPath`,\n- `packagePaths`.\n\n_Note: `outputPath` and `packageSourcesPath` config parameters are ignored by the build tool plugin._\n\nSee the [configuration](#configuration) section for more information.\n\nIf you need to put license files to `Settings.bundle` or any other specific place add the following script to build phases:\n```bash\necho \"Will copy acknowledgements\"\nACKNOWLEDGEMENTS_DIR=${BUILT_PRODUCTS_DIR}\u002F${CONTENTS_FOLDER_PATH}\u002Fcom.mono0926.LicensePlist.Output\nDESTINATION_PATH=${BUILT_PRODUCTS_DIR}\u002F${CONTENTS_FOLDER_PATH}\u002FSettings.bundle\u002F\ncp -r \"${ACKNOWLEDGEMENTS_DIR}\"\u002F* \"${DESTINATION_PATH}\"\nrm -rf \"${ACKNOWLEDGEMENTS_DIR}\"\n```\n\nOr in project contextual menu click \"AddAcknowledgementsCopyScriptCommand\" and select application target to create the build phase automatically.\n\n![AddAcknowledgementsCopyScriptCommand](Screenshots\u002Fcopy_script_command.png)\n\nBuild the app. At the first run, Xcode asks a permission to run the plugin. Click \"Trust & Enable All\"\n\n![Trust & Enable All](Screenshots\u002Ftrust_and_enable.png)\n\nFor unattended use (e.g. on CI), you can disable the package validation dialog by\n\n* individually passing `-skipPackagePluginValidation` to `xcodebuild` or\n* globally setting `defaults write com.apple.dt.Xcode IDESkipPackagePluginFingerprintValidatation -bool YES` \n  for that user.\n\n_Note: This implicitly trusts all Xcode package plugins and bypasses Xcode's package validation\n       dialogs, which has security implications._\n\n### Contextual menu command\n\n_LicensePlist command requires [Swift package installation](#xcode-project---spm)._\n\nIn the project contextual menu click \"GenerateAcknowledgementsCommand\".\n\n![Generate Acknowledgements menu command in Xcode](Screenshots\u002Fgenerate_acknowledgements_menu.png)\n\nThe command dialog allows to specify [command line arguments](#options). Since Xcode doesn't save the arguments for future use, it's recommended to use a [configuration file](#configuration).\n\nClick \"Run\" to run LicensePlist.\n\n![Generate Acknowledgements command dialog in Xcode](Screenshots\u002Fgenerate_acknowledgements_command.png)\n\nClick \"Allow Command to Change files\". This action provides LicensePlist write access to your project directory.\n\n\"Don't ask again\" option prevents showing this dialog in the future.\n\n![Allow command to change files dialog in Xcode](Screenshots\u002Fallow_command_to_change_files.png)\n\n_Note: `--package-sources-path` option and `packageSourcesPath` config parameter are ignored by the command plugin._\n\n## Configuration\n\n### General options\n\nThe main parameters from the [Options](#Options) can be defined in the configuration file.\n\nAll the parameters are optional.\n\nThe tool uses the command line value if both the command line and the config specify values for the same attribute.\n\n#### Example\n\n```yml\noptions:\n  outputPath: \".\u002Fcom.mono0926.LicensePlist.Output\"\n  cartfilePath: Cartfile\n  mintfilePath: Mintfile\n  nestfilePath: nestfile.yaml\n  podsPath: Pods\n  packagePaths:\n    - Package.swift\n  packageSourcesPath: \".\u002FSourcePackages\"\n  xcodeprojPath: \"*.xcodeproj\"\n  xcworkspacePath: \"*.xcworkspace\"\n  prefix: com.mono0926.LicensePlist\n  gitHubToken: YOUR_GITHUB_TOKEN\n  htmlPath: acknowledgements.html\n  markdownPath: acknowledgements.md\n  licenseFileNames:\n    - LICENSE\n    - LICENSE.*\n  force: false\n  addVersionNumbers: false\n  suppressOpeningDirectory: false\n  singlePage: false\n  failIfMissingLicense: false\n  addSources: false\n  sandboxMode: false\n```\n\n### Manual GitHub source\n\nA GitHub source can be explicitly defined to include the license in the scenario where it can't be inferred from your dependency files.\n\n#### Examples\n\n```yml\ngithub:\n  - owner: mono0926\n    name: LicensePlist\n    version: 1.2.0\n```\n\n### Manual License Body\n\nIf you need to include a license that isn't available on GitHub, you can place the license text in the config file to be included in the output.\nThe license text can also be read from a local file, to keep the config file clean.\n\n#### Examples\n\nLicense body directly in the config file:\n\n```yml\nmanual:\n  - source: https:\u002F\u002Fwebrtc.googlesource.com\u002Fsrc\n    name: WebRTC\n    version: M61\n    body: |-\n      Copyright (c) 2011, The WebRTC project authors. All rights reserved.\n      ...\n      ...\n      ...\n```\n\nLicense body in local file:\n\n```yml\nmanual:\n  - name: \"Dummy License File\"\n    file: \"dummy_license.txt\"\n```\n\n### Excludes\n\nExcludes can be defined to exclude matching libraries from the final output.\nAn exclude is a dictionary containing any combination of `name`, `source`, `owner`, or `licenseType`.\n\nWhen using the dictionary format:\n\n- The exclusion rule is only applied if _all_ properties match for a dependency. eg, `(name: LicensePlist) AND (owner: mono0926)`\n- Any property can be either a string or a regular expression. \n\n#### Examples\n\nExclude a package by name:\n\n```yml\nexclude:\n  - name: LicensePlist\n```\n\nExclude packages using a specific license:\n\n```yml\nexclude:\n  - licenseType: \"Apache 2.0\"\n```\n\nExclude packages using any matching licenses:\n\n```yml\nexclude:\n  - licenseType: \u002FBSD\u002F\n```\n\nExclude packages from a specific github owner:\n\n```yml\nexclude:\n  - owner: mycompany\n```\n\nExclude packages from a specific github owner containing matching licenses:\n\n```yml\nexclude:\n  - owner: mycompany\n    licenseType: \u002F^(?!.*MIT).*$\u002F # this regex excludes packages that do NOT use the MIT license\n``` \n\nExclude a package from a specific github owner and repo:\n\n```yml\nexclude:\n  - owner: mycompany\n    name: private-repo\n```\n\n### Rename\n\nIf a library name is unsuitable for the output bundle, you can explicitly rename it. This can be used when a library name is too vague, or if more human-readable names are needed.\n\n#### Examples\n\n```yml\nrename:\n  LicensePlist: License Plist # Rename LicensePlist to \"License Plist\"\n  WebRTC: Web RTC # Rename WebRTC to \"Web RTC\" (which is faulty, but used for test)\n```\n\n## Q&A\n\n### How to generate Xcode project?\n\nExecute `swift package generate-xcodeproj` or `make xcode`.\n\n---\n\n## Related Articles\n\n- [LicensePlist というiOSアプリ利用ライブラリのライセンス一覧生成するツールを作りました – Swift・iOSコラム – Medium](https:\u002F\u002Fmedium.com\u002Fswift-column\u002Flicense-plist-c0363a008c67)\n- [Swift Package Manager(SwiftPM)で作ったコマンドラインツールをHomebrewに登録する方法 - Qiita](http:\u002F\u002Fqiita.com\u002Fmono0926\u002Fitems\u002Fc32c008384df40bf4e41)\n\n\n---\n\n## Stargazers over time\n\n[![Stargazers over time](https:\u002F\u002Fstarcharts.herokuapp.com\u002Fmono0926\u002FLicensePlist.svg)](https:\u002F\u002Fstarcharts.herokuapp.com\u002Fmono0926\u002FLicensePlist)\n\n---\n\n## 寄付(Donation)\n\nDonations are welcome if you like LicensePlist🤗\n\n- [PayPal.Me](https:\u002F\u002Fwww.paypal.me\u002Fmono0926)\n  - Transfer commission will be charged (40 yen + 3.6%)\n- [mono is creating LicensePlist | Patreon](https:\u002F\u002Fwww.patreon.com\u002Flicenseplist)\n- [Amazonギフト券- Eメールタイプ](https:\u002F\u002Fwww.amazon.co.jp\u002Fexec\u002Fobidos\u002FASIN\u002FB004N3APGO\u002Fmono0926-22\u002F)\n  - メールアドレス: mono0926@gmail.com\n- [ほしい物リスト](https:\u002F\u002Fwww.amazon.co.jp\u002Fgp\u002Fregistry\u002Fwishlist\u002F3P51MRDW2WBN6\u002Fref=nav_wishlist_lists_1)\n\n\n### Send Money by [ウォレットアプリ Kyash](https:\u002F\u002Fkyash.co\u002F)\n\n![Kyash](Screenshots\u002Fkyash.jpeg)\n","LicensePlist 是一个用于 iOS 应用程序依赖项许可证列表生成器的命令行工具。它能够自动收集项目中通过 Carthage 或 CocoaPods 管理的所有第三方库的许可证信息，并支持手动添加的文件（通过 YAML 配置文件指定）。该工具使用 Swift 语言编写，具有与 Xcode 和主流包管理器的良好集成性。生成的 Plist 文件可以直接在 iOS 设置应用中展示所有依赖项的许可证详情。适用于需要遵守开源软件许可协议、提高开发效率以及希望透明化其应用程序所使用组件版权信息的 iOS 开发场景。","2026-06-11 03:10:41","top_language"]