# Record names
-define(nsc_set_name, `define(`CURRENT_NAME', nsc_corr_dot($1))define(`PRINT_NAME', CURRENT_NAME)')
+define(nsc_set_name, `define(`CURRENT_NAME', nsc_name($1))define(`PRINT_NAME', CURRENT_NAME)')
define(nsc_emit_name, `ifdef(`PRINT_NAME', `PRINT_NAME`'undefine(`PRINT_NAME')', `')')
-define(nsc_abs_name, `ifelse(CURRENT_NAME, translit(CURRENT_NAME,.,:), CURRENT_NAME.CURRENT_DOMAIN, CURRENT_NAME)')
+define(nsc_abs_name, `ifelse(regexp(CURRENT_NAME,\.$),-1,CURRENT_NAME.CURRENT_DOMAIN,CURRENT_NAME)')
define(nsc_abs_name_nodot, `define(`nsc_tmp', nsc_abs_name)substr(nsc_tmp,0,decr(len(nsc_tmp)))')
# SOA record
define(nsc_SOA, `
ifelse(CURRENT_DOMAIN,@,`',$ORIGIN CURRENT_DOMAIN)
$TTL MINTTL
-nsc_emit_name `SOA' nsc_corr_dot(NSNAME) MAINTNAME (
+nsc_emit_name `SOA' nsc_name(NSNAME) MAINTNAME (
VERSION REFRESH RETRY EXPIRE MINTTL )')
define(SOA, `ifdef(`CURRENT_DOMAIN',`ifdef(`REVERSE_MODE',,`nsc_fatal_error(`SOA record defined twice')')')dnl
define(`CURRENT_DOMAIN',ifelse($1,@,@,$1.))dnl
# NS record
-define(nsc_NS, `nsc_emit_name `NS' nsc_corr_dot($1)
+define(nsc_NS, `nsc_emit_name `NS' nsc_name($1)
')
define(NS, `nsc_iterate(`nsc_NS', $@)dnl')
# MX record
-define(nsc_MX, `nsc_emit_name `MX' nsc_corr_dot($1)
+define(nsc_MX, `nsc_emit_name `MX' nsc_name($1)
')
define(MX, `nsc_iterate(`nsc_MX', $@)dnl')
# RP (responsible person) records
-define(RP, `nsc_emit_name `RP' nsc_corr_dot($1) nsc_corr_dot($2)')
+define(RP, `nsc_emit_name `RP' nsc_name($1) nsc_name($2)')
# SRV records
-define(SRV, `_`'$1`'._`'$2`'.CURRENT_NAME `SRV' $3 $4 $5 nsc_corr_dot($6)`'nsc_set_name(CURRENT_NAME)')
+define(SRV, `_`'$1`'._`'$2`'.CURRENT_NAME `SRV' $3 $4 $5 nsc_name($6)`'nsc_set_name(CURRENT_NAME)')
# CNAME records
-define(CNAME, `$1 `CNAME' nsc_corr_dot($2)')
+define(CNAME, `$1 `CNAME' nsc_name($2)')
# Explicit PTR records
-define(PTR, `$1 `PTR' nsc_corr_dot($2)')
+define(PTR, `$1 `PTR' nsc_name($2)')
# DS records (DNSSEC keys for subdomains)