Hello,

I'm using the following show_users() function in order to retreive in
postgresql the output from the unix "ps" command.

When run directly from a shell, this code:

  $ps = `ps -afux | grep postgres`;
  @fields = split /\n/, $ps;
  return "{" . join(",", @fields) . "}";

... runs fine.

But when run inside a plperlu function, lines are being truncated after
a certain width.

Is that a known limitation of plperlu? Or maybe something else?



Philippe

------------------------------------------------------------
--  TYPE: line_type
------------------------------------------------------------
CREATE TYPE public.line_type AS
(
  line text
);

------------------------------------------------------------
--  UTILITY FUNCTION: ps
------------------------------------------------------------
CREATE FUNCTION public.ps()
  RETURNS text[] AS
'
  $ps = `ps -afux | grep postgres`;
  @fields = split /\n/, $ps;
  return "{" . join(",", @fields) . "}";
'
  LANGUAGE 'plperlu' VOLATILE;

------------------------------------------------------------
--  UTILITY FUNCTION: show_users
------------------------------------------------------------
CREATE FUNCTION public.show_users()
  RETURNS SETOF user_type AS
'
DECLARE
  users        text[];
  user_rec     line_type%ROWTYPE;
  i            int2;

BEGIN
  users = ps();

  FOR i IN 1 .. array_upper(users, 1) LOOP

    user_rec.line = users[i];
    RETURN NEXT user_rec;

  END LOOP;

  RETURN;
END
'
  LANGUAGE 'plpgsql' VOLATILE;

------------------------------------------------------------
--  MAIN
------------------------------------------------------------
select * from show_users();


---------------------------(end of broadcast)---------------------------
TIP 8: explain analyze is your friend

Reply via email to