C ++ 11-Template-Funktion mit rvalue-Parameteraufruf

In einer Klasse O habe ich die Funktion als Vorlage verwendettest2:

struct A{int value;};

struct O{
    A value;

    template<typename Args>
    static void test2(Args &&args){
        std::cout << std::endl << "!!!" << std::is_rvalue_reference<decltype(args)>::value << std::endl;
    }
};

Dann möchte ich diese Funktion von einer anderen aufrufen:

template<typename Args>
void test(Args &&args){
    using t = decltype(std::forward<Args>(args).value);
    std::cout << std::is_rvalue_reference<decltype(args)>::value;
    std::cout << std::is_rvalue_reference<decltype(std::forward<Args>(args).value)>::value;
    std::cout << std::is_rvalue_reference<t>::value;

    // All ok
    O.test2(std::forward<Args>(args).value);            

    // Alvays rvalue, even if agrs is lvalue
    O::template test2<t>(
        std::forward<t>(
            std::forward<Args>(args).value
        )
    );

   // Nor work at all, cant cast A to A&&
   O::template test2<t>(
        std::forward<Args>(args).value
    );
);

}

http://coliru.stacked-crooked.com/a/3bbf040904845a54

Wenn ich nur passierestd::forward<Args>(args).value Ohne Angabe des Vorlagentyps wird der Typ korrekt abgeleitet. Wie soll ich die Funktion dann aufrufen, wenn ich den Typ übergeben muss?

Es scheint, ich kann nicht manuell Typ richtig ableiten.

AKTUALISIEREN

Ich muss Argumente explizit angeben, da ich folgende Funktionen habe (Pseudocode):

//initially call wind from somewhere.

// Tuple defined in class and is std::tuple
template<class Callback, class ...Args>
void wind(Tuple&& tuple, Callback &&callback){   
    using elementT = decltype(std::get<index>(std::forward<Tuple>(tuple)));

    ///
    /// !!! Problem here !!!
    ///
    callback.template operator()<elementT, Args...>(  std::get<index>(std::forward<Tuple>(tuple))  );              // std::get automatically return &/&&

   // recursivly call wind until the end
   wind<Callback, Args...>( std::forward<Tuple>(tuple), std::forward<Callback>(callback));
}

// callback looks like:
struct CallMe{   
  // Args provide type info. No function arguments here.
  template<class Data, class ...Args>
  void operator(Data &&data){

  }
}

Diese Frage bezog sich auf die Funktionen - wind und callback ().

Antworten auf die Frage(2)

Ihre Antwort auf die Frage