mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 12:42:12 +08:00 
			
		
		
		
	* feat: create e2e test readme Signed-off-by: Xinwei Xiong (cubxxw) <3293172751nss@gmail.com> * feat: fix markdown file * feat: add openim make lint * feat: add git chglog pull request * feat: add git chglog pull request * fix: fix openim api err code * fix: fix openim api err code * fix: fix openim api err code * feat: Improve CICD * feat: Combining GitHub and Google Workspace for Effective Project Management' * feat: fix openim tools error code * feat: fix openim tools error code * feat: add openim error handle * feat: add openim error handle * feat: optimize tim white prom code return err * feat: fix openim tools error code * style: format openim server code style * feat: add openim optimize commit code * feat: add openim optimize commit code * feat: add openim auto format code * feat: add openim auto format code * feat: add openim auto format code * feat: add openim auto format code * feat: add openim auto format code * feat: format openim code * feat: Some of the notes were translated * feat: Some of the notes were translated * feat: update openim server code * feat: optimize openim reset code * feat: optimize openim reset code --------- Signed-off-by: Xinwei Xiong (cubxxw) <3293172751nss@gmail.com>
		
			
				
	
	
	
		
			4.8 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			4.8 KiB
		
	
	
	
	
	
	
	
Code conventions
POSIX shell
Go
- Go Code Review Comments
- Effective Go
- Know and avoid Go landmines
- Comment your code.
- Go's commenting conventions
- If reviewers ask questions about why the code is the way it is, that's a sign that comments might be helpful.
 
- Command-line flags should use dashes, not underscores
- Naming
- Please consider package name when selecting an interface name, and avoid redundancy. For example, storage.Interfaceis better thanstorage.StorageInterface.
- Do not use uppercase characters, underscores, or dashes in package names.
- Please consider parent directory name when choosing a package name. For example, pkg/controllers/autoscaler/foo.goshould saypackage autoscalernotpackage autoscalercontroller.- Unless there's a good reason, the package fooline should match the name of the directory in which the.gofile exists.
- Importers can use a different name if they need to disambiguate.Ⓜ️
 
- Unless there's a good reason, the 
 
- Please consider package name when selecting an interface name, and avoid redundancy. For example, 
OpenIM Naming Conventions Guide
Welcome to the OpenIM Naming Conventions Guide. This document outlines the best practices and standardized naming conventions that our project follows to maintain clarity, consistency, and alignment with industry standards, specifically taking cues from the Google Naming Conventions.
1. General File Naming
Files within the OpenIM project should adhere to the following rules:
- Both hyphens (-) and underscores (_) are acceptable in file names.
- Underscores (_) are preferred for general files to enhance readability and compatibility.
- For example: data_processor.py,user_profile_generator.go
2. Special File Types
a. Script and Markdown Files
- Bash scripts and Markdown files should use hyphens (-) to facilitate better searchability and compatibility in web browsers.
- For example: deploy-script.sh,project-overview.md
b. Uppercase Markdown Documentation
- Markdown files with uppercase names, such as README, may include underscores (_) to separate words if necessary.
- For example: README_SETUP.md,CONTRIBUTING_GUIDELINES.md
3. Directory Naming
- Directories must use hyphens (-) exclusively to maintain a clean and organized file structure.
- For example: image-assets,user-data
4. Configuration Files
- Configuration files, including but not limited to .yamlfiles, should use hyphens (-).
- For example: app-config.yaml,logging-config.yaml
Best Practices
- Keep names concise but descriptive enough to convey the file's purpose or contents at a glance.
- Avoid using spaces in names; use hyphens or underscores instead to improve compatibility across different operating systems and environments.
- Stick to lowercase naming where possible for consistency and to prevent issues with case-sensitive systems.
- Include version numbers or dates in file names if the file is subject to updates, following the format: project-plan-v1.2.mdorbackup-2023-03-15.sql.
Directory and File Conventions
- Avoid generic utility packages. Instead of naming a package "util", choose a name that clearly describes its purpose. For instance, functions related to waiting operations are contained within the waitpackage, which includes methods likePoll, fully named aswait.Poll.
- All filenames, script files, configuration files, and directories should be in lowercase and use dashes (-) as separators.
- For Go language files, filenames should be in lowercase and use underscores (_).
- Package names should match their directory names to ensure consistency. For example, within the openim-apidirectory, the Go file should be namedopenim-api.go, following the convention of using dashes for directory names and aligning package names with directory names.
Testing conventions
Please refer to TESTING.md document.