#!/usr/bin/env bash

# Copyright © 2012-2026 ScriptFanix
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License.

# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.

# A copy of the GNU General Public License v3 is includded in the LICENSE file
# at the root of the project.

upgradedatabase_5_6() {
	echo "Upgrading database to version 6... (backup is $database.bak_v5)"
	cp "$database" "$database.bak_v5"
	echo '
		ALTER TABLE tags ADD COLUMN replaygain_alb TEXT;
		ALTER TABLE tags ADD COLUMN replaygain_trk TEXT;
		-- Recreate trigger to also watch the new ReplayGain columns
		DROP TRIGGER force_destination_update_on_tag_update;
		CREATE TRIGGER IF NOT EXISTS force_destination_update_on_tag_update
		AFTER UPDATE OF
			genre,
			albumartist,
			year,
			album,
			disc,
			artist,
			track,
			title,
			composer,
			performer,
			releasecountry,
			replaygain_alb,
			replaygain_trk,
			rate,
			channels,
			bitrate,
			depth
		ON tags
		BEGIN
			UPDATE destination_files SET last_change=0
			WHERE source_file_id=old.source_file;
		END;
	' >&3

	Update atom version 6 <<<"1 = 1"
}
