3
0

logname.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * Mini logname implementation for busybox
  4. *
  5. * Copyright (C) 2000 Edward Betts <edward@debian.org>.
  6. *
  7. * Licensed under GPLv2 or later, see file LICENSE in this source tree.
  8. */
  9. /* BB_AUDIT SUSv3 compliant */
  10. /* http://www.opengroup.org/onlinepubs/007904975/utilities/logname.html */
  11. /* Mar 16, 2003 Manuel Novoa III (mjn3@codepoet.org)
  12. *
  13. * SUSv3 specifies the string used is that returned from getlogin().
  14. * The previous implementation used getpwuid() for geteuid(), which
  15. * is _not_ the same. Erik apparently made this change almost 3 years
  16. * ago to avoid failing when no utmp was available. However, the
  17. * correct course of action wrt SUSv3 for a failing getlogin() is
  18. * a diagnostic message and an error return.
  19. */
  20. //usage:#define logname_trivial_usage
  21. //usage: ""
  22. //usage:#define logname_full_usage "\n\n"
  23. //usage: "Print the name of the current user"
  24. //usage:
  25. //usage:#define logname_example_usage
  26. //usage: "$ logname\n"
  27. //usage: "root\n"
  28. #include "libbb.h"
  29. /* This is a NOFORK applet. Be very careful! */
  30. int logname_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
  31. int logname_main(int argc UNUSED_PARAM, char **argv UNUSED_PARAM)
  32. {
  33. char buf[64];
  34. if (argv[1]) {
  35. bb_show_usage();
  36. }
  37. /* Using _r function - avoid pulling in static buffer from libc */
  38. if (getlogin_r(buf, sizeof(buf)) == 0) {
  39. puts(buf);
  40. return fflush_all();
  41. }
  42. bb_perror_msg_and_die("getlogin");
  43. }