2025-04-07 15:12:12 -04:00
|
|
|
import { Comparer, DatabaseEnum, Reason } from 'src/sql-tools/types';
|
|
|
|
|
|
|
|
|
|
export const compareEnums: Comparer<DatabaseEnum> = {
|
|
|
|
|
onMissing: (source) => [
|
|
|
|
|
{
|
2025-07-03 10:59:17 -04:00
|
|
|
type: 'EnumCreate',
|
2025-04-07 15:12:12 -04:00
|
|
|
enum: source,
|
|
|
|
|
reason: Reason.MissingInTarget,
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
onExtra: (target) => [
|
|
|
|
|
{
|
2025-07-03 10:59:17 -04:00
|
|
|
type: 'EnumDrop',
|
2025-04-07 15:12:12 -04:00
|
|
|
enumName: target.name,
|
|
|
|
|
reason: Reason.MissingInSource,
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
onCompare: (source, target) => {
|
|
|
|
|
if (source.values.toString() !== target.values.toString()) {
|
|
|
|
|
// TODO add or remove values if the lists are different or the order has changed
|
|
|
|
|
const reason = `enum values has changed (${source.values} vs ${target.values})`;
|
|
|
|
|
return [
|
|
|
|
|
{
|
2025-07-03 10:59:17 -04:00
|
|
|
type: 'EnumDrop',
|
2025-04-07 15:12:12 -04:00
|
|
|
enumName: source.name,
|
|
|
|
|
reason,
|
|
|
|
|
},
|
|
|
|
|
{
|
2025-07-03 10:59:17 -04:00
|
|
|
type: 'EnumCreate',
|
2025-04-07 15:12:12 -04:00
|
|
|
enum: source,
|
|
|
|
|
reason,
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return [];
|
|
|
|
|
},
|
|
|
|
|
};
|