9.2 KiB
Executable File
[[post_data { "author" : "Tarsier y KyMAN", "since" : 20210623, "version" : 20210624 }]]
¿Cómo montar un diccionario?
Los diccionarios no son más que meros ficheros JSON con una estructura muy concreta, la cual es la siguiente:
- pattern (required): Patrón o patrones regulares por los cuales buscar la o las palabras concretas.
- result (required): Resultado o resultados formatados de los patrones.
- words (optional): Palabras con las que aparecer en el buscador de palabras del diccionario.
- description (required): Descripción de la palabra o palabras.
- links (optional): Links a las fuentes que se consideren para corroborar o ampliar información al respecto.
El campo pattern puede ser un campo de tipo String para un único patrón, o de tipo Array para uno o más patrones regulares. Las Expresiones Regulares están encapsuladas entre Backslashes y pueden ir acompañadas de modificadores por el estándar de JavaScript.
IMPORTANTE: Las Expresiones Regulares están en un String, por lo que el uso del caracter Slash, tanto para su uso como para sus escapes, requiere de ser autoescapado, y hay que contar que éste también requiere de escape para las RE.
Acerca del campo result, éste puede ser un String o un Array, siguiendo el tipado del campo pattern, y en el caso de ser un Array, ha de tener un resultado por cada patrón que tenga. Los resultados pueden trabajar las variables de las Expresiones Regulares del campo pattern, entendiendo las variables por el estándar de las Expresiones Regulares de JavaScript, aquellas encapsulaciones entre paréntesis que no vengan precedidas por un operador "?", siendo éstas un Array el cual, cada posición representacada una de las variables, y donde su posición 0 el recurso completo. Para poder identificar dentro del String de resultado una variable acorde a su Expresión Regular se usará el caracter "$" seguido del número al que se quiera hacer referencia, de esta forma podemos incluso hacer correcciones sintácticas o de escritura de un concepto concreto.
IMPORTANTE: El trabajo con las variables solo se puede hacer con las primeras 10 variables entendiendo que vas desde la variable 0 hasta la 9.
El campo de words solo es necesario cuando el campo result trabaje alguna variable del campo pattern pues si no se especifica el campo words, por defecto saldrán como palabras en el buscador de conceptos del campo result, pero si se establece el campo words sólo saldrán las de este último campo.
El campo description permite establecer un texto que describe y define el concepto. Se puede hacer uso de HTML, y para estructurar correctamente un JSON, éste puede ser un Array de Strings, un String vacío dictamina un cambio de párrafo. En sí, el texto se engloba automáticamente en párrafos siguiendo el concepto del String vacío en un Array.
Finalmente, el campo links provee de enlaces con información y fuentes acerca del concepto que se esté trabajando. Puede que un concepto no tenga Links por el hecho de ser un concepto propio o no haberse encontrado una fuente acorde al mismo.
Ejemplo
Un ejemplo sencillo de cómo crear un diccionario podría ser el siguiente:
[{
"pattern" : "/\\btarsi(er)?s?\\b/gi",
"result" : "Tarsier",
"description" : "Algo de todo",
"links" : "https://git.k3y.pw/Tarsier/"
}, {
"pattern" : "/\\b[kcq](y|ai)man\\b/gi",
"result" : "KyMAN",
"description" : "Desarrollador.",
"links" : [
"https://kyman.k3y.pw/",
"https://git.k3y.pw/KyMAN/",
"https://git.a3do.net/KyMAN/",
"https://www.youtube.com/channel/UCCAWOt-AxTyAiFWBgyb3X9Q",
"https://github.com/0KyMAN0"
]
}, {
"pattern" : "/\\b(c)osa(s)? ?inventadas?\\b/gi",
"result" : "$1osa$2 inventada$2",
"words" : "Cosas inventadas",
"description" : "Pues vamos, que tenemos mucha imaginación..."
}, {
"pattern" : ["/\\bw(halers)?[ \\-_\\.]?markdown\\b/gi", "/\\bw(\\. ?)?m(\\. ?)?d(\\. ?)?\\b/gi"],
"result" : ["WMarkDown", "WMD"],
"description" : [
"Conjunto de librerías que mezclan lenguajes de marcas de MediaWiki y MarkDown con ",
"algunas correcciones y customizaciones.",
"",
"Simplifica mucho a la hora de documentar cosas."
],
"links" : [
"https://wmarkdown.k3y.pw/",
"https://git.k3y.pw/Whalers/WMarkDown"
]
}]
En este ejemplo hemos descrito 4 conceptos: Tarsier, KyMAN, algo incentado y WMarkDown. En el caso de Tarsier, que también es llamado Tarsi, y como puede ser un animal pues podría darse el caso de tener plural, se le corrige la letra capital de nombre propio, se completa el diminutivo ignore Tarsi y se le elimina el plural por tratarse en este caso de un nombre propio y no de más de un ignore tarsier; Continuando con KyMAN, nos encontramos que aquí se entiende que el sonido caiman o quiman es referido a KyMAN mientras que el sonido caimán será el animal, y corrige todas las posibilidades ocurridas en el momento sobre el sonido caiman o quiman sobre el nombre KyMAN (No admite plurales, excluyendo éstos), y el cual tiene más de un Link; el concepto de cosa inventada corrige su letra capital y considera la opción de que pueda ser plural o singular a partir de la "S" de plural de "cosas", y especifica las palabras nativas para su muestreo en la tabla de búsqueda de conceptos del diccionario, y donde podemos ver que no tiene ningún Link por el hecho de ser algo inventado; y finalmente tenemos el concepto de WMarkDown donde tenemos dos formas de llamarlo y por tanto de resultados, con una descripción más extensa, con dos párrafos definidos por un separador de un String vacío.
NOTA: En el caso de WMarkDown se corrige también la posibilidad de incluir el origen de la "W", que viene siendo el proyecto Whalers. También quitiamos la posibilidad de siglas.
IMPORTANTE: Es importante saber que el fichero solo constará del texto que se le dé, no pudiendo poner textos alternativos como pudiera ser en un gestor de idiomas. Para dichos casos se requerirá la creación de tantos ficheros como idiomas. También permite la división del contenido como pudimos ver en el apartado de como llamar a los diccionarios.
¿Cómo iconificar un enlace?
Si te haces esta pregunta es porque estarás en un entorno de WMarkDown donde los enlaces son unos círculos blancos vacíos donde algunos tienen un icono del sitio concreto como puede ser GitLab, Wikipedia u otros. Si este es el caso decir que se hace en el propio WMarkDown o añadiendo un CSS tal como se muestra a continuación:
SASS (SCSS) | CSS |
---|---|
|
IMPORTANTE: Los enlaces se formatean automáticamente quitando el protocolo y dejando solo hasta el raíz de la URL, substituyendo cualquier caracter fuera del rango de la A-Z y de cualquier dígito por guiones bajos. En caso de duda de como saldría, siempre queda la opción de inspeccionar elemento.
[[html_data { "title" : "WDictionaries - Manual", "url" : "https://wmarkdown.k3y.pw/es/build.html", "author" : "Tarsier, KyMAN, angelus", "since" : 20210623, "version" : 20210624, "key_words" : "Whalers,MarkDown,MediaWiki,WMarkDown,dictionary,wdictioaries,manual,crear,construir", "description" : "Manual del WDictionaries.", "project" : "WDictionaries", "logo" : "https://wdictionaries.k3y.pw/images/logo.png" }]]