Can somebody point out when this patch will be included in source? I am trying to do compilation on Solaris 10 but right now I am getting errors as mentioned in this post.
Vikram On Jun 4, 1:42 pm, Kenton Varda <ken...@google.com> wrote: > Thanks for the patch! > It looks like you were using the examples as a test. Running "make check" > in the top directory will run a much better suite of tests -- do they pass? > > Assuming it does work, can you re-send that patch as an attachment (it looks > like it has been mangled), or even send it to me via codereview.appspot.com? > Also, for me to submit it you'll need to sign the contributor license > agreement: > > http://code.google.com/legal/individual-cla-v1.0.html-- if you own > copyright on this patchhttp://code.google.com/legal/corporate-cla-v1.0.html-- > if your employer > does > > On Wed, Jun 3, 2009 at 10:53 PM, <bmcarnes_proto...@oddren.com> wrote: > > > > Probably not. LibCstd isn't complete enough for protobuf. > > > I was able to get protobuf 2.1.0 to work well under Sun Studio 11, > > using libCstd, with a few patches. Works well enough to compile and > > run the add_person_cpp/list_people_cpp examples. > > > I include the build instructions and patch set below Also included > > are patches to the examples makefile to test it out. > > > <Apply below patchset first against protobuf 2.1.0> > > $ CXX=CC CC=cc ./configure --disable-shared > > $ make > > $ cd examples > > $ make cpp > > $ ./add_person_cpp addressbook.test > > (enter a test record) > > $ ./list_people_cpp addressbook.test > > (test record is displayed correctly) > > $ ldd list_people_cpp (or ldd add_person_cpp ) > > libpthread.so.1 => /lib/libpthread.so.1 > > libCstd.so.1 => /usr/lib/libCstd.so.1 > > libCrun.so.1 => /usr/lib/libCrun.so.1 > > libm.so.2 => /lib/libm.so.2 > > libc.so.1 => /lib/libc.so.1 > > > Index: src/google/protobuf/repeated_field.h > > =================================================================== > > --- src/google/protobuf/repeated_field.h (revision 2) > > +++ src/google/protobuf/repeated_field.h (working copy) > > @@ -69,7 +69,7 @@ > > class LIBPROTOBUF_EXPORT GenericRepeatedField { > > public: > > inline GenericRepeatedField() {} > > -#if defined(__DECCXX) && defined(__osf__) > > +#if defined(__SUNPRO_CC) || defined(__DECCXX) && defined(__osf__) > > // HP C++ on Tru64 has trouble when this is not defined inline. > > virtual ~GenericRepeatedField() {} > > #else > > @@ -548,7 +548,7 @@ > > current_size_ = 0; > > } > > > -#if defined(__DECCXX) && defined(__osf__) > > +#if defined(__SUNPRO_CC) || defined(__DECCXX) && defined(__osf__) > > // HP C++ on Tru64 has trouble when this is not defined inline. > > template <> > > inline void RepeatedPtrField<string>::Clear() { > > Index: src/google/protobuf/descriptor_database.cc > > =================================================================== > > --- src/google/protobuf/descriptor_database.cc (revision 2) > > +++ src/google/protobuf/descriptor_database.cc (working copy) > > @@ -127,7 +127,13 @@ > > > // Insert the new symbol using the iterator as a hint, the new > > entry will > > // appear immediately before the one the iterator is pointing at. > > + > > + // Sun Studio 11 needs a little help here > > +#if defined(__SUNPRO_CC) > > + by_symbol_.insert(iter, make_pair<const string,Value>(name, > > value)); > > +#else > > by_symbol_.insert(iter, make_pair(name, value)); > > +#endif > > > return true; > > } > > Index: src/google/protobuf/compiler/command_line_interface.cc > > =================================================================== > > --- src/google/protobuf/compiler/command_line_interface.cc (revision > > 2) > > +++ src/google/protobuf/compiler/command_line_interface.cc (working > > copy) > > @@ -474,7 +474,7 @@ > > > // If no --proto_path was given, use the current working directory. > > if (proto_path_.empty()) { > > - proto_path_.push_back(make_pair("", ".")); > > + proto_path_.push_back(make_pair(string(""), string("."))); > > } > > > // Check some errror cases. > > Index: src/google/protobuf/repeated_field.cc > > =================================================================== > > --- src/google/protobuf/repeated_field.cc (revision 2) > > +++ src/google/protobuf/repeated_field.cc (working copy) > > @@ -40,7 +40,7 @@ > > // HP C++ on Tru64 can't handle the stuff below being defined out-of- > > line, so > > // on that platform everything is defined in repeated_field.h. On > > other > > // platforms, we want these to be out-of-line to avoid code bloat. > > -#if !defined(__DECCXX) || !defined(__osf__) > > +#if !defined(__SUNPRO_CC) && (!defined(__DECCXX) || !defined > > (__osf__)) > > > namespace internal { > > > ------- Below changes the examples makefile to exercise protobuf under > > solaris > > > Index: examples/Makefile > > =================================================================== > > --- examples/Makefile (revision 2) > > +++ examples/Makefile (working copy) > > @@ -1,5 +1,13 @@ > > # See README.txt. > > > +# For the rest of the world > > +#CXX = c++ > > +#PROTOC = protoc > > + > > +# Testing For Solaris (pre-install) > > +CXX = CC -I../src -L../src/.libs > > +PROTOC = ../src/protoc > > + > > .PHONY: all cpp java python clean > > > all: cpp java python > > @@ -18,14 +26,14 @@ > > rmdir com 2>/dev/null || true > > > protoc_middleman: addressbook.proto > > - protoc --cpp_out=. --java_out=. --python_out=. addressbook.proto > > + $(PROTOC) --cpp_out=. --java_out=. --python_out=. addressbook.proto > > �...@touch protoc_middleman > > > add_person_cpp: add_person.cc protoc_middleman > > - c++ add_person.cc addressbook.pb.cc -lprotobuf -lpthread -o > > add_person_cpp > > + $(CXX) add_person.cc addressbook.pb.cc -lprotobuf -lpthread -o > > add_person_cpp > > > list_people_cpp: list_people.cc protoc_middleman > > - c++ list_people.cc addressbook.pb.cc -lprotobuf -lpthread -o > > list_people_cpp > > + $(CXX) list_people.cc addressbook.pb.cc -lprotobuf -lpthread -o > > list_people_cpp > > > javac_middleman: AddPerson.java ListPeople.java protoc_middleman > > javac AddPerson.java ListPeople.java com/example/tutorial/ > > AddressBookProtos.java --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Protocol Buffers" group. To post to this group, send email to protobuf@googlegroups.com To unsubscribe from this group, send email to protobuf+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/protobuf?hl=en -~----------~----~----~----~------~----~------~--~---