Compare commits
No commits in common. "c8s" and "c8-beta" have entirely different histories.
2
.gitignore
vendored
2
.gitignore
vendored
@ -1 +1 @@
|
|||||||
/lv_LV-1.0.0.oxt
|
SOURCES/lv_LV-1.0.0.oxt
|
||||||
|
1
.openoffice-lv.metadata
Normal file
1
.openoffice-lv.metadata
Normal file
@ -0,0 +1 @@
|
|||||||
|
b78ce560b15f860026d3f2ad26c363c0cf29c190 SOURCES/lv_LV-1.0.0.oxt
|
@ -1,6 +0,0 @@
|
|||||||
--- !Policy
|
|
||||||
product_versions:
|
|
||||||
- rhel-8
|
|
||||||
decision_context: osci_compose_gate
|
|
||||||
rules:
|
|
||||||
- !PassingTestCaseRule {test_case_name: osci.brew-build.tier0.functional}
|
|
1
sources
1
sources
@ -1 +0,0 @@
|
|||||||
SHA512 (lv_LV-1.0.0.oxt) = e9f3dea2ed3291a3448143261f3c812e1b6ea30036b8bf800727a9dbaa82beb59785811f00faf541cf1d38f46204704098d909b63da7c18fce42fd13f1ad845d
|
|
@ -1,23 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
echo "=== Tests for hunspell-lv ==="
|
|
||||||
python3 test_dic_availability.py
|
|
||||||
echo ""
|
|
||||||
python3 test_suggest_words.py
|
|
||||||
|
|
||||||
echo ""
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
echo "=== Tests for hyphen-lv ==="
|
|
||||||
gcc -Wall test-hyphen.c -o test-hyphen -lhyphen
|
|
||||||
|
|
||||||
echo "Test to hyphenate given word => pretpulksteņrādītājvirziens"
|
|
||||||
echo "pretpulksteņrādītājvirziens" | ./test-hyphen /usr/share/hyphen/hyph_lv_LV.dic /dev/stdin
|
|
||||||
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
echo "Test to give all possible ways to hyphenate the given word => pretpulksteņrādītājvirziens"
|
|
||||||
echo "pretpulksteņrādītājvirziens" | ./test-hyphen -d /usr/share/hyphen/hyph_lv_LV.dic /dev/stdin
|
|
||||||
|
|
@ -1,212 +0,0 @@
|
|||||||
/* This test file is part of upstream hyphen project */
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <ctype.h>
|
|
||||||
|
|
||||||
#include "hyphen.h"
|
|
||||||
|
|
||||||
#define BUFSIZE 1000
|
|
||||||
|
|
||||||
void help() {
|
|
||||||
fprintf(stderr,"correct syntax is:\n");
|
|
||||||
fprintf(stderr,"example [-d | -dd] hyphen_dictionary_file file_of_words_to_check\n");
|
|
||||||
fprintf(stderr,"-o = use old algorithm (without non-standard hyphenation)\n");
|
|
||||||
fprintf(stderr,"-d = hyphenation with listing of the possible hyphenations\n");
|
|
||||||
fprintf(stderr,"-n = print hyphenation vector\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* get a pointer to the nth 8-bit or UTF-8 character of the word */
|
|
||||||
char * hindex(char * word, int n, int utf8) {
|
|
||||||
int j = 0;
|
|
||||||
while (j < n) {
|
|
||||||
j++;
|
|
||||||
word++;
|
|
||||||
while (utf8 && ((((unsigned char) *word) >> 6) == 2)) word++;
|
|
||||||
}
|
|
||||||
return word;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* list possible hyphenations with -dd option (example for the usage of the hyphenate2() function) */
|
|
||||||
void single_hyphenations(char * word, char * hyphen, char ** rep, int * pos, int * cut, int utf8) {
|
|
||||||
int i, k, j = 0;
|
|
||||||
char r;
|
|
||||||
for (i = 0; (i + 1) < strlen(word); i++) {
|
|
||||||
if (utf8 && ((((unsigned char) word[i]) >> 6) == 2)) continue;
|
|
||||||
if ((hyphen[j] & 1)) {
|
|
||||||
if (rep && rep[j]) {
|
|
||||||
k = hindex(word, j - pos[j] + 1, utf8) - word;
|
|
||||||
r = word[k];
|
|
||||||
word[k] = 0;
|
|
||||||
printf(" - %s%s", word, rep[j]);
|
|
||||||
word[k] = r;
|
|
||||||
printf("%s\n", hindex(word + k, cut[j], utf8));
|
|
||||||
} else {
|
|
||||||
k = hindex(word, j + 1, utf8) - word;
|
|
||||||
r = word[k];
|
|
||||||
word[k] = 0;
|
|
||||||
printf(" - %s=", word);
|
|
||||||
word[k] = r;
|
|
||||||
printf("%s\n", word + k);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
j++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
main(int argc, char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
HyphenDict *dict;
|
|
||||||
int df;
|
|
||||||
int wtc;
|
|
||||||
FILE* wtclst;
|
|
||||||
int k, n, i, j, c;
|
|
||||||
char buf[BUFSIZE + 1];
|
|
||||||
int nHyphCount;
|
|
||||||
char *hyphens;
|
|
||||||
char *lcword;
|
|
||||||
char *hyphword;
|
|
||||||
char hword[BUFSIZE * 2];
|
|
||||||
int arg = 1;
|
|
||||||
int optd = 1;
|
|
||||||
int optn = 0;
|
|
||||||
int optdd = 0;
|
|
||||||
char ** rep;
|
|
||||||
int * pos;
|
|
||||||
int * cut;
|
|
||||||
|
|
||||||
/* first parse the command line options */
|
|
||||||
/* arg1 - hyphen dictionary file, arg2 - file of words to check */
|
|
||||||
|
|
||||||
if (argv[arg]) {
|
|
||||||
if (strcmp(argv[arg], "-o") == 0) {
|
|
||||||
optd = 0;
|
|
||||||
arg++;
|
|
||||||
}
|
|
||||||
if (strcmp(argv[arg], "-n") == 0) {
|
|
||||||
optn = 1;
|
|
||||||
arg++;
|
|
||||||
}
|
|
||||||
if (argv[arg] && strcmp(argv[arg], "-d") == 0) {
|
|
||||||
optd = 1;
|
|
||||||
optdd = 1;
|
|
||||||
arg++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (argv[arg]) {
|
|
||||||
df = arg++;
|
|
||||||
} else {
|
|
||||||
help();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (argv[arg]) {
|
|
||||||
wtc = arg++;
|
|
||||||
} else {
|
|
||||||
help();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* load the hyphenation dictionary */
|
|
||||||
if ((dict = hnj_hyphen_load(argv[df])) == NULL) {
|
|
||||||
fprintf(stderr, "Couldn't find file %s\n", argv[df]);
|
|
||||||
fflush(stderr);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* open the words to check list */
|
|
||||||
wtclst = fopen(argv[wtc],"r");
|
|
||||||
if (!wtclst) {
|
|
||||||
fprintf(stderr,"Error - could not open file of words to check\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* now read each word from the wtc file */
|
|
||||||
while(fgets(buf,BUFSIZE,wtclst) != NULL) {
|
|
||||||
k = strlen(buf);
|
|
||||||
if (k && buf[k - 1] == '\n') buf[k - 1] = '\0';
|
|
||||||
if (k >=2 && buf[k - 2] == '\r') buf[k-- - 2] = '\0';
|
|
||||||
|
|
||||||
/* set aside some buffers to hold lower cased */
|
|
||||||
/* and hyphen information */
|
|
||||||
lcword = (char *) malloc(k+1);
|
|
||||||
hyphens = (char *)malloc(k+5);
|
|
||||||
/* basic ascii lower-case, not suitable for real-world usage*/
|
|
||||||
for (i = 0; i < k; ++i) {
|
|
||||||
lcword[i] = buf[i];
|
|
||||||
if ( (lcword[i] >= 'A') && (lcword[i] <= 'Z') )
|
|
||||||
lcword[i] += 32;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* first remove any trailing periods */
|
|
||||||
n = k-1;
|
|
||||||
while((n >=0) && (lcword[n] == '.')) n--;
|
|
||||||
n++;
|
|
||||||
|
|
||||||
/* now actually try to hyphenate the word */
|
|
||||||
|
|
||||||
rep = NULL;
|
|
||||||
pos = NULL;
|
|
||||||
cut = NULL;
|
|
||||||
hword[0] = '\0';
|
|
||||||
|
|
||||||
if ((!optd && hnj_hyphen_hyphenate(dict, lcword, n-1, hyphens)) ||
|
|
||||||
(optd && hnj_hyphen_hyphenate2(dict, lcword, n-1, hyphens, hword, &rep, &pos, &cut))) {
|
|
||||||
free(hyphens);
|
|
||||||
free(lcword);
|
|
||||||
fprintf(stderr, "hyphenation error\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (optn) fprintf(stderr, "%s\n", hyphens);
|
|
||||||
|
|
||||||
if (!optd) {
|
|
||||||
/* now backfill hyphens[] for any removed periods */
|
|
||||||
for (c = n; c < k; c++) hyphens[c] = '0';
|
|
||||||
hyphens[k] = '\0';
|
|
||||||
|
|
||||||
/* now create a new char string showing hyphenation positions */
|
|
||||||
/* count the hyphens and allocate space for the new hypehanted string */
|
|
||||||
nHyphCount = 0;
|
|
||||||
for (i = 0; i < n; i++)
|
|
||||||
if (hyphens[i]&1)
|
|
||||||
nHyphCount++;
|
|
||||||
hyphword = (char *) malloc(k+1+nHyphCount);
|
|
||||||
j = 0;
|
|
||||||
for (i = 0; i < n; i++) {
|
|
||||||
hyphword[j++] = buf[i];
|
|
||||||
if (hyphens[i]&1) {
|
|
||||||
hyphword[j++] = '-';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
hyphword[j] = '\0';
|
|
||||||
fprintf(stdout,"%s\n",hyphword);
|
|
||||||
fflush(stdout);
|
|
||||||
free(hyphword);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout,"%s\n", hword);
|
|
||||||
|
|
||||||
|
|
||||||
if (optdd) single_hyphenations(lcword, hyphens, rep, pos, cut, dict->utf8);
|
|
||||||
if (rep) {
|
|
||||||
for (i = 0; i < n - 1; i++) {
|
|
||||||
if (rep[i]) free(rep[i]);
|
|
||||||
}
|
|
||||||
free(rep);
|
|
||||||
free(pos);
|
|
||||||
free(cut);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
free(hyphens);
|
|
||||||
free(lcword);
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(wtclst);
|
|
||||||
hnj_hyphen_free(dict);
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
#!/usr/bin/python3
|
|
||||||
|
|
||||||
import enchant
|
|
||||||
|
|
||||||
lang = "lv"
|
|
||||||
try:
|
|
||||||
dic = enchant.request_dict(lang)
|
|
||||||
print("Dictionary for {0} language is available for use".format(lang))
|
|
||||||
except enchant.errors.DictNotFoundError:
|
|
||||||
print("Dictionary is not installed for use")
|
|
@ -1,10 +0,0 @@
|
|||||||
#!/usr/bin/python3
|
|
||||||
|
|
||||||
import enchant
|
|
||||||
|
|
||||||
wdlst = [ "Sveikii", "atsēstis", "buķtes"]
|
|
||||||
dic = enchant.Dict("lv")
|
|
||||||
for wd in wdlst:
|
|
||||||
dic.check(wd)
|
|
||||||
print("input word = {0}, Suggestions => {1}".format(wd, dic.suggest(wd)))
|
|
||||||
|
|
@ -1,14 +0,0 @@
|
|||||||
- hosts: localhost
|
|
||||||
roles:
|
|
||||||
- role: standard-test-basic
|
|
||||||
required_packages:
|
|
||||||
- python3-enchant
|
|
||||||
- hyphen-devel
|
|
||||||
- gcc
|
|
||||||
tags:
|
|
||||||
- classic
|
|
||||||
tests:
|
|
||||||
- sample:
|
|
||||||
dir: scripts/
|
|
||||||
run: ./run_tests.sh
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user