transmission/libtransmission
Charles Kerr fa35b8ad39
refactor: use std::string in tr_variantToStr() (#2351)
* refactor: use std::string in tr_variantToStr()
2021-12-27 16:47:25 -06:00
..
.clang-tidy build: enable more .clang-tidy checks (#2088) 2021-11-03 08:59:39 -05:00
CMakeLists.txt refactor: tr_torrent_metainfo (#2340) 2021-12-25 15:21:13 -06:00
README.md
announce-list.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
announce-list.h refactor: take string_view in tr_loadFile(), tr_saveFile() (#2335) 2021-12-24 13:37:34 -06:00
announcer-common.h refactor: add tr_interned_string (#2332) 2021-12-23 11:16:05 -06:00
announcer-http.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
announcer-udp.cc refactor: add tr_interned_string (#2332) 2021-12-23 11:16:05 -06:00
announcer.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
announcer.h refactor: add tr_interned_string (#2332) 2021-12-23 11:16:05 -06:00
bandwidth.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
bandwidth.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
bitfield.cc fix: more sonarcloud warnings (#2324) 2021-12-16 23:47:51 -06:00
bitfield.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
block-info.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
block-info.h refactor: use tr_torrent_metainfo in transmission-show (#2341) 2021-12-25 16:41:18 -06:00
blocklist.cc refactor: fix uninit var warnings in blocklist.cc (#2087) 2021-11-02 22:55:43 -05:00
blocklist.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
cache.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
cache.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
clients.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
clients.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
completion.cc refactor: remove tr_file.offset (#2347) 2021-12-26 12:43:27 -06:00
completion.h refactor: remove tr_file.offset (#2347) 2021-12-26 12:43:27 -06:00
crypto-utils-ccrypto.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto-utils-cyassl.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto-utils-fallback.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto-utils-openssl.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto-utils-polarssl.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto-utils.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto-utils.h refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
crypto.cc fix: clang warnings (#2339) 2021-12-25 11:22:12 -06:00
crypto.h fix: clang warnings (#2339) 2021-12-25 11:22:12 -06:00
error-types.h
error.cc fix: more sonarcloud warnings (#2324) 2021-12-16 23:47:51 -06:00
error.h refactor: prefer tr_strv*() funcs (#2317) 2021-12-15 20:09:46 -06:00
fdlimit.cc fix: more sonarcloud warnings (#2324) 2021-12-16 23:47:51 -06:00
fdlimit.h
file-piece-map.cc refactor: move tr_ioFindFileLocation() to tr_file_piece_manager (#2334) 2021-12-24 00:39:55 -06:00
file-piece-map.h refactor: remove tr_file.offset (#2347) 2021-12-26 12:43:27 -06:00
file-posix.cc refactor: tr_sys_path_dirname(), tr_sys_path_basename() now take std::string_view parameters (#2177) 2021-11-15 18:50:14 -06:00
file-win32.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
file.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
file.h refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
foo refactor: add tr_interned_string (#2332) 2021-12-23 11:16:05 -06:00
handshake.cc refactor: further decouple tr_torrent and tr_info (#2336) 2021-12-24 15:12:33 -06:00
handshake.h
history.h
inout.cc refactor: move tr_ioFindFileLocation() to tr_file_piece_manager (#2334) 2021-12-24 00:39:55 -06:00
inout.h refactor: move tr_ioFindFileLocation() to tr_file_piece_manager (#2334) 2021-12-24 00:39:55 -06:00
interned-string.h fix: clang warnings (#2339) 2021-12-25 11:22:12 -06:00
jsonsl.c
jsonsl.h
libt.dox
log.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
log.h refactor: web_utils (#2121) 2021-11-08 21:30:03 -06:00
magnet-metainfo.cc refactor: tr_torrent_metainfo (#2340) 2021-12-25 15:21:13 -06:00
magnet-metainfo.h refactor: use tr_torrent_metainfo in transmission-show (#2341) 2021-12-25 16:41:18 -06:00
makemeta.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
makemeta.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
metainfo.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
metainfo.h refactor: remove tr_file.priv (#2349) 2021-12-26 16:04:20 -06:00
mime-types.h
mime-types.js
natpmp.cc
natpmp_local.h
net.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
net.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
peer-common.h refactor: add tr_interned_string (#2332) 2021-12-23 11:16:05 -06:00
peer-io.cc fix: clang warnings (#2339) 2021-12-25 11:22:12 -06:00
peer-io.h fix: clang warnings (#2339) 2021-12-25 11:22:12 -06:00
peer-mgr-active-requests.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
peer-mgr-active-requests.h refactor: swarm (#2103) 2021-11-19 12:37:38 -06:00
peer-mgr-wishlist.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
peer-mgr-wishlist.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
peer-mgr.cc refactor: further decouple tr_torrent and tr_info (#2336) 2021-12-24 15:12:33 -06:00
peer-mgr.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
peer-msgs.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
peer-msgs.h refactor: more tr_torrent housekeeping (#2320) 2021-12-16 03:43:51 -06:00
peer-socket.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
platform-quota.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
platform-quota.h refactor: tr_dirSpace() (#2143) 2021-11-13 12:09:14 -06:00
platform.cc refactor: take string_view in tr_loadFile(), tr_saveFile() (#2335) 2021-12-24 13:37:34 -06:00
platform.h refactor: use std mutex/lock intead of bespoke (#2194) 2021-11-20 15:20:45 -06:00
port-forwarding.cc
port-forwarding.h
ptrarray.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
ptrarray.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
quark.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
quark.h refactor: add tr_interned_string (#2332) 2021-12-23 11:16:05 -06:00
resume.cc refactor: remove tr_file.priv (#2349) 2021-12-26 16:04:20 -06:00
resume.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
rpc-server.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
rpc-server.h fix: some sonarcloud warnings (#2189) 2021-11-17 18:17:09 -06:00
rpcimpl.cc refactor: use tr_torrent_metainfo in tr ctor (#2345) 2021-12-26 10:25:07 -06:00
rpcimpl.h refactor: prefer tr_strv*() funcs (#2317) 2021-12-15 20:09:46 -06:00
session-id.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
session-id.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
session.cc fix: sonarcloud warnings (#2350) 2021-12-26 18:32:36 -06:00
session.h refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
stats.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
stats.h
subprocess-posix.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
subprocess-win32.cc fix: more sonarcloud warnings (#2324) 2021-12-16 23:47:51 -06:00
subprocess.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
torrent-ctor.cc refactor: use tr_torrent_metainfo in tr ctor (#2345) 2021-12-26 10:25:07 -06:00
torrent-magnet.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
torrent-magnet.h refactor: more tr_torrent housekeeping (#2320) 2021-12-16 03:43:51 -06:00
torrent-metainfo.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
torrent-metainfo.h refactor: tr_torrent_metainfo (#2340) 2021-12-25 15:21:13 -06:00
torrent.cc fix: sonarcloud warnings (#2350) 2021-12-26 18:32:36 -06:00
torrent.h refactor: remove tr_file.priv (#2349) 2021-12-26 16:04:20 -06:00
tr-assert.cc
tr-assert.h
tr-dht.cc refactor: tr_torrent_metainfo (#2340) 2021-12-25 15:21:13 -06:00
tr-dht.h
tr-getopt.cc
tr-getopt.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
tr-lpd.cc refactor: further decouple tr_torrent and tr_info (#2336) 2021-12-24 15:12:33 -06:00
tr-lpd.h
tr-macros.h refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
tr-udp.cc refactor: tr_session.congestion (#2151) 2021-11-14 00:41:44 -06:00
tr-udp.h refactor: more tr_torrent housekeeping (#2320) 2021-12-16 03:43:51 -06:00
tr-utp.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
tr-utp.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
transmission.h refactor: remove tr_file.priv (#2349) 2021-12-26 16:04:20 -06:00
trevent.cc fixup! refactor: use std mutex/lock intead of bespoke (#2194) (#2211) 2021-11-24 10:39:09 -06:00
trevent.h
upnp.cc
upnp.h
utils.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
utils.h refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
variant-benc.cc fix: more sonarcloud warnings (#2324) 2021-12-16 23:47:51 -06:00
variant-common.h refactor: make tr_variantFromBuf() public (#2187) 2021-11-17 23:37:35 -06:00
variant-json.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
variant.cc refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
variant.h refactor: use std::string in tr_variantToStr() (#2351) 2021-12-27 16:47:25 -06:00
verify.cc fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
verify.h
version.h.in
watchdir-common.h
watchdir-generic.cc
watchdir-inotify.cc
watchdir-kqueue.cc
watchdir-win32.cc
watchdir.cc refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
watchdir.h refactor: tidy libtransmission includes (#2316) 2021-12-15 15:25:42 -06:00
web-utils.cc refactor: use tr_sha1_digest_t everywhere (#2330) 2021-12-21 16:14:15 -06:00
web-utils.h fix: sonarcloud (#2322) 2021-12-16 16:58:58 -06:00
web.cc fix: more sonarcloud warnings (#2324) 2021-12-16 23:47:51 -06:00
web.h refactor: tr_web's callback now uses std::string_view (#2172) 2021-11-15 12:10:18 -06:00
webseed.cc chore: remove tr_pieceOffset() (#2346) 2021-12-26 11:25:51 -06:00
webseed.h refactor: add tr_torrentWebseed(), tr_torrentWebseedCount() (#2277) 2021-12-07 12:11:28 -06:00
wildmat.c

README.md

Notes on the C-to-C++ Conversion

  • libtransmission was written in C for fifteen years, so eliminating all Cisms is nearly impossible. Modernization patches are welcomed but it won't all happen overnight. tr_strdup() and constexpr wil exist side-by-side in the codebase for the forseeable future.

  • It's so tempting to refactor all the things! Please keep modernization patches reasonably focused so that they will be easy to review.

  • Prefer std:: tools over bespoke ones. For example, use std::vector instead of tr_ptrArray. Redundant bespoke code should be removed.

  • Consider ripple effects before adding C++ into public headers. Will it break C code that #includes that header? If you think it might, consult with downstream projects to see if this is a problem for them.

Checklist for modernization of a module

NOTE:
The version in libtransmission/CMakeLists.txt is C++17.
See https://github.com/AnthonyCalandra/modern-cpp-features

This can be done in multiple smaller passes:

  1. Satisfy clang-tidy. libtransmission/.clang-tidy's list of rules should eventually be expanded to a list similar to the one in qt/.clang-tidy.
  2. Group member functions and their parent structs
    • Use namespace libtransmission
    • Split large modules into smaller groups of files in a libtransmission/<name> subdirectories, with own sub-namespace.
  3. Enums replaced with new enum class syntax. Numeric #define constants replaced with C++ const/constexpr.
  4. Memory - promote init and free functions to C++ ctors and dtors, and ensure it is only managed with new/delete
  5. Owned memory - promote simple pointer fields owning their data to smart pointers (unique_ptr, shared_ptr, vector, string)

Detailed Steps

  1. Satisfy clang-tidy warnings

    • Change C includes to C++ wraps, example: <string.h> becomes and update calls to standard library to use std:: namespace prefix. This clearly delineates the border between std library and transmission. Headers must be sorted alphabetically.
    • Headers which are used conditionally based on some #ifdef in the code, should also have same #ifdef in the include section.
    • Revisit type warnings, int vs unsigned int. Sizes and counts should use size_t type where this does not break external API declarations. Ideally change that too.
  2. Move and group code together.

    • Move member functions into structs. To minimize code churn, create function forward declarations inside structs, and give struct_name:: prefixes to the functions.
      typedef struct {
          int field;
      } foo;
      int foo_blep(struct foo *f) {
          return f->field;
      }
      
      becomes:
      struct foo {
          int field;
          void blep(); 
      };
      int foo::blep() {
          return this->field; 
      }
      
    • For functions taking const pointer, add const after the function prototype: int blep() const like so.
    • For structs used by other modules, struct definitions should relocate to internal *-common.h header files.
    • Split large files into sub-modules sharing own separate sub-namespace and sitting in a subdirectory under libtransmission/.
    • Some externally invoked functions must either not move OR have extern "C" adapter functions.
  3. Enums promoted to enum class and given a type:

    enum { A, B, C };
    

    becomes

    enum: int { A, B, C };        // unscoped, use A, B, C
    enum MyEnum: int { A, B, C }; // unscoped, use A, B, C
    // OR wrap into a scope -
    enum struct MyEnum: int { A, B, C }; // scoped, use MyEnum::A
    enum class MyEnum: int { A, B, C };  // scoped, use MyEnum::A
    

    this will make all values of enum to have that numeric type.

  4. Numeric/bool #define constants should be replaced with C++ const/constexpr.

  5. Memory management:

    • Prefer constructors and destructors vs manual construction and destruction. But when doing so must ensure that the struct is never constructed using C malloc/free, but must use C++ new/delete.
    • Avoid using std::memset on a new struct. It is allowed in C, and C++ struct but will destroy virtual table on a C++ class. Use field initializers in C++.
  6. Owned memory:

    • If destructor deletes something, it means it was owned. Promote that field to owning type (vector, unique_ptr, shared_ptr or string).