//NETWRKNB
USES Math;
CONST
tfi = '';
tfo = '';
TYPE
node = record
u,v,k,c,pos,pa: longint;
end;
arr = array[0..100000] of node;
VAR
fi,fo : text;
n,m,cnt,res,jmax,t1,t2 : longint;
ke,next,ts : array[-100000..100000] of longint;
head,free,tin,tout,ans : array[0..100000] of longint;
p,q1,q2,pp : arr;
f : array[0..100000,0..20] of longint;
t,tt : array[0..400000] of longint;
Procedure add(i,u,v,c: longint);
Begin
ke[i]:=v;
next[i]:=head[u];
head[u]:=i;
ts[i]:=c;
End;
Procedure inp;
Var
i: longint;
Begin
Read(fi,n,m);
For i:=1 to n-1 do
with p[i] do
begin
read(fi,u,v,c);
add(i,u,v,c);
add(-i,v,u,c);
end;
Readln(fi);
jmax:=trunc(ln(n)/ln(2));
End;
Procedure dfs(u: longint);
Var
j,v: longint;
Begin
inc(cnt);
tin[u]:=cnt;
j:=1;
While f[u,j-1]<>0 do
begin
f[u,j]:=f[f[u,j-1],j-1];
inc(j);
end;
j:=head[u];
While j<>0 do
begin
v:=ke[j];
If tin[v]=0 then
begin
f[v,0]:=u;
dfs(v);
end;
j:=next[j];
end;
tout[u]:=cnt;
End;
Function check(u,v: longint): boolean;
Begin
exit((tin[u]<=tin[v]) and (tout[u]>=tout[v]));
End;
Function lca(u,v: longint): longint;
Var
j: longint;
Begin
If check(u,v) then exit(u);
If check(v,u) then exit(v);
For j:=jmax downto 0 do
If (f[u,j]<>0) and not check(f[u,j],v) then u:=f[u,j];
exit(f[u,0]);
End;
Procedure swap(var x,y: node);
Var
tg: node;
Begin
tg:=x; x:=y; y:=tg;
End;
Procedure qsort(l,r: longint; var a: arr);
Var
i,j,mid,key: longint;
Begin
i:=l;
j:=r;
mid:=l+random(r-l+1);
key:=a[mid].c;
Repeat
While a[i].c<key do inc(i);
While a[j].c>key do dec(j);
If i<=j then
begin
swap(a[i],a[j]);
inc(i);
dec(j);
end;
Until i>j;
If i<r then qsort(i,r,a);
If l<j then qsort(l,j,a);
End;
Procedure init;
Var
i,tg: longint;
ch: char;
Begin
dfs(1);
t1:=0; t2:=0;
For i:=1 to m do
begin
read(fi,ch);
If ch='P' then
begin
inc(t1);
with q1[t1] do
begin
read(fi,u,v,c);
pos:=i;
end;
end
else
begin
inc(t2);
with q2[t2] do
begin
read(fi,k,c);
pos:=i;
end;
end;
readln(fi);
end;
For i:=1 to n-1 do pp[i]:=p[i];
qsort(1,n-1,pp);
qsort(1,t1,q1);
qsort(1,t2,q2);
For i:=1 to n-1 do
with pp[i] do
If check(v,u) then
begin
tg:=u; u:=v; v:=tg;
end;
End;
Procedure new(i,con1,con2: longint);
Begin
inc(tt[con1],tt[i]);
inc(tt[con2],tt[i]);
inc(t[con1],tt[i]);
inc(t[con2],tt[i]);
tt[i]:=0;
End;
Procedure update(i,l,r,u,v: longint);
Var
mid: longint;
Begin
If (l=u) and (v=r) then
begin
inc(tt[i]);
inc(t[i]);
exit;
end;
If (r<u) or (v<l) then exit;
mid:=(l+r) div 2;
new(i,2*i,2*i+1);
update(2*i,l,mid,u,min(v,mid));
update(2*i+1,mid+1,r,max(mid+1,u),v);
t[i]:=t[2*i]+t[2*i+1];
End;
Function get(i,l,r,u,v: longint): longint;
Var
mid: longint;
Begin
If (l=u) and (v=r) then exit(t[i]);
If (r<u) or (v<l) then exit(0);
mid:=(l+r) div 2;
new(i,2*i,2*i+1);
exit(get(2*i,l,mid,u,min(mid,v))+get(2*i+1,mid+1,r,max(mid+1,u),v));
End;
Procedure query1;
Var
i,j: longint;
Begin
For i:=1 to t1 do
with q1[i] do pa:=lca(u,v);
j:=1;
For i:=1 to t1 do
with q1[i] do
begin
While (j<=n-1) and (pp[j].c<=c) do
begin
with pp[j] do update(1,1,n,tin[v],tout[v]);
inc(j);
end;
ans[pos]:=get(1,1,n,tin[u],tin[u])+get(1,1,n,tin[v],tin[v])-get(1,1,n,tin[pa],tin[pa])*2;
end;
End;
Procedure query2;
Var
i,j,tmp: longint;
Begin
For i:=1 to n*4 do
begin
t[i]:=0; tt[i]:=0;
end;
j:=1;
For i:=1 to t2 do
with q2[i] do
begin
While (j<=n-1) and (pp[j].c<=c) do
begin
with pp[j] do update(1,1,n,tin[u],tin[u]);
inc(j);
end;
with p[k] do
If check(u,v) then tmp:=get(1,1,n,tin[v],tout[v])
else
begin
tmp:=get(1,1,n,1,n)-get(1,1,n,tin[u],tout[u]);
If c<=q2[i].c then dec(res);
end;
ans[pos]:=tmp;
end;
End;
Procedure process;
Var
i: longint;
Begin
query1;
query2;
For i:=1 to m do writeln(fo,ans[i]);
End;
BEGIN
assign(fi,tfi); reset(fi);
assign(fo,tfo); rewrite(fo);
inp;
init;
process;
close(fi); close(fo);
END.
//NETWRKNB
USES Math;
CONST
    tfi = '';
    tfo = '';
