mirror of
				https://github.com/bestnite/sub2clash.git
				synced 2025-10-26 01:01:35 +00:00 
			
		
		
		
	fix
This commit is contained in:
		| @@ -93,7 +93,7 @@ func BuildSub(clashType model.ClashType, query validator.SubValidator, template | ||||
| 	if len(query.Proxies) != 0 { | ||||
| 		proxyList = append(proxyList, utils.ParseProxy(query.Proxies...)...) | ||||
| 	} | ||||
| 	// 去重 | ||||
| 	// 去掉配置相同的节点 | ||||
| 	proxies := make(map[string]*model.Proxy) | ||||
| 	newProxies := make([]model.Proxy, 0, len(proxyList)) | ||||
| 	for i := range proxyList { | ||||
| @@ -104,14 +104,6 @@ func BuildSub(clashType model.ClashType, query validator.SubValidator, template | ||||
| 		} | ||||
| 	} | ||||
| 	proxyList = newProxies | ||||
| 	// 重名检测 | ||||
| 	names := make(map[string]bool) | ||||
| 	for i := range proxyList { | ||||
| 		if _, exist := names[proxyList[i].Name]; exist { | ||||
| 			proxyList[i].Name = proxyList[i].Name + "@" + proxyList[i].Server + ":" + strconv.Itoa(proxyList[i].Port) | ||||
| 		} | ||||
| 		names[proxyList[i].Name] = true | ||||
| 	} | ||||
| 	// 删除节点 | ||||
| 	if strings.TrimSpace(query.Remove) != "" { | ||||
| 		newProxyList := make([]model.Proxy, 0, len(proxyList)) | ||||
| @@ -156,6 +148,14 @@ func BuildSub(clashType model.ClashType, query validator.SubValidator, template | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	// 重名检测 | ||||
| 	names := make(map[string]int) | ||||
| 	for i := range proxyList { | ||||
| 		if _, exist := names[proxyList[i].Name]; exist { | ||||
| 			proxyList[i].Name = proxyList[i].Name + " " + strconv.Itoa(names[proxyList[i].Name]) | ||||
| 		} | ||||
| 		names[proxyList[i].Name] = names[proxyList[i].Name] + 1 | ||||
| 	} | ||||
| 	// trim | ||||
| 	for i := range proxyList { | ||||
| 		proxyList[i].Name = strings.TrimSpace(proxyList[i].Name) | ||||
|   | ||||
| @@ -35,7 +35,9 @@ func LoadSubscription(url string, refresh bool) ([]byte, error) { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		defer func(file *os.File) { | ||||
| 			if file != nil { | ||||
| 				_ = file.Close() | ||||
| 			} | ||||
| 		}(file) | ||||
| 		fileLock.RLock() | ||||
| 		defer fileLock.RUnlock() | ||||
| @@ -56,7 +58,9 @@ func FetchSubscriptionFromAPI(url string) ([]byte, error) { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	defer func(Body io.ReadCloser) { | ||||
| 		if Body != nil { | ||||
| 			_ = Body.Close() | ||||
| 		} | ||||
| 	}(resp.Body) | ||||
| 	data, err := io.ReadAll(resp.Body) | ||||
| 	if err != nil { | ||||
| @@ -67,7 +71,9 @@ func FetchSubscriptionFromAPI(url string) ([]byte, error) { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	defer func(file *os.File) { | ||||
| 		if file != nil { | ||||
| 			_ = file.Close() | ||||
| 		} | ||||
| 	}(file) | ||||
| 	fileLock.Lock() | ||||
| 	defer fileLock.Unlock() | ||||
|   | ||||
| @@ -17,7 +17,9 @@ func LoadTemplate(template string) ([]byte, error) { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		defer func(file *os.File) { | ||||
| 			if file != nil { | ||||
| 				_ = file.Close() | ||||
| 			} | ||||
| 		}(file) | ||||
| 		result, err := io.ReadAll(file) | ||||
| 		if err != nil { | ||||
|   | ||||
| @@ -16,7 +16,9 @@ func writeTemplate(path string, template string) error { | ||||
| 			return err | ||||
| 		} | ||||
| 		defer func(file *os.File) { | ||||
| 			if file != nil { | ||||
| 				_ = file.Close() | ||||
| 			} | ||||
| 		}(file) | ||||
| 		_, err = file.WriteString(template) | ||||
| 		if err != nil { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user