Revision history for App::DrivePlayer.

0.2.5 2026-04-18
        - Unified sheet sync: Library -> Sync now does a single
          bidirectional reconcile after the Drive scan.  Rules: both
          sides have a value -> DB wins; one side blank -> filled from
          the other; drive_id only in DB -> added to sheet; drive_id
          only on sheet -> Drive is queried and the track is either
          added to the DB (exists) or removed from the sheet (gone).
          Drive API errors during the existence check preserve the row
          on both sides -- sync never destroys data on an API error.
        - Removed the separate File -> Sync from Sheet / Sync to Sheet
          menu items.  Auto-push after metadata edits/fetches is kept
          as a targeted merge-push, since running a full two-way sync
          after every field edit would be wasteful.
        - Fix: clicking a track in the list no longer auto-scrolls the
          viewport between the two clicks of a double-click, which
          could cause a different track to end up under the cursor and
          be played instead of the one clicked.  The tracklist now
          handles left-clicks manually so GTK's set_cursor auto-scroll
          never fires on click.

0.2.4 2026-04-17
        - Sheet push is now a merge instead of a full replace: local
          non-blank values overwrite the sheet, local blanks preserve
          existing sheet values, and drive_ids only present on the sheet
          are kept intact.  Prevents a device with partially-populated
          metadata from wiping data pushed from another device.
        - No longer auto-fetches metadata on startup.  If another device
          has already populated metadata and synced it to the sheet, a
          new device doesn't need to refetch.  Use Library → Fetch All
          Metadata to trigger a fetch manually.
        - Dropped the Composer field entirely (sheet, edit-metadata
          dialog, metadata-fetch pipeline, and DB schema).  The only
          source was embedded FLAC tags, which in practice populated
          almost no tracks, so it was carrying no value.  Existing
          databases have the column dropped on first run (SQLite >= 3.35).

0.2.3 2026-04-17
        - Edit Metadata dialog now auto-syncs to the Google Sheet after save,
          so manual edits (e.g. fixing a genre) propagate to other devices
          without waiting for the next Library → Sync.

0.2.2 2026-04-16
        - Fix duration_ms and genre not propagating to new devices on sheet
          pull: duration_ms was overwritten by Drive scans (moved to metadata
          fields) and was absent from skeleton-track creation.

0.2.1 2026-04-16
        - Fix window height: replace alpha-strip button VBox with TreeView so
          the sidebar ScrolledWindow can properly constrain minimum height,
          allowing the main window to be resized smaller.
        - Alpha strip width increased to 32px to avoid scrollbar overlap.

0.2.0 2026-04-15
        - GUI refactored into Moo roles (MetadataFetch, SheetSync, FolderBrowse).
        - Background metadata fetch via fork+pipe; UI remains responsive.
        - Live track-row updates in the list view as metadata arrives.
        - Retry Incomplete Metadata: re-fetches only tracks missing key fields.
        - FLAC embedded tag reading via Audio::FLAC::Header (optional).
        - MusicBrainz genre support (curated genres preferred over folksonomy tags).
        - Genre lookup now falls back through release → release-group levels.
        - Title cleaning now strips leading track numbers from underscore filenames.
        - Duration captured from mpv playback and persisted to DB and sheet.
        - Config supports google_restapi key introduced in Google::RestApi 2.2.1.
        - Track lookup fixed after column sort (was using stale position index).
        - Column widths set to sensible defaults on initial load.
        - Log4perl appenders set to UTF-8 to suppress wide-character warnings.
        - Library → Refresh menu item added.
        - Stop button hidden when playback is idle.
        - Folder-scoped metadata fetch via sidebar right-click.

0.1.0 2026-04-12
        - Initial release.
        - GTK3 music player for Google Drive with SQLite local library.
        - Google Sheets sync for cross-device metadata portability.
        - AcoustID / iTunes / MusicBrainz metadata fetching.
        - Incremental folder sync with large-deletion confirmation.
