mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	 f1b49b7bb9
			
		
	
	
		f1b49b7bb9
		
	
	
	
	
		
			
			* enc/jis/props.kwd: constify character property tables of JIS based encodings by perfect hash. * enc/euc_jp.c, enc/shift_jis.c: use character property functions. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@46039 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			163 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| % inplace = File.identical?($top_srcdir, ".")
 | |
| % workdirs = %w"$(ENCSODIR) $(TRANSSODIR) enc enc/trans"
 | |
| % CONFIG["WORKDIRS"] = workdirs.join(' ')
 | |
| % enable_shared = CONFIG['ENABLE_SHARED'] == 'yes'
 | |
| % deffile = (true if /\$\(DEFFILE\)/ =~ CONFIG["LINK_SO"])
 | |
| % dependencies = ENCS + TRANS
 | |
| % cleanlibs = Shellwords.shellwords(CONFIG["cleanlibs"] || "")
 | |
| % cleanobjs = Shellwords.shellwords(CONFIG["cleanobjs"] || "")
 | |
| % cleanobjs << "$*.def" if deffile
 | |
| % rule_subst = CONFIG["RULE_SUBST"] || "%s"
 | |
| % transvpath = rule_subst.dup.sub!(/\{[^{}]+\}/, '$(TRANSVPATH)/') || "enc/trans/%s"
 | |
| % transvpath_prefix = (rule_subst.dup.sub!(/\{[^{}]+\}/, '{$(TRANSVPATH)}') || "%s") % ""
 | |
| % CONFIG['ARFLAGS'] = 'rcu ' if (CONFIG['ARFLAGS'] || "").empty?
 | |
| % CONFIG['RANLIB'] = ':' if (CONFIG['RANLIB'] || "").empty?
 | |
| % CONFIG['CPPFLAGS'] += " -DRUBY_EXPORT=1" if CONFIG["EXTSTATIC"] == "static"
 | |
| % if File::ALT_SEPARATOR
 | |
| %   pathrep = proc {|path| path.gsub('/', File::ALT_SEPARATOR).gsub(/\$\(([@<?*]\w?|\w+)\)/, "$(\\1:/=\\#{File::ALT_SEPARATOR})")}
 | |
| % else
 | |
| %   pathrep = proc {|path| path}
 | |
| % end
 | |
| 
 | |
| VPATH = <%=%w[$(arch_hdrdir)/ruby $(hdrdir)/ruby $(srcdir) $(encsrcdir)].join(CONFIG["PATH_SEPARATOR"])%>
 | |
| LIBPATH = <%=libpathflag($DEFLIBPATH)%>
 | |
| LIBS = <%=
 | |
| if enable_shared or RbConfig.expand(CONFIG["LIBRUBY"].dup) != RbConfig.expand(CONFIG["LIBRUBY_A"].dup)
 | |
|   CONFIG['LIBRUBYARG']
 | |
| else
 | |
|   ''
 | |
| end %> <%=CONFIG['LIBS']%> $(EXTLIBS)
 | |
| 
 | |
| ENCOBJS = <%=ENCS.map {|e|"enc/#{e}.$(OBJEXT)"}.join(" \\\n\t  ")%><%="\n" if ENCS.size>1%>
 | |
| ENCSOS = <%=ENCS.map {|e|"$(ENCSODIR)/#{e}.$(DLEXT)"}.join(" \\\n\t ")%><%="\n" if ENCS.size>1%>
 | |
