179456c69Sopenharmony_ci<?xml version="1.0" encoding="UTF-8"?>
279456c69Sopenharmony_ci<!-- Copyright (c) 2021 Huawei Device Co., Ltd.
379456c69Sopenharmony_ci
479456c69Sopenharmony_ci     Licensed under the Apache License, Version 2.0 (the "License");
579456c69Sopenharmony_ci     you may not use this file except in compliance with the License.
679456c69Sopenharmony_ci     You may obtain a copy of the License at
779456c69Sopenharmony_ci
879456c69Sopenharmony_ci          http://www.apache.org/licenses/LICENSE-2.0
979456c69Sopenharmony_ci
1079456c69Sopenharmony_ci     Unless required by applicable law or agreed to in writing, software
1179456c69Sopenharmony_ci     distributed under the License is distributed on an "AS IS" BASIS,
1279456c69Sopenharmony_ci     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1379456c69Sopenharmony_ci     See the License for the specific language governing permissions and
1479456c69Sopenharmony_ci     limitations under the License.
1579456c69Sopenharmony_ci     
1679456c69Sopenharmony_ci     Notes:
1779456c69Sopenharmony_ci     This is project config file for OpenHarmony OSS Audit Tool, if you have any questions or concerns, please email chenyaxun.
1879456c69Sopenharmony_ci-->
1979456c69Sopenharmony_ci<!-- OAT(OSS Audit Tool) configuration guide:
2079456c69Sopenharmony_cibasedir: Root dir, the basedir + project path is the real source file location.
2179456c69Sopenharmony_cilicensefile: 
2279456c69Sopenharmony_ci1.If the project don't have "LICENSE" in root dir, please define all the license files in this project in , OAT will check license files according to this rule.
2379456c69Sopenharmony_ci
2479456c69Sopenharmony_citasklist(only for batch mode):
2579456c69Sopenharmony_ci1. task: Define oat check thread, each task will start a new thread.
2679456c69Sopenharmony_ci2. task name: Only an name, no practical effect.
2779456c69Sopenharmony_ci3. task policy: Default policy for projects under this task, this field is required and the specified policy must defined in policylist.
2879456c69Sopenharmony_ci4. task filter: Default filefilter for projects under this task, this field is required and the specified filefilter must defined in filefilterlist.
2979456c69Sopenharmony_ci5. task project: Projects to be checked, the path field define the source root dir of the project.
3079456c69Sopenharmony_ci
3179456c69Sopenharmony_ci
3279456c69Sopenharmony_cipolicyList:
3379456c69Sopenharmony_ci1. policy: All policyitems will be merged to default OAT.xml rules, the name of policy doesn't affect OAT check process.
3479456c69Sopenharmony_ci2. policyitem: The fields type, name, path, desc is required, and the fields rule, group, filefilter is optional,the default value is:
3579456c69Sopenharmony_ci<policyitem type="" name="" path="" desc="" rule="may" group="defaultGroup" filefilter="defaultPolicyFilter"/>
3679456c69Sopenharmony_ci3. policyitem type:
3779456c69Sopenharmony_ci    "compatibility" is used to check license compatibility in the specified path; 
3879456c69Sopenharmony_ci    "license" is used to check source license header in the specified path;
3979456c69Sopenharmony_ci    "copyright" is used to check source copyright header in the specified path;
4079456c69Sopenharmony_ci    "import" is used to check source dependency in the specified path, such as import ... ,include ...
4179456c69Sopenharmony_ci    "filetype" is used to check file type in the specified path, supported file types: archive, binary
4279456c69Sopenharmony_ci    "filename" is used to check whether the specified file exists in the specified path(support projectroot in default OAT.xml), supported file names: LICENSE, README, README.OpenSource
4379456c69Sopenharmony_ci
4479456c69Sopenharmony_ci4. policyitem name: This field is used for define the license, copyright, "*" means match all, the "!" prefix means could not match this value. For example, "!GPL" means can not use GPL license. 
4579456c69Sopenharmony_ci5. policyitem path: This field is used for define the source file scope to apply this policyitem, the "!" prefix means exclude the files. For example, "!.*/lib/.*" means files in lib dir will be exclude while process this policyitem.
4679456c69Sopenharmony_ci6. policyitem rule and group: These two fields are used together to merge policy results. "may" policyitems in the same group means any one in this group passed, the result will be passed.
4779456c69Sopenharmony_ci7. policyitem filefilter: Used to bind filefilter which define filter rules.
4879456c69Sopenharmony_ci8. filefilter: Filter rules, the type filename is used to filter file name, the type filepath is used to filter file path.
4979456c69Sopenharmony_ci
5079456c69Sopenharmony_ciNote:If the text contains special characters, please escape them according to the following rules:
5179456c69Sopenharmony_ci" == &gt;
5279456c69Sopenharmony_ci& == &gt;
5379456c69Sopenharmony_ci' == &gt;
5479456c69Sopenharmony_ci< == &gt;
5579456c69Sopenharmony_ci> == &gt;
5679456c69Sopenharmony_ci-->
5779456c69Sopenharmony_ci<configuration>
5879456c69Sopenharmony_ci    <oatconfig>
5979456c69Sopenharmony_ci        <licensefile>COPYING</licensefile>
6079456c69Sopenharmony_ci        <policylist>
6179456c69Sopenharmony_ci            <policy name="projectPolicy" desc="">
6279456c69Sopenharmony_ci                <policyitem type="compatibility" name="OFL-1.1-no-RFN" path="test/shaping/data/in-house/COPYING" desc="license applies to many of the fonts in this folder"/>
6379456c69Sopenharmony_ci            </policy>
6479456c69Sopenharmony_ci        </policylist>
6579456c69Sopenharmony_ci        <filefilterlist>
6679456c69Sopenharmony_ci            <filefilter name="defaultFilter" desc="Files not to check">
6779456c69Sopenharmony_ci                <filteritem type="filename" name="git.mk" desc="a small Makefile to autogenerate .gitignore files"/>
6879456c69Sopenharmony_ci                <filteritem type="filepath" name="test/shaping/texts/in-house/shaper-arabic/script-arabic/language-urdu/crulp/ligatures/LICENSE" desc="license file for language"/>
6979456c69Sopenharmony_ci                <filteritem type="filename" name="mingw-ldd.py" desc="WTFPL"/>
7079456c69Sopenharmony_ci                <filteritem type="filepath" name="util/hb-fc-list.c" desc="This is free software"/>
7179456c69Sopenharmony_ci                <filteritem type="filepath" name="m4/ax_check_link_flag.m4" desc="auto config file"/>
7279456c69Sopenharmony_ci                <filteritem type="filepath" name="m4/ax_pthread.m4" desc="auto config file"/>
7379456c69Sopenharmony_ci                <filteritem type="filepath" name="m4/ax_code_coverage.m4" desc="auto config file"/>
7479456c69Sopenharmony_ci            </filefilter>
7579456c69Sopenharmony_ci            <filefilter name="binaryFileTypePolicyFilter" desc="Filters for binary file policies">
7679456c69Sopenharmony_ci                <filteritem type="filepath" name="test/.*" desc="harfbuzz test file, not to check"/>
7779456c69Sopenharmony_ci                <filteritem type="filepath" name="docs/HarfBuzz.png" desc="harfbuzz file, not to check"/>
7879456c69Sopenharmony_ci            </filefilter>
7979456c69Sopenharmony_ci        </filefilterlist>
8079456c69Sopenharmony_ci    </oatconfig>
8179456c69Sopenharmony_ci</configuration>