mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	 4ff3f20540
			
		
	
	
		4ff3f20540
		
	
	
	
	
		
			
			According to MSVC manual (*1), cl.exe can skip including a header file when that: - contains #pragma once, or - starts with #ifndef, or - starts with #if ! defined. GCC has a similar trick (*2), but it acts more stricter (e. g. there must be _no tokens_ outside of #ifndef...#endif). Sun C lacked #pragma once for a looong time. Oracle Developer Studio 12.5 finally implemented it, but we cannot assume such recent version. This changeset modifies header files so that each of them include strictly one #ifndef...#endif. I believe this is the most portable way to trigger compiler optimizations. [Bug #16770] *1: https://docs.microsoft.com/en-us/cpp/preprocessor/once *2: https://gcc.gnu.org/onlinedocs/cppinternals/Guard-Macros.html
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef RUBY_ENCINDEX_H
 | |
| #define RUBY_ENCINDEX_H 1
 | |
| /**********************************************************************
 | |
| 
 | |
|   encindex.h -
 | |
| 
 | |
|   $Author$
 | |
|   created at: Tue Sep 15 13:21:14 JST 2015
 | |
| 
 | |
|   Copyright (C) 2015 Yukihiro Matsumoto
 | |
| 
 | |
| **********************************************************************/
 | |
| 
 | |
| #include "ruby/encoding.h"      /* rb_ascii8bit_encindex etc. */
 | |
| #if defined(__cplusplus)
 | |
| extern "C" {
 | |
| #if 0
 | |
| } /* satisfy cc-mode */
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| enum ruby_preserved_encindex {
 | |
|     RUBY_ENCINDEX_ASCII,
 | |
|     RUBY_ENCINDEX_UTF_8,
 | |
|     RUBY_ENCINDEX_US_ASCII,
 | |
| 
 | |
|     /* preserved indexes */
 | |
|     RUBY_ENCINDEX_UTF_16BE,
 | |
|     RUBY_ENCINDEX_UTF_16LE,
 | |
|     RUBY_ENCINDEX_UTF_32BE,
 | |
|     RUBY_ENCINDEX_UTF_32LE,
 | |
|     RUBY_ENCINDEX_UTF_16,
 | |
|     RUBY_ENCINDEX_UTF_32,
 | |
|     RUBY_ENCINDEX_UTF8_MAC,
 | |
| 
 | |
|     /* for old options of regexp */
 | |
|     RUBY_ENCINDEX_EUC_JP,
 | |
|     RUBY_ENCINDEX_Windows_31J,
 | |
| 
 | |
|     RUBY_ENCINDEX_BUILTIN_MAX
 | |
| };
 | |
| 
 | |
| #define ENCINDEX_ASCII       RUBY_ENCINDEX_ASCII
 | |
| #define ENCINDEX_UTF_8       RUBY_ENCINDEX_UTF_8
 | |
| #define ENCINDEX_US_ASCII    RUBY_ENCINDEX_US_ASCII
 | |
| #define ENCINDEX_UTF_16BE    RUBY_ENCINDEX_UTF_16BE
 | |
| #define ENCINDEX_UTF_16LE    RUBY_ENCINDEX_UTF_16LE
 | |
| #define ENCINDEX_UTF_32BE    RUBY_ENCINDEX_UTF_32BE
 | |
| #define ENCINDEX_UTF_32LE    RUBY_ENCINDEX_UTF_32LE
 | |
| #define ENCINDEX_UTF_16      RUBY_ENCINDEX_UTF_16
 | |
| #define ENCINDEX_UTF_32      RUBY_ENCINDEX_UTF_32
 | |
| #define ENCINDEX_UTF8_MAC    RUBY_ENCINDEX_UTF8_MAC
 | |
| #define ENCINDEX_EUC_JP      RUBY_ENCINDEX_EUC_JP
 | |
| #define ENCINDEX_Windows_31J RUBY_ENCINDEX_Windows_31J
 | |
| #define ENCINDEX_BUILTIN_MAX RUBY_ENCINDEX_BUILTIN_MAX
 | |
| 
 | |
| #define rb_ascii8bit_encindex() RUBY_ENCINDEX_ASCII
 | |
| #define rb_utf8_encindex()      RUBY_ENCINDEX_UTF_8
 | |
| #define rb_usascii_encindex()   RUBY_ENCINDEX_US_ASCII
 | |
| 
 | |
| int rb_enc_find_index2(const char *name, long len);
 | |
| 
 | |
| #if defined(__cplusplus)
 | |
| #if 0
 | |
| { /* satisfy cc-mode */
 | |
| #endif
 | |
| }  /* extern "C" { */
 | |
| #endif
 | |
| 
 | |
| #endif /* RUBY_ENCINDEX_H */
 |