Here add a pid_t to record the result of vte_terminal_fork_command,
when new tab creation, read the current shell's cwd first, then
keep the new tab on consistent curdir with current tab.

Signed-off-by: CHENG Renquan <[email protected]>

Index: src/lxterminal.c
===================================================================
--- src/lxterminal.c    (revision 2145)
+++ src/lxterminal.c    (working copy)
@@ -357,7 +357,19 @@ static void terminal_newtab(GtkWidget *w
 {
        LXTerminal *terminal = (LXTerminal *)data;
 
-       Term *term = terminal_new(terminal, _("LXTerminal"), 
g_get_current_dir(), NULL, NULL);
+       const gchar *pwd;
+       char cwd_file[64], buf[PATH_MAX+1];
+       int len;
+
+       Term *curr_term = g_ptr_array_index(terminal->terms, 
gtk_notebook_get_current_page(GTK_NOTEBOOK(terminal->notebook)));
+       g_snprintf(cwd_file, sizeof cwd_file, "/proc/%d/cwd", curr_term->pid);
+       len = readlink(cwd_file, buf, (sizeof buf) - 1);
+       if (len > 0 && buf[0] == '/')
+               pwd = g_strndup(buf, len);
+       else
+               pwd = g_get_current_dir();
+
+       Term *term = terminal_new(terminal, _("LXTerminal"), pwd, NULL, NULL);
 
        /* add page to notebook */
        gtk_notebook_append_page(GTK_NOTEBOOK(terminal->notebook), term->box, 
term->label->main);
@@ -675,10 +687,10 @@ static Term *terminal_new(LXTerminal *te
        if (exec) {
                gchar **command;
                g_shell_parse_argv(exec, NULL, &command, NULL);
-               vte_terminal_fork_command(VTE_TERMINAL(term->vte), (const char 
*)*(command), command, env, pwd, FALSE, TRUE, TRUE);
+               term->pid = vte_terminal_fork_command(VTE_TERMINAL(term->vte), 
(const char *)*(command), command, env, pwd, FALSE, TRUE, TRUE);
                g_strfreev(command);
        } else {
-               vte_terminal_fork_command(VTE_TERMINAL(term->vte), NULL, NULL, 
env, pwd, FALSE, TRUE, TRUE);
+               term->pid = vte_terminal_fork_command(VTE_TERMINAL(term->vte), 
NULL, NULL, env, pwd, FALSE, TRUE, TRUE);
        }
 
        /* signal handler */
Index: src/lxterminal.h
===================================================================
--- src/lxterminal.h    (revision 2145)
+++ src/lxterminal.h    (working copy)
@@ -62,6 +62,7 @@ typedef struct _term {
        GtkWidget *vte;
        GtkWidget *scrollbar;
        GtkWidget *box;
+       pid_t   pid;
 } Term;
 
 LXTerminal *lxterminal_init(LXTermWindow *lxtermwin, gint argc, gchar **argv, 
Setting *setting);

---
CHENG Renquan (程任全), from SMU (Singapore Management University)

------------------------------------------------------------------------------
Let Crystal Reports handle the reporting - Free Crystal Reports 2008 30-Day 
trial. Simplify your report design, integration and deployment - and focus on 
what you do best, core application coding. Discover what's new with
Crystal Reports now.  http://p.sf.net/sfu/bobj-july
_______________________________________________
Lxde-list mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/lxde-list

Reply via email to