mirror of
				https://github.com/godotengine/godot.git
				synced 2025-10-31 13:41:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			166 lines
		
	
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			166 lines
		
	
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /********************************************************************
 | |
|  *                                                                  *
 | |
|  * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
 | |
|  * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
 | |
|  * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
 | |
|  * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
 | |
|  *                                                                  *
 | |
|  * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
 | |
|  * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
 | |
|  *                                                                  *
 | |
|  ********************************************************************
 | |
| 
 | |
|   function:
 | |
|     last mod: $Id$
 | |
| 
 | |
|  ********************************************************************/
 | |
| 
 | |
| #include <stdlib.h>
 | |
| #include <string.h>
 | |
| #include <limits.h>
 | |
| #include "apiwrapper.h"
 | |
| 
 | |
| 
 | |
| 
 | |
| const char *theora_version_string(void){
 | |
|   return th_version_string();
 | |
| }
 | |
| 
 | |
| ogg_uint32_t theora_version_number(void){
 | |
|   return th_version_number();
 | |
| }
 | |
| 
 | |
| void theora_info_init(theora_info *_ci){
 | |
|   memset(_ci,0,sizeof(*_ci));
 | |
| }
 | |
| 
 | |
| void theora_info_clear(theora_info *_ci){
 | |
|   th_api_wrapper *api;
 | |
|   api=(th_api_wrapper *)_ci->codec_setup;
 | |
|   memset(_ci,0,sizeof(*_ci));
 | |
|   if(api!=NULL){
 | |
|     if(api->clear!=NULL)(*api->clear)(api);
 | |
|     _ogg_free(api);
 | |
|   }
 | |
| }
 | |
| 
 | |
| void theora_clear(theora_state *_th){
 | |
|   /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
 | |
|   if(_th->internal_decode!=NULL){
 | |
|     (*((oc_state_dispatch_vtable *)_th->internal_decode)->clear)(_th);
 | |
|   }
 | |
|   if(_th->internal_encode!=NULL){
 | |
|     (*((oc_state_dispatch_vtable *)_th->internal_encode)->clear)(_th);
 | |
|   }
 | |
|   if(_th->i!=NULL)theora_info_clear(_th->i);
 | |
|   memset(_th,0,sizeof(*_th));
 | |
| }
 | |
| 
 | |
| int theora_control(theora_state *_th,int _req,void *_buf,size_t _buf_sz){
 | |
|   /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
 | |
|   if(_th->internal_decode!=NULL){
 | |
|     return (*((oc_state_dispatch_vtable *)_th->internal_decode)->control)(_th,
 | |
|      _req,_buf,_buf_sz);
 | |
|   }
 | |
|   else if(_th->internal_encode!=NULL){
 | |
|     return (*((oc_state_dispatch_vtable *)_th->internal_encode)->control)(_th,
 | |
|      _req,_buf,_buf_sz);
 | |
|   }
 | |
|   else return TH_EINVAL;
 | |
| }
 | |
| 
 | |
| ogg_int64_t theora_granule_frame(theora_state *_th,ogg_int64_t _gp){
 | |
|   /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
 | |
|   if(_th->internal_decode!=NULL){
 | |
|     return (*((oc_state_dispatch_vtable *)_th->internal_decode)->granule_frame)(
 | |
|      _th,_gp);
 | |
|   }
 | |
|   else if(_th->internal_encode!=NULL){
 | |
|     return (*((oc_state_dispatch_vtable *)_th->internal_encode)->granule_frame)(
 | |
|      _th,_gp);
 | |
|   }
 | |
|   else return -1;
 | |
| }
 | |
| 
 | |
| double theora_granule_time(theora_state *_th, ogg_int64_t _gp){
 | |
|   /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
 | |
|   if(_th->internal_decode!=NULL){
 | |
|     return (*((oc_state_dispatch_vtable *)_th->internal_decode)->granule_time)(
 | |
|      _th,_gp);
 | |
|   }
 | |
|   else if(_th->internal_encode!=NULL){
 | |
|     return (*((oc_state_dispatch_vtable *)_th->internal_encode)->granule_time)(
 | |
|      _th,_gp);
 | |
|   }
 | |
|   else return -1;
 | |
| }
 | |
