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 * A simple utility class.
183af6ab5fSopenharmony_ci */
193af6ab5fSopenharmony_cideclare class Utility {
203af6ab5fSopenharmony_ci  /**
213af6ab5fSopenharmony_ci   * Constructor for Utility.
223af6ab5fSopenharmony_ci   */
233af6ab5fSopenharmony_ci  constructor();
243af6ab5fSopenharmony_ci
253af6ab5fSopenharmony_ci  /**
263af6ab5fSopenharmony_ci   * Concatenates two strings.
273af6ab5fSopenharmony_ci   * @param {string} str1 - The first string.
283af6ab5fSopenharmony_ci   * @param {string} str2 - The second string.
293af6ab5fSopenharmony_ci   * @returns {string} The concatenated string.
303af6ab5fSopenharmony_ci   */
313af6ab5fSopenharmony_ci  concatenateStrings(str1: string, str2: string): string;
323af6ab5fSopenharmony_ci
333af6ab5fSopenharmony_ci  /**
343af6ab5fSopenharmony_ci   * A method to check if a number is even.
353af6ab5fSopenharmony_ci   * @param {number} num - The number to check.
363af6ab5fSopenharmony_ci   * @returns {boolean} True if the number is even, false otherwise.
373af6ab5fSopenharmony_ci   */
383af6ab5fSopenharmony_ci  isEven(num: number): boolean;
393af6ab5fSopenharmony_ci}
403af6ab5fSopenharmony_ci
413af6ab5fSopenharmony_ci/**
423af6ab5fSopenharmony_ci * An interface representing a user profile.
433af6ab5fSopenharmony_ci * @interface
443af6ab5fSopenharmony_ci */
453af6ab5fSopenharmony_cideclare interface UserProfile {
463af6ab5fSopenharmony_ci  username: string;
473af6ab5fSopenharmony_ci  age: number;
483af6ab5fSopenharmony_ci}
493af6ab5fSopenharmony_ci
503af6ab5fSopenharmony_ci/**
513af6ab5fSopenharmony_ci * A function to greet a user.
523af6ab5fSopenharmony_ci * @param {UserProfile} user - The user profile.
533af6ab5fSopenharmony_ci * @returns {string} A personalized greeting.
543af6ab5fSopenharmony_ci */
553af6ab5fSopenharmony_cideclare function greetUser(user: UserProfile): string;
56