Compare commits

..

No commits in common. "c8s" and "c9s" have entirely different histories.
c8s ... c9s

9 changed files with 188 additions and 216 deletions

View File

@ -0,0 +1 @@
4438c0e73dabef733a80132cd99178807cc4a073 AbyssinicaSIL1.200.zip

View File

@ -1,5 +1,5 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE fontconfig SYSTEM "../fonts.dtd"> <!DOCTYPE fontconfig SYSTEM "urn:fontconfig:fonts.dtd">
<fontconfig> <fontconfig>
<!-- Generic names --> <!-- Generic names -->
<alias> <alias>
@ -16,7 +16,7 @@
</prefer> </prefer>
</alias> </alias>
<match target="font"> <match target="font">
<test name="family" ignore-blanks="yes"> <test name="family" ignore-blanks="true">
<string>Abyssinica SIL</string> <string>Abyssinica SIL</string>
</test> </test>
<edit name="autohint" mode="assign"> <edit name="autohint" mode="assign">

View File

@ -1,6 +1,6 @@
--- !Policy --- !Policy
product_versions: product_versions:
- rhel-8 - rhel-9
decision_context: osci_compose_gate decision_context: osci_compose_gate
rules: rules:
- !PassingTestCaseRule {test_case_name: osci.brew-build.tier0.functional} - !PassingTestCaseRule {test_case_name: osci.brew-build.tier0.functional}

View File

