#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
using namespace std;
const int maxn = 100+5;
char pic[maxn][maxn];
int m,n,idx[maxn][maxn];
void dfs(int r,int c,int id)//深度优先遍历,递归
{
if(r<0 || r>=m || c<0 || c>=n) return ;//出界
if(idx[r][c]>0||pic[r][c]!='@') return ;//不是'@'或者是已经访问过的格子
idx[r][c]=id;//连通分量编号
for(int dr=-1;dr<=1;dr++)
{
for(int dc=-1;dc<=1;dc++)
{
if(dr!=0||dc!=0)dfs(r+dr,c+dc,id);
}
}
}
int main()
{
while(cin>>m>>n)
{
if(m==0&&n==0)break;
for(int i=0;i<m;i++)
{
for(int j=0;j<n;j++)
{
cin>>pic[i][j];
}
}
memset(idx,0,sizeof(idx));
int cnt=0;
for(int i=0;i<m;i++)
{
for(int j=0;j<n;j++)
{
if(idx[i][j]==0 && pic[i][j]=='@')
dfs(i,j,++cnt);
}
}
cout<<cnt<<endl;
}
return 0;
}