Hi Marc, I added the instructions to the wiki as you suggested. Thanks for applying the patch. I'll continue to test wfreerdp and hope that it makes some progress. The reason for my interest in wfreerdp is actually that I want to have a tool which can establish an RDP session in batch mode. This can't be done with mstsc as you cannot specify a password on the command line (and in the most recent version not even in the .rdp file anymore).
I'll use the github workflow for future patches. Cheers, Felix Am Sonntag, den 29.01.2012, 11:27 -0500 schrieb Marc-André Moreau: > Hi Felix, > > > I have just applied your patch, it's on the git repository now. If you > wish to contribute more patches in the future though it would be > appreciated if you could use the regular github workflow (you create a > github fork, you make your changes there, and then you create a pull > request for us to review and merge easily). > > > You are likely the first person to cross-compile wfreerdp, I'd be cool > if you add the compilation instructions to our wiki: > https://github.com/FreeRDP/FreeRDP/wiki/Compilation > > > As for the current state of wfreerdp, it is correct. It is functional, > but only a minimal set of functionality is maintained. A lot of stuff > hasn't been tested, especially virtual channel extensions, and a lot > of them would need to be ported. There is less work in developing a > Windows port since RDP is traditionally "Windows to Windows", but we > just don't have dedicated people working on it. The real focus is > getting FreeRDP on non-Windows systems, where mstsc.exe is not > available. > > > I maintain a basic amount of functionality in wfreerdp such that if > someone wants to dedicate more of their time to it in the future, > there will be a good starting point. I've seen a couple of patches for > wfreerdp recently, but we still do not have people really dedicated to > making wfreerdp awesome or as good as xfreerdp. Two weeks ago I talked > with people from the ReactOS project, apparently they didn't know we > had a Windows port and they wanted to see if they could have that > usable on ReactOS. That's a valid use of wfreerdp, since mstsc is not > present on ReactOS. Otherwise, I was thinking that the main use for > wfreerdp would be to have something customizable, unlike mstsc. Other > ideas I had if wfreerdp were to be as polished as xfreerdp would be to > run it through wine: a lot of the work in xfreerdp is to bridge the > "Windows world" with X11, but wine does a lot of the same in the end. > > > If you're interested in using wfreerdp, please know that it's not > really considered good for production since only a minimal feature set > is maintained. If you'd like to help extend this set of features > currently supported in wfreerdp, please go ahead, I've been waiting > for more help with it :) > > > Cheers, > - Marc-Andre > > On Sun, Jan 29, 2012 at 5:17 AM, Felix Wolfheimer > <f.wolfhei...@googlemail.com> wrote: > I tried to cross-compile wfreerdp on my Linux box with a > recent > Mingw-w64 release (Mingw-w64 2.0, gcc 4.7) and found some > minor issues > which I think can be fixed for the next release of FreeRDP as > they are > mostly related to the case sensitive behavior on Linux when > include > files are specified. > With this patch Freerdp-1.0.0 builds correctly (although with > some > compiler warnings) and the resulting wfreerdp.exe at least > shows the > login screen of one of my terminal servers. I've concluded > from the > discussions on the list and from the bugtracker that wfreerdp > at the > moment is not really considered functional. Is this correct? > > > Index: include/freerdp/types.h > ================================================================== > --- include/freerdp/types.h > +++ include/freerdp/types.h > @@ -20,11 +20,11 @@ > > #ifndef __RDP_TYPES_H > #define __RDP_TYPES_H > > #ifdef _WIN32 > -#include <WinDef.h> > +#include <windef.h> > #endif > > /* Base Types */ > > #ifdef HAVE_LIMITS_H > @@ -66,11 +66,12 @@ > #endif /* HAVE_INTTYPES_H */ > > #ifdef HAVE_STDBOOL_H > > #include <stdbool.h> > -typedef int boolean; > +typedef unsigned char boolean; > + > > #else > > #ifndef __cplusplus > > > Index: include/freerdp/window.h > ================================================================== > --- include/freerdp/window.h > +++ include/freerdp/window.h > @@ -21,11 +21,11 @@ > #define __UPDATE_WINDOW_H > > #include <freerdp/types.h> > > #ifdef _WIN32 > -#include <Windows.h> > +#include <windows.h> > #endif > > /* Window Order Header Flags */ > #define WINDOW_ORDER_TYPE_WINDOW > 0x01000000 > #define WINDOW_ORDER_TYPE_NOTIFY > 0x02000000 > > Index: libfreerdp-core/listener.c > ================================================================== > --- libfreerdp-core/listener.c > +++ libfreerdp-core/listener.c > @@ -168,13 +168,20 @@ > { > peer_addr_size = sizeof(peer_addr); > peer_sockfd = accept(listener->sockfds[i], > (struct sockaddr > *)&peer_addr, &peer_addr_size); > if (peer_sockfd == -1) > { > +#ifdef _WIN32 > + int wsa_error = WSAGetLastError(); > + > + /* No data available */ > + if (wsa_error == WSAEWOULDBLOCK) > + continue; > +#else > if (errno == EAGAIN || errno == > EWOULDBLOCK) > continue; > - > +#endif > perror("accept"); > return false; > } > > client = freerdp_peer_new(peer_sockfd); > > Index: libfreerdp-core/tcp.c > ================================================================== > --- libfreerdp-core/tcp.c > +++ libfreerdp-core/tcp.c > @@ -218,14 +218,24 @@ > > status = send(tcp->sockfd, data, length, MSG_NOSIGNAL); > > if (status < 0) > { > +#ifdef _WIN32 > + int wsa_error = WSAGetLastError(); > + > + /* No data available */ > + if (wsa_error == WSAEWOULDBLOCK) > + status = 0; > + else > + perror("send"); > +#else > if (errno == EAGAIN || errno == EWOULDBLOCK) > status = 0; > else > perror("send"); > +#endif > } > > return status; > } > > > Index: libfreerdp-core/tcp.h > ================================================================== > --- libfreerdp-core/tcp.h > +++ libfreerdp-core/tcp.h > @@ -21,11 +21,11 @@ > #ifndef __TCP_H > #define __TCP_H > > #ifdef _WIN32 > #include <winsock2.h> > -#include <Windows.h> > +#include <windows.h> > #include <ws2tcpip.h> > #endif > > #include <freerdp/types.h> > #include <freerdp/settings.h> > > Index: libfreerdp-utils/pcap.c > ================================================================== > --- libfreerdp-utils/pcap.c > +++ libfreerdp-utils/pcap.c > @@ -24,15 +24,17 @@ > #include <sys/time.h> > #else > #include <time.h> > #include <sys/timeb.h> > > +#if !defined(__MINGW32__) && !defined(__MINGW64__) > struct timeval > { > long tv_sec; > long tv_usec; > }; > +#endif > > int gettimeofday(struct timeval* tp, void* tz) > { > struct _timeb timebuffer; > _ftime (&timebuffer); > > Index: libfreerdp-utils/thread.c > ================================================================== > --- libfreerdp-utils/thread.c > +++ libfreerdp-utils/thread.c > @@ -21,11 +21,11 @@ > #include <stdlib.h> > #include <string.h> > #include <time.h> > > #ifdef _WIN32 > -#include <Windows.h> > +#include <windows.h> > #ifdef _MSC_VER > #include <process.h> > #endif > #endif > > > > > ------------------------------------------------------------------------------ > Try before you buy = See our experts in action! > The most comprehensive online learning library for Microsoft > developers > is just $99.99! Visual Studio, SharePoint, SQL - plus HTML5, > CSS3, MVC3, > Metro Style Apps, more. Free future releases when you > subscribe now! > http://p.sf.net/sfu/learndevnow-dev2 > _______________________________________________ > Freerdp-devel mailing list > Freerdp-devel@lists.sourceforge.net > https://lists.sourceforge.net/lists/listinfo/freerdp-devel > > ------------------------------------------------------------------------------ Try before you buy = See our experts in action! The most comprehensive online learning library for Microsoft developers is just $99.99! Visual Studio, SharePoint, SQL - plus HTML5, CSS3, MVC3, Metro Style Apps, more. Free future releases when you subscribe now! http://p.sf.net/sfu/learndevnow-dev2 _______________________________________________ Freerdp-devel mailing list Freerdp-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/freerdp-devel