Maybe it's a bug with <lift:loc locid=""/> .... It's so confused.
Cheers, Neil On Nov 10, 12:11 pm, YING-KWANG TU <ying.kwang...@gmail.com> wrote: > By adding a println line in my localeCalculator churned the following > output: > > en_US > en_us > en_us > en_us > en_us > INFO - Service request (GET) / took 53 Milliseconds > en_us > ms_my > ms_my > ms_my > ms_my > INFO - Service request (GET) / took 37 Milliseconds > ms_my > th_th > th_th > th_th > th_th > INFO - Service request (GET) / took 37 Milliseconds > > It almost seems like it is java.util.Locale... Mysteriously, adding symlinks > helps. For e.g. > > lift-core_en_us.properties -> lift-core_en_US.properties > > On Tue, Nov 10, 2009 at 9:58 AM, YING-KWANG TU <ying.kwang...@gmail.com>wrote: > > > Tim, > > > You can browse tohttp://219.94.110.243for the test site running on > > Ubuntu Server 9.10. > > There is a down-loadable test project which you can test out. > > > Before this discussion thread on UTF-8 or ISO8859-1, > > > 1. localization is running great on windows+maven2.2.1+liftweb1.1-M7 > > 2. <lift:loc locid=""/> yet to work for both platform > > 3. on linux, even S.??("") not working at all. > > > Cheers, > > yk > > > On Sat, Nov 7, 2009 at 8:29 PM, Timothy Perrett > > <timo...@getintheloop.eu>wrote: > > >> You should always be working with UTF-8 files for properties / > >> localisation - I think the encoding reported by jetty is something > >> different (that it reads from the system)... ensure your props files > >> are UTF-8 and go from there. > > >> Cheers, Tim > > >> On Nov 7, 12:48 am, yk <ying.kwang...@gmail.com> wrote: > >> > Hi Tim, > > >> > I've developed n tested localization on windows and it worked > >> > perfectly. however, localization of the same project placed on ubuntu > >> > server 9.10 did not. > > >> > WinXP > >> > ----------- > >> > jdk1.6 > >> > maven 2.2.1 > >> > lifeweb 1.1-M7 > >> > encoding=cp1252 (as reported by "mvn jetty:run") > > >> > Ubuntu 9.10 server > >> > --------------------------- > >> > openjdk OR sun-jdk6 > >> > maven 2.2.1 > >> > liftweb 1.1-M7 > >> > encoding=UTF-8 (as reported by "mvn jetty:run") > > >> > I can't quite point my finger on why it worked on windows but not on > >> > linux. Do i have to convert all files that need to be deployed to > >> > UTF-8 encoding? > > >> > Thank you in advance. > > >> > Cheers, > >> > yk > > >> > On Oct 26, 9:12 pm, Timothy Perrett <timo...@getintheloop.eu> wrote: > > >> > > The browser already knows the locale, you have it backward! Your > >> > > localeCalculator is so that the browser can get lift to return the > >> > > right content. > > >> > > Take a look at: > > >> > >http://scala-tools.org/mvnsites/liftweb-1.1-M6/lift-webkit/scaladocs/. > >> .. > > >> > > I would start with just getting lift to explicitly set locale based on > > >> > > a query string or something... it will help you understand how the > >> > > mechanism works. > > >> > > Cheers, Tim > > >> > > On 26 Oct 2009, at 12:34, Neil.Lv wrote: > > >> > > > ... > > >> > > > Where is the locale to be set that the browser can know the > >> > > > locale ? > > >> > > > Thanks very much! > > >> > > > Cheers, > >> > > > Neil > > >> > > > On Oct 26, 7:50 pm, Timothy Perrett <timo...@getintheloop.eu> > >> wrote: > >> > > >> setLocale was a method created by me, specific to my application - > >> it > >> > > >> does not exist in Lift... hence why I removed it in my simplified > >> > > >> example. > > >> > > >> Cheers, Tim > > >> > > >> On 26 Oct 2009, at 11:45, Neil.Lv wrote: > > >> > > >>> I have a silly question , where is the setLocale method ? > > >> > > >>> I don't know where the package located. > > >> > > >>> src\main\scala\bootstrap\liftweb\Boot.scala:63: error: not found: > >> > > >>> value setLocale > >> > > >>> setLocale(selectedLocale) > > >> > > >>> :) > > >> > > >>> Cheers, > >> > > >>> Neil > > >> > > >>> On Oct 26, 5:50 pm, Timothy Perrett <timo...@getintheloop.eu> > >> wrote: > >> > > >>>> Yes, your template code is right - your just seeing the default > >> > > >>>> value > >> > > >>>> because you have not told lift what resources to use when it gets > > >> > > >>>> the > >> > > >>>> locale header from the browser. > > >> > > >>>> tryo() is like try/catch however, it will catch exceptions and > >> > > >>>> returns > >> > > >>>> Box[T] > > >> > > >>>> I would really suggest starting with something a lot simpler than > > >> > > >>>> the > >> > > >>>> one i detailed that uses cookies and all sorts. Perhaps something > >> > > >>>> like: > > >> > > >>>> def localeCalculator(request : Box[HTTPRequest]): Locale = > >> > > >>>> request.flatMap(r => { > >> > > >>>> tryo(r.locale) match { > >> > > >>>> // your match here > >> > > >>>> } > > >> > > >>>> }).openOr(java.util.Locale.getDefault()) > > >> > > >>>> Hope that helps > > >> > > >>>> Cheers, Tim > > >> > > >>>> On 26 Oct 2009, at 09:21, Neil.Lv wrote: > > >> > > >>>>> <lift:loc locid="login">Log in 222</lift:loc> > >> > > >>>>> That means this code is correctly, the problem is that the > >> > > >>>>> browser > >> > > >>>>> doesn't know the locale? > > >> > > >>>>> So we need to calculate the locale in the Boot.scala file ? > > >> > > >>>>> Cheers, > >> > > >>>>> Neil > > >> > > >>>>> On Oct 26, 5:09 pm, "Neil.Lv" <anim...@gmail.com> wrote: > >> > > >>>>>> tryo(r.getParameter("locale")) match { > >> > > >>>>>> case Full(null) => workOutLocale > >> > > >>>>>> case Empty => workOutLocale > >> > > >>>>>> case Failure(_,_,_) => workOutLocale > >> > > >>>>>> case Full(selectedLocale) => { > >> > > >>>>>> setLocale(selectedLocale) > >> > > >>>>>> selectedLocale > >> > > >>>>>> } > >> > > >>>>>> } > > >> > > >>>>>> In this code , what's the tryo ? is try ? > >> > > >>>>>> tryo () match {} > > >> > > >>>>>> What's the changes about the HTTP container providers? > > >> > > >>>>>> Thanks very much! > > >> > > >>>>>> Cheers, > >> > > >>>>>> Neil > > >> > > >>>>>> On Oct 26, 4:44 pm, Timothy Perrett <timo...@getintheloop.eu> > >> > > >>>>>> wrote: > > >> > > >>>>>>> Hmm - you posted a link to my article at the begining of this > >> > > >>>>>>> thread; > >> > > >>>>>>> in that article I explain lifts locale calculator. Without > >> this, > >> > > >>>>>>> Lift > >> > > >>>>>>> has no idea how you want to handle different locales. By > >> > > >>>>>>> default, > >> > > >>>>>>> the > >> > > >>>>>>> following is used: > > >> > > >>>>>>> var localeCalculator: Box[HTTPRequest] => Locale = > >> > > >>>>>>> defaultLocaleCalculator _ > > >> > > >>>>>>> def defaultLocaleCalculator(request: Box[HTTPRequest]) = > >> > > >>>>>>> request.flatMap(_.locale).openOr(Locale.getDefault()) > > >> > > >>>>>>> As you can see, that will get only the locale of your JVM, not > > >> > > >>>>>>> the > >> > > >>>>>>> browser. You will need to write the appropriate locale > >> > > >>>>>>> calculator; > >> > > >>>>>>> the > >> > > >>>>>>> one in my article is a little out of date as there was a > >> > > >>>>>>> breaking > >> > > >>>>>>> change not so long ago to the HTTP container providers but it > >> > > >>>>>>> should > >> > > >>>>>>> give you enough to go on. > > >> > > >>>>>>> Does that help? > > >> > > >>>>>>> Cheers, Tim > > >> > > >>>>>>> On Oct 26, 8:35 am, "Neil.Lv" <anim...@gmail.com> wrote: > > >> > > >>>>>>>> 1:) I create a file in the i18n folder > >> > > >>>>>>>> /src/main/resources/i18n/lift-core_zh_CN.properties > >> > > >>>>>>>> ..... > >> > > >>>>>>>> login = \u767b\u5f55 > >> > > >>>>>>>> logout = \u9000\u51fa > >> > > >>>>>>>> log.in = \u767b\u5f55 > >> > > >>>>>>>> log.out = \u9000\u51fa > >> > > >>>>>>>> sign.up = \u6ce8\u518c > >> > > >>>>>>>> logged.in = \u5df2\u7ecf\u767b\u5f55 > >> > > >>>>>>>> ...... > >> > > >>>>>>>> the others are default (copy from lift-core_en_US.properties) > > >> > > >>>>>>>> 2:) > >> > > >>>>>>>> ### index.html > >> > > >>>>>>>> <lift:surround with="default" at="content"> > >> > > >>>>>>>> <lift:loc id="login">Log in 111</lift:loc> > >> > > >>>>>>>> <lift:loc locid="login">Log in 222</lift:loc> > >> > > >>>>>>>> </lift:surround> > > >> > > >>>>>>>> The lift:loc doesn't work that it should read the i18n string > >> > > >>>>>>>> from the > >> > > >>>>>>>> lift-core_zh_CN.properties and show the chinese chars, (login > >> = > >> > > >>>>>>>> \u767b > >> > > >>>>>>>> \u5f55) > > >> > > >>>>>>>> but it always shows the default string (Log in 111, Log in > >> > > >>>>>>>> 222). > > >> > > >>>>>>>> Has anything will be config ? > > >> > > >>>>>>>> Cheers, > >> > > >>>>>>>> Neil > > >> > > >>>>>>>> On Oct 26, 4:17 pm, Timothy Perrett <timo...@getintheloop.eu > > >> > > >>>>>>>> wrote: > > >> > > >>>>>>>>> Neil, > > >> > > >>>>>>>>> Can you zip and send me an example? It's quite likley your > >> > > >>>>>>>>> missing > >> > > >>>>>>>>> something and without seeing the code it's difficult to say. > > >> > > >>>>>>>>> Cheers, Tim > > >> > > >>>>>>>>> Sent from my iPhone > > >> > > >>>>>>>>> On 26 Oct 2009, at 03:54, "Neil.Lv" <anim...@gmail.com> > >> wrote: > > >> > > >>>>>>>>>> in the /index.html > >> > > >>>>>>>>>> ### both of them are not work ! > >> > > >>>>>>>>>> <lift:loc locid="log.in">Log in</lift:loc> > >> > > >>>>>>>>>> <lift:loc id="log.in">Log in</lift:loc> > >> > > >>>>>>>>>> ### > > >> > > >>>>>>>>>> Cheers, > >> > > >>>>>>>>>> Neil > > >> > > >>>>>>>>>> On Oct 25, 6:27 pm, Timothy Perrett > >> <timo...@getintheloop.eu> > >> > > >>>>>>>>>> wrote: > >> > > >>>>>>>>>>> Neil, > > >> > > >>>>>>>>>>> This is normal practice with javalocalisation- the best > >> > > >>>>>>>>>>> thing is do > >> > > >>>>>>>>>>> write all your strings then use native2ascii or similar > >> > > >>>>>>>>>>> tooling to > >> > > >>>>>>>>>>> convert it into the unicode representation. > > >> > > >>>>>>>>>>> Glad you found my article helpful. > > >> > > >>>>>>>>>>> Cheers, Tim > > >> > > >>>>>>>>>>> On Oct 25, 5:02 am, "Neil.Lv" <anim...@gmail.com> wrote: > > >> > > >>>>>>>>>>>> if i use this code and it works correctly ! > > >> > > >>>>>>>>>>>> Code: > > ... > > read more ยป --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Lift" group. To post to this group, send email to liftweb@googlegroups.com To unsubscribe from this group, send email to liftweb+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/liftweb?hl=en -~----------~----~----~----~------~----~------~--~---