TYPE
    node = record
        u,v,k,c,pos,pa: longint;
    end;
    arr = array[0..100000] of node;
VAR
    fi,fo                           : text;
    n,m,cnt,res,jmax,t1,t2          : longint;
    ke,next,ts                      : array[-100000..100000] of longint;
    head,free,tin,tout,ans          : array[0..100000] of longint;
    p,q1,q2,pp                      : arr;
    f                               : array[0..100000,0..20] of longint;
    t,tt                            : array[0..400000] of longint;

Procedure add(i,u,v,c: longint);
    Begin
        ke[i]:=v;
        next[i]:=head[u];
        head[u]:=i;
        ts[i]:=c;
    End;

Procedure inp;
    Var
        i: longint;
    Begin
        Read(fi,n,m);
        For i:=1 to n-1 do
            with p[i] do
                begin
                    read(fi,u,v,c);
                    add(i,u,v,c);
                    add(-i,v,u,c);
                end;
        Readln(fi);
        jmax:=trunc(ln(n)/ln(2));
    End;

Procedure dfs(u: longint);
    Var
        j,v: longint;
    Begin
        inc(cnt);
        tin[u]:=cnt;
        j:=1;
        While f[u,j-1]<>0 do
            begin
                f[u,j]:=f[f[u,j-1],j-1];
                inc(j);
            end;
        j:=head[u];
        While j<>0 do
            begin
                v:=ke[j];
                If tin[v]=0 then
                    begin
                        f[v,0]:=u;
                        dfs(v);
                    end;
                j:=next[j];
            end;
        tout[u]:=cnt;
    End;

Function check(u,v: longint): boolean;
    Begin
        exit((tin[u]<=tin[v]) and (tout[u]>=tout[v]));
    End;

Function lca(u,v: longint): longint;
    Var
        j: longint;
    Begin
        If check(u,v) then exit(u);
        If check(v,u) then exit(v);
        For j:=jmax downto 0 do
            If (f[u,j]<>0) and not check(f[u,j],v) then u:=f[u,j];
        exit(f[u,0]);
    End;

Procedure swap(var x,y: node);
    Var
        tg: node;
    Begin
        tg:=x; x:=y; y:=tg;
    End;

