Foro de elhacker.net

Programación => Programación General => Mensaje iniciado por: Joe Fraddy en 18 Marzo 2015, 21:24 pm



Título: Objetive C portar a Windows y Linux
Publicado por: Joe Fraddy en 18 Marzo 2015, 21:24 pm
Hola amigos, si he desarrollado aplicaciones para Mac, en Objetive C y quisiera pasarlas a Windows y Linux, hay alguna forma de hacerlo??

Y si fuera posible a FreeBSD sería muy bueno también.

Saludos :-)


Título: Re: Objetive C portar a Windows y Linux
Publicado por: Joe Fraddy en 19 Marzo 2015, 19:18 pm
Esto lo encontre en Taringa, no se si en windows es posible compilar, lo que quiero es algo multiplataforma, había optado por FreePASCAL/LAZARUS, pero me dicen que esta muy verde.

Por que objective-c y no c++ ?

objective-c tiene muchas ventajas sobre c++ en el manejo de memoria, pero la mas interesante que no trataremos por ahora es objective-c++ que permite combinar codigo de c++ dentro de objective-c.

como compilar ?


primero instalar

En FreeBSD instala : devel/gnustep


En linux depende de cada distro

en gentoo http://www.gentoo-wiki.info/GNUstep

en ubuntu es muy facil solo tienes que buscar los paquetes gobjc++ clang y gnustep-devel en synaptic.

lamentablemente no tengo tiempo para probar con mas distros lo mejor seria revisar las respectivas wikis

modo general (hay otras maneras que veremos en otros tutos)

Crea un archivo llamado

GNUmakefile

y escribe en el lo siguiente



Código:
# Sample GNUmake file



include $(GNUSTEP_MAKEFILES)/common.make



APP_NAME = HelloWorld

HelloWorld_HEADERS =

HelloWorld_OBJC_FILES = hello.m

HelloWorld_RESOURCE_FILES =



include $(GNUSTEP_MAKEFILES)/application.make


ejecute en linux :


. /usr/share/GNUstep/Makefiles/GNUstep.sh (puede cambiar en cada distro lo mejor es usar "locate GNUstep.sh" )


En FreeBSD


. /usr/local/GNUstep/System/Library/Makefiles/GNUstep.sh  (probado en FreeBSD 9)


código de ejemplo

Código
  1. #import <Foundation/Foundation.h>
  2.  
  3.  
  4. int main(int argc, char *argv[])
  5.  
  6. {
  7.  
  8.  
  9.   NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
  10.  
  11.  
  12.   NSLog(@"yoxter te saluda");
  13.  
  14.  
  15.   [pool drain];
  16.  
  17.  
  18. return 0;
  19.  
  20. }

pondremos esta código en la misma carpeta que el GNUmakefile y lo nombraremos hello.m


ejecutaremos gmake en FreeBSD y make en Linux


si todo sale bien

podremos ejecutar


openapp ./HelloWorld


y debería salir algo así


2012-07-28 06:31:21.891 HelloWorld[10483] yoxter te saluda


Bueno hemos logrado compilar ahora lo mas importante explicar el código (espero explicarlo bien )


Código:
#import <Foundation/Foundation.h>


si bienes de C notaras que es como el #include, para los que no, esto lo que hace es incluir un archivo llamado Foundation.h dentro de nuestro archivo hello.m, el Foundation.h contiene un conjunto de funciones que ya fueron hechas por otra persona y que están lista para que las usemos.

Código:
int main(int argc, char *argv[]) { }

La función main (la función principal). es lo primero que se ejecuta en nuestro programa.
no quiero indagar mucho en esto de momento para no confundir, por ahora solo diré que "int argc, char *argv[]" son usadas para detectar argumentos pasado por la linea de comandos y que las llaves "{ }" existen para delimitar la función main.


Código:
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];



 [pool drain];


También funcionan como llaves para delimitar,

lo que hace básicamente es

NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init] le pide a la computadora que le preste algo de memoria

y [pool drain] la devuelve una vez que no la necesita mas.

Código:
NSLog(@"yoxter te saluda");

si vienen de c/c++ esto es como un cout o un printf (mas parecido a este ultimo), para los que no, como se habrán dado cuenta lo que esto es mostrar por pantalla una cadena de caracteres (string), "yoxter te saluda" puede ser cambiado por cualquier cosa

como habrán notado todas las acciones dentro del main terminan como un ;


return 0;


por tradición en unix cuando un programa ha sido ejecutado correctamente devuelve un 0 (y cunado se ejecuta mal cualquier otro numero dependiendo de donde se haya producido el error). notaran que este 0 no se muestra al ejecutar programa.

después de ejecutar el programa (sin haber ejecutado otro desde la terminal), ejecuta "echo $?" y veras el 0
puedes cambiar este numero por el que quieras,


por cuestiones de tiempo solo, haré un tutorial por semana,


espero que les sirva por lo menos de base, pasen por mi blog (la fuente)

Salu2