Skip to content

Commit d3c66a6

Browse files
committed
improve portability (esp. musl)
cf. Github PR#56
1 parent ff634c9 commit d3c66a6

File tree

2 files changed

+12
-13
lines changed

2 files changed

+12
-13
lines changed

src/core/abi.cc

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -20,9 +20,7 @@ __ID("@(#) $Id: mem.cc 1352 2006-05-27 23:54:13Z ezix $");
2020
bool scan_abi(hwNode & system)
2121
{
2222
// are we compiled as 32- or 64-bit process ?
23-
long sc = sysconf(LONG_BIT);
24-
if(sc==-1) sc = sysconf(_SC_LONG_BIT);
25-
if(sc!=-1) system.setWidth(sc);
23+
system.setWidth(LONG_BIT);
2624

2725
pushd(PROC_SYS);
2826

src/core/sysfs.cc

Lines changed: 11 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@
1616
#include <sys/stat.h>
1717
#include <sys/types.h>
1818
#include <sys/mount.h>
19+
#include <libgen.h>
1920

2021

2122
__ID("@(#) $Id$");
@@ -103,7 +104,7 @@ static string sysfs_getbustype(const string & path)
103104
{
104105
string devname =
105106
string(fs.path + "/bus/") + string(namelist[i]->d_name) +
106-
"/devices/" + basename(path.c_str());
107+
"/devices/" + basename(const_cast<char*>(path.c_str()));
107108

108109
if (samefile(devname, path))
109110
{
@@ -151,7 +152,7 @@ static string sysfstobusinfo(const string & path)
151152

152153
if (bustype == "usb")
153154
{
154-
string name = basename(path.c_str());
155+
string name = basename(const_cast<char*>(path.c_str()));
155156
if (matches(name, "^[0-9]+-[0-9]+(\\.[0-9]+)*:[0-9]+\\.[0-9]+$"))
156157
{
157158
size_t colon = name.rfind(":");
@@ -162,18 +163,18 @@ static string sysfstobusinfo(const string & path)
162163

163164
if (bustype == "virtio")
164165
{
165-
string name = basename(path.c_str());
166+
string name = basename(const_cast<char*>(path.c_str()));
166167
if (name.compare(0, 6, "virtio") == 0)
167168
return "virtio@" + name.substr(6);
168169
else
169170
return "virtio@" + name;
170171
}
171172

172173
if (bustype == "vio")
173-
return string("vio@") + basename(path.c_str());
174+
return string("vio@") + basename(const_cast<char*>(path.c_str()));
174175

175176
if (bustype == "ccw")
176-
return string("ccw@") + basename(path.c_str());
177+
return string("ccw@") + basename(const_cast<char*>(path.c_str()));
177178

178179
if (bustype == "ccwgroup")
179180
{
@@ -251,7 +252,7 @@ string entry::driver() const
251252
string driverlink = This->devpath + "/driver";
252253
if (!exists(driverlink))
253254
return "";
254-
return basename(readlink(driverlink).c_str());
255+
return basename(const_cast<char*>(readlink(driverlink).c_str()));
255256
}
256257

257258

@@ -339,7 +340,7 @@ string entry::name_in_class(const string & classname) const
339340

340341
string entry::name() const
341342
{
342-
return basename(This->devpath.c_str());
343+
return basename(const_cast<char*>(This->devpath.c_str()));
343344
}
344345

345346

@@ -351,17 +352,17 @@ entry entry::parent() const
351352

352353
string entry::classname() const
353354
{
354-
return basename(dirname(This->devpath).c_str());
355+
return basename(const_cast<char*>(dirname(This->devpath).c_str()));
355356
}
356357

357358
string entry::subsystem() const
358359
{
359-
return basename(realpath(This->devpath+"/subsystem").c_str());
360+
return basename(const_cast<char*>(realpath(This->devpath+"/subsystem").c_str()));
360361
}
361362

362363
bool entry::isvirtual() const
363364
{
364-
return string(basename(dirname(dirname(This->devpath)).c_str())) == "virtual";
365+
return string(basename(const_cast<char*>(dirname(dirname(This->devpath)).c_str()))) == "virtual";
365366
}
366367

367368
string entry::string_attr(const string & name, const string & def) const

0 commit comments

Comments
 (0)