/* hunspell dictionaries */ { lib, stdenv, fetchurl, fetchzip, fetchFromGitHub, unzip, coreutils, bash, which, zip, ispell, perl, python3, hunspell }: let mkDict = { pname, readmeFile, dictFileName, ... }@args: stdenv.mkDerivation ({ inherit pname; installPhase = '' runHook preInstall # hunspell dicts install -dm755 "$out/share/hunspell" install -m644 ${dictFileName}.dic "$out/share/hunspell/" install -m644 ${dictFileName}.aff "$out/share/hunspell/" # myspell dicts symlinks install -dm755 "$out/share/myspell/dicts" ln -sv "$out/share/hunspell/${dictFileName}.dic" "$out/share/myspell/dicts/" ln -sv "$out/share/hunspell/${dictFileName}.aff" "$out/share/myspell/dicts/" # docs install -dm755 "$out/share/doc" install -m644 ${readmeFile} $out/share/doc/${pname}.txt runHook postInstall ''; } // args); mkDictFromRla = { shortName, shortDescription, dictFileName }: mkDict rec { inherit dictFileName; version = "2.5"; pname = "hunspell-dict-${shortName}-rla"; readmeFile = "README.txt"; src = fetchFromGitHub { owner = "sbosio"; repo = "rla-es"; rev = "v${version}"; sha256 = "sha256-oGnxOGHzDogzUMZESydIxRTbq9Dmd03flwHx16AK1yk="; }; meta = with lib; { description = "Hunspell dictionary for ${shortDescription} from rla"; homepage = "https://github.com/sbosio/rla-es"; license = with licenses; [ gpl3 lgpl3 mpl11 ]; maintainers = with maintainers; [ renzo ]; platforms = platforms.all; }; nativeBuildInputs = [ bash coreutils which zip unzip ]; postPatch = '' substituteInPlace ortograf/herramientas/make_dict.sh \ --replace /bin/bash ${bash}/bin/bash \ --replace /dev/stderr stderr.log substituteInPlace ortograf/herramientas/remover_comentarios.sh \ --replace /bin/bash ${bash}/bin/bash \ ''; buildPhase = '' cd ortograf/herramientas bash -x ./make_dict.sh -l ${dictFileName} -2 unzip ${dictFileName}.zip \ ${dictFileName}.dic ${dictFileName}.aff ${readmeFile} ''; }; mkDictFromDSSO = { shortName, shortDescription, dictFileName }: mkDict rec { inherit dictFileName; version = "2.40"; # Should really use a string function or something _version = "2-40"; pname = "hunspell-dict-${shortName}-dsso"; _name = "ooo_swedish_dict_${_version}"; readmeFile = "LICENSE_en_US.txt"; src = fetchurl { url = "https://extensions.libreoffice.org/extensions/swedish-spelling-dictionary-den-stora-svenska-ordlistan/${version}/@@download/file/${_name}.oxt"; sha256 = "b982881cc75f5c4af1199535bd4735ee476bdc48edf63e3f05fb4f715654a7bc"; }; meta = with lib; { longDescription = '' Svensk ordlista baserad på DSSO (den stora svenska ordlistan) och Göran Anderssons (goran@init.se) arbete med denna. Ordlistan hämtas från LibreOffice då dsso.se inte längre verkar vara med oss. ''; description = "Hunspell dictionary for ${shortDescription} from LibreOffice"; license = licenses.lgpl3; platforms = platforms.all; }; nativeBuildInputs = [ unzip ]; sourceRoot = "."; unpackCmd = '' unzip $src dictionaries/${dictFileName}.dic dictionaries/${dictFileName}.aff $readmeFile ''; installPhase = '' # hunspell dicts install -dm755 "$out/share/hunspell" install -m644 dictionaries/${dictFileName}.dic "$out/share/hunspell/" install -m644 dictionaries/${dictFileName}.aff "$out/share/hunspell/" # myspell dicts symlinks install -dm755 "$out/share/myspell/dicts" ln -sv "$out/share/hunspell/${dictFileName}.dic" "$out/share/myspell/dicts/" ln -sv "$out/share/hunspell/${dictFileName}.aff" "$out/share/myspell/dicts/" # docs install -dm755 "$out/share/doc" install -m644 ${readmeFile} $out/share/doc/${pname}.txt ''; }; mkDictFromDicollecte = { shortName, shortDescription, longDescription, dictFileName, isDefault ? false }: mkDict rec { inherit dictFileName; version = "5.3"; pname = "hunspell-dict-${shortName}-dicollecte"; readmeFile = "README_dict_fr.txt"; src = fetchurl { url = "http://www.dicollecte.org/download/fr/hunspell-french-dictionaries-v${version}.zip"; sha256 = "0ca7084jm7zb1ikwzh1frvpb97jn27i7a5d48288h2qlfp068ik0"; }; meta = with lib; { inherit longDescription; description = "Hunspell dictionary for ${shortDescription} from Dicollecte"; homepage = "https://www.dicollecte.org/home.php?prj=fr"; license = licenses.mpl20; maintainers = with maintainers; [ renzo ]; platforms = platforms.all; }; nativeBuildInputs = [ unzip ]; sourceRoot = "."; unpackCmd = '' unzip $src ${dictFileName}.dic ${dictFileName}.aff ${readmeFile} ''; postInstall = lib.optionalString isDefault '' for ext in aff dic; do ln -sv $out/share/hunspell/${dictFileName}.$ext $out/share/hunspell/fr_FR.$ext ln -sv $out/share/myspell/dicts/${dictFileName}.$ext $out/share/myspell/dicts/fr_FR.$ext done ''; }; mkDictFromWordlist = { shortName, shortDescription, srcFileName, dictFileName, src }: mkDict rec { inherit src srcFileName dictFileName; version = "2018.04.16"; pname = "hunspell-dict-${shortName}-wordlist"; srcReadmeFile = "README_" + srcFileName + ".txt"; readmeFile = "README_" + dictFileName + ".txt"; meta = with lib; { description = "Hunspell dictionary for ${shortDescription} from Wordlist"; homepage = "http://wordlist.aspell.net/"; license = licenses.bsd3; maintainers = with maintainers; [ renzo ]; platforms = platforms.all; }; nativeBuildInputs = [ unzip ]; sourceRoot = "."; unpackCmd = '' unzip $src ${srcFileName}.dic ${srcFileName}.aff ${srcReadmeFile} ''; postUnpack = '' mv ${srcFileName}.dic ${dictFileName}.dic || true mv ${srcFileName}.aff ${dictFileName}.aff || true mv ${srcReadmeFile} ${readmeFile} || true ''; }; mkDictFromLinguistico = { shortName, shortDescription, dictFileName, src }: mkDict rec { inherit src dictFileName; version = "2.4"; pname = "hunspell-dict-${shortName}-linguistico"; readmeFile = dictFileName + "_README.txt"; meta = with lib; { description = "Hunspell dictionary for ${shortDescription}"; homepage = "https://sourceforge.net/projects/linguistico/"; license = licenses.gpl3; maintainers = with maintainers; [ renzo ]; platforms = platforms.all; }; nativeBuildInputs = [ unzip ]; sourceRoot = "."; prePatch = '' # Fix dic file empty lines (FS#22275) sed '/^\/$/d' -i ${dictFileName}.dic ''; unpackCmd = '' unzip $src ${dictFileName}.dic ${dictFileName}.aff ${readmeFile} ''; }; mkDictFromXuxen = { shortName, srcs, shortDescription, longDescription, dictFileName }: stdenv.mkDerivation rec { pname = "hunspell-dict-${shortName}-xuxen"; version = "5-2015.11.10"; inherit srcs; sourceRoot = "."; # Copy files stripping until first dash (path and hash) unpackCmd = "cp $curSrc \${curSrc##*-}"; installPhase = '' # hunspell dicts install -dm755 "$out/share/hunspell" install -m644 ${dictFileName}.dic "$out/share/hunspell/" install -m644 ${dictFileName}.aff "$out/share/hunspell/" # myspell dicts symlinks install -dm755 "$out/share/myspell/dicts" ln -sv "$out/share/hunspell/${dictFileName}.dic" "$out/share/myspell/dicts/" ln -sv "$out/share/hunspell/${dictFileName}.aff" "$out/share/myspell/dicts/" ''; meta = with lib; { homepage = "http://xuxen.eus/"; description = shortDescription; longDescription = longDescription; license = licenses.gpl2; maintainers = with maintainers; [ zalakain ]; platforms = platforms.all; }; }; mkDictFromJ3e = { shortName, shortDescription, dictFileName }: stdenv.mkDerivation rec { pname = "hunspell-dict-${shortName}-j3e"; version = "20161207"; src = fetchurl { url = "https://j3e.de/ispell/igerman98/dict/igerman98-${version}.tar.bz2"; sha256 = "1a3055hp2bc4q4nlg3gmg0147p3a1zlfnc65xiv2v9pyql1nya8p"; }; nativeBuildInputs = [ ispell perl hunspell ]; dontBuild = true; installPhase = '' patchShebangs bin make hunspell/${dictFileName}.aff hunspell/${dictFileName}.dic # hunspell dicts install -dm755 "$out/share/hunspell" install -m644 hunspell/${dictFileName}.dic "$out/share/hunspell/" install -m644 hunspell/${dictFileName}.aff "$out/share/hunspell/" # myspell dicts symlinks install -dm755 "$out/share/myspell/dicts" ln -sv "$out/share/hunspell/${dictFileName}.dic" "$out/share/myspell/dicts/" ln -sv "$out/share/hunspell/${dictFileName}.aff" "$out/share/myspell/dicts/" ''; meta = with lib; { homepage = "https://www.j3e.de/ispell/igerman98/index_en.html"; description = shortDescription; license = with licenses; [ gpl2 gpl3 ]; maintainers = with maintainers; [ timor ]; platforms = platforms.all; }; }; mkDictFromLibreOffice = { shortName , shortDescription , dictFileName , license , readmeFile ? "README_${dictFileName}.txt" , sourceRoot ? dictFileName }: mkDict rec { pname = "hunspell-dict-${shortName}-libreoffice"; version = "6.3.0.4"; inherit dictFileName readmeFile; src = fetchFromGitHub { owner = "LibreOffice"; repo = "dictionaries"; rev = "libreoffice-${version}"; sha256 = "14z4b0grn7cw8l9s7sl6cgapbpwhn1b3gwc3kn6b0k4zl3dq7y63"; }; buildPhase = '' cp -a ${sourceRoot}/* . ''; meta = with lib; { homepage = "https://wiki.documentfoundation.org/Development/Dictionaries"; description = "Hunspell dictionary for ${shortDescription} from LibreOffice"; license = license; maintainers = with maintainers; [ vlaci ]; platforms = platforms.all; }; }; in rec { /* ENGLISH */ en_US = en-us; en-us = mkDictFromWordlist { shortName = "en-us"; shortDescription = "English (United States)"; srcFileName = "en_US"; dictFileName = "en_US"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_US-2018.04.16.zip"; sha256 = "18hbncvqnckzqarrmnzk58plymjqyi93k4qj98fac5mr71jbmzaf"; }; }; en_US-large = en-us-large; en-us-large = mkDictFromWordlist { shortName = "en-us-large"; shortDescription = "English (United States) Large"; srcFileName = "en_US-large"; dictFileName = "en_US"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_US-large-2018.04.16.zip"; sha256 = "1xm9jgqbivp5cb78ykjxg47vzq1yqj82l7r4q5cjpivrv99s49qc"; }; }; en_CA = en-ca; en-ca = mkDictFromWordlist { shortName = "en-ca"; shortDescription = "English (Canada)"; srcFileName = "en_CA"; dictFileName = "en_CA"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_CA-2018.04.16.zip"; sha256 = "06yf3s7y1215jmikbs18cn4j8a13csp4763w3jfgah8zlim6vc47"; }; }; en_CA-large = en-ca-large; en-ca-large = mkDictFromWordlist { shortName = "en-ca-large"; shortDescription = "English (Canada) Large"; srcFileName = "en_CA-large"; dictFileName = "en_CA"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_CA-large-2018.04.16.zip"; sha256 = "1200xxyvv6ni8nk52v3059c367817vnrkm0cdh38rhiigb5flfha"; }; }; en_AU = en-au; en-au = mkDictFromWordlist { shortName = "en-au"; shortDescription = "English (Australia)"; srcFileName = "en_AU"; dictFileName = "en_AU"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_AU-2018.04.16.zip"; sha256 = "1kp06npl1kd05mm9r52cg2iwc13x02zwqgpibdw15b6x43agg6f5"; }; }; en_AU-large = en-au-large; en-au-large = mkDictFromWordlist { shortName = "en-au-large"; shortDescription = "English (Australia) Large"; srcFileName = "en_AU-large"; dictFileName = "en_AU"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_AU-large-2018.04.16.zip"; sha256 = "14l1w4dpk0k1js2wwq5ilfil89ni8cigph95n1rh6xi4lzxj7h6g"; }; }; en_GB-ise = en-gb-ise; en-gb-ise = mkDictFromWordlist { shortName = "en-gb-ise"; shortDescription = "English (United Kingdom, 'ise' ending)"; srcFileName = "en_GB-ise"; dictFileName = "en_GB"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_GB-ise-2018.04.16.zip"; sha256 = "0ylg1zvfvsawamymcc9ivrqcb9qhlpgpnizm076xc56jz554xc2l"; }; }; en_GB-ize = en-gb-ize; en-gb-ize = mkDictFromWordlist { shortName = "en-gb-ize"; shortDescription = "English (United Kingdom, 'ize' ending)"; srcFileName = "en_GB-ize"; dictFileName = "en_GB"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_GB-ize-2018.04.16.zip"; sha256 = "1rmwy6sxmd400cwjf58az6g14sq28p18f5mlq8ybg8y33q9m42ps"; }; }; en_GB-large = en-gb-large; en-gb-large = mkDictFromWordlist { shortName = "en-gb-large"; shortDescription = "English (United Kingdom) Large"; srcFileName = "en_GB-large"; dictFileName = "en_GB"; src = fetchurl { url = "mirror://sourceforge/wordlist/speller/2018.04.16/hunspell-en_GB-large-2018.04.16.zip"; sha256 = "1y4d7x5vvi1qh1s3i09m0vvqrpdzzqhsdngr8nsh7hc5bnlm37mi"; }; }; /* SPANISH */ es_ANY = es-any; es-any = mkDictFromRla { shortName = "es-any"; shortDescription = "Spanish (any variant)"; dictFileName = "es_ANY"; }; es_AR = es-ar; es-ar = mkDictFromRla { shortName = "es-ar"; shortDescription = "Spanish (Argentina)"; dictFileName = "es_AR"; }; es_BO = es-bo; es-bo = mkDictFromRla { shortName = "es-bo"; shortDescription = "Spanish (Bolivia)"; dictFileName = "es_BO"; }; es_CL = es-cl; es-cl = mkDictFromRla { shortName = "es-cl"; shortDescription = "Spanish (Chile)"; dictFileName = "es_CL"; }; es_CO = es-co; es-co = mkDictFromRla { shortName = "es-co"; shortDescription = "Spanish (Colombia)"; dictFileName = "es_CO"; }; es_CR = es-cr; es-cr = mkDictFromRla { shortName = "es-cr"; shortDescription = "Spanish (Costa Rica)"; dictFileName = "es_CR"; }; es_CU = es-cu; es-cu = mkDictFromRla { shortName = "es-cu"; shortDescription = "Spanish (Cuba)"; dictFileName = "es_CU"; }; es_DO = es-do; es-do = mkDictFromRla { shortName = "es-do"; shortDescription = "Spanish (Dominican Republic)"; dictFileName = "es_DO"; }; es_EC = es-ec; es-ec = mkDictFromRla { shortName = "es-ec"; shortDescription = "Spanish (Ecuador)"; dictFileName = "es_EC"; }; es_ES = es-es; es-es = mkDictFromRla { shortName = "es-es"; shortDescription = "Spanish (Spain)"; dictFileName = "es_ES"; }; es_GT = es-gt; es-gt = mkDictFromRla { shortName = "es-gt"; shortDescription = "Spanish (Guatemala)"; dictFileName = "es_GT"; }; es_HN = es-hn; es-hn = mkDictFromRla { shortName = "es-hn"; shortDescription = "Spanish (Honduras)"; dictFileName = "es_HN"; }; es_MX = es-mx; es-mx = mkDictFromRla { shortName = "es-mx"; shortDescription = "Spanish (Mexico)"; dictFileName = "es_MX"; }; es_NI = es-ni; es-ni = mkDictFromRla { shortName = "es-ni"; shortDescription = "Spanish (Nicaragua)"; dictFileName = "es_NI"; }; es_PA = es-pa; es-pa = mkDictFromRla { shortName = "es-pa"; shortDescription = "Spanish (Panama)"; dictFileName = "es_PA"; }; es_PE = es-pe; es-pe = mkDictFromRla { shortName = "es-pe"; shortDescription = "Spanish (Peru)"; dictFileName = "es_PE"; }; es_PR = es-pr; es-pr = mkDictFromRla { shortName = "es-pr"; shortDescription = "Spanish (Puerto Rico)"; dictFileName = "es_PR"; }; es_PY = es-py; es-py = mkDictFromRla { shortName = "es-py"; shortDescription = "Spanish (Paraguay)"; dictFileName = "es_PY"; }; es_SV = es-sv; es-sv = mkDictFromRla { shortName = "es-sv"; shortDescription = "Spanish (El Salvador)"; dictFileName = "es_SV"; }; es_UY = es-uy; es-uy = mkDictFromRla { shortName = "es-uy"; shortDescription = "Spanish (Uruguay)"; dictFileName = "es_UY"; }; es_VE = es-ve; es-ve = mkDictFromRla { shortName = "es-ve"; shortDescription = "Spanish (Venezuela)"; dictFileName = "es_VE"; }; /* FRENCH */ fr-any = mkDictFromDicollecte { shortName = "fr-any"; dictFileName = "fr-toutesvariantes"; shortDescription = "French (any variant)"; longDescription = '' Ce dictionnaire contient les nouvelles et les anciennes graphies des mots concernés par la réforme de 1990. ''; }; fr-classique = mkDictFromDicollecte { shortName = "fr-classique"; dictFileName = "fr-classique"; shortDescription = "French (classic)"; longDescription = '' Ce dictionnaire est une extension du dictionnaire «Moderne» et propose en sus des graphies alternatives, parfois encore très usitées, parfois tombées en désuétude. ''; }; fr-moderne = mkDictFromDicollecte { shortName = "fr-moderne"; dictFileName = "fr-moderne"; shortDescription = "French (modern)"; longDescription = '' Ce dictionnaire propose une sélection des graphies classiques et réformées, suivant la lente évolution de l’orthographe actuelle. Ce dictionnaire contient les graphies les moins polémiques de la réforme. ''; isDefault = true; }; fr-reforme1990 = mkDictFromDicollecte { shortName = "fr-reforme1990"; dictFileName = "fr-reforme1990"; shortDescription = "French (1990 reform)"; longDescription = '' Ce dictionnaire ne connaît que les graphies nouvelles des mots concernés par la réforme de 1990. ''; }; /* ITALIAN */ it_IT = it-it; it-it = mkDictFromLinguistico { shortName = "it-it"; dictFileName = "it_IT"; shortDescription = "Hunspell dictionary for 'Italian (Italy)' from Linguistico"; src = fetchurl { url = "mirror://sourceforge/linguistico/italiano_2_4_2007_09_01.zip"; sha256 = "0m9frz75fx456bczknay5i446gdcp1smm48lc0qfwzhz0j3zcdrd"; }; }; /* BASQUE */ eu_ES = eu-es; eu-es = mkDictFromXuxen { shortName = "eu-es"; dictFileName = "eu_ES"; shortDescription = "Basque (Xuxen 5)"; longDescription = '' Itxura berritzeaz gain, testuak zuzentzen laguntzeko zenbait hobekuntza egin dira Xuxen.eus-en. Lexikoari dagokionez, 18645 sarrera berri erantsi ditugu, eta proposamenak egiteko sistema ere aldatu dugu. Esate baterako, gaizki idatzitako hitz baten inguruko proposamenak eskuratzeko, euskaraz idaztean egiten ditugun akats arruntenak hartu dira kontuan. Sistemak ematen dituen proposamenak ordenatzeko, berriz, aipatutako irizpidea erabiltzeaz gain, Internetetik automatikoki eskuratutako euskarazko corpus bateko datuen arabera ordenatu daitezke emaitzak. Erabiltzaileak horrela ordenatu nahi baditu proposamenak, hautatu egin behar du aukera hori testu-kutxaren azpian dituen aukeren artean. Interesgarria da proposamenak ordenatzeko irizpide hori, hala sistemak formarik erabilienak proposatuko baitizkigu gutxiago erabiltzen direnen aurretik. ''; srcs = [ (fetchurl { url = "http://xuxen.eus/static/hunspell/eu_ES.aff"; sha256 = "12w2j6phzas2rdzc7f20jnk93sm59m2zzfdgxv6p8nvcvbrkmc02"; }) (fetchurl { url = "http://xuxen.eus/static/hunspell/eu_ES.dic"; sha256 = "0lw193jr7ldvln5x5z9p21rz1by46h0say9whfcw2kxs9vprd5b3"; }) ]; }; /* HUNGARIAN */ hu_HU = hu-hu; hu-hu = mkDictFromLibreOffice { shortName = "hu-hu"; dictFileName = "hu_HU"; shortDescription = "Hungarian (Hungary)"; license = with lib.licenses; [ mpl20 lgpl3 ]; }; /* SWEDISH */ sv_SE = sv-se; sv-se = mkDictFromDSSO { shortName = "sv-se"; dictFileName = "sv_SE"; shortDescription = "Swedish (Sweden)"; }; # Finlandian Swedish (hello Linus Torvalds) sv_FI = sv-fi; sv-fi = mkDictFromDSSO { shortName = "sv-fi"; dictFileName = "sv_FI"; shortDescription = "Swedish (Finland)"; }; /* GERMAN */ de_DE = de-de; de-de = mkDictFromJ3e { shortName = "de-de"; shortDescription = "German (Germany)"; dictFileName = "de_DE"; }; de_AT = de-at; de-at = mkDictFromJ3e { shortName = "de-at"; shortDescription = "German (Austria)"; dictFileName = "de_AT"; }; de_CH = de-ch; de-ch = mkDictFromJ3e { shortName = "de-ch"; shortDescription = "German (Switzerland)"; dictFileName = "de_CH"; }; /* UKRAINIAN */ uk_UA = uk-ua; uk-ua = mkDict rec { pname = "hunspell-dict-uk-ua"; version = "4.6.3"; _version = "4-6.3"; src = fetchurl { url = "https://extensions.libreoffice.org/extensions/ukrainian-spelling-dictionary-and-thesaurus/${_version}/@@download/file/dict-uk_UA-${version}.oxt"; sha256 = "14rd07yx4fx2qxjr5xqc8qy151idd8k2hr5yi18d9r8gccnm9w50"; }; dictFileName = "uk_UA"; readmeFile = "README_uk_UA.txt"; nativeBuildInputs = [ unzip ]; unpackCmd = '' unzip $src ${dictFileName}/{${dictFileName}.dic,${dictFileName}.aff,${readmeFile}} ''; meta = with lib; { description = "Hunspell dictionary for Ukrainian (Ukraine) from LibreOffice"; homepage = "https://extensions.libreoffice.org/extensions/ukrainian-spelling-dictionary-and-thesaurus/"; license = licenses.mpl20; maintainers = with maintainers; [ dywedir ]; platforms = platforms.all; }; }; /* RUSSIAN */ ru_RU = ru-ru; ru-ru = mkDictFromLibreOffice { shortName = "ru-ru"; dictFileName = "ru_RU"; shortDescription = "Russian (Russian)"; license = with lib.licenses; [ mpl20 lgpl3 ]; }; /* CZECH */ cs_CZ = cs-cz; cs-cz = mkDictFromLibreOffice { shortName = "cs-cz"; dictFileName = "cs_CZ"; shortDescription = "Czech (Czechia)"; readmeFile = "README_cs.txt"; license = with lib.licenses; [ gpl2 ]; }; /* SLOVAK */ sk_SK = sk-sk; sk-sk = mkDictFromLibreOffice { shortName = "sk-sk"; dictFileName = "sk_SK"; shortDescription = "Slovak (Slovakia)"; readmeFile = "README_sk.txt"; license = with lib.licenses; [ gpl2 lgpl21 mpl11 ]; }; /* DANISH */ da_DK = da-dk; da-dk = mkDict rec { pname = "hunspell-dict-da-dk"; version = "2.5.189"; src = fetchurl { url = "https://stavekontrolden.dk/dictionaries/da_DK/da_DK-${version}.oxt"; sha256 = "sha256:0i1cw0nfg24b0sg2yc3q7315ng5vc5245nvh0l1cndkn2c9z4978"; }; shortName = "da-dk"; shortDescription = "Danish (Danmark)"; dictFileName = "da_DK"; readmeFile = "README_da_DK.txt"; nativeBuildInputs = [ unzip ]; unpackCmd = '' unzip $src ${dictFileName}.dic ${dictFileName}.aff ${readmeFile} -d ${dictFileName} ''; meta = with lib; { description = "Hunspell dictionary for Danish (Denmark) from Stavekontrolden"; homepage = "https://github.com/jeppebundsgaard/stavekontrolden"; license = with lib.licenses; [ gpl2Only lgpl21Only mpl11 ]; maintainers = with maintainers; [ louisdk1 ]; }; }; /* DUTCH */ nl_NL = nl_nl; nl_nl = mkDict rec { pname = "hunspell-dict-nl-nl"; version = "2.20.19"; src = fetchFromGitHub { owner = "OpenTaal"; repo = "opentaal-hunspell"; rev = version; sha256 = "0jma8mmrncyzd77kxliyngs4z6z4769g3nh0a7xn2pd4s5y2xdpy"; }; preInstall = '' mv nl.aff nl_NL.aff mv nl.dic nl_NL.dic ''; dictFileName = "nl_NL"; readmeFile = "README.md"; meta = with lib; { description = "Hunspell dictionary for Dutch (Netherlands) from OpenTaal"; homepage = "https://www.opentaal.org/"; license = with licenses; [ bsd3 /* or */ cc-by-30 ]; maintainers = with maintainers; [ artturin ]; }; }; /* HEBREW */ he_IL = he-il; he-il = mkDictFromLibreOffice { shortName = "he-il"; dictFileName = "he_IL"; shortDescription = "Hebrew (Israel)"; readmeFile = "README_he_IL.txt"; license = with lib.licenses; [ agpl3Plus ]; }; /* THAI */ th_TH = th-th; th-th = mkDict { pname = "hunspell-dict-th-th"; version = "experimental-2024-04-15"; dictFileName = "th_TH"; readmeFile = "README.md"; src = fetchFromGitHub { owner = "SyafiqHadzir"; repo = "Hunspell-TH"; rev = "419eb32115b936da9c949e35b35c29b8187f6c93"; sha256 = "sha256-aXjof5dcEoCmep3PtvVkBhcgcd2NtqUpUEu37wsi1Uk="; }; meta = with lib; { description = "Hunspell dictionary for Central Thai (Thailand)"; homepage = "https://github.com/SyafiqHadzir/Hunspell-TH"; license = with licenses; [ gpl3 ]; maintainers = with maintainers; [ toastal ]; # looking for a native speaker platforms = platforms.all; }; }; /* CROATIAN */ hr_HR = hr-hr; hr-hr = mkDictFromLibreOffice { shortName = "hr-hr"; dictFileName = "hr_HR"; shortDescription = "Croatian (Croatia)"; readmeFile = "README_hr_HR.txt"; license = with lib.licenses; [ gpl2Only lgpl21Only mpl11 ]; }; /* NORWEGIAN */ nb_NO = nb-no; nb-no = mkDictFromLibreOffice { shortName = "nb-no"; dictFileName = "nb_NO"; sourceRoot = "no"; readmeFile = "README_hyph_NO.txt"; shortDescription = "Norwegian Bokmål (Norway)"; license = with lib.licenses; [ gpl2Only ]; }; nn_NO = nn-no; nn-no = mkDictFromLibreOffice { shortName = "nn-no"; dictFileName = "nn_NO"; sourceRoot = "no"; readmeFile = "README_hyph_NO.txt"; shortDescription = "Norwegian Nynorsk (Norway)"; license = with lib.licenses; [ gpl2Only ]; }; /* TOKI PONA */ tok = mkDict rec { pname = "hunspell-dict-tok"; version = "20220829"; dictFileName = "tok"; readmeFile = "README.en.adoc"; src = fetchzip { url = "https://github.com/somasis/hunspell-tok/releases/download/${version}/hunspell-tok-${version}.tar.gz"; sha256 = "sha256-RiAODKXPUeIcf8IFcU6Tacehq5S8GYuPTuxEiN2CXD0="; }; dontBuild = true; meta = with lib; { description = "Hunspell dictionary for Toki Pona"; homepage = "https://github.com/somasis/hunspell-tok"; license = with lib.licenses; [ cc0 publicDomain cc-by-sa-30 cc-by-sa-40 ]; maintainers = with maintainers; [ somasis ]; platforms = platforms.all; }; }; /* POLISH */ pl_PL = pl-pl; pl-pl = mkDictFromLibreOffice { shortName = "pl-pl"; dictFileName = "pl_PL"; shortDescription = "Polish (Poland)"; readmeFile = "README_en.txt"; # the README doesn't specify versions of licenses :/ license = with lib.licenses; [ gpl2Plus lgpl2Plus mpl10 asl20 cc-by-sa-25 ]; }; /* PORTUGUESE */ pt_BR = pt-br; pt-br = mkDictFromLibreOffice { shortName = "pt-br"; dictFileName = "pt_BR"; shortDescription = "Portuguese (Brazil)"; readmeFile = "README_pt_BR.txt"; license = with lib.licenses; [ lgpl3 ]; }; pt_PT = pt-pt; pt-pt = mkDictFromLibreOffice { shortName = "pt-pt"; dictFileName = "pt_PT"; shortDescription = "Portuguese (Portugal)"; readmeFile = "README_pt_PT.txt"; license = with lib.licenses; [ gpl2 lgpl21 mpl11 ]; }; /* PERSIAN */ fa_IR = fa-ir; fa-ir = mkDict { pname = "hunspell-dict-fa-ir"; version = "experimental-2022-09-04"; dictFileName = "fa-IR"; readmeFile = "README.md"; src = fetchFromGitHub { owner = "b00f"; repo = "lilak"; rev = "1a80a8e5c9377ac424d29ef20be894e250bc9765"; hash = "sha256-xonnrclzgFEHdQ9g8ijm0bo9r5a5Y0va52NoJR5d8mo="; }; nativeBuildInputs = [ python3 ]; buildPhase = '' runHook preBuild mkdir build (cd src && python3 lilak.py) mv build/* ./ # remove timestamp from file sed -i 's/^\(## *File Version[^,]*\),.*/\1/' fa-IR.aff runHook postBuild ''; meta = with lib; { description = "Hunspell dictionary for Persian (Iran)"; homepage = "https://github.com/b00f/lilak"; license = licenses.asl20; maintainers = with maintainers; [ nix-julia ]; platforms = platforms.all; }; }; }