First, I have arrival Haikou tonight, and then have eaten some delicious. :)
Secondly, the GSoC payment has sent to my store value card right now! Hopefully every GSoCers have got it. :)
Well, finally I have came back to the earth!
After a super busy month, many things get done - the exams, TOEFL, GSoC midterm evaluation, rent room in Singapore, … Another good news is my GSoC project still on track! Though, well, I have a little trouble of implementing the Python buffer support - I havn’t a clear plan about what I am going to do…
Tonight I will go to Haikou, and then contiune my summer in this hot beatiful city. :)
After waiting and waiting, finally I got my card from Google! Yoohoo!
Thank you Google for the Childern’s Day gift! :p
BTW, an ad: help Firefox 3 to Set a Guinness World Record!
After waiting and waiting, finally I got my card from Google! Yoohoo!
Thank you Google for the Childern’s Day gift! :p
BTW, an ad: help Firefox 3 to Set a Guinness World Record!
I’m so glad to see that my blog has been added to Planet Python/SoC! Thanks Titus Brown for doing so.
Just saying a hello to everybody, and happy coding! :)
There’s some useful technique for debugging Python extension module, gathered during these days work.
There’s some useful technique for debugging Python extension module, gathered during these days work.
You can see it here: http://bugs.python.org/issue2899
It is about a problem in SWIG’s test cases. It used string.find(s, ‘abc’) to test whether ‘abc’ is contained in s. However, I don’t know what it has been written in this way. Maybe for compatibility with older Python like 2.2, 2.3?
And a good news, after these day’s working, nearly all test cases passed! Currently only 2 cases related to PyFile and 2 cases related to exception are still failed. I’ll continue to work on them.
Another good news is I have received my book from Google yesterday. A really beautiful book! :)
You can see it here: http://bugs.python.org/issue2899
It is about a problem in SWIG’s test cases. It used string.find(s, ‘abc’) to test whether ‘abc’ is contained in s. However, I don’t know what it has been written in this way. Maybe for compatibility with older Python like 2.2, 2.3?
And a good news, after these day’s working, nearly all test cases passed! Currently only 2 cases related to PyFile and 2 cases related to exception are still failed. I’ll continue to work on them.
Another good news is I have received my book from Google yesterday. A really beautiful book! :)
You can see it here: http://bugs.python.org/issue2899
It is about a problem in SWIG’s test cases. It used string.find(s, ‘abc’) to test whether ‘abc’ is contained in s. However, I don’t know what it has been written in this way. Maybe for compatibility with older Python like 2.2, 2.3?
And a good news, after these day’s working, nearly all test cases passed! Currently only 2 cases related to PyFile and 2 cases related to exception are still failed. I’ll continue to work on them.
Another good news is I have received my book from Google yesterday. A really beautiful book! :)
May 12, Beijing time 4:28, China suffered a big earthquake! Center of the earthquake is on Wenchuan, Sichuan. A county near Chengdu, the magnitude is about 7.8.
Seems the whole China was affected by the earthquake. In Beijing, Shanghai, peoples working in higher floor of tall building felt the buildings swagging. They felt dizzy and ran out. But I was staying on 3th floor when the earthquake happening.
I tried to contact one of my friends who live in Chengdu, but failed. Hopes they are safe…
Anyway, bless my friends, bless China…
I’ve ever annoyed with the mixed tab and spaces in SWIG’s code. Just talked it with William Fulton in #swig-gsoc. He suggested some tips.
This is a way to specific coding style by project:
au BufRead /[SWIG|swig]/* set tabstop=8 | set shiftwidth=2 | set softtabstop=2 | set expandtab " SWIG
And a Syntax file for SWIG, add this in ~/.vimrc or ~/.vim/filetype.vim to use it:
" SWIG filetype file
if exists("didloadfiletypes")
finish
endif
augroup filetypedetect
au! BufRead,BufNewFile *.swg setfiletype swig
au! BufRead,BufNewFile *.i setfiletype swig
augroup END
Finally, a big thanks to William! :)
I’ve ever annoyed with the mixed tab and spaces in SWIG’s code. Just talked it with William Fulton in #swig-gsoc. He suggested some tips.
This is a way to specific coding style by project:
au BufRead /[SWIG|swig]/* set tabstop=8 | set shiftwidth=2 | set softtabstop=2 | set expandtab " SWIG
And a Syntax file for SWIG, add this in ~/.vimrc or ~/.vim/filetype.vim to use it:
" SWIG filetype file
if exists("didloadfiletypes")
finish
endif
augroup filetypedetect
au! BufRead,BufNewFile *.swg setfiletype swig
au! BufRead,BufNewFile *.i setfiletype swig
augroup END
Finally, a big thanks to William! :)
Finally I have solved most of the segmentation faults in yesterday’s midnight. Just two lines of code!
Now I understood that PyObject_New() only allocate memory, but haven’t do the works like creating the object’s __dict__ and etc. We should use PyBaseObject_Type.tp_new() to create a “full” object. Or maybe PyType_GenericNew() also works?
Another mistake I’ve made is using obj->tp_dict() directly to access the object’s dict. *Must* use _PyObject_GetDictPtr() instead! Otherwise, we only get the dict of the object’s type!
Well done, now more than 90% test cases passed! Cheers!
I’ve just looked into the failed testcases these days. Reasons of the failures can be fallen into below several categories: e411a145477ece8c1520046bb365e465
This would be a todo-list for me in the next weeks.
I’ve just looked into the failed testcases these days. Reasons of the failures can be fallen into below several categories:
This would be a todo-list for me in the next weeks.
I’m writing SWIG makefile rules for testing today. Now I can see the test progress running well when I type “make check-python3-test-suite”. It wonders me that so many tests can be passed! However, the failed tests should be the hardest part.
I have spend some time to work on Python 3’s relative import, which mentioned on PEP 328, and PEP 366 seems a solution to my problem. But there is no 2to3 fixer to apply the PEP 366, so I had to disable the “import” fixer. The 2to3 has no option to disable a fixer now, so, this is how I did that:
$ 2to3 `2to3 -l | grep -v -E “Available|import$” | awk ‘{print “-f “$0}’` foo.py
This is the first time I tried to use awk, and the first time to write such a complicated command line. However, there should be a more clever way to do it.
I’m writing SWIG makefile rules for testing today. Now I can see the test progress running well when I type “make check-python3-test-suite”. It wonders me that so many tests can be passed! However, the failed tests should be the hardest part.
I have spend some time to work on Python 3’s relative import, which mentioned on PEP 328, and PEP 366 seems a solution to my problem. But there is no 2to3 fixer to apply the PEP 366, so I had to disable the “import” fixer. The 2to3 has no option to disable a fixer now, so, this is how I did that:
$ 2to3 `2to3 -l | grep -v -E “Available|import$” | awk ‘{print “-f “$0}’` foo.py
This is the first time I tried to use awk, and the first time to write such a complicated command line. However, there should be a more clever way to do it.
Thanks to William, I have set up my own SVN branch now! Previous modifications also committed when starting the branch.
But unluckily since I did “svn cp” on my local working copy, but forgot “svn up” before it. So I have branched an older revision (r10394), and SWIG trunk’s head revision is r10404 now!
So I tried to merge changes from trunk. I did:
$ svn merge -r 10394:10404 ../../trunk
But there are many annoying “Skipped Examples/python/shadow/some_file ” lines, mostly occurred when “Examples/python/shadow” was deleted. After google, seems it means there are non version controlled files in these directory, so svn decide to keep them.
One dirty solution is:
$ rm -rf gsoc2008-bhy
$ svn co https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy
Then redo the merge, everything works well.
Thanks to William, I have set up my own SVN branch now! Previous modifications also committed when starting the branch.
But unluckily since I did “svn cp” on my local working copy, but forgot “svn up” before it. So I have branched an older revision (r10394), and SWIG trunk’s head revision is r10404 now!
So I tried to merge changes from trunk. I did:
$ svn merge -r 10394:10404 ../../trunk
But there are many annoying “Skipped Examples/python/shadow/some_file ” lines, mostly occurred when “Examples/python/shadow” was deleted. After google, seems it means there are non version controlled files in these directory, so svn decide to keep them.
A dirty solution is:
$ rm -rf gsoc2008-bhy
$ svn co https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy
Then redo the merge, everything works well.