#include<iostream>//cout cin endl
#include<cmath>//sqrt fabs
#include<iomanip>//fix setprecision
#include<algorithm>//max sort fill
#include<cstdlib>//abs
 
using namespace std;
 
char a[1001][1001];
int dir[8][2]={{-1,-1},{-1,0},{-1,1},{0,1},{1,1},{1,0},{1,-1},{0,-1}};
 
int main()
{
    int n,m;
    cin>>n>>m;

    fill(&a[0][0],&a[0][0]+1001*1001,'.');

    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            cin>>a[i][j];
        }
    }
 
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            int cnt=0;
            if(a[i][j]=='*') cout<<'*';
            else
            {
                for(int k=0;k<8;k++)
                {
                    if(a[i+dir[k][0]][j+dir[k][1]]=='*')
                    {
                        cnt++;
                    }
                }
                cout<<cnt;
            }
        }
        cout<<endl;
    }
 
    return 0;
}