13af6ab5fSopenharmony_ci/*
23af6ab5fSopenharmony_ci * Copyright (c) 2021-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_cifunction main(): void {
173af6ab5fSopenharmony_ci    let a: byte = 2;
183af6ab5fSopenharmony_ci    let b: short = 20000;
193af6ab5fSopenharmony_ci    let c: int = 2000000;
203af6ab5fSopenharmony_ci    let d: long = 200000000000;
213af6ab5fSopenharmony_ci    let e: float = 2.2;
223af6ab5fSopenharmony_ci    let f: double = 2.2222222222;
233af6ab5fSopenharmony_ci    let g: double[] = [a, b, c, d, e, f];
243af6ab5fSopenharmony_ci    assert g[0] == 2;
253af6ab5fSopenharmony_ci    assert g[1] == 20000;
263af6ab5fSopenharmony_ci    assert g[2] == 2000000;
273af6ab5fSopenharmony_ci    assert g[3] == 200000000000;
283af6ab5fSopenharmony_ci    assert g[4] == (2.2 as float);
293af6ab5fSopenharmony_ci    assert g[5] == 2.2222222222;
303af6ab5fSopenharmony_ci
313af6ab5fSopenharmony_ci    const h: byte = 2;
323af6ab5fSopenharmony_ci    const i: short = 2;
333af6ab5fSopenharmony_ci    const j: int = 2;
343af6ab5fSopenharmony_ci    const k: long = 2;
353af6ab5fSopenharmony_ci    const l: float = 2.0;
363af6ab5fSopenharmony_ci    const m: double = 2.0;
373af6ab5fSopenharmony_ci    const n: byte[] = [h, i, j, k, l, m];
383af6ab5fSopenharmony_ci    assert n[0] == 2;
393af6ab5fSopenharmony_ci    assert n[1] == 2;
403af6ab5fSopenharmony_ci    assert n[2] == 2;
413af6ab5fSopenharmony_ci    assert n[3] == 2;
423af6ab5fSopenharmony_ci    assert n[4] == 2;
433af6ab5fSopenharmony_ci    assert n[5] == 2;
443af6ab5fSopenharmony_ci
453af6ab5fSopenharmony_ci    let o: Object[] = [1, 1.1, "testStr", new Int(2), d, k];
463af6ab5fSopenharmony_ci    assert (o[0] as Int) == 1;
473af6ab5fSopenharmony_ci    assert (o[1] as Double) == 1.1;
483af6ab5fSopenharmony_ci    assert (o[2] as String).equals("testStr");
493af6ab5fSopenharmony_ci    assert (o[3] as Int) == 2;
503af6ab5fSopenharmony_ci    assert (o[4] as Long) == 200000000000;
513af6ab5fSopenharmony_ci    assert (o[5] as Long) == 2;
523af6ab5fSopenharmony_ci
533af6ab5fSopenharmony_ci    let p: long[] = [new Int(3), new Short(2 as short), new Long(4)];
543af6ab5fSopenharmony_ci    assert p[0] == 3;
553af6ab5fSopenharmony_ci    assert p[1] == 2;
563af6ab5fSopenharmony_ci    assert p[2] == 4;
573af6ab5fSopenharmony_ci}
58