| ENCCLEANLIBS = <%=cleanlibs.map {|clean|
 | |
|   clean.gsub(/\$\*(\.\w+)?/) {"$(ENCOBJS#{$1 ? ":.#{CONFIG["OBJEXT"]}=#{$1}" : ""})"}
 | |
| }.join(" ")%>
 | |
| ENCCLEANOBJS = <%=cleanobjs.map {|clean|
 | |
|   clean.gsub(/\$\*(\.\w+)?/) {"$(ENCOBJS#{$1 ? ":.#{CONFIG["OBJEXT"]}=#{$1}" : ""})"}
 | |
| }.join(" ")%>
 | |
| LIBENC=enc/libenc.$(LIBEXT)
 | |
| 
 | |
| TRANSVPATH = $(srcdir)/enc/trans
 | |
| 
 | |
| TRANSCSRCS = <%=ATRANS.map {|e| transvpath % "#{e}.c"}.join(" \\\n\t     ")%><%="\n" if TRANS.size>1%>
 | |
| TRANSOBJS = <%=TRANS.map {|e|"enc/#{e}.$(OBJEXT)"}.join(" \\\n\t    ")%><%="\n" if TRANS.size>1%>
 | |
| TRANSSOS = <%=TRANS.map {|e|"$(ENCSODIR)/#{e}.$(DLEXT)"}.join(" \\\n\t   ")%><%="\n" if TRANS.size>1%>
 | |
| TRANSCLEANLIBS = <%=cleanlibs.map {|clean|
 | |
|   clean.gsub(/\$\*(\.\w+)?/) {"$(TRANSOBJS#{$1 ? ":.#{CONFIG["OBJEXT"]}=#{$1}" : ""})"}
 | |
| }.join(" ")%>
 | |
| TRANSCLEANOBJS = <%=cleanobjs.map {|clean|
 | |
|   clean.gsub(/\$\*(\.\w+)?/) {"$(TRANSOBJS#{$1 ? ":.#{CONFIG["OBJEXT"]}=#{$1}" : ""})"}
 | |
| }.join(" ")%>
 | |
| LIBTRANS=enc/libtrans.$(LIBEXT)
 | |
| 
 | |
| encs: all
 | |
| % if MODULE_TYPE == :static
 | |
| all: libenc libtrans
 | |
| % else
 | |
| all: enc trans
 | |
| %end
 | |
| libencs: libenc libtrans
 | |
| enc: $(ENCSOS)
 | |
| libenc: $(LIBENC)
 | |
| trans: $(TRANSSOS)
 | |
| libtrans: $(LIBTRANS)
 | |
| 
 | |
| $(LIBENC): $(ENCOBJS)
 | |
| 	@$(RM) $@
 | |
| 	$(ECHO) linking statically-linked encoding library $@
 | |
| 	$(Q) $(AR) $(ARFLAGS)$@ $(ENCOBJS)
 | |
| 	@-$(RANLIB) $@ 2> /dev/null || true
 | |
| $(LIBTRANS): $(TRANSOBJS)
 | |
| 	@$(RM) $@
 | |
| 	$(ECHO) linking statically-linked transcoder library $@
 | |
| 	$(Q) $(AR) $(ARFLAGS)$@ $(TRANSOBJS)
 | |
| 	@-$(RANLIB) $@ 2> /dev/null || true
 | |
| 
 | |
| srcs: $(TRANSCSRCS)
 | |
| 
 | |
| <%=transvpath_prefix%>.trans<%=transvpath_prefix%>.c:
 | |
| 	$(ECHO) generating table from $@
 | |
| 	$(Q)$(MINIRUBY) "$(srcdir)/tool/transcode-tblgen.rb" -vo "$@" "$<"
 | |
| 
 | |
| % unless ENCS.empty? or TRANS.empty?
 | |
| 
 | |
| %   unless ENCS.empty?
 | |
| $(ENCOBJS): $(hdrdir)/ruby.h regenc.h oniguruma.h config.h defines.h ruby.h missing.h subst.h intern.h st.h encoding.h
 | |
| %   end
 | |
| %   ENC_DEPS.each do |e, deps|
 | |
| enc/<%=e%>.$(OBJEXT): <%=deps.map {|n| rule_subst % n}.join(' ')%>
 | |
| %   end
 | |
| %   unless TRANS.empty?
 | |
| $(TRANSOBJS): $(hdrdir)/ruby.h ruby.h intern.h config.h defines.h missing.h encoding.h oniguruma.h st.h transcode_data.h subst.h encoding.h
 | |
| %   end
 | |
| %   ATRANS.each do |e|
 | |
| %     src = "#{e}.trans"
 | |
| 
 | |
| <%=transvpath % "#{e}.c"%>: <%= transvpath % "#{e}.trans"%>
 | |
| %     src = [*IO.read(File.join($srcdir, "trans", src)).scan(/^\s*require\s+[\'\"]([^\'\"]*)/).flatten.map{|c|c+".rb"}]
 | |
| <%=transvpath % "#{e}.c"%>: <%= src.map {|s| transvpath % "#{s}"}.join(" ")%> $(srcdir)/tool/transcode-tblgen.rb
 | |
| %   end
 | |
| 
 | |
| % end
 | |
| % link_so = LINK_SO.gsub(/([^\\])\n/, "\\1\n$(Q) ").gsub(/\n/, "\n\t")
 | |
| % link_so.gsub!(/(-(?:implib|pdb):\S+)-\$\(arch\)\./, '\1.')
 | |
| % dependencies.each do |e|
 | |
| %   obj = "enc/#{e}.$(OBJEXT)"
 | |
| %   df = ("enc/#{e}.def" if deffile)
 | |
| %   target = e.dup
 | |
| %   if target.sub!(/\Atrans\//, '$(TRANSSODIR)/')
 | |
| %     mesg = "transcoder"
 | |
| %   else
 | |
| %     target = "$(ENCSODIR)/#{e}"
 | |
| %     mesg = "encoding"
 | |
| %   end
 | |
| <%=target%>.$(DLEXT): <%=obj%>
 | |
| 	$(ECHO) linking <%=mesg%> $(@F)
 | |
| %   cmd = link_so.sub(/\$\(OBJS\)/) {obj}
 | |
| %   base = File.basename(e)
 | |
| %   if df
 | |
| 	$(Q)echo> <%=df%> EXPORTS
 | |
| 	$(Q)echo>> <%=df%> <%=EXPORT_PREFIX%>Init_<%=base%>
 | |
| %     cmd.sub!(/\$\(DEFFILE\)/) {df}
 | |
| %     cmd.gsub!(/-(?:implib|pdb):/) {|s|"#{s}enc/#{e.sub(/[^\/]+\z/, '')}"}
 | |
| %   end
 | |
| 	$(Q)$(MAKEDIRS) "$(@D)"
 | |
| 	$(Q)<%=cmd%>
 | |
| 
 | |
| % end
 | |
| % dependencies.each do |e|
 | |
| <%="enc/#{e}.$(OBJEXT)"%>: <%="$(encsrcdir)/#{e}.c"%>
 | |
| 	-$(Q)$(MAKEDIRS) "$(@D)"
 | |
| 	$(ECHO) compiling <%= "$(encsrcdir)/#{e}.c"%>
 | |
| 	$(Q)<%=COMPILE_C.gsub(/\$(\()?<(\:[^)]+)?(\))?/){"$(encsrcdir)/#{e}.c"}%>
 | |
| 
 | |
| % end
 | |
| 
 | |
| enc/encdb.$(OBJEXT): encdb.h
 | |
| enc/trans/transdb.$(OBJEXT): transdb.h
 | |
| 
 | |
| clean:
 | |
| % %w[$(ENCSOS) $(LIBENC) $(ENCOBJS) $(ENCCLEANOBJS) $(ENCCLEANLIBS) $(TRANSSOS) $(LIBTRANS) $(TRANSOBJS) $(TRANSCLEANOBJS) $(TRANSCLEANLIBS)].each do |clean|
 | |
| 	$(Q)$(RM) <%=pathrep[clean]%>
 | |
| % end
 | |
| % @ignore_error = $nmake ? '' : ' 2> /dev/null || true'
 | |
| % unless inplace
 | |
| 	$(Q)$(RM) enc/unicode/name2ctype.h
 | |
| 	$(Q)$(RM) enc/jis/props.h
 | |
| 	-$(Q)$(RMDIR) enc/unicode<%=@ignore_error%>
 | |
| % end
 | |
| % workdirs.reverse_each do|d|
 | |
| 	-$(Q)$(RMDIR) <%=pathrep[d]%><%=@ignore_error%>
 | |
| % end
 | |
| 
 | |
| clean-srcs:
 | |
| 	$(Q)$(RM) <%=pathrep['$(TRANSCSRCS)']%>
 | |
| 	-$(Q)$(RMDIR) <%=pathrep['enc/trans']%><%=@ignore_error%>
 | |
| 	$(Q)$(RM) enc/unicode/name2ctype.h
 | |
| 	$(Q)$(RM) enc/jis/props.h
 | |
| 	-$(Q)$(RMDIR) <%=pathrep['enc/unicode']%><%=@ignore_error%>
 | |
| 	-$(Q)$(RMDIR) <%=pathrep['enc/props']%><%=@ignore_error%>
 | |
| 	-$(Q)$(RMDIR) <%=pathrep['enc']%><%=@ignore_error%>
 | |
| 
 | |
| <%# vim: set ft=eruby noexpandtab ts=8 sw=2 : -%>
 |