Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/foxglove/mcapspotlightimporter
macOS Spotlight Importer for MCAP files
https://github.com/foxglove/mcapspotlightimporter
macos mcap mdimporter spotlight swift
Last synced: 2 months ago
JSON representation
macOS Spotlight Importer for MCAP files
- Host: GitHub
- URL: https://github.com/foxglove/mcapspotlightimporter
- Owner: foxglove
- License: mit
- Created: 2022-11-02T04:15:37.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-13T21:57:49.000Z (10 months ago)
- Last Synced: 2024-05-01T19:12:59.983Z (9 months ago)
- Topics: macos, mcap, mdimporter, spotlight, swift
- Language: Swift
- Homepage: https://foxglove.dev/blog/implementing-a-macos-search-plugin-for-robotics-data
- Size: 43.9 KB
- Stars: 6
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MCAPSpotlightImporter
MCAPSpotlightImporter is a macOS [Spotlight Importer](https://developer.apple.com/library/archive/documentation/Carbon/Conceptual/MDImporters/Concepts/WritingAnImp.html) for [MCAP](https://mcap.dev/) files. The importer gives Spotlight the ability to index MCAP files so the names of their topics, schemas, attachments, and metadata are visible and searchable in Finder and anywhere else that Spotlight is used.
This importer is included with the [Foxglove](https://foxglove.dev/) desktop app for macOS.
## Development
### Releasing a new version
1. Update version numbers in [Config.xcconfig](./MCAPSpotlightImporter/Config.xcconfig).
1. Create a corresponding version tag, e.g. `v1.2.3`, and push the tag to GitHub. CI will automatically build and create a [draft release](https://github.com/foxglove/MCAPSpotlightImporter/releases) with the build products attached as release assets.
1. Manually edit the release notes and publish the release.
### Local testing
You can make a local build using Xcode, or by running `make build`. When using `make build`, the output is placed in `./build/Release`.
- To test the .mdimporter locally, copy it to ~/Library/Spotlight.
- After each rebuild of the importer, once it has been copied to ~/Library/Spotlight, sometimes it is necessary to kill Spotlight-related processes, to ensure a cached version of the importer is not being used: `sudo killall mds mdworker mdworker_shared corespotlightd mdbulkimport`. `/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/Support/lsregister -kill` may also help.
- Run `mdimport -L` to see whether the importer plugin has been loaded. Sometimes the output of this command does not update immediately.
- Run `mdimport -d2 -t path/to/file.mcap` to run the importer on a file. The first line of output indicates whether the importer was actually used by saying `Imported '...' of type '...' with plugIn '...'`. If it instead says `with no plugIn`, the importer was not correctly loaded. Imported attributes will be displayed as part of the output.
- To enable debug logging, run `sudo log config --subsystem dev.foxglove.studio.mcap-mdimporter --mode level:debug`.
- To view logs from the importer, run `log stream --level debug --predicate 'subsystem = "dev.foxglove.studio.mcap-mdimporter"'`.
See also: [Troubleshooting Spotlight Importers](https://developer.apple.com/library/archive/documentation/Carbon/Conceptual/MDImporters/Concepts/Troubleshooting.html#//apple_ref/doc/uid/TP40001690-CJBEJBHH)