Finally add support for building Mac resource forks. This adds a new kind
[u/mdw/putty] / mkfiles.pl
index faf4b1c..fabdc87 100755 (executable)
@@ -90,12 +90,17 @@ foreach $i (@prognames) {
   foreach $j (@list) {
     # Dependencies for "x" start with "x.c".
     # Dependencies for "x.res" start with "x.rc".
+    # Dependencies for "x.rsrc" start with "x.r".
     # Both types of file are pushed on the list of files to scan.
     # Libraries (.lib) don't have dependencies at all.
     if ($j =~ /^(.*)\.res$/) {
       $file = "$1.rc";
       $depends{$j} = [$file];
       push @scanlist, $file;
+    } elsif ($j =~ /^(.*)\.rsrc$/) {
+      $file = "$1.r";
+      $depends{$j} = [$file];
+      push @scanlist, $file;
     } elsif ($j =~ /\.lib$/) {
       # libraries don't have dependencies
     } else {
@@ -183,7 +188,7 @@ sub objects {
   @ret = ();
   foreach $i (@{$programs{$prog}}) {
     $x = "";
-    if ($i =~ /^(.*)\.res/) {
+    if ($i =~ /^(.*)\.(res|rsrc)/) {
       $y = $1;
       ($x = $rtmpl) =~ s/X/$y/;
     } elsif ($i =~ /^(.*)\.lib/) {
@@ -218,7 +223,7 @@ sub deps {
   @ret = ();
   $depchar ||= ':';
   foreach $i (sort keys %depends) {
-    if ($i =~ /^(.*)\.res/) {
+    if ($i =~ /^(.*)\.(res|rsrc)/) {
       next if !defined $rtmpl;
       $y = $1;
       ($x = $rtmpl) =~ s/X/$y/;
@@ -588,61 +593,95 @@ END
 print $_;
 print <<END;
 
-# -w 53 disables "unused parameter" warnings
-COptions     = -i : -i :: -w 35
-COptions_68K = {COptions} -proto strict -model far
-COptions_PPC = {COptions}
-ILinkOptions = -t 'APPL' -c 'pTTY' -br 68k -model far
+# -w 35 disables "unused parameter" warnings
+COptions     = -i : -i :: -w 35 -w err -proto strict
+COptions_68K = {COptions} -model far -opt space
+# Enabling "-opt space" for CFM-68K gives me undefined references to
+# _$LDIVT and _$LMODT.
+COptions_CFM68K = {COptions} -model cfmSeg -opt time
+COptions_PPC = {COptions} -opt size
+
+LinkOptions = -c 'pTTY' -fragname PuTTY
+LinkOptions_68K = {LinkOptions} -br 68k -model far -compact
+LinkOptions_CFM68K = {LinkOptions} -br 020 -model cfmseg -compact
+LinkOptions_PPC = {LinkOptions}
 
-Libs_68K =      "{CLibraries}StdCLib.o" \xb6
+Libs_68K =     "{CLibraries}StdCLib.far.o" \xb6
                "{Libraries}MacRuntime.o" \xb6
                "{Libraries}MathLib.far.o" \xb6
-               "{Libraries}IntEnv.o" \xb6
+               "{Libraries}IntEnv.far.o" \xb6
                "{Libraries}Interface.o" \xb6
-               "{Libraries}OpenTransport.o" \xb6
-               "{Libraries}OpenTransportApp.o" \xb6
-               "{Libraries}OpenTptInet.o" \xb6
                "{Libraries}UnicodeConverterLib.far.o"
 
-Libs_PPC =     "{SharedLibraries}InterfaceLib" \xb6
+Libs_CFM =     "{SharedLibraries}InterfaceLib" \xb6
                "{SharedLibraries}StdCLib" \xb6
-               "{SharedLibraries}MathLib" \xb6
                "{SharedLibraries}AppearanceLib" \xb6
                        -weaklib AppearanceLib \xb6
-               "{SharedLibraries}OpenTransportLib" \xb6
-                       -weaklib OTGlobalLib \xb6
-                       -weaklib OTUtilityLib \xb6
-                       -weaklib OTClientUtilLib \xb6
-                       -weaklib OTClientLib \xb6
-                       -weaklib OTStreamUnixLib \xb6
-                       -weaklib OTXTILib \xb6
-                       -weaklib OTConfigLib \xb6
-                       -weaklib OTNtvUtilLib \xb6
-                       -weaklib OTNativeClientLib \xb6
-               "{SharedLibraries}OpenTptInternetLib" \xb6
-                       -weaklib OTInetClientLib \xb6
+               "{SharedLibraries}TextCommon" \xb6
+                       -weaklib TextCommon \xb6
+               "{SharedLibraries}UnicodeConverter" \xb6
+                       -weaklib UnicodeConverter
+
+Libs_CFM68K =  {Libs_CFM} \xb6
+               "{CFM68KLibraries}NuMacRuntime.o"
+
+Libs_PPC =     {Libs_CFM} \xb6
                "{PPCLibraries}StdCRuntime.o" \xb6
                "{PPCLibraries}PPCCRuntime.o" \xb6
-               "{PPCLibraries}OpenTransportAppPPC.o" \xb6
-               "{PPCLibraries}OpenTptInetPPC.o"
-
+               "{PPCLibraries}CarbonAccessors.o"
 
 END
 print &splitline("all \xc4 " . join(" ", &progrealnames("M")), undef, "\xb6");
 print "\n\n";
 foreach $p (&prognames("M")) {
   ($prog, $type) = split ",", $p;
-  $objstr = &objects($p, "X.c.o", undef, undef);
-  print &splitline($prog . " \xc4 " . $objstr, undef, "\xb6"), "\n";
-  print &splitline("\tILink -o {Targ} {ILinkOptions} " .
-                   $objstr . " {Libs_68K}", 69, "\xb6"), "\n\n";
+
+  print &splitline("$prog \xc4 $prog.68k $prog.cfm68k $prog.ppc",
+                  undef, "\xb6"), "\n\n";
+
+  $rsrc = &objects($p, "", "X.rsrc", undef);
+
+  $objstr = &objects($p, "X.68k.o", "", undef);
+  print &splitline("$prog.68k \xc4 $objstr $rsrc", undef, "\xb6"), "\n";
+  print &splitline("\tDuplicate -y $rsrc {Targ}", 69, "\xb6"), "\n";
+  print &splitline("\tILink -o {Targ} {LinkOptions_68K} " .
+                   $objstr . " {Libs_68K}", 69, "\xb6"), "\n";
+  print &splitline("\tSetFile -a BM {Targ}", 69, "\xb6"), "\n\n";
+
+  $objstr = &objects($p, "X.cfm68k.o", "", undef);
+  print &splitline("$prog.cfm68k \xc4 $objstr", undef, "\xb6"), "\n";
+  print &splitline("\tDuplicate -y $rsrc {Targ}", 69, "\xb6"), "\n";
+  print &splitline("\tILink -o {Targ} {LinkOptions_CFM68K} " .
+                   $objstr . " {Libs_CFM68K}", 69, "\xb6"), "\n";
+  print &splitline("\tSetFile -a BM {Targ}", 69, "\xb6"), "\n\n";
+
+  $objstr = &objects($p, "X.ppc.o", "", undef);
+  print &splitline("$prog.ppc \xc4 $objstr", undef, "\xb6"), "\n";
+  print &splitline("\tDuplicate -y $rsrc {Targ}", 69, "\xb6"), "\n";
+  print &splitline("\tPPCLink -o {Targ} {LinkOptions_PPC} " .
+                   $objstr . " {Libs_PPC}", 69, "\xb6"), "\n";
+  print &splitline("\tSetFile -a BM {Targ}", 69, "\xb6"), "\n\n";
 }
-foreach $d (&deps("X.c.o", undef, "::", ":")) {
+foreach $d (&deps("", "X.rsrc", "::", ":")) {
+  next unless $d->{obj};
+  print &splitline(sprintf("%s \xc4 %s", $d->{obj}, join " ", @{$d->{deps}}),
+                  undef, "\xb6"), "\n";
+  print "\tRez ", $d->{deps}->[0], " -o {Targ} {ROptions}\n\n";
+} 
+foreach $d (&deps("X.68k.o", "", "::", ":")) {
+  next unless $d->{obj};
   print &splitline(sprintf("%s \xc4 %s", $d->{obj}, join " ", @{$d->{deps}}),
                   undef, "\xb6"), "\n";
   print "\t{C} ", $d->{deps}->[0], " -o {Targ} {COptions_68K}\n\n";
 }
-foreach $d (&deps("X.c.x", undef, "::", ":")) {
+foreach $d (&deps("X.cfm68k.o", "", "::", ":")) {
+  next unless $d->{obj};
+  print &splitline(sprintf("%s \xc4 %s", $d->{obj}, join " ", @{$d->{deps}}),
+                  undef, "\xb6"), "\n";
+  print "\t{C} ", $d->{deps}->[0], " -o {Targ} {COptions_CFM68K}\n\n";
+}
+foreach $d (&deps("X.ppc.o", "", "::", ":")) {
+  next unless $d->{obj};
   print &splitline(sprintf("%s \xc4 %s", $d->{obj}, join " ", @{$d->{deps}}),
                   undef, "\xb6"), "\n";
   # The odd stuff here seems to stop afpd getting confused.