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