const fi='network.inp';
fo='network.out';
maxn=round(1e5)*2;
maxn1=round(1e6)*5;
var w,a,h,p,x,y,z,u,v,c,cs,tt,con,nhan,d,loai,nhancuadinh:array[0..maxn]of longint;
it2,it,lazy:array[0..maxn1]of longint;
b:array[0..round(1e5),0..20]of longint;
n,m,slnhan,top:longint;
procedure mo;
begin
assign(input,fi);reset(input);
assign(output,fo);rewrite(output);
end;
procedure dong;
begin
closE(input);closE(output);
end;
procedure nhap;
var i,k:longint;
xx:char;
begin
readln(n,m);
for i:=1 to n-1 do
begin
readln(X[i],y[i],z[i]);
inc(h[x[i]]);
inc(h[y[i]]);
end;
for i:=1 to n+1 do inc(h[i],h[i-1]);
for i:=1 to n-1 do
begin
a[h[x[i]]]:=y[i];
p[h[x[i]]]:=z[i];
dec(h[x[i]]);
a[h[y[i]]]:=x[i];
p[h[y[i]]]:=z[i];
dec(h[y[i]]);
end;
for i:=1 to m do
begin
read(xx);
if xx='P' then
begin
readln(u[i],v[i],c[i]);
loai[i]:=1;
end
else
begin
readln(k,c[i]);
u[i]:=x[k];
v[i]:=y[k];
loai[i]:=2;
end;
end;
end;
procedure swap(var i,j:longint);
var t:longint;
begin
t:=i;
i:=j;
j:=t;
end;
procedure qs(l,r:longint);
var x,i,j:longint;
begin
i:=l;
j:=r;
x:=w[random(r-l)+1+l];
repeat
while w[i]<x do inc(i);
while x<w[j] do dec(j);
if i<=j then
begin
swap(cs[i],cs[j]);
swap(w[i],w[j]);
inc(i);
dec(j);
end;
until i>j;
if i<r then qs(i,r);
if l<j then qs(l,j);
end;
procedure qstv(l,r:longint);
var x,i,j:longint;
begin
i:=l;
j:=r;
x:=c[random(r-l)+1+l];
repeat
while (c[i]<x) do inc(i);
while (x<c[j]) do dec(j);
if i<=j then
begin
swap(c[i],c[j]);
swap(u[i],u[j]);
swap(v[i],v[j]);
swap(tt[i],tt[j]);
swap(loai[i],loai[j]);
inc(i);
dec(j);
end;
until i>j;
if i<r then qstv(i,r);
if l<j then qstv(l,j);
end;
procedure dfs(u:longint);
var v:longint;
begin
con[u]:=1;
for v:=h[u]+1 to h[u+1] do
if nhan[a[v]]=0 then
begin
w[a[v]]:=p[v];
b[a[v],0]:=u;
d[a[v]]:=d[u]+1;
inc(slnhan);
nhan[a[v]]:=slnhan;
dfs(a[v]);
con[u]:=con[a[v]]+con[u];
end;
end;
procedure sort;
var i:longint;
begin
slnhan:=1;
nhan[1]:=1;
d[1]:=1;
dfs(1);
//for i:=1 to n do
// writeln(nhan[i],' ',con[i]);
for i:=1 to n do cs[i]:=i;
qs(1,n);
//for i:=1 to n do writeln(cs[i],' ',w[i]);
for i:=1 to m do tt[i]:=i;
qstv(1,m);
//for i:=1 to m do writeln(u[i],' ',v[i],' ',c[i],' ',tt[i]);
end;
procedure qsnhan(l,r:longint);
var i,j,x:longint;
begin
i:=l;
j:=r;
x:=nhan[random(r-l)+1+l];
repeat
while nhan[i]<x do inc(i);
while x<nhan[j] do dec(j);
if i<=j then
begin
swap(nhan[i],nhan[j]);
//swap(nhancuadinh[i],nhancuadinh[j]);
inc(i);
dec(j);
end;
until i>j;
if i<r then qsnhan(i,r);
if l<j then qsnhan(l,j);
end;
procedure update(u,v,l,r,i:longint);
var mid:longint;
begin
it[i]:=it[i]+lazy[i];
lazy[i*2]:=lazy[i*2]+lazy[i];
lazy[i*2+1]:=lazy[i*2+1]+lazy[i];
lazy[i]:=0;
if (r<u) or (v<l) then exit;
if (u<=l) and (r<=v) then
begin
it[i]:=it[i]+1;
lazy[i]:=0;
lazy[i*2]:=lazy[i*2]+1;
lazy[i*2+1]:=lazy[i*2+1]+1;
exit;
end;
mid:=(l+r) div 2;
update(u,v,l,mid,i*2);
update(u,v,mid+1,r,i*2+1);
//it[i]:=it[i*2]+it[i*2+1];
end;
function find(u,l,r,i:longint):longint;
var mid:longint;
begin
it[i]:=it[i]+lazy[i];
lazy[i*2]:=lazy[i*2]+lazy[i];
lazy[i*2+1]:=lazy[i*2+1]+lazy[i];
lazy[i]:=0;
if (r<u) or (u<l) then exit(0);
if (l=u) and (l=r) then exit(it[i]);
mid:=(l+r) div 2;
exit(find(u,l,mid,i*2)+find(u,mid+1,r,i*2+1));
end;
procedure rmq;
var i,j:longint;
begin
for j:=1 to 20 do
for i:=1 to n do
b[i,j]:=b[b[i,j-1],j-1];
end;
function lca(u,v:longint):longint;
var k,i,res:longint;
begin
if d[u]>=d[v] then
begin
k:=d[u]-d[v];
if k>0 then
for i:=20 downto 0 do
if k>=1 shl i then
begin
k:=k-1 shl i;
u:=b[u,i];
end;
if u=v then exit(u);
for i:=20 downto 0 do
if b[u,i]=b[v,i] then res:=b[u,i] else
begin
u:=b[u,i];
v:=b[v,i];
end;
exit(res);
end
else exit(lca(v,u));
end;
procedure push(xx,tt:longint);
begin
inc(top);
x[top]:=xx;
y[top]:=tt;
end;
procedure update2(u,l,r,i:longint);
var mid:longint;
begin
if (r<u) or (u<l) then exit;
if (l=r) and (l=u) then
begin
it2[i]:=1;
exit;
end;
mid:=(l+r) div 2;
update2(u,l,mid,i*2);
update2(u,mid+1,r,i*2+1);
it2[i]:=it2[i*2]+it2[i*2+1];
end;
function find2(u,v,l,r,i:longint):longint;
var mid:longint;
begin
if (r<u) or (v<l) then exit(0);
if (u<=l) and (r<=v) then exit(it2[i]);
mid:=(l+r) div 2;
exit(find2(u,v,l,mid,i*2)+find2(u,v,mid+1,r,i*2+1));
end;
function min(a,b:longint):longint;
begin
if a<b then exit(a) else exit(b);
end;
procedure truyvan;
var jj,t,i,j,resu,resc,resv,chung:longint;
begin
rmq;
for i:=1 to n do nhancuadinh[i]:=nhan[i];
qsnhan(1,n);
j:=0;
for i:=1 to m do
begin
while (c[i]>=w[j+1])and (j<n) do
begin
inc(j);
update(nhancuadinh[cs[j]],nhancuadinh[cs[j]]+con[cs[j]]-1,1,n,1);
update2(nhancuadinh[cs[j]],1,n,1);
//writeln(nhancuadinh[cs[j]],' ',nhancuadinh[cs[j]]+con[cs[j]]-1);
{for jj:=1 to n do
begin
t:=(find(jj,1,maxn1,1));
writeln(t);
end; }
end;
if loai[i]=1 then
begin
chung:=lca(u[i],v[i]);
resu:=find(nhancuadinh[u[i]],1,n,1);
resv:=find(nhancuadinh[v[i]],1,n,1);
resc:=find(nhancuadinh[chung],1,n,1);
push(resu+resv-2*resc,tt[i]);
//writeln(resu,' ',resv,' ',resc,' ',u[i],' ',v[i],' ',c[i],' ',resu+resv-2*resc);
//writeln(resu+resv-2*resc);
end
else
begin
if b[v[i],0]=u[i] then
begin
t:=find2(nhancuadinh[v[i]]+1,nhancuadinh[v[i]]+con[v[i]]-1,1,n,1);
push(t,tt[i]);
//writeln(t,' ',u[i],' ',v[i],' ',j);
//writeln(t);
//for jj:=1 to n do
// begin
// writeln(find2(nhancuadinh[jj]+1,nhancuadinh[jj]+con[jj]-1,1,maxn,1),' dinh ',jj);
// end;
end
else
begin
push(find2(nhancuadinh[u[i]]+1,nhancuadinh[u[i]]+con[u[i]]-1,1,n,1),tt[i]);
//writeln(find(v[i],1,maxn1,1)-1);
end;
end;
//writeln(tt[i],' ',x[i]);
end;
end;
procedure qskq(l,r:longint);
var i,j,xx:longint;
begin
i:=l;
j:=r;
xx:=y[random(r-l)+1+l];
repeat
while y[i]<xx do inc(i);
while xx<y[j] do dec(j);
if i<=j then
begin
swap(x[i],x[j]);
swap(y[i],y[j]);
dec(j);
inc(i);
end;
until i>j;
if i<r then qskq(i,r);
if l<j then qskq(l,j);
end;
procedure xuat;
var i:longint;
begin
qskq(1,top);
for i:=1 to top do writeln(x[i]);
//for i:=1 to n do writeln(find(1,1,maxn1,1));
end;
begin
mo;
nhap;
sort;
truyvan;
xuat;
dong;
end.

    const fi='network.inp';
          fo='network.out';
            maxn=round(1e5)*2;
            maxn1=round(1e6)*5;

    var w,a,h,p,x,y,z,u,v,c,cs,tt,con,nhan,d,loai,nhancuadinh:array[0..maxn]of longint;
        it2,it,lazy:array[0..maxn1]of longint;
        b:array[0..round(1e5),0..20]of longint;
        n,m,slnhan,top:longint;
    procedure mo;
        begin
            assign(input,fi);reset(input);
            assign(output,fo);rewrite(output);
        end;

    procedure dong;
        begin
            closE(input);closE(output);
        end;

    procedure nhap;
        var i,k:longint;
            xx:char;
            begin
                readln(n,m);
                for i:=1 to n-1 do
                    begin
                        readln(X[i],y[i],z[i]);
                        inc(h[x[i]]);
                        inc(h[y[i]]);
                    end;
                for i:=1 to n+1 do inc(h[i],h[i-1]);
                for i:=1 to n-1 do
                    begin
                        a[h[x[i]]]:=y[i];
                        p[h[x[i]]]:=z[i];
                        dec(h[x[i]]);
                        a[h[y[i]]]:=x[i];
                        p[h[y[i]]]:=z[i];
                        dec(h[y[i]]);
                    end;

                for i:=1 to m do
                    begin
                        read(xx);
                        if xx='P' then
                            begin
                            readln(u[i],v[i],c[i]);
                            loai[i]:=1;
                            end
                        else
                            begin
                                readln(k,c[i]);
                                u[i]:=x[k];
                                v[i]:=y[k];
                                loai[i]:=2;
                            end;
                    end;
            end;

    procedure swap(var i,j:longint);
        var t:longint;
            begin
                t:=i;
                i:=j;
                j:=t;
            end;

    procedure qs(l,r:longint);
        var x,i,j:longint;
            begin
                i:=l;
                j:=r;
                x:=w[random(r-l)+1+l];
                repeat
                    while w[i]<x do inc(i);
                    while x<w[j] do dec(j);
                    if i<=j then
                        begin
                            swap(cs[i],cs[j]);
                            swap(w[i],w[j]);
                            inc(i);
                            dec(j);
                        end;
                until i>j;
                if i<r then qs(i,r);
                if l<j then qs(l,j);
            end;

    procedure qstv(l,r:longint);
        var x,i,j:longint;
            begin
                i:=l;
                j:=r;
                x:=c[random(r-l)+1+l];
                repeat
                    while (c[i]<x) do inc(i);
                    while (x<c[j]) do dec(j);
                    if i<=j then
                        begin
                            swap(c[i],c[j]);
                            swap(u[i],u[j]);
                            swap(v[i],v[j]);
                            swap(tt[i],tt[j]);
                            swap(loai[i],loai[j]);
                            inc(i);
                            dec(j);
                        end;
                until i>j;
                if i<r then qstv(i,r);
                if l<j then qstv(l,j);
            end;

    procedure dfs(u:longint);
        var v:longint;
            begin
                con[u]:=1;
                for v:=h[u]+1 to h[u+1] do
                    if nhan[a[v]]=0 then
                        begin
                            w[a[v]]:=p[v];
                            b[a[v],0]:=u;
                            d[a[v]]:=d[u]+1;
                            inc(slnhan);
                            nhan[a[v]]:=slnhan;
                            dfs(a[v]);
                            con[u]:=con[a[v]]+con[u];
                        end;
            end;

    procedure sort;
        var i:longint;
            begin
                slnhan:=1;
                nhan[1]:=1;
                d[1]:=1;
                dfs(1);
                //for i:=1 to n do
                //    writeln(nhan[i],' ',con[i]);
                for i:=1 to n do cs[i]:=i;
                qs(1,n);
                //for i:=1 to n do writeln(cs[i],' ',w[i]);
                for i:=1 to m do tt[i]:=i;
                qstv(1,m);
                //for i:=1 to m do writeln(u[i],' ',v[i],' ',c[i],' ',tt[i]);
            end;

    procedure qsnhan(l,r:longint);
        var i,j,x:longint;
            begin
                i:=l;
                j:=r;
                x:=nhan[random(r-l)+1+l];
                repeat
                    while nhan[i]<x do inc(i);
                    while x<nhan[j] do dec(j);
                    if i<=j then
                        begin
                            swap(nhan[i],nhan[j]);
                            //swap(nhancuadinh[i],nhancuadinh[j]);
                            inc(i);
                            dec(j);
                        end;
                until i>j;
                if i<r then qsnhan(i,r);
                if l<j then qsnhan(l,j);
            end;

        procedure update(u,v,l,r,i:longint);
            var mid:longint;
                begin
                    it[i]:=it[i]+lazy[i];
                    lazy[i*2]:=lazy[i*2]+lazy[i];
                    lazy[i*2+1]:=lazy[i*2+1]+lazy[i];
                    lazy[i]:=0;
                    if (r<u) or (v<l) then exit;
                    if (u<=l) and (r<=v) then
                        begin
                            it[i]:=it[i]+1;
                            lazy[i]:=0;
                            lazy[i*2]:=lazy[i*2]+1;
                            lazy[i*2+1]:=lazy[i*2+1]+1;
                            exit;
                        end;
                    mid:=(l+r) div 2;
                    update(u,v,l,mid,i*2);
                    update(u,v,mid+1,r,i*2+1);
                    //it[i]:=it[i*2]+it[i*2+1];
                end;

        function find(u,l,r,i:longint):longint;
            var mid:longint;
                begin
                    it[i]:=it[i]+lazy[i];
                    lazy[i*2]:=lazy[i*2]+lazy[i];
                    lazy[i*2+1]:=lazy[i*2+1]+lazy[i];
                    lazy[i]:=0;
                    if (r<u) or (u<l) then exit(0);
                    if (l=u) and (l=r) then exit(it[i]);
                    mid:=(l+r) div 2;
                    exit(find(u,l,mid,i*2)+find(u,mid+1,r,i*2+1));
                end;

        procedure rmq;
            var i,j:longint;
                begin
                    for j:=1 to 20 do
                        for i:=1 to n do
                            b[i,j]:=b[b[i,j-1],j-1];
                end;

        function lca(u,v:longint):longint;
            var k,i,res:longint;
                begin
                    if d[u]>=d[v] then
                        begin
                            k:=d[u]-d[v];
                            if k>0 then
                                for i:=20 downto 0 do
                                    if k>=1 shl i then
                                        begin
                                            k:=k-1 shl i;
                                            u:=b[u,i];
                                        end;
                            if u=v then exit(u);
                            for i:=20 downto 0 do
                                if b[u,i]=b[v,i] then res:=b[u,i] else
                                    begin
                                        u:=b[u,i];
                                        v:=b[v,i];
                                    end;
                            exit(res);
                        end
                    else exit(lca(v,u));
                end;

        procedure push(xx,tt:longint);
            begin
                inc(top);
                x[top]:=xx;
                y[top]:=tt;
            end;

        procedure update2(u,l,r,i:longint);
            var mid:longint;
                begin
                    if (r<u) or (u<l) then exit;
                    if (l=r) and (l=u) then
                        begin
                            it2[i]:=1;
                            exit;
                        end;
                    mid:=(l+r) div 2;
                    update2(u,l,mid,i*2);
                    update2(u,mid+1,r,i*2+1);
                    it2[i]:=it2[i*2]+it2[i*2+1];
                end;
        function find2(u,v,l,r,i:longint):longint;
            var mid:longint;
                begin
                    if (r<u) or (v<l) then exit(0);
                    if (u<=l) and (r<=v) then exit(it2[i]);
                    mid:=(l+r) div 2;
                    exit(find2(u,v,l,mid,i*2)+find2(u,v,mid+1,r,i*2+1));
                end;

        function min(a,b:longint):longint;
            begin
                if a<b  then exit(a) else exit(b);
            end;

        procedure truyvan;
        var jj,t,i,j,resu,resc,resv,chung:longint;
            begin
                    rmq;
                    for i:=1 to n do nhancuadinh[i]:=nhan[i];
                    qsnhan(1,n);
                    j:=0;
                    for i:=1 to m do
                        begin
                            while (c[i]>=w[j+1])and (j<n) do
                                begin
                                inc(j);
                                update(nhancuadinh[cs[j]],nhancuadinh[cs[j]]+con[cs[j]]-1,1,n,1);
                                update2(nhancuadinh[cs[j]],1,n,1);
                                //writeln(nhancuadinh[cs[j]],' ',nhancuadinh[cs[j]]+con[cs[j]]-1);
                                {for jj:=1 to n do
                                    begin
                                    t:=(find(jj,1,maxn1,1));
                                    writeln(t);
                                    end; }
                                end;
                            if loai[i]=1 then
                                begin
                                    chung:=lca(u[i],v[i]);
                                    resu:=find(nhancuadinh[u[i]],1,n,1);
                                    resv:=find(nhancuadinh[v[i]],1,n,1);
                                    resc:=find(nhancuadinh[chung],1,n,1);
                                    push(resu+resv-2*resc,tt[i]);
                                    //writeln(resu,' ',resv,' ',resc,' ',u[i],' ',v[i],' ',c[i],' ',resu+resv-2*resc);
                                    //writeln(resu+resv-2*resc);
                                end
                            else
                                begin
                                    if b[v[i],0]=u[i] then
                                        begin
                                            t:=find2(nhancuadinh[v[i]]+1,nhancuadinh[v[i]]+con[v[i]]-1,1,n,1);
                                            push(t,tt[i]);
                                            //writeln(t,' ',u[i],' ',v[i],' ',j);
                                            //writeln(t);
                                            //for jj:=1 to n do
                                            //    begin
                                            //        writeln(find2(nhancuadinh[jj]+1,nhancuadinh[jj]+con[jj]-1,1,maxn,1),' dinh ',jj);
                                            //    end;
                                        end
                                    else
                                        begin
                                            push(find2(nhancuadinh[u[i]]+1,nhancuadinh[u[i]]+con[u[i]]-1,1,n,1),tt[i]);
                                            //writeln(find(v[i],1,maxn1,1)-1);
                                        end;
                                end;
                            //writeln(tt[i],' ',x[i]);
                        end;
            end;

    procedure qskq(l,r:longint);
        var i,j,xx:longint;
            begin
                i:=l;
                j:=r;
                xx:=y[random(r-l)+1+l];
                repeat
                    while y[i]<xx do inc(i);
                    while xx<y[j] do dec(j);
                    if i<=j then
                        begin
                            swap(x[i],x[j]);
                            swap(y[i],y[j]);
                            dec(j);
                            inc(i);
                        end;
                until i>j;
                if i<r then qskq(i,r);
                if l<j then qskq(l,j);
            end;

    procedure xuat;
        var i:longint;
            begin
                qskq(1,top);
                for i:=1 to top do writeln(x[i]);
                //for i:=1 to n do writeln(find(1,1,maxn1,1));
            end;

begin
        mo;
        nhap;
        sort;
        truyvan;
        xuat;
        dong;
    end.