@ -1,26 +1,20 @@
%global fontname sil-abyssinica
%global archive_name AbyssinicaSIL
%global fontconf 66-%{fontname}.conf
Name: %{fontname}-fonts
Version: 1.200 Version: 1.200
Release: 14%{?dist} Release: 23%{?dist}
Summary: SIL Abyssinica fonts
License: OFL %global foundry SIL
URL: http://scripts.sil.org/AbyssinicaSIL %global fontlicense OFL
# download from http://scripts.sil.org/cms/scripts/render_download.php?site_id=nrsi&format=file&media_id=AbyssinicaSIL1.200.zip&filename=AbyssinicaSIL1.200.zip %global fontlicenses OFL.txt
Source0: %{archive_name}%{version}.zip %global fontdocs *.txt documentation/*.txt
Source1: %{fontconf} %global fontdocsex %{fontlicenses}
Source2: %{fontname}.metainfo.xml
BuildArch: noarch %global fontfamily Abyssinica SIL
Requires: fontpackages-filesystem %global fontsummary SIL Abyssinica fonts
BuildRequires: fontpackages-devel %global projectname AbyssinicaSIL
BuildRequires: dos2unix %global archivename %{lua:t=string.gsub(rpm.expand("%{fontfamily}"), "[%p%s]+", ""); print(t)}%{version}
URL: https://software.sil.org/%{projectname}/
%global fonts *.ttf
%description %global fontconfs %{SOURCE1}
%global fontdescription %{expand:
SIL Abyssinica is a Unicode typeface family containing glyphs for the SIL Abyssinica is a Unicode typeface family containing glyphs for the
Ethiopic script. Ethiopic script.
@ -32,41 +26,62 @@ non-Unicode characters in the Private Use Area (see Private-use (PUA)
characters supported by Abyssinica SIL). characters supported by Abyssinica SIL).
Abyssinica SIL is based on Ethiopic calligraphic traditions. This release is Abyssinica SIL is based on Ethiopic calligraphic traditions. This release is
a regular typeface, with no bold or italic version available or planned. a regular typeface, with no bold or italic version available or planned.}
# download from http://scripts.sil.org/cms/scripts/render_download.php?site_id=nrsi&format=file&media_id=AbyssinicaSIL1.200.zip&filename=AbyssinicaSIL1.200.zip
Source0: %{archivename}.zip
Source1: 66-%{fontpkgname}.conf
%fontpkg
%prep %prep
%setup -q -n %{archive_name}-%{version} %setup -q -n %{projectname}-%{version}
%linuxtext FONTLOG.txt OFL.txt OFL-FAQ.txt README.txt documentation/DOCUMENTATION.txt
%build %build
dos2unix FONTLOG.txt OFL.txt OFL-FAQ.txt README.txt documentation/DOCUMENTATION.txt %fontbuild
%install %install
#fonts %fontinstall
install -d -m 0755 %{buildroot}%{_fontdir}
install -m 0644 *.ttf %{buildroot}%{_fontdir}
#fontconfig %check
install -d -m 0755 %{buildroot}%{_fontconfig_templatedir} \ %fontcheck
%{buildroot}%{_fontconfig_confdir}
install -m 0644 -p %{SOURCE1} %{buildroot}%{_fontconfig_templatedir}/%{fontconf}
ln -s %{_fontconfig_templatedir}/%{fontconf} \
%{buildroot}%{_fontconfig_confdir}/%{fontconf}
# Add AppStream metadata %fontfiles
install -Dm 0644 -p %{SOURCE2} \
%{buildroot}%{_datadir}/appdata/%{fontname}.metainfo.xml
%_font_pkg -f %{fontconf} *.ttf
%doc FONTLOG.txt OFL.txt OFL-FAQ.txt README.txt
%doc documentation/*
%{_datadir}/appdata/%{fontname}.metainfo.xml
%changelog %changelog
* Mon Nov 18 2019 Parag Nemade <pnemade AT redhat DOT com> - 1.200-14 * Tue Aug 10 2021 Mohan Boddu <mboddu@redhat.com>
- Resolves:rh#1682211 - Added CI tests - Rebuilt for IMA sigs, glibc 2.34, aarch64 flags
Related: rhbz#1991688
* Fri Apr 16 2021 Mohan Boddu <mboddu@redhat.com>
- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937
* Wed Jan 27 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-21
- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild
* Wed Jul 29 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-20
- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
* Sun May 24 2020 Parag Nemade <pnemade AT redhat DOT com> - 1.200-19
- Update fontconfig DTD id in conf file
* Thu Mar 12 2020 Parag Nemade <pnemade AT redhat DOT com> - 1.200-18
- Convert to new fonts packaging guidelines
* Thu Jan 30 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-17
- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
* Fri Jul 26 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-16
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
* Sat Feb 02 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-15
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
* Sat Jul 14 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
* Fri Feb 09 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-13 * Fri Feb 09 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.200-13
- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild - Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild

View File

@ -1,17 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!-- Copyright 2014 Parag Nemade <pnemade AT redhat DOT com> -->
<component type="font">
<id>sil-abyssinica</id>
<metadata_license>CC-BY-3.0</metadata_license>
<name>Abyssinica SIL</name>
<summary>SIL Abyssinica fonts</summary>
<description>
<p>
SIL Abyssinica is a Unicode typeface family containing glyphs for the
Ethiopic script.
</p>
</description>
<updatecontact>pnemade_at_redhat_dot_com</updatecontact>
<url type="homepage">http://scripts.sil.org/AbyssinicaSIL</url>
</component>

View File

@ -1 +1 @@
SHA512 (AbyssinicaSIL1.200.zip) = 49c74476da85a38b0bccf341953198c5f5f750fbeaec724e2d50ea305d8c127b928304d7410b001997a3c91d4d5d5144c226c29873eae9e18de38cdfef7a6ada 8210f0468e297009638be9cbe9fb4bda AbyssinicaSIL1.200.zip

View File

@ -28,7 +28,7 @@ _EOF_
PROG="${PROG:-${0##*/}}" PROG="${PROG:-${0##*/}}"
DEBUG="${DEBUG:-}" DEBUG="${DEBUG:-}"
OPT_LANG="${OPT_LANG:-en}" OPT_LANG="${OPT_LANG:-en}"
OPT_PATH=() OPT_PATH="${OPT_PATH:-}"
OPT_ARTIFACTS_DIR="${OPT_ARTIFACTS_DIR:-}" OPT_ARTIFACTS_DIR="${OPT_ARTIFACTS_DIR:-}"
OPT_EXCLUDE=() OPT_EXCLUDE=()
OPT_INCLUDE=() OPT_INCLUDE=()
@ -55,7 +55,7 @@ while [[ $# -gt 0 ]]; do
shift 2 shift 2
;; ;;
-p|--path) -p|--path)
OPT_PATH+=("$2") OPT_PATH="$2"
shift 2 shift 2
;; ;;
-l|--lang) -l|--lang)
@ -84,12 +84,36 @@ if [ -z "$OPT_ARTIFACTS_DIR" ] || [ -z "$OPT_LANG" ] || [ -z "$OPT_PATH" ]; then
exit 0 exit 0
fi fi
STR_TEST_DASHED=$(echo "${OPT_NAME:-$OPT_LANG}" | sed -e 's/\//-/g') expand_regex() {
local e ret=()
local path="$1"
shift
(cd $path;
for e; do
debug "$e"
set +f
local x=$(find -regextype posix-egrep -regex "./$e" -print|sed -e 's,^\./,,g')
ret+=($x)
set -f
echo ${ret[@]}
done)
echo ${ret[@]}
}
OPT_INCLUDE=($(expand_regex $OPT_PATH ${OPT_INCLUDE[@]}))
OPT_EXCLUDE=($(expand_regex $OPT_PATH ${OPT_EXCLUDE[@]}))
debug "Path: $OPT_PATH"
debug "Lang: $OPT_LANG"
debug "Artifacts dir: $OPT_ARTIFACTS_DIR"
debug "Exclude: ${OPT_EXCLUDE[@]}"
debug "Include: ${OPT_INCLUDE[@]}"
STR_TEST_DASHED=$(echo "${OPT_NAME:-${OPT_LANG}_${OPT_PATH}}" | sed -e 's/\//-/g')
clean_exit() { clean_exit() {
rc=$?; rc=$?;
trap - SIGINT SIGTERM SIGABRT EXIT trap - SIGINT SIGTERM SIGABRT EXIT
echo "Run test $OPT_LANG: done." echo "Run test $OPT_PATH: done."
for pid in $(ps -o pid --no-headers --ppid $$); do for pid in $(ps -o pid --no-headers --ppid $$); do
if [ -n "$(ps -p $pid -o pid=)" ]; then if [ -n "$(ps -p $pid -o pid=)" ]; then
kill -s HUP $pid kill -s HUP $pid
@ -106,8 +130,6 @@ clean_exit() {
status="FAIL" status="FAIL"
elif grep -q "RESULT: PASS" "$log_file_path"; then elif grep -q "RESULT: PASS" "$log_file_path"; then
status="PASS" status="PASS"
elif grep -q "WARN" "$log_file_path"; then
status="ERROR"
elif grep -q "FAIL" "$log_file_path"; then elif grep -q "FAIL" "$log_file_path"; then
status="FAIL" status="FAIL"
elif grep -q "PASS" "$log_file_path"; then elif grep -q "PASS" "$log_file_path"; then
@ -115,12 +137,12 @@ clean_exit() {
else else
status="ERROR" status="ERROR"
fi fi
echo "$status $OPT_LANG" >> "$OPT_ARTIFACTS_DIR/test.log" echo "$status $OPT_PATH" >> "$OPT_ARTIFACTS_DIR/test.log"
mv "$log_file_path" "$OPT_ARTIFACTS_DIR/${status}_${log_file_name}" mv "$log_file_path" "$OPT_ARTIFACTS_DIR/${status}_${log_file_name}"
local results="$OPT_ARTIFACTS_DIR/results.yml" local results="$OPT_ARTIFACTS_DIR/results.yml"
local result=$(echo $status | tr '[:upper:]' '[:lower:]') local result=$(echo $status | tr '[:upper:]' '[:lower:]')
test -f "$results" || echo 'results:' > "$results" test -f "$results" || echo 'results:' > "$results"
echo "- {result: $result, test: $OPT_LANG}" >> "$results" echo "- {result: $result, test: $OPT_PATH}" >> "$results"
exit 0 exit 0
} }
trap clean_exit SIGINT SIGTERM SIGABRT EXIT trap clean_exit SIGINT SIGTERM SIGABRT EXIT
@ -131,53 +153,6 @@ logfile_stdout="$OPT_ARTIFACTS_DIR/$STR_TEST_DASHED.log"
logfile_stderr="$OPT_ARTIFACTS_DIR/$STR_TEST_DASHED-err.log" logfile_stderr="$OPT_ARTIFACTS_DIR/$STR_TEST_DASHED-err.log"
exec 3>&1 4>&2 1> >(tee -a "$logfile_stdout" >&3) 2> >(tee -a "$logfile_stderr" >&4) exec 3>&1 4>&2 1> >(tee -a "$logfile_stdout" >&3) 2> >(tee -a "$logfile_stderr" >&4)
expand_regex() {
local p ret=()
local regex="$1"
shift
debug "Expanding $regex"
for p; do
set +f
debug "$p: $regex"
(cd $p;
local x=$(find -regextype posix-egrep -regex "./$regex" -print|sed -e 's,^\./,,g')
debug "$x"
ret+=($x)
set -f
echo -n ${ret[@]}
)
done
echo -n ${ret[@]}
}
iv=()
ev=()
x=()
for p in ${OPT_INCLUDE[@]}; do
x=$(expand_regex $p ${OPT_PATH[@]})
if [ "x$x" == "x" ]; then
echo "RESULT: WARN: No matches on \"$p\". maybe typo or something changed?"
continue
fi
iv=("${iv[@]}" "${x[@]}")
done
for p in ${OPT_EXCLUDE[@]}; do
x=$(expand_regex $p ${OPT_PATH[@]})
if [ "x$x" == "x" ]; then
echo "RESULT: WARN: No matches on \"$p\". maybe typo or something changed?"
continue
fi
ev=("${ev[@]}" "${x[@]}")
done
OPT_EXCLUDE=(${ev[@]})
OPT_INCLUDE=(${iv[@]})
debug "Path: ${OPT_PATH[@]}"
debug "Lang: $OPT_LANG"
debug "Artifacts dir: $OPT_ARTIFACTS_DIR"
debug "Exclude: ${#OPT_EXCLUDE[@]}: ${OPT_EXCLUDE[@]}"
debug "Include: ${#OPT_INCLUDE[@]}: ${OPT_INCLUDE[@]}"
contains() { contains() {
local e match="$1" local e match="$1"
shift shift
@ -187,9 +162,8 @@ contains() {
debug "Check language coverage" debug "Check language coverage"
set +f set +f
for p in ${OPT_PATH[@]}; do for i in `find $OPT_PATH -regex '.*/*\.\(t1\)?\(ttf\)?\(otf\)?\(ttc\)?\(pcf.*\)?\(pfa\)?'`; do
for i in `find $p -regex '.*/*\.\(t1\)?\(ttf\)?\(otf\)?\(ttc\)?\(pcf.*\)?\(pfa\)?'`; do set -f
set -f
debug "$i" debug "$i"
if test -f $i; then if test -f $i; then
n=`basename $i` n=`basename $i`
@ -210,7 +184,6 @@ for p in ${OPT_PATH[@]}; do
debug "$i isn't targeted file" debug "$i isn't targeted file"
continue continue
fi fi
NOT_MATCHED=("${NOT_MATCHED[@]/$n}")
fi fi
debug " $i" debug " $i"
res=`fc-validate -l $OPT_LANG $i` res=`fc-validate -l $OPT_LANG $i`
@ -220,5 +193,5 @@ for p in ${OPT_PATH[@]}; do
echo "RESULT: PASS: $i satisfy $OPT_LANG language coverage." echo "RESULT: PASS: $i satisfy $OPT_LANG language coverage."
fi fi
fi fi
done
done done

View File

@ -2,7 +2,7 @@
- block: - block:
- name: language coverage - name: language coverage
script: run-lang-coverage-test --lang "{{ item }}" {% if coverage.values is not defined or coverage[item].path_prefix is not defined %} --path {{ path_prefix }} {% else %} {{ '--path "' + (coverage[item].path_prefix | join('" --path "')) + '"' }} {% endif %} --artifactsdir "{{ remote_artifacts }}" {{ "" if coverage.values is not defined or coverage[item].name is not defined else "--name " + coverage[item].name }} {{ "" if coverage.values is not defined or coverage[item].exclude is not defined else '--exclude "' + (coverage[item].exclude | join('" --exclude "')) + '"'}} {{ "" if coverage.values is not defined or coverage[item].include is not defined else '--include "' + (coverage[item].include | join('" --include "')) + '"'}} script: run-lang-coverage-test --lang "{{ item }}" --path "{{ path_prefix }}" --artifactsdir "{{ remote_artifacts }}" {{ "" if coverage.values is not defined or coverage[item].name is not defined else "--name " + coverage[item].name }} {{ "" if coverage.values is not defined or coverage[item].exclude is not defined else '--exclude "' + (coverage[item].exclude | join('" --exclude "')) + '"'}} {{ "" if coverage.values is not defined or coverage[item].include is not defined else '--include "' + (coverage[item].include | join('" --include "')) + '"'}}
with_items: with_items:
- "{{ coverage if coverage.keys is not defined else coverage.keys()|list }}" - "{{ coverage if coverage.keys is not defined else coverage.keys()|list }}"
- name: generic family assignment - name: generic family assignment

View File

@ -5,7 +5,7 @@
- role: custom-test-fonts - role: custom-test-fonts
required_packages: required_packages:
- sil-abyssinica-fonts - sil-abyssinica-fonts
path_prefix: /usr/share/fonts/sil-abyssinica path_prefix: /usr/share/fonts/sil-abyssinica-fonts
package: sil-abyssinica-fonts package: sil-abyssinica-fonts
coverage: coverage:
- en - en