Eu tenho o jogo Counter Strike: Condition Zero. Sempre que instalo em uma pasta como C:\FolderName
e inicio o jogo após a instalação, o jogo inicia com 2 vídeos de introdução (encontrei esses vídeos dentro da pasta de instalação do jogo, ambos possuem extensões .avi) .
Mas um comportamento bem estranho eu notei. Se eu remover e instalar o jogo novamente, C:\Folder Name
o jogo funcionará bem, exceto que esses 2 vídeos de introdução não serão reproduzidos no lançamento. Bem estranho.
Para confirmar se este é o motivo exato, tentei pelo menos 15 vezes a instalação deste jogo com diferentes pastas nomeadas. Poucos com nome de pasta com espaços e poucos sem espaços. E confirmou que esses vídeos de introdução não serão reproduzidos se o nome da pasta tiver espaços.
Esses arquivos de vídeo têm este caminho: C:\My Folder Name\czero\media
OUC:\MyFolderName\czero\media
O arquivo de inicialização do jogo hl.exe
tem o caminho: C:\My Folder Name
OUC:\MyFolderName
O jogo é instalado corretamente em ambos os casos, mas os vídeos são reproduzidos apenas no segundo caso, ou seja, MyFolderName
.
Parece que o jogo tenta evitar arquivos .avi ou algum recurso do Windows força o jogo a não reproduzir esses arquivos - sempre que houver espaço(s) no nome da pasta.
Eu perguntaria isso na rede SE de jogos, mas sinto fortemente que esse comportamento estranho é apenas por causa do espaço no nome da pasta principal e relacionado apenas a esses arquivos .avi.
Pode haver alguma razão específica para isso? É por causa de alguma proteção e regras de firewall/antivírus/UAC?
Parece um bug no jogo onde o código abre o vídeo sem aspas e, como tal, parte do caminho do vídeo é assumido como um parâmetro onde realmente não é, resultando em um erro e, portanto, o vídeo nunca é reproduzido. O console provavelmente registrará um erro também.
Para explicar um pouco... No Windows, quando você trabalha com caminhos, você digita assim:
ou
Observe as citações.
Quando você inicia um programa externo, por exemplo um player de vídeo, o player de vídeo pode ter sua lista de argumentos da seguinte forma (este é um exemplo)
Agora vamos dizer que você tem Half Life como nome da pasta:
Não há vídeo chamado Half sem extensão nem entende o parâmetro Life\intro.avi porque o videoplayer não o reconhece.
Note que HalfLife 1 é um jogo muito antigo. Foi na época em que os nomes de arquivo de 8,3 comprimentos ainda eram muito comuns.
O problema subjacente é que, no Windows , o receptor é responsável por analisar a linha de comando. O chamado recebe toda a linha de comando como uma única string. (A família *nix de sistemas operacionais, por outro lado, passa um conjunto de argumentos únicos para o receptor, correspondendo a
argv
. Separar argumentos simplesmente não é um problema.) Convenções típicas separam argumentos de linha de comando por espaços; consequentemente, argumentos únicos que contenham espaços devem ser citados. As aspas fazem parte da linha de comando passada para o chamado! Para uma discussão, consulte este artigo da Microsoft . Como uma questão secundária, não há garantia de que o destinatário lide com as cotações! Não cite parâmetros gratuitamente.No seu caso, a citação do argumento path foi esquecida: um bug no jogo. Além disso, um grupo inteiro de equivalência nos testes do módulo foi perdido.
Você pode conhecer esses problemas do seu shell * nix favorito: Como faço para passar novamente um argumento que contém aspas? O shell do usuário é o único programa no mundo *nix que precisa analisar linhas de comando. Chamar programaticamente um binário de outro, por outro lado, não tem esse problema: o chamador simplesmente preenche uma matriz de argumentos antes da
exec
chamada, servindo argumentos únicos para o chamado em uma bandeja de prata.É essa combinação mal concebida de uma convenção de chamada DOS herdada mal concebida com uma ideia hippie mal concebida (a culpa é da Apple! 1 ) de espaços em nomes de caminho que precipita erros como o seu.
1 Sim, eu sei, espaços (e outros caracteres engraçados) em nomes de caminho existiam antes da adoção da apple; mas nenhum usuário *nix sensato nomearia voluntariamente uma pasta como "Arquivos de Programas". Tal absurdo não tem o direito de existir em sistemas de usuários finais.