Aller au contenu

Module:langues

Définition, traduction, prononciation, anagramme et synonyme sur le dictionnaire libre Wiktionnaire.

 Documentation[voir] [modifier] [historique] [purger]

Ce module permet de renvoyer les informations des différentes langues, notamment leur nom, à partir de leur code (fr=français).

Importation dans un module : l = require("Module:langues")

Fonctions utilisables dans les modules

get_nom(code)
renvoie le nom de la langue s'il est défini dans la liste locale Module:langues/data. Si aucune langue ne correspond, la fonction renvoie nil.
  • nom_langue = l.get_nom('fr')
get_tri(code)
renvoie la clé de tri de la langue si elle est définie dans la liste locale Module:langues/data. Se rabat sur le nom si la clé n’est pas définie. Si aucune langue ne correspond, la fonction renvoie nil.
  • cle_langue = l.get_tri('fr')
get_lien_Wikimedia(code)
renvoie le code correspondant à cette langue si le code diffère chez Wikimédia (Module:langues/data), à utiliser pour les liens vers les autres langues. S'il n'y a pas de code spécial chez Wikimédia, la fonction renvoie nil.
  • code_Wikimedia = l.get_lien_Wikimedia('fr')
has_portail(code)
renvoie true ou false selon que le code langue est associé à une langue qui a un portail ou non (les portails sont écrits en dur dans Module:langues/data).

Fonction utilisable dans un modèle ou dans une page

nom_langue(code)
affiche le nom de la langue ou, à défaut, une chaîne vide
  • {{#invoke:langues|nom_langue|fr}} affiche « français »
  • {{#invoke:langues|nom_langue|blabla}} affiche «  »

local m_bases = require("Module:bases")
local m_params = require("Module:paramètres")

local langues = mw.loadData("Module:langues/data")

local p = {}

p.specialCodes = {
  ["zh-Hans"] = "zh",
  ["zh-Hant"] = "zh",
  ["yue-Hant"] = "yue",
  ["wuu-Hant"] = "wuu",
  ["ko-Hani"] = "ko",
  ["vi-Hani"] = "vi",
  ["vi-Hans"] = "vi",
  ["vi-Hant"] = "vi",
  ["nan-Hani"] = "nan",
  ["nan-Hans"] = "nan",
  ["nan-Hant"] = "nan",
}

-- Cherche et renvoie le nom de la langue depuis notre liste locale [[Module:langues/data]].
-- Fonction utilisable dans d’autres modules seulement
function p.get_nom(code)
  if not code then
    return nil
  end

  code = mw.text.trim(code)

  if langues[code] and langues[code]["nom"] then
    return langues[code]["nom"]
  else
    return nil
  end
end

-- Cherche et renvoie la clé de tri de la langue depuis notre liste locale [[Module:langues/data]].
-- Fonction utilisable dans d’autres modules seulement
function p.get_tri(code)
  if not code then
    return nil
  end

  code = mw.text.trim(code)

  if langues[code] and langues[code]["tri"] then
    return langues[code]["tri"]
  else
    if langues[code] then
      return langues[code]["nom"]
    else
      return nil
    end
  end
end

-- Fonction pouvant remplacer les appels de type {{ {{{lang}}} }} dans les modèles
-- Cette fonction marche pour un modèle
function p.nom_langue(frame)
  local args

  if frame.args ~= nil and frame.args[1] ~= nil then
    args = frame.args
  else
    args = frame:getParent().args
  end
  local code = args[1]

  local langue = p.get_nom(code)

  if langue == nil or langue == "" then
    return ''
  else
    return langue
  end
end

-- Fonction pouvant remplacer les appels de type {{ {{{lang}}} }} dans les modèles
-- Cette fonction marche pour un modèle
function p.tri_langue(frame)
  local args

  if frame.args ~= nil and frame.args[1] ~= nil then
    args = frame.args
  else
    args = frame:getParent().args
  end
  local code = args[1]

  local tri = p.get_tri(code)

  if tri == nil or tri == "" then
    return ''
  else
    return tri
  end
end

-- Fonction pour écrire le nom d'une langue dans une liste (or traductions)
-- Cette fonction marche pour un modèle {{L}}
function p.langue_pour_liste(frame)
  local args
  if frame.args ~= nil and frame.args[1] ~= nil then
    args = frame.args
  else
    args = frame:getParent().args
  end
  local code = args[1]

  -- Un code est-il donné?
  if code == nil or mw.text.trim(code) == "" then
    return "''Pas de code donné''" .. m_bases.fait_categorie_contenu("Wiktionnaire:Codes langue manquants")
  end

  code = mw.text.trim(code)

  local langue = p.get_nom(code)

  if langue == nil or langue == "" then
    return code .. "*" .. m_bases.fait_categorie_contenu("Wiktionnaire:Codes langue non définis")
  else
    return m_bases.ucfirst(langue)
  end
end

-- Cherche et renvoie le code Wikimedia du Wiktionnaire correspondant s'il existe
function p.get_lien_Wikimedia(code)
  -- Permet l'usage depuis un modèle (via #invoke)
  if table.getn(mw.getCurrentFrame()) == 0 then
    code = mw.getCurrentFrame().args[1] or code
  end

  -- Pas de code langue ? Renvoie nil.
  if code == nil then
    return nil
  end

  -- Espaces avant et après enlevés
  code = mw.text.trim(code)

  -- A-t-on la langue correspondant au code donné ?
  if langues[code] and langues[code]["wmlien"] then
    -- Trouvé ! Renvoie le nom
    return langues[code]["wmlien"]
  else
    -- Pas trouvé : on renvoie nil
    return nil
  end
end

--- Indicates whether there exists a local “Portail” for the given language code.
--- @param code string The language code.
--- @return boolean True if a “Portail” exists, false otherwise or if the language code is unknown.
function p.has_portail(code)
  return langues[code] and langues[code]["portail"]
end

--- Indicates whether there exists a Wiktionary for the given language code.
--- @param code string The language code.
--- @return boolean True if a Wiktionary exists, false otherwise or if the language code is unknown.
function p.has_wiktionary(code)
  return langues[code] and langues[code]["wiktionnaire"]
end

--- Looks up the code for the given language name in [[Module:langues/data]].
--- @param languageName string Name of the language.
--- @return string|nil The code for the language or nil if none were found.
function p._getLanguageCode(languageName)
  for code, langue_table in pairs(langues) do
    if languageName == langue_table["nom"] then
      return code
    end
  end

  return nil
end

--- Looks up the code for the given language name in [[Module:langues/data]].
--- Parameters:
---  frame.args[1] (string): Name of the language.
--- @return string|nil The code for the language or an empty string if none were found.
function p.getLanguageCode(frame)
  local args = m_params.process(frame.args, {
    [1] = { required = true }
  })

  return p._getLanguageCode(args[1]) or ""
end

return p