mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
 | |
|    
 | |
|    This program is free software; you can redistribute it and/or modify
 | |
|    it under the terms of the GNU General Public License as published by
 | |
|    the Free Software Foundation; version 2 of the License.
 | |
|    
 | |
|    This program is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|    GNU General Public License for more details.
 | |
|    
 | |
|    You should have received a copy of the GNU General Public License
 | |
|    along with this program; if not, write to the Free Software
 | |
|    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1335  USA */
 | |
| 
 | |
| #include "sql_cache.h"                         /* Query_cache_block */
 | |
| 
 | |
| class Querycache_stream
 | |
| {
 | |
|   uchar *cur_data;
 | |
|   uchar *data_end;
 | |
|   Query_cache_block *block;
 | |
|   uint headers_len;
 | |
| public:
 | |
| #ifndef DBUG_OFF
 | |
|   Query_cache_block *first_block;
 | |
|   uint stored_size;
 | |
| #endif
 | |
|   Querycache_stream(Query_cache_block *ini_block, uint ini_headers_len) :
 | |
|     block(ini_block), headers_len(ini_headers_len)    
 | |
|   {
 | |
|     cur_data= ((uchar*)block)+headers_len;
 | |
|     data_end= cur_data + (block->used-headers_len);
 | |
| #ifndef DBUG_OFF
 | |
|     first_block= ini_block;
 | |
|     stored_size= 0;
 | |
| #endif
 | |
|   }
 | |
|   void use_next_block(bool writing)
 | |
|   {
 | |
|     /*
 | |
|       This shouldn't be called if there is only one block, or to loop
 | |
|       around to the first block again. That means we're trying to write
 | |
|       more data than we allocated space for.
 | |
|     */
 | |
|     DBUG_ASSERT(block->next != block);
 | |
|     DBUG_ASSERT(block->next != first_block);
 | |
| 
 | |
|     block= block->next;
 | |
|     /*
 | |
|       While writing, update the type of each block as we write to it.
 | |
|       While reading, make sure that the block is of the expected type.
 | |
|     */
 | |
|     if (writing)
 | |
|       block->type= Query_cache_block::RES_CONT;
 | |
|     else
 | |
|       DBUG_ASSERT(block->type == Query_cache_block::RES_CONT);
 | |
| 
 | |
|     cur_data= ((uchar*)block)+headers_len;
 | |
|     data_end= cur_data + (block->used-headers_len);
 | |
|   }
 | |
| 
 | |
|   void store_uchar(uchar c);
 | |
|   void store_short(ushort s);
 | |
|   void store_int(uint i);
 | |
|   void store_ll(ulonglong ll);
 | |
|   void store_str_only(const char *str, uint str_len);
 | |
|   void store_str(const char *str, uint str_len);
 | |
|   void store_safe_str(const char *str, uint str_len);
 | |
| 
 | |
|   uchar load_uchar();
 | |
|   ushort load_short();
 | |
|   uint load_int();
 | |
|   ulonglong load_ll();
 | |
|   void load_str_only(char *buffer, uint str_len);
 | |
|   char *load_str(MEM_ROOT *alloc, uint *str_len);
 | |
|   int load_safe_str(MEM_ROOT *alloc, char **str, uint *str_len);
 | |
|   int load_column(MEM_ROOT *alloc, char **column);
 | |
| };
 | |
| 
 | |
| uint emb_count_querycache_size(THD *thd);
 | |
| int emb_load_querycache_result(THD *thd, Querycache_stream *src);
 | |
| void emb_store_querycache_result(Querycache_stream *dst, THD* thd);
 | |
| bool net_send_eof(THD *thd, uint server_status, uint total_warn_count);
 |