kill CAST_INIT, use reinterpret_cast<> on sockaddr

Just use static_cast directly instead of inscrutible "shortcut"
macro.

It was not always used and doesn't seem to do much besides scramble
things up; encountering CAST_INIT() in the code seems likely to lead
to head scratching due to the transformation taking place.

It was added to save folks typing the type twice, now with 100
columns available, let's roll that convenience macro back.

sockaddr_dl:

Perform reinterpret_cast<sockaddr_dl> conversion. The cast affected
alignment and looks fishy to a compiler (but it's fine). Ditch
C-style cast and communicate we're doing that on purpose.
This commit is contained in:
Aaron Gyes 2016-07-30 12:01:37 -07:00
parent ee26eafc25
commit d51a1e4fe2
5 changed files with 18 additions and 20 deletions

View file

@ -27,10 +27,6 @@
#define OS_IS_CYGWIN #define OS_IS_CYGWIN
#endif #endif
/// Avoid writing the type name twice in a common "static_cast-initialization". Caveat: This doesn't
/// work with type names containing commas!
#define CAST_INIT(type, dst, src) type dst = static_cast<type>(src)
// Common string type. // Common string type.
typedef std::wstring wcstring; typedef std::wstring wcstring;
typedef std::vector<wcstring> wcstring_list_t; typedef std::vector<wcstring> wcstring_list_t;

View file

@ -935,7 +935,7 @@ static bool get_mac_address(unsigned char macaddr[MAC_ADDRESS_MAX_LEN],
if (p->ifa_addr->sa_family == AF_LINK) { if (p->ifa_addr->sa_family == AF_LINK) {
if (p->ifa_name && p->ifa_name[0] && if (p->ifa_name && p->ifa_name[0] &&
!strcmp((const char *)p->ifa_name, interface)) { !strcmp((const char *)p->ifa_name, interface)) {
const sockaddr_dl &sdl = *(sockaddr_dl *)p->ifa_addr; const sockaddr_dl &sdl = *reinterpret_cast<sockaddr_dl *>(p->ifa_addr);
size_t alen = sdl.sdl_alen; size_t alen = sdl.sdl_alen;
if (alen > MAC_ADDRESS_MAX_LEN) alen = MAC_ADDRESS_MAX_LEN; if (alen > MAC_ADDRESS_MAX_LEN) alen = MAC_ADDRESS_MAX_LEN;

View file

@ -105,7 +105,7 @@ static bool redirection_is_to_real_file(const io_data_t *io) {
bool result = false; bool result = false;
if (io != NULL && io->io_mode == IO_FILE) { if (io != NULL && io->io_mode == IO_FILE) {
// It's a file redirection. Compare the path to /dev/null. // It's a file redirection. Compare the path to /dev/null.
CAST_INIT(const io_file_t *, io_file, io); const io_file_t *io_file = static_cast<const io_file_t *>(io);
const char *path = io_file->filename_cstr; const char *path = io_file->filename_cstr;
if (strcmp(path, "/dev/null") != 0) { if (strcmp(path, "/dev/null") != 0) {
// It's not /dev/null. // It's not /dev/null.
@ -268,7 +268,7 @@ static bool io_transmogrify(const io_chain_t &in_chain, io_chain_t *out_chain,
case IO_FILE: { case IO_FILE: {
// Transmogrify file redirections. // Transmogrify file redirections.
int fd; int fd;
CAST_INIT(io_file_t *, in_file, in.get()); io_file_t *in_file = static_cast<io_file_t *>(in.get());
if ((fd = open(in_file->filename_cstr, in_file->flags, OPEN_MASK)) == -1) { if ((fd = open(in_file->filename_cstr, in_file->flags, OPEN_MASK)) == -1) {
debug(1, FILE_ERROR, in_file->filename_cstr); debug(1, FILE_ERROR, in_file->filename_cstr);
@ -404,7 +404,7 @@ void exec_job(parser_t &parser, job_t *j) {
const shared_ptr<io_data_t> &io = all_ios.at(idx); const shared_ptr<io_data_t> &io = all_ios.at(idx);
if ((io->io_mode == IO_BUFFER)) { if ((io->io_mode == IO_BUFFER)) {
CAST_INIT(io_buffer_t *, io_buffer, io.get()); io_buffer_t *io_buffer = static_cast<io_buffer_t *>(io.get());
assert(!io_buffer->is_input); assert(!io_buffer->is_input);
} }
} }
@ -450,7 +450,7 @@ void exec_job(parser_t &parser, job_t *j) {
for (size_t i = 0; i < all_ios.size(); i++) { for (size_t i = 0; i < all_ios.size(); i++) {
io_data_t *io = all_ios.at(i).get(); io_data_t *io = all_ios.at(i).get();
if (io->io_mode == IO_BUFFER) { if (io->io_mode == IO_BUFFER) {
CAST_INIT(io_buffer_t *, io_buffer, io); io_buffer_t *io_buffer = static_cast<io_buffer_t *>(io);
if (!io_buffer->avoid_conflicts_with_io_chain(all_ios)) { if (!io_buffer->avoid_conflicts_with_io_chain(all_ios)) {
// We could not avoid conflicts, probably due to fd exhaustion. Mark an error. // We could not avoid conflicts, probably due to fd exhaustion. Mark an error.
exec_error = true; exec_error = true;
@ -715,7 +715,7 @@ void exec_job(parser_t &parser, job_t *j) {
if (in) { if (in) {
switch (in->io_mode) { switch (in->io_mode) {
case IO_FD: { case IO_FD: {
CAST_INIT(const io_fd_t *, in_fd, in.get()); const io_fd_t *in_fd = static_cast<const io_fd_t *>(in.get());
// Ignore user-supplied fd redirections from an fd other than the // Ignore user-supplied fd redirections from an fd other than the
// standard ones. e.g. in source <&3 don't actually read from fd 3, // standard ones. e.g. in source <&3 don't actually read from fd 3,
// which is internal to fish. We still respect this redirection in // which is internal to fish. We still respect this redirection in
@ -730,13 +730,13 @@ void exec_job(parser_t &parser, job_t *j) {
break; break;
} }
case IO_PIPE: { case IO_PIPE: {
CAST_INIT(const io_pipe_t *, in_pipe, in.get()); const io_pipe_t *in_pipe = static_cast<const io_pipe_t *>(in.get());
local_builtin_stdin = in_pipe->pipe_fd[0]; local_builtin_stdin = in_pipe->pipe_fd[0];
break; break;
} }
case IO_FILE: { case IO_FILE: {
// Do not set CLO_EXEC because child needs access. // Do not set CLO_EXEC because child needs access.
CAST_INIT(const io_file_t *, in_file, in.get()); const io_file_t *in_file = static_cast<const io_file_t *>(in.get());
local_builtin_stdin = local_builtin_stdin =
open(in_file->filename_cstr, in_file->flags, OPEN_MASK); open(in_file->filename_cstr, in_file->flags, OPEN_MASK);
if (local_builtin_stdin == -1) { if (local_builtin_stdin == -1) {
@ -932,8 +932,10 @@ void exec_job(parser_t &parser, job_t *j) {
// performance quite a bit in complex completion code. // performance quite a bit in complex completion code.
debug(3, L"Skipping fork: buffered output for internal builtin '%ls'", debug(3, L"Skipping fork: buffered output for internal builtin '%ls'",
p->argv0()); p->argv0());
CAST_INIT(io_buffer_t *, io_buffer, stdout_io.get());
io_buffer_t *io_buffer = static_cast<io_buffer_t *>(stdout_io.get());
const std::string res = wcs2string(builtin_io_streams->out.buffer()); const std::string res = wcs2string(builtin_io_streams->out.buffer());
io_buffer->out_buffer_append(res.data(), res.size()); io_buffer->out_buffer_append(res.data(), res.size());
fork_was_skipped = true; fork_was_skipped = true;
} else if (stdout_io.get() == NULL && stderr_io.get() == NULL) { } else if (stdout_io.get() == NULL && stderr_io.get() == NULL) {

View file

@ -137,7 +137,7 @@ static int handle_child_io(const io_chain_t &io_chain) {
case IO_FILE: { case IO_FILE: {
// Here we definitely do not want to set CLO_EXEC because our child needs access. // Here we definitely do not want to set CLO_EXEC because our child needs access.
CAST_INIT(const io_file_t *, io_file, io); const io_file_t *io_file = static_cast<const io_file_t *>(io);
int tmp = open(io_file->filename_cstr, io_file->flags, OPEN_MASK); int tmp = open(io_file->filename_cstr, io_file->flags, OPEN_MASK);
if (tmp < 0) { if (tmp < 0) {
if ((io_file->flags & O_EXCL) && (errno == EEXIST)) { if ((io_file->flags & O_EXCL) && (errno == EEXIST)) {
@ -181,7 +181,7 @@ static int handle_child_io(const io_chain_t &io_chain) {
case IO_BUFFER: case IO_BUFFER:
case IO_PIPE: { case IO_PIPE: {
CAST_INIT(const io_pipe_t *, io_pipe, io); const io_pipe_t *io_pipe = static_cast<const io_pipe_t *>(io);
// If write_pipe_idx is 0, it means we're connecting to the read end (first pipe // If write_pipe_idx is 0, it means we're connecting to the read end (first pipe
// fd). If it's 1, we're connecting to the write end (second pipe fd). // fd). If it's 1, we're connecting to the write end (second pipe fd).
unsigned int write_pipe_idx = (io_pipe->is_input ? 0 : 1); unsigned int write_pipe_idx = (io_pipe->is_input ? 0 : 1);
@ -340,7 +340,7 @@ bool fork_actions_make_spawn_properties(posix_spawnattr_t *attr,
const shared_ptr<const io_data_t> io = io_chain.at(idx); const shared_ptr<const io_data_t> io = io_chain.at(idx);
if (io->io_mode == IO_FD) { if (io->io_mode == IO_FD) {
CAST_INIT(const io_fd_t *, io_fd, io.get()); const io_fd_t *io_fd = static_cast<const io_fd_t *>(io.get());
if (io->fd == io_fd->old_fd) continue; if (io->fd == io_fd->old_fd) continue;
} }
@ -351,7 +351,7 @@ bool fork_actions_make_spawn_properties(posix_spawnattr_t *attr,
} }
case IO_FILE: { case IO_FILE: {
CAST_INIT(const io_file_t *, io_file, io.get()); const io_file_t *io_file = static_cast<const io_file_t *>(io.get());
if (!err) if (!err)
err = posix_spawn_file_actions_addopen(actions, io->fd, io_file->filename_cstr, err = posix_spawn_file_actions_addopen(actions, io->fd, io_file->filename_cstr,
io_file->flags /* mode */, OPEN_MASK); io_file->flags /* mode */, OPEN_MASK);
@ -359,7 +359,7 @@ bool fork_actions_make_spawn_properties(posix_spawnattr_t *attr,
} }
case IO_FD: { case IO_FD: {
CAST_INIT(const io_fd_t *, io_fd, io.get()); const io_fd_t *io_fd = static_cast<const io_fd_t *>(io.get());
if (!err) if (!err)
err = posix_spawn_file_actions_adddup2(actions, io_fd->old_fd /* from */, err = posix_spawn_file_actions_adddup2(actions, io_fd->old_fd /* from */,
io->fd /* to */); io->fd /* to */);
@ -368,7 +368,7 @@ bool fork_actions_make_spawn_properties(posix_spawnattr_t *attr,
case IO_BUFFER: case IO_BUFFER:
case IO_PIPE: { case IO_PIPE: {
CAST_INIT(const io_pipe_t *, io_pipe, io.get()); const io_pipe_t *io_pipe = static_cast<const io_pipe_t *>(io.get());
unsigned int write_pipe_idx = (io_pipe->is_input ? 0 : 1); unsigned int write_pipe_idx = (io_pipe->is_input ? 0 : 1);
int from_fd = io_pipe->pipe_fd[write_pipe_idx]; int from_fd = io_pipe->pipe_fd[write_pipe_idx];
int to_fd = io->fd; int to_fd = io->fd;

View file

@ -711,7 +711,7 @@ static int select_try(job_t *j) {
for (size_t idx = 0; idx < chain.size(); idx++) { for (size_t idx = 0; idx < chain.size(); idx++) {
const io_data_t *io = chain.at(idx).get(); const io_data_t *io = chain.at(idx).get();
if (io->io_mode == IO_BUFFER) { if (io->io_mode == IO_BUFFER) {
CAST_INIT(const io_pipe_t *, io_pipe, io); const io_pipe_t *io_pipe = static_cast<const io_pipe_t *>(io);
int fd = io_pipe->pipe_fd[0]; int fd = io_pipe->pipe_fd[0];
// fwprintf( stderr, L"fd %d on job %ls\n", fd, j->command ); // fwprintf( stderr, L"fd %d on job %ls\n", fd, j->command );
FD_SET(fd, &fds); FD_SET(fd, &fds);