# common_util **Repository Path**: cpplibs/common_util ## Basic Information - **Project Name**: common_util - **Description**: common util library for C++ - **Primary Language**: C++ - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: http://sunlogging.com/docs/common_util/ - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 6 - **Created**: 2024-09-11 - **Last Updated**: 2024-09-11 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README @mainpage ## 1. Source code | Region | Platform | Source Code Repository URL | | --- | --- | --- | | Mainland China | gitcode | [https://gitcode.com/luoweifu1/common_util](https://gitcode.com/luoweifu1/common_util) | | Mainland China | Gitee | [https://gitee.com/spencer_luo/common_util](https://gitee.com/spencer_luo/common_util) | | International | Github | [https://github.com/spencer-luo/common_util](https://github.com/spencer-luo/common_util) | ## 2. Overview common_util is a general-purpose C++ utility library, include the following functions: - Time utilities - Function timer - Filepath utilities - Filesystem utilities - String utilities - Data formatting - Singleton pattern macro definition common_util is implemented in modern C++ syntax (C++11 and above), using cutl as the namespace. The naming convention of all interfaces is consistent with the STL, and it can be used as an extensions of C++ standard library. You can use common_util just like using the STL, For example: ```C++ // Data formatting std::cout << "fmt_uint: " << cutl::fmt_uint(12, 5) << std::endl; std::cout << "fmt_double: " << cutl::fmt_double(3.141592653, 4) << std::endl; std::cout << "fmt_filesize: " << cutl::fmt_filesize(33600) << std::endl; // Get the current system time auto now = cutl::datetime::now(); std::cout << "current time(UTC time): " << now.utctime() << std::endl; std::cout << "current time(local time): " << now.format() << std::endl; ``` ## 3. Library Features - **Simple and lightweigh**: Based on basic C++ syntax and STL, it independent on any third-party libraries. - **Multi-platform support**: Supports multiple platforms such as Linux/macOS/Windows, it can be compiled and run on multiple platforms. - **Clean code**: The code style is clean, and the naming convention is consistent with the STL, you can use this library just like use the C++ standard library. - **Comprehensive documentation**: All exported header files have detail comments, it has complete API reference and usage demos. - **C++ version requirement**: C++11 and above versions. ## 4. Testing Platforms This library has been tested and verified on the following platforms: | Operating System Platform and Version | C++ Compiler and Version | Testing Status | Remarks | | ------------------------------------- | ------------------------ | -------------- | ------- | | Windows 10 | Visual Studio 2015 | tested | | | Ubuntu 20.04.4 | GNU GCC 9.4.0 | tested | | | macOS xxx | Clang version 15.0.0 | tested | | | Android | | To be tested | | | iOS | | To be tested | | | HarmonyOS | | To be tested | | ## 5. Related Documents - off-line: [docs/reference/html/index.html](./docs/reference/html/index.html) - on line : [http://sunlogging.com/docs/common_util/](http://sunlogging.com/docs/common_util/) ## 6. Welcome to Collaborate We welcome all developers who are interested in this project to join us, whether you are an experienced senior developer or a newcomer just starting out, we look forward to your participation. You can get involved in the project in the following ways: - **Code Contribution:** You can fork our code repository, conduct code development, and submit your code via a pull request. - **Issue Feedback:** If you encounter any problems during use or have any suggestions, feel free to raise them in the issue section. - **Documentation Writing:** We welcome you to write documentation for the project, helping other developers better understand and use our project. - **Testing and Feedback:** You can assist us in code testing and provide valuable feedback. If you have any questions or need help, please feel free to contact me through the following methods: Email: [spencer.luo@foxmail.com] Looking forward to your participation! ## 7. 源码仓库 | 地区 | 代码托管平台 | 源码仓库地址 | | --- | --- | --- | | 中国大陆 | gitcode | [https://gitcode.com/luoweifu1/common_util](https://gitcode.com/luoweifu1/common_util) | | 中国大陆 | Gitee | [https://gitee.com/spencer_luo/common_util](https://gitee.com/spencer_luo/common_util) | | 国际站点 | Github | [https://github.com/spencer-luo/common_util](https://github.com/spencer-luo/common_util) | ## 8. 概述 common_util是C++的一个通用工具库,主要包含以下功能: - 时间处理 - 函数计时器 - 路径处理 - 文件操作 - 字符串处理 - 数据格式化 - 单例模式宏定义 common_util采用现代C++语法(C++11及以上)实现,使用cutl作为命名空间,所有接口的命名方式与STL保持一致,可以作为STL库的一个补充。你可以像使用STL一样使用common_util,如: ```C++ // 数据格式化 std::cout << "fmt_uint: " << cutl::fmt_uint(12, 5) << std::endl; std::cout << "fmt_double: " << cutl::fmt_double(3.141592653, 4) << std::endl; std::cout << "fmt_filesize: " << cutl::fmt_filesize(33600) << std::endl; // 获取系统当前时间 auto now = cutl::datetime::now(); std::cout << "current time(UTC time): " << now.utctime() << std::endl; std::cout << "current time(local time): " << now.format() << std::endl; ``` ## 9. 设计特点 - **轻量极简**: 基于基础C++语法和STL,不依赖任何第三方库。 - **多平台支持**: 支持Linux/OS-X/Windows等多个平台,一套代码多平台编译。 - **代码整洁**: 代码风格整洁,命名方式与STL保持一致,你可以像使用STL一样使用本库。 - **文档规范全面**: 所有对外接口的头文件都有详细的代码注释,且有完整的API文档和使用Demo,可供查阅。 - **C++版本要求**: C++11及以上版本。 ## 10. 已验证的平台 本库在以下平台上测试验证过: | 操作系统平台及版本 | C++编译器及版本 | 验证状态 | 备注 | | ------------------ | ------------------ | -------- | ---- | | Windows 10 | Visual Studio 2015 | 已验证 | | | Ubuntu 20.04.4 | GNU GCC 9.4.0 | 已验证 | | | macOS xxx | Clang version 15.0.0| 已验证 | | | Android | | 待验证 | | | iOS | | 待验证 | | | HarmonyOS | | 待验证 | | ## 11. 相关文档 - 离线文档: [docs/reference/html/index.html](./docs/reference/html/index.html) - 在线文档: [http://sunlogging.com/docs/common_util/](http://sunlogging.com/docs/common_util/) ## 12. 欢迎共建 我们欢迎所有对此项目感兴趣的开发者加入我们,无论您是经验丰富的资深开发者,还是刚刚入门的新手,我们都期待您的参与。您可以通过以下方式参与到项目中: - **代码贡献:** 您可以 fork 我们的代码仓库,进行代码开发,并通过 pull request 提交您的代码。 - **问题反馈:** 如果您在使用过程中遇到任何问题或有任何建议,欢迎在 issue 区提出。 - **文档编写:** 我们欢迎您为项目编写文档,帮助其他开发者更好地理解和使用我们的项目。 - **测试与反馈:** 您可以帮助我们进行代码测试,并提供宝贵的反馈意见。 如果您有任何疑问或需要帮助,欢迎通过以下方式联系我: 邮箱:[spencer.luo@foxmail.com] 期待你的参与!