| 
 | |
| void oc_theora_info2th_info(th_info *_info,const theora_info *_ci){
 | |
|   _info->version_major=_ci->version_major;
 | |
|   _info->version_minor=_ci->version_minor;
 | |
|   _info->version_subminor=_ci->version_subminor;
 | |
|   _info->frame_width=_ci->width;
 | |
|   _info->frame_height=_ci->height;
 | |
|   _info->pic_width=_ci->frame_width;
 | |
|   _info->pic_height=_ci->frame_height;
 | |
|   _info->pic_x=_ci->offset_x;
 | |
|   _info->pic_y=_ci->offset_y;
 | |
|   _info->fps_numerator=_ci->fps_numerator;
 | |
|   _info->fps_denominator=_ci->fps_denominator;
 | |
|   _info->aspect_numerator=_ci->aspect_numerator;
 | |
|   _info->aspect_denominator=_ci->aspect_denominator;
 | |
|   switch(_ci->colorspace){
 | |
|     case OC_CS_ITU_REC_470M:_info->colorspace=TH_CS_ITU_REC_470M;break;
 | |
|     case OC_CS_ITU_REC_470BG:_info->colorspace=TH_CS_ITU_REC_470BG;break;
 | |
|     default:_info->colorspace=TH_CS_UNSPECIFIED;break;
 | |
|   }
 | |
|   switch(_ci->pixelformat){
 | |
|     case OC_PF_420:_info->pixel_fmt=TH_PF_420;break;
 | |
|     case OC_PF_422:_info->pixel_fmt=TH_PF_422;break;
 | |
|     case OC_PF_444:_info->pixel_fmt=TH_PF_444;break;
 | |
|     default:_info->pixel_fmt=TH_PF_RSVD;
 | |
|   }
 | |
|   _info->target_bitrate=_ci->target_bitrate;
 | |
|   _info->quality=_ci->quality;
 | |
|   _info->keyframe_granule_shift=_ci->keyframe_frequency_force>0?
 | |
|    OC_MINI(31,oc_ilog(_ci->keyframe_frequency_force-1)):0;
 | |
| }
 | |
| 
 | |
| int theora_packet_isheader(ogg_packet *_op){
 | |
|   return th_packet_isheader(_op);
 | |
| }
 | |
| 
 | |
| int theora_packet_iskeyframe(ogg_packet *_op){
 | |
|   return th_packet_iskeyframe(_op);
 | |
| }
 | |
| 
 | |
| int theora_granule_shift(theora_info *_ci){
 | |
|   /*This breaks when keyframe_frequency_force is not positive or is larger than
 | |
|      2**31 (if your int is more than 32 bits), but that's what the original
 | |
|      function does.*/
 | |
|   return oc_ilog(_ci->keyframe_frequency_force-1);
 | |
| }
 | |
| 
 | |
| void theora_comment_init(theora_comment *_tc){
 | |
|   th_comment_init((th_comment *)_tc);
 | |
| }
 | |
| 
 | |
| char *theora_comment_query(theora_comment *_tc,char *_tag,int _count){
 | |
|   return th_comment_query((th_comment *)_tc,_tag,_count);
 | |
| }
 | |
| 
 | |
| int theora_comment_query_count(theora_comment *_tc,char *_tag){
 | |
|   return th_comment_query_count((th_comment *)_tc,_tag);
 | |
| }
 | |
| 
 | |
| void theora_comment_clear(theora_comment *_tc){
 | |
|   th_comment_clear((th_comment *)_tc);
 | |
| }
 | |
| 
 | |
| void theora_comment_add(theora_comment *_tc,char *_comment){
 | |
|   th_comment_add((th_comment *)_tc,_comment);
 | |
| }
 | |
| 
 | |
| void theora_comment_add_tag(theora_comment *_tc, char *_tag, char *_value){
 | |
|   th_comment_add_tag((th_comment *)_tc,_tag,_value);
 | |
| }
 | 
