13af6ab5fSopenharmony_ci/* 23af6ab5fSopenharmony_ci * Copyright (c) 2023 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_ci/** 173af6ab5fSopenharmony_ci * This is a sample class. 183af6ab5fSopenharmony_ci */ 193af6ab5fSopenharmony_cideclare class MyClass { 203af6ab5fSopenharmony_ci name: string; 213af6ab5fSopenharmony_ci 223af6ab5fSopenharmony_ci /** 233af6ab5fSopenharmony_ci * Constructor for MyClass. 243af6ab5fSopenharmony_ci * @param {string} name - The name parameter. 253af6ab5fSopenharmony_ci */ 263af6ab5fSopenharmony_ci constructor(name: string); 273af6ab5fSopenharmony_ci 283af6ab5fSopenharmony_ci /** 293af6ab5fSopenharmony_ci * A simple function. 303af6ab5fSopenharmony_ci * @param {number} x - The first number. 313af6ab5fSopenharmony_ci * @param {number} y - The second number. 323af6ab5fSopenharmony_ci * @returns {number} The sum of x and y. 333af6ab5fSopenharmony_ci */ 343af6ab5fSopenharmony_ci add(x: number, y: number): number; 353af6ab5fSopenharmony_ci 363af6ab5fSopenharmony_ci /** 373af6ab5fSopenharmony_ci * A method that greets. 383af6ab5fSopenharmony_ci * @param {string} greeting - The greeting message. 393af6ab5fSopenharmony_ci */ 403af6ab5fSopenharmony_ci greet(greeting: string): void; 413af6ab5fSopenharmony_ci} 423af6ab5fSopenharmony_ci 433af6ab5fSopenharmony_ci/** 443af6ab5fSopenharmony_ci * A simple function declaration. 453af6ab5fSopenharmony_ci * @param {string} message - The message parameter. 463af6ab5fSopenharmony_ci * @returns {string} The formatted message. 473af6ab5fSopenharmony_ci */ 483af6ab5fSopenharmony_cideclare function formatMessage(message: string): string; 493af6ab5fSopenharmony_ci 503af6ab5fSopenharmony_ci/** 513af6ab5fSopenharmony_ci * An interface representing a point. 523af6ab5fSopenharmony_ci * @interface 533af6ab5fSopenharmony_ci */ 543af6ab5fSopenharmony_cideclare interface Point { 553af6ab5fSopenharmony_ci x: number; 563af6ab5fSopenharmony_ci y: number; 573af6ab5fSopenharmony_ci} 583af6ab5fSopenharmony_ci 593af6ab5fSopenharmony_ci/** 603af6ab5fSopenharmony_ci * A type alias for a callback function. 613af6ab5fSopenharmony_ci * @typedef {function} Callback 623af6ab5fSopenharmony_ci * @param {string} result - The result parameter. 633af6ab5fSopenharmony_ci */ 643af6ab5fSopenharmony_citype Callback = (result: string) => void; 653af6ab5fSopenharmony_ci 663af6ab5fSopenharmony_ci/** 673af6ab5fSopenharmony_ci * An enumeration of colors. 683af6ab5fSopenharmony_ci * @enum {string} 693af6ab5fSopenharmony_ci */ 703af6ab5fSopenharmony_cideclare enum Color { 713af6ab5fSopenharmony_ci Red = "RED", 723af6ab5fSopenharmony_ci Green = "GREEN", 733af6ab5fSopenharmony_ci Blue = "BLUE", 743af6ab5fSopenharmony_ci} 75