¿Especialización de plantilla de clase en el alcance de la clase?

¿Por qué la especialización S en A legal y S en B no?

(si B no está comentado) GCC 4.8.1: error: especialización explícita en ‘clase B’ del ámbito del espacio de nombres

#include <type_traits>
#include <iostream>

class Y {};
class X {};

struct A {
  template<class T, class = void>
  class S;

  template<class T>
  struct S < T, typename std::enable_if< std::is_same< Y, T >::value >::type > 
  {
    int i = 0;
  };

  template<class T>
  struct S < T, typename std::enable_if< std::is_same< X, T >::value >::type > 
  {
    int i = 1;
  };
};

/*
class B
{
    template<class T>
    class S;

    template<>
    class S < Y > {};

    template<>
    class S < X > {};
};
*/


int main()
{
    A::S< X > asd;
    std::cout << asd.i << std::endl;
}

en coliru: B comentó

en coliru: con B (error)

Respuestas a la pregunta(1)

Su respuesta a la pregunta