Revision history for App::DrivePlayer.

0.2.6 2026-04-20
        - Fix: track auto-advance now handles mpv 'end-file' with
          reason=error (transient network/stream failures), and no
          longer spuriously advances on reason=stop (which fires for
          user-initiated stop and for loadfile-replace pre-emption).
        - Fix: re-playing a track already visible in the list no
          longer re-centres the tracklist viewport.  _highlight_path
          checks get_visible_range first and only scrolls when the
          target row is off-screen.
        - A-Z sidebar strip now follows the selected category:
          operates on Artists / Albums / Genres depending on the
          current sidebar selection, and is disabled (insensitive)
          while All Tracks or a Folders entry is selected.
        - New "YYYY-AlbumName" folder/filename convention: when an
          album (inferred from the folder path) or a filename starts
          with a 19xx/20xx year followed by '-', the prefix is
          stripped from the album/title and the year is written to
          the track's year metadata.  Re-scan to populate existing
          tracks.
        - Tracklist gains a Year column between Genre and Duration.

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.
