17f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*
27f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * Copyright (C) 2008 The Android Open Source Project
37f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project *
47f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
57f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * you may not use this file except in compliance with the License.
67f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * You may obtain a copy of the License at
77f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project *
87f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
97f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project *
107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * Unless required by applicable law or agreed to in writing, software
117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * See the License for the specific language governing permissions and
147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * limitations under the License.
157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project */
167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- includes ----------------------------------------------------------- */
187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_BasicEm/Functions.h"
207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_BasicEm/Math.h"
217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_BitFeatureEm/Sequence.h"
227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ auxiliary functions } ---------------------------------------- */
287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ constructor / destructor } ----------------------------------- */
367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bbf_Sequence_init( struct bbs_Context* cpA,
427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project					    struct bbf_Sequence* ptrA )
437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_memset16( ptrA->ftrPtrArrE, 0, bbs_SIZEOF16( ptrA->ftrPtrArrE ) );
457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbf_Feature_init( cpA, &ptrA->baseE );
477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	ptrA->baseE.typeE = ( uint32 )bbf_FT_SEQUENCE;
487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	ptrA->baseE.vpActivityE = bbf_Sequence_activity;
497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	ptrA->sizeE = 0;
507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_Int32Arr_init( cpA, &ptrA->thrArrE );
517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_UInt16Arr_init( cpA, &ptrA->wgtArrE );
527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_UInt16Arr_init( cpA, &ptrA->dataArrE );
537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bbf_Sequence_exit( struct bbs_Context* cpA,
587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project					    struct bbf_Sequence* ptrA )
597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint16 iL;
617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	for( iL = 0; iL < ptrA->sizeE; iL++ ) bbf_featureExit( cpA, ptrA->ftrPtrArrE[ iL ] );
627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_memset16( ptrA->ftrPtrArrE, 0, bbs_SIZEOF16( ptrA->ftrPtrArrE ) );
647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbf_Feature_exit( cpA, &ptrA->baseE );
657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	ptrA->sizeE = 0;
667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_Int32Arr_exit( cpA, &ptrA->thrArrE );
677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_UInt16Arr_exit( cpA, &ptrA->wgtArrE );
687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_UInt16Arr_exit( cpA, &ptrA->dataArrE );
697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ operators } -------------------------------------------------- */
767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
777f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
787f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
797f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
807f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
817f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bbf_Sequence_copy( struct bbs_Context* cpA,
827f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project					    struct bbf_Sequence* ptrA,
837f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project					    const struct bbf_Sequence* srcPtrA )
847f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
857f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_ERROR0( "bbf_Sequence_copy:\n Function is not available" );
867f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
877f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
887f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
897f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
907f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectflag bbf_Sequence_equal( struct bbs_Context* cpA,
917f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project						 const struct bbf_Sequence* ptrA,
927f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project						 const struct bbf_Sequence* srcPtrA )
937f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
947f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	bbs_ERROR0( "bbf_Sequence_equal:\n Function is not available" );
957f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	return TRUE;
967f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
977f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
987f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
997f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1007f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
1017f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
1027f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ query functions } -------------------------------------------- */
1037f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
1047f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
1057f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1067f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
1077f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1087f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
1097f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
1107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ modify functions } ------------------------------------------- */
1117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
1127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
1137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
1157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
1177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
1187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ I/O } -------------------------------------------------------- */
1197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
1207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
1217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
1237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectuint32 bbf_Sequence_memSize( struct bbs_Context* cpA,
1257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project						     const struct bbf_Sequence* ptrA )
1267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
1277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint16 iL;
1287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint32 memSizeL = bbs_SIZEOF16( uint32 ) +
1297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project					  bbs_SIZEOF16( uint32 ); /* version */
1307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memSizeL += bbf_Feature_memSize( cpA, &ptrA->baseE );
1327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memSizeL += bbs_SIZEOF16( ptrA->sizeE );
1337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memSizeL += bbs_Int32Arr_memSize( cpA, &ptrA->thrArrE );
1347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memSizeL += bbs_UInt16Arr_memSize( cpA, &ptrA->wgtArrE );
1357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	for( iL = 0; iL < ptrA->sizeE; iL++ ) memSizeL += bbf_featureMemSize( cpA, ptrA->ftrPtrArrE[ iL ] );
1367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	return memSizeL;
1377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
1387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
1407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectuint32 bbf_Sequence_memWrite( struct bbs_Context* cpA,
1427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project						      const struct bbf_Sequence* ptrA,
1437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project							  uint16* memPtrA )
1447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
1457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint16 iL;
1467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint32 memSizeL = bbf_Sequence_memSize( cpA, ptrA );
1477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_memWrite32( &memSizeL, memPtrA );
1487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_memWriteUInt32( bbf_SEQUENCE_VERSION, memPtrA );
1497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbf_Feature_memWrite( cpA, &ptrA->baseE, memPtrA );
1507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_memWrite32( &ptrA->sizeE, memPtrA );
1517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_Int32Arr_memWrite( cpA, &ptrA->thrArrE, memPtrA );
1527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_UInt16Arr_memWrite( cpA, &ptrA->wgtArrE, memPtrA );
1537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	for( iL = 0; iL < ptrA->sizeE; iL++ ) memPtrA += bbf_featureMemWrite( cpA, ptrA->ftrPtrArrE[ iL ], memPtrA );
1547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	return memSizeL;
1557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
1567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
1587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectuint32 bbf_Sequence_memRead( struct bbs_Context* cpA,
1607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project						     struct bbf_Sequence* ptrA,
1617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project							 const uint16* memPtrA,
1627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project							 struct bbs_MemTbl* mtpA )
1637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
1647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint16 iL;
1657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	uint32 memSizeL, versionL;
1667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	struct bbs_MemTbl memTblL = *mtpA;
1677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	struct bbs_MemSeg* espL = bbs_MemTbl_fastestSegPtr( cpA, &memTblL, 0 );
1687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	if( bbs_Context_error( cpA ) ) return 0;
1697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_memRead32( &memSizeL, memPtrA );
1707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_memReadVersion32( cpA, &versionL, bbf_SEQUENCE_VERSION, memPtrA );
1717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbf_Feature_memRead( cpA, &ptrA->baseE, memPtrA );
1727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_memRead32( &ptrA->sizeE, memPtrA );
1737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	if( ptrA->sizeE > bbf_SEQUENCE_MAX_SIZE )
1757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	{
1767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		bbs_ERROR0( "bbf_Sequence_memRead:\n Sequence size exceeds bbf_SEQUENCE_MAX_SIZE" );
1777f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		return 0;
1787f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	}
1797f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1807f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	memPtrA += bbs_Int32Arr_memRead( cpA, &ptrA->thrArrE, memPtrA, espL );
1817f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1827f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	if( versionL >= 101 ) memPtrA += bbs_UInt16Arr_memRead( cpA, &ptrA->wgtArrE, memPtrA, espL );
1837f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1847f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	/* check features & allocate data buffer */
1857f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	{
1867f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		const uint16* memPtrL = memPtrA;
1877f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		uint32 dataSizeL = 0;
1887f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		for( iL = 0; iL < ptrA->sizeE; iL++ )
1897f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		{
1907f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			enum bbf_FeatureType typeL = ( enum bbf_FeatureType )bbs_memPeek32( memPtrL + 4 );
1917f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			dataSizeL += bbf_featureSizeOf16( cpA, typeL );
1927f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			memPtrL += bbs_memPeek32( memPtrL );
1937f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		}
1947f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		bbs_UInt16Arr_create( cpA, &ptrA->dataArrE, dataSizeL, espL );
1957f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	}
1967f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
1977f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	/* load features & initialize pointers */
1987f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	{
1997f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		uint16* dataPtrL = ptrA->dataArrE.arrPtrE;
2007f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		for( iL = 0; iL < ptrA->sizeE; iL++ )
2017f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		{
2027f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			enum bbf_FeatureType typeL = ( enum bbf_FeatureType )bbs_memPeek32( memPtrA + 4 );
2037f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			ptrA->ftrPtrArrE[ iL ] = ( struct bbf_Feature* )dataPtrL;
2047f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			bbf_featureInit( cpA, ptrA->ftrPtrArrE[ iL ], typeL );
2057f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			memPtrA += bbf_featureMemRead( cpA, ptrA->ftrPtrArrE[ iL ], memPtrA, &memTblL );
2067f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			dataPtrL += bbf_featureSizeOf16( cpA, typeL );
2077f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		}
2087f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	}
2097f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*	if( memSizeL != bbf_Sequence_memSize( cpA, ptrA ) )
2117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	{
2127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		bbs_ERR0( bbs_ERR_CORRUPT_DATA, "uint32 bbf_Sequence_memRead( struct bem_ScanGradientMove* ptrA, const uint16* memPtrA ):\n"
2137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			        "size mismatch" );
2147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		return 0;
2157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	}
2167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project*/
2177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	return memSizeL;
2197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
2207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
2227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
2247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
2257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ exec functions } --------------------------------------------- */
2267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/*                                                                           */
2277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
2287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
2307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectint32 bbf_Sequence_activity( const struct bbf_Feature* ptrA, const uint32* patchA )
2327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{
2337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	const struct bbf_Sequence* ptrL = ( struct bbf_Sequence* )ptrA;
2347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	count_t iL;
2367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	int32 sizeL = ptrL->sizeE;
2387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	/* 12.20 */
2407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	int32 actSumL = ( -sizeL ) << 20;
2417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	if( sizeL == 0 ) return 0x10000000; /* 1.0 in 4.28 format */
2437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	if( ptrL->wgtArrE.sizeE == 0 )
2457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	{
2467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		for( iL = 0; iL < ptrL->sizeE; iL++ )
2477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		{
2487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			/* 4.28 */
2497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			int32 actL = ptrL->ftrPtrArrE[ iL ]->vpActivityE( ptrL->ftrPtrArrE[ iL ], patchA ) - ptrL->thrArrE.arrPtrE[ iL ];
2507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			actSumL += ( actL >> 8 );
2517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			if( actL < 0 ) return ( actSumL / sizeL ) << 7; /* return 4.28 */
2527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		}
2537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	}
2547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	else
2557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	{
2567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		for( iL = 0; iL < ptrL->sizeE; iL++ )
2577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		{
2587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			/* 4.28 */
2597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			int32 actL = ptrL->ftrPtrArrE[ iL ]->vpActivityE( ptrL->ftrPtrArrE[ iL ], patchA ) - ptrL->thrArrE.arrPtrE[ iL ];
2607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			int32 wgtL = ptrL->wgtArrE.arrPtrE[ iL ];
2617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			actL = ( actL >> 16 ) * wgtL + ( ( ( int32 )( actL & 0x0000FFFF ) * wgtL ) >> 16 );
2627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			actSumL += ( actL >> 8 );
2637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project			if( actL < 0 ) return ( actSumL / sizeL ) << 7; /* return 4.28 */
2647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project		}
2657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	}
2667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	actSumL += sizeL << 20;
2687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project    /* positive activity: ] 0, 1 ] */
2707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project	return ( actSumL / sizeL ) << 7; /* return 4.28 */
2717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project}
2727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */
2747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
2757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */
2767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project
277