diff --git a/src/lib66/parser_enabled.c b/src/lib66/parser_enabled.c
index 2e381e47fcece90bfb799f7b83ccbcb484f4b683..8b5bf3917eb58237751573f4a66d9e32599a5be7 100644
--- a/src/lib66/parser_enabled.c
+++ b/src/lib66/parser_enabled.c
@@ -48,13 +48,12 @@ int parse_service_before(ssexec_t *info,stralloc *parsed_list,stralloc *tree_lis
 	svsrclen = strlen(svsrc) ;
 	svnamelen = strlen(svname) ;
 	char svpath[svsrclen + svnamelen + 1] ;
-	if (scan_mode(sv,S_IFDIR) == 1) return 1 ;
 	char tree[info->tree.len + SS_SVDIRS_LEN + 1] ;
 	auto_strings(tree,info->tree.s,SS_SVDIRS) ;
 	
 	int r = parse_service_check_enabled(tree,svname,force,&exist) ;
 	if (!r) goto freed ;
-		
+
 	sv_alltype sv_before = SV_ALLTYPE_ZERO ;
 	sasv->len = 0 ;
 
@@ -75,6 +74,10 @@ int parse_service_before(ssexec_t *info,stralloc *parsed_list,stralloc *tree_lis
 	if (!get_svtype(&sv_before,sasv->s)) 
 		log_warn_return (LOG_EXIT_ZERO,"invalid value for key: ",get_key_by_enum(ENUM_KEY_SECTION_MAIN,KEY_MAIN_TYPE)," in service file: ",svsrc,svname) ;
 	
+	/** contain of directory should be listed by ss_resolve_src_path
+	 * execpt for module type */
+	if (scan_mode(sv,S_IFDIR) == 1 && sv_before.cname.itype != TYPE_MODULE) return 1 ;
+	
 	if (insta > 0)
 	{
 		if (!instance_create(sasv,svname,SS_INSTANCE,insta))
@@ -97,7 +100,7 @@ int parse_service_before(ssexec_t *info,stralloc *parsed_list,stralloc *tree_lis
 		goto freed ;
 	}
 	if (!parser(&sv_before,sasv,svname,sv_before.cname.itype)) return 0 ;
-
+	
 	/** keep the name set by user
 	 * uniquely for instantiated service
 	 * The name must contain the template string */
@@ -173,8 +176,8 @@ int parse_service_before(ssexec_t *info,stralloc *parsed_list,stralloc *tree_lis
 	if ((sv_before.cname.itype > TYPE_CLASSIC && force > 1) || !exist)
 	{
 		if (!parse_service_deps(info,parsed_list,tree_list,&sv_before,sv,nbsv,sasv,force)) return 0 ;
-		if (!parse_service_opts_deps(info,parsed_list,tree_list,&sv_before,sv,nbsv,sasv,force,KEY_MAIN_OPTSDEPS)) return 0 ;
 		if (!parse_service_opts_deps(info,parsed_list,tree_list,&sv_before,sv,nbsv,sasv,force,KEY_MAIN_EXTDEPS)) return 0 ;
+		if (!parse_service_opts_deps(info,parsed_list,tree_list,&sv_before,sv,nbsv,sasv,force,KEY_MAIN_OPTSDEPS)) return 0 ;
 	}
 	freed:
 	return 1 ;
@@ -225,7 +228,7 @@ int parse_module(sv_alltype *sv_before,char const *svname,uid_t owner,uint8_t fo
 	}
 	
 	/** regex file content */
-	if (!sastr_dir_get_recursive(&list,sdir.s,".configure",S_IFREG)) 
+	if (!sastr_dir_get_recursive(&list,sdir.s,"",S_IFREG)) 
 		log_warnusys_return(LOG_EXIT_ZERO,"get file(s) of module: ",svname) ;
 	
 	pos = sv_before->type.module.start_infiles, len = sv_before->type.module.end_infiles ;
@@ -381,17 +384,16 @@ int parse_service_opts_deps(ssexec_t *info,stralloc *parsed_list,stralloc *tree_
 	stralloc newsv = STRALLOC_ZERO ;
 		
 	size_t pos = 0 , baselen = strlen(info->base.s) + SS_SYSTEM_LEN ;
-	uint8_t found = 0, ext = 0 ;
+	uint8_t found = 0, ext = mandatory == KEY_MAIN_EXTDEPS ? 1 : 0 ;
 	char *optname = 0 ;
 	char btmp[baselen + 1] ;
 	auto_strings(btmp,info->base.s,SS_SYSTEM) ;
 	
 	int idref = sv_before->cname.idopts ;
 	unsigned int nref = sv_before->cname.nopts ;
-	if (mandatory == KEY_MAIN_EXTDEPS) {
+	if (ext) {
 		idref = sv_before->cname.idext ;
 		nref = sv_before->cname.next ;
-		ext = 1 ;
 	}
 	// only pass here for the first time
 	if (!tree_list->len)
@@ -568,7 +570,7 @@ int regex_replace(int id,unsigned int nid, char const *sdir,mode_t mode)
 	stralloc list = STRALLOC_ZERO ;
 	stralloc tmp = STRALLOC_ZERO ;
 	size_t pos = id, len = nid, in ;
-	if (!sastr_dir_get_recursive(&list,sdir,".configure",mode)) 
+	if (!sastr_dir_get_recursive(&list,sdir,"",mode)) 
 		log_warnusys_return(LOG_EXIT_ZERO,"get content of: ",sdir) ;
 		
 	pos = id, len = nid ;