Total Complexity | 3 |
Total Lines | 43 |
Duplicated Lines | 0 % |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
12 | final class Version20250926142500 extends AbstractMigrationChamilo |
||
13 | { |
||
14 | public function getDescription(): string |
||
15 | { |
||
16 | return "Fix mis-labeled 'Português do Brasil': change isocode from pt_PT to pt_BR only when pt_PT appears twice and pt_BR doesn't exist."; |
||
17 | } |
||
18 | |||
19 | public function up(Schema $schema): void |
||
20 | { |
||
21 | // Convert the Brazilian row from pt_PT -> pt_BR |
||
22 | // Only do it when there are at least 2 rows with isocode 'pt_PT' and there's no existing 'pt_BR' |
||
23 | $this->addSql(" |
||
24 | UPDATE language l |
||
25 | JOIN ( |
||
26 | SELECT id |
||
27 | FROM language |
||
28 | WHERE isocode = 'pt_PT' |
||
29 | AND ( |
||
30 | original_name = 'Português do Brasil' |
||
31 | OR english_name LIKE '%Brazil%' |
||
32 | OR english_name LIKE '%brazilian%' |
||
33 | ) |
||
34 | LIMIT 1 |
||
35 | ) b ON b.id = l.id |
||
36 | SET l.isocode = 'pt_BR' |
||
37 | WHERE |
||
38 | (SELECT COUNT(*) FROM language WHERE isocode = 'pt_PT') > 1 |
||
39 | AND (SELECT COUNT(*) FROM language WHERE isocode = 'pt_BR') = 0 |
||
40 | "); |
||
41 | |||
42 | // Normalize english_name for Brazilian row (optional, harmless if already set) |
||
43 | $this->addSql(" |
||
44 | UPDATE language |
||
45 | SET english_name = 'brazilian portuguese' |
||
46 | WHERE isocode = 'pt_BR' |
||
47 | AND (english_name IS NULL OR english_name = '' OR english_name LIKE '%brazil%') |
||
48 | "); |
||
49 | } |
||
50 | |||
51 | public function down(Schema $schema): void |
||
55 | UPDATE language l |
||
56 | JOIN ( |
||
57 | SELECT id |
||
71 |