1
0
Fork 0
mirror of git://git.code.sf.net/p/cdesktopenv/code synced 2025-03-09 15:50:02 +00:00
cde/cde/programs/dtsearchpath/libCliSrv/UnixEnv.C
Pascal Stumpf 71f3ed16f8 Patches for dtscreen, dtsearchpath, dtsession on OBSD.
Do not redefine round(3), and provide a manpath for OpenBSD.
(this is one of the few things that need to be adjusted for other BSDs)
2012-08-11 20:06:44 -06:00

355 lines
7.8 KiB
C

/*
* CDE - Common Desktop Environment
*
* Copyright (c) 1993-2012, The Open Group. All rights reserved.
*
* These libraries and programs are free software; you can
* redistribute them and/or modify them under the terms of the GNU
* Lesser General Public License as published by the Free Software
* Foundation; either version 2 of the License, or (at your option)
* any later version.
*
* These libraries and programs are distributed in the hope that
* they will be useful, but WITHOUT ANY WARRANTY; without even the
* implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU Lesser General Public License for more
* details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with these librararies and programs; if not, write
* to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
* Floor, Boston, MA 02110-1301 USA
*/
/* $TOG: UnixEnv.C /main/11 1998/12/14 17:06:02 mgreess $ */
/*******************************************************************
** (c) Copyright Hewlett-Packard Company, 1990, 1991, 1992, 1993.
** All rights are reserved. Copying or other reproduction of this
** program except for archival purposes is prohibited without prior
** written consent of Hewlett-Packard Company.
********************************************************************
****************************<+>*************************************/
#include "Environ.h"
#include "DirIterator.h"
#include <sys/stat.h>
#if defined(USL) || defined(__uxp__)
#define S_ISLNK(mode) ((mode & S_IFMT) == S_IFLNK)
#endif
#include <stdlib.h>
#include <string.h>
#if defined(linux)
#include <iostream>
#else
#include <iostream.h>
#endif
#include <stdio.h>
#include <unistd.h>
#include <grp.h>
#include <pwd.h>
#if defined(sun) || defined(USL) || defined(__uxp__)
#include <regexpr.h>
#else
#include <regex.h>
#endif
#include <errno.h>
#if defined(sun) || defined(_AIX) || defined(__osf__) || defined(USL) || defined(__uxp__) || defined(linux) || defined(CSRG_BASED)
#define UID_NO_CHANGE ((uid_t) -1)
#define GID_NO_CHANGE ((gid_t) -1)
#endif
UnixEnvironment::UnixEnvironment()
{
dtMountPoint = getEnvironmentVariable("DTMOUNTPOINT");
if (dtMountPoint.isNull())
#if defined(sun) || defined(USL) || defined(__uxp__)
dtMountPoint = "/net/";
#else
dtMountPoint = "/nfs/";
#endif
CString temp = getEnvironmentVariable("MANPATH");
if (temp.isNull())
#if defined(sun) || defined(USL) || defined(__uxp__)
manpath = "/usr/share/man";
#elif defined(_AIX)
manpath = "/usr/share/man:/usr/lpp/info";
#elif defined(hpux)
manpath = "/usr/man:/usr/contrib/man:/usr/local/man";
#elif defined(__osf__)
manpath = "/usr/share/%L/man:/usr/share/man:/usr/local/man";
#elif defined(linux)
manpath = "/usr/share/man/%L:/usr/share/man:/usr/contrib/man/%L:/usr/contrib/man:/usr/local/man/%L:/usr/local/man";
#elif defined(__OpenBSD__)
manpath = "/usr/share/man:/usr/X11R6/man:/usr/local/man:/usr/ports/infrastructure/man";
#endif
else
manpath = temp;
lang = getEnvironmentVariable("LANG");
if (lang.isNull())
lang = "C";
localHost = "localhost";
CString sh(getEnvironmentVariable("SHELL"));
cshFormat = 0;
if (isCsh(sh)) {
shell_ = new CShell();
cshFormat = 1;
}
else
shell_ = new KShell();
uid_ = getuid();
gid_ = getgid();
}
UnixEnvironment::~UnixEnvironment()
{
delete shell_;
}
int UnixEnvironment::FileExists
(
const CString & filename
) const
{
struct stat file;
if (stat((const char *)filename.data(),&file) == 0)
return 1;
return 0;
}
void UnixEnvironment::MakeDirectory
(
const CString & dirname,
mode_t permissions
)
{
if (mkdir (dirname.data(), permissions) == -1) {
CString errorStr("MakeDirectory: " + dirname);
perror(errorStr.data());
}
}
CString UnixEnvironment::getEnvironmentVariable
(
const char * envvar
)
{
char * value = getenv(envvar);
if (value == 0)
return CString("");
return CString(value);
}
int UnixEnvironment::isDirectory
(
const CString & directory
)
{
struct stat file;
if (stat((const char *)directory.data(),&file) == 0)
if (S_ISDIR(file.st_mode))
return 1;
return 0;
}
int UnixEnvironment::isFile
(
const CString & filespec
)
{
struct stat file;
if (stat((const char *)filespec.data(),&file) == 0)
if (S_ISREG(file.st_mode))
return 1;
return 0;
}
int UnixEnvironment::isLink
(
const CString & filespec
)
{
struct stat file;
if (lstat((const char *)filespec.data(),&file) == 0)
if (S_ISLNK(file.st_mode))
return 1;
return 0;
}
void UnixEnvironment::symbolicLink
(
const CString & linkto,
const CString & linkee
)
{
if (symlink (linkto.data(), linkee.data()) == -1) {
CString errorStr("symbolicLink: " + linkee + " -> " + linkto + "| ");
perror(errorStr.data());
}
}
void UnixEnvironment::setUserId
(
const char * name
)
{
uid_t uid = UID_NO_CHANGE;
if (name && name[0]) {
struct passwd * pwent = getpwnam(name);
uid = pwent->pw_uid;
}
else if (name == 0)
uid = uid_;
if (setuid(uid) == -1) {
CString errorStr("setUserId: ");
errorStr += name;
errorStr += "| ";
perror(errorStr.data());
}
}
void UnixEnvironment::changePermissions
(
const CString & filespec,
mode_t mode
)
{
if (chmod (filespec.data(), mode) == -1) {
CString errorStr("changePermissions: " + filespec + "| ");
perror(errorStr.data());
}
}
void UnixEnvironment::changeOwnerGroup
(
const CString & filespec,
const char * owner,
const char * group
)
{
uid_t uid = UID_NO_CHANGE;
gid_t gid = GID_NO_CHANGE;
if (owner) {
if (owner[0]) {
struct passwd * pwent = getpwnam(owner);
uid = pwent->pw_uid;
}
else
uid = getuid();
}
if (group) {
if (group[0]) {
struct group * grent = getgrnam(group);
gid = grent->gr_gid;
}
else
gid = getgid();
}
if (chown(filespec.data(),uid,gid) == -1) {
CString errorStr("changeOwnerGroup: " + filespec + "| ");
perror(errorStr.data());
}
}
void UnixEnvironment::removeDirectory
(
const CString & dirspec
)
{
#ifdef sun
removeFiles(dirspec, ".~*");
removeFiles(dirspec, "*");
#else
removeFiles(dirspec, "[.]~*");
removeFiles(dirspec, "[.]*");
#endif
if (rmdir (dirspec.data()) == -1) {
CString errorStr("removeDirectory: " + dirspec + "| ");
perror(errorStr.data());
}
}
void UnixEnvironment::removeFiles
(
const CString & dirspec,
const CString & filespec
)
{
#if defined(sun) || defined(__uxp__)
char buffer[100];
sprintf(buffer,"rm -f %s/%s", dirspec.data(),filespec.data());
system(buffer);
#else
DirectoryIterator dir(dirspec);
struct dirent * direntry;
while (direntry = dir()) {
/*# ifdef should_be_sun_but_this_dont_work*/
#if defined(USL)
char * re = NULL;
re = compile (filespec.data(), NULL, NULL);
if (step (direntry->d_name,re)) {
# else
regex_t re;
regcomp (&re, filespec.data(), 0);
if (regexec (&re, direntry->d_name, 0, NULL, 0) == 0) {
# endif
if (strcmp(direntry->d_name,".") == 0 ||
strcmp(direntry->d_name,"..") == 0)
continue;
removeFile(dirspec + "/" + direntry->d_name);
}
}
#endif
}
void UnixEnvironment::removeFile
(
const CString & filespec
)
{
if (isDirectory(filespec) && !isLink(filespec))
removeDirectory(filespec);
else {
if (unlink (filespec.data()) == -1) {
CString errorStr("removeFile(unlink): " + filespec + "| ");
perror(errorStr.data());
}
}
}
void UnixEnvironment::removeDeadLinks
(
const CString & dirspec
)
{
DIR * dir = opendir(dirspec.data());
struct dirent * direntry;
while (direntry = readdir(dir)) {
if (isLink(dirspec + "/" + direntry->d_name))
if (!isFile(dirspec + "/" + direntry->d_name) &&
!isDirectory(dirspec + "/" + direntry->d_name))
removeFile(dirspec + "/" + direntry->d_name);
}
closedir(dir);
}