13af6ab5fSopenharmony_ci/* 23af6ab5fSopenharmony_ci * Copyright (c) 2023-2024 Huawei Device Co., Ltd. 33af6ab5fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 43af6ab5fSopenharmony_ci * you may not use this file except in compliance with the License. 53af6ab5fSopenharmony_ci * You may obtain a copy of the License at 63af6ab5fSopenharmony_ci * 73af6ab5fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 83af6ab5fSopenharmony_ci * 93af6ab5fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 103af6ab5fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 113af6ab5fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 123af6ab5fSopenharmony_ci * See the License for the specific language governing permissions and 133af6ab5fSopenharmony_ci * limitations under the License. 143af6ab5fSopenharmony_ci */ 153af6ab5fSopenharmony_ci 163af6ab5fSopenharmony_ciexport interface LoggerInterface { 173af6ab5fSopenharmony_ci trace: (message: string) => void; 183af6ab5fSopenharmony_ci debug: (message: string) => void; 193af6ab5fSopenharmony_ci info: (message: string) => void; 203af6ab5fSopenharmony_ci warn: (message: string) => void; 213af6ab5fSopenharmony_ci error: (message: string) => void; 223af6ab5fSopenharmony_ci} 233af6ab5fSopenharmony_ci 243af6ab5fSopenharmony_ciexport class Logger { 253af6ab5fSopenharmony_ci static init(instance: LoggerInterface): void { 263af6ab5fSopenharmony_ci this.instance_ = instance; 273af6ab5fSopenharmony_ci } 283af6ab5fSopenharmony_ci 293af6ab5fSopenharmony_ci static trace(message: string): void { 303af6ab5fSopenharmony_ci this.getInstance().trace(message); 313af6ab5fSopenharmony_ci } 323af6ab5fSopenharmony_ci 333af6ab5fSopenharmony_ci static debug(message: string): void { 343af6ab5fSopenharmony_ci this.getInstance().debug(message); 353af6ab5fSopenharmony_ci } 363af6ab5fSopenharmony_ci 373af6ab5fSopenharmony_ci static info(message: string): void { 383af6ab5fSopenharmony_ci this.getInstance().info(message); 393af6ab5fSopenharmony_ci } 403af6ab5fSopenharmony_ci 413af6ab5fSopenharmony_ci static warn(message: string): void { 423af6ab5fSopenharmony_ci this.getInstance().warn(message); 433af6ab5fSopenharmony_ci } 443af6ab5fSopenharmony_ci 453af6ab5fSopenharmony_ci static error(message: string): void { 463af6ab5fSopenharmony_ci this.getInstance().error(message); 473af6ab5fSopenharmony_ci } 483af6ab5fSopenharmony_ci 493af6ab5fSopenharmony_ci private static getInstance(): LoggerInterface { 503af6ab5fSopenharmony_ci if (!this.instance_) { 513af6ab5fSopenharmony_ci throw new Error('Not initialized'); 523af6ab5fSopenharmony_ci } 533af6ab5fSopenharmony_ci return this.instance_; 543af6ab5fSopenharmony_ci } 553af6ab5fSopenharmony_ci 563af6ab5fSopenharmony_ci private static instance_?: LoggerInterface; 573af6ab5fSopenharmony_ci} 58