Procedure qsort(l,r: longint; var a: arr);
    Var
        i,j,mid,key: longint;
    Begin
        i:=l;
        j:=r;
        mid:=l+random(r-l+1);
        key:=a[mid].c;
        Repeat
            While a[i].c<key do inc(i);
            While a[j].c>key do dec(j);
            If i<=j then
                begin
                    swap(a[i],a[j]);
                    inc(i);
                    dec(j);
                end;
        Until i>j;
        If i<r then qsort(i,r,a);
        If l<j then qsort(l,j,a);
    End;

Procedure init;
    Var
        i,tg: longint;
        ch: char;
    Begin
        dfs(1);
        t1:=0; t2:=0;
        For i:=1 to m do
            begin
                read(fi,ch);
                If ch='P' then
                    begin
                        inc(t1);
                        with q1[t1] do
                            begin
                                read(fi,u,v,c);
                                pos:=i;
                            end;
                    end
                else
                    begin
                        inc(t2);
                        with q2[t2] do
                            begin
                                read(fi,k,c);
                                pos:=i;
                            end;
                    end;
                readln(fi);
            end;
        For i:=1 to n-1 do pp[i]:=p[i];
        qsort(1,n-1,pp);
        qsort(1,t1,q1);
        qsort(1,t2,q2);
        For i:=1 to n-1 do
            with pp[i] do
                If check(v,u) then
                    begin
                        tg:=u; u:=v; v:=tg;
                    end;
    End;

Procedure new(i,con1,con2: longint);
    Begin
        inc(tt[con1],tt[i]);
        inc(tt[con2],tt[i]);
        inc(t[con1],tt[i]);
        inc(t[con2],tt[i]);
        tt[i]:=0;
    End;
Procedure update(i,l,r,u,v: longint);
    Var
        mid: longint;
    Begin
        If (l=u) and (v=r) then
            begin
                inc(tt[i]);
                inc(t[i]);
                exit;
            end;
        If (r<u) or (v<l) then exit;
        mid:=(l+r) div 2;
        new(i,2*i,2*i+1);
        update(2*i,l,mid,u,min(v,mid));
        update(2*i+1,mid+1,r,max(mid+1,u),v);
        t[i]:=t[2*i]+t[2*i+1];
    End;

Function get(i,l,r,u,v: longint): longint;
    Var
        mid: longint;
    Begin
        If (l=u) and (v=r) then exit(t[i]);
        If (r<u) or (v<l) then exit(0);
        mid:=(l+r) div 2;
        new(i,2*i,2*i+1);
        exit(get(2*i,l,mid,u,min(mid,v))+get(2*i+1,mid+1,r,max(mid+1,u),v));
    End;

Procedure query1;
    Var
        i,j: longint;
    Begin
        For i:=1 to t1 do
            with q1[i] do pa:=lca(u,v);
        j:=1;
        For i:=1 to t1 do
            with q1[i] do
                begin
                    While (j<=n-1) and (pp[j].c<=c) do
                        begin
                            with pp[j] do update(1,1,n,tin[v],tout[v]);
                            inc(j);
                        end;
                    ans[pos]:=get(1,1,n,tin[u],tin[u])+get(1,1,n,tin[v],tin[v])-get(1,1,n,tin[pa],tin[pa])*2;
                end;
    End;

Procedure query2;
    Var
        i,j,tmp: longint;
    Begin
        For i:=1 to n*4 do
            begin
                t[i]:=0; tt[i]:=0;
            end;
        j:=1;
        For i:=1 to t2 do
            with q2[i] do
                begin
                    While (j<=n-1) and (pp[j].c<=c) do
                        begin
                            with pp[j] do update(1,1,n,tin[u],tin[u]);
                            inc(j);
                        end;
                    with p[k] do
                        If check(u,v) then tmp:=get(1,1,n,tin[v],tout[v])
                        else
                            begin
                                tmp:=get(1,1,n,1,n)-get(1,1,n,tin[u],tout[u]);
                                If c<=q2[i].c then dec(res);
                            end;
                    ans[pos]:=tmp;
                end;
    End;

Procedure process;
    Var
        i: longint;
    Begin
        query1;
        query2;
        For i:=1 to m do writeln(fo,ans[i]);
    End;

BEGIN
    assign(fi,tfi); reset(fi);
    assign(fo,tfo); rewrite(fo);
        inp;
        init;
        process;
    close(fi); close(fo);
END.
