diff --git a/DevApple.vii b/DevApple.vii new file mode 100644 index 0000000..aee5f34 Binary files /dev/null and b/DevApple.vii differ diff --git a/Makefile b/Makefile index 10c160a..a896eda 100644 --- a/Makefile +++ b/Makefile @@ -1,31 +1,92 @@ -APP=a2048 +# +# Makefile +# Apple2BuildPipelineSample +# +# Part of a sample build pipeline for Apple ][ software development +# +# Created by Quinn Dunki on 8/15/14. +# One Girl, One Laptop Productions +# http://www.quinndunki.com +# http://www.quinndunki.com/blondihacks +# -SYS=$(APP).system.sys -MAPFILE=$(APP).map +include make/head.mk -INSTALL_DIR=~/Documents/"Apple ]["/Transfer +# Customize this file to control what gets built, what machines to +# target, where in memory to put it, etc. -SRCS=$(wildcard *.c) -ASM=$(wildcard *.s) +# The name of your system or binary file to build goes here: +PGM=a2048 -C_OBJS=$(SRCS:.c=.o) -ASM_OBJS=$(ASM:.s=.o) -OBJS=$(C_OBJS) $(ASM_OBJS) +# Set the config you are building for. See these pages for details: +# http://cc65.github.io/cc65/doc/apple2.html#s4 +# http://cc65.github.io/cc65/doc/apple2enh.html#s4 +# +# Uncomment the one you want below (the first one is the default): +# MACHINE = apple2 +# MACHINE = apple2-dos33 +# MACHINE = apple2-system +# MACHINE = apple2-loader +# MACHINE = apple2-reboot +# MACHINE = apple2enh +# MACHINE = apple2enh-dos33 +# MACHINE = apple2enh-system +# MACHINE = apple2enh-loader +# MACHINE = apple2enh-reboot +MACHINE = apple2enh-system -PLATFORM=apple2enh -PLATFORM_CFG=-C apple2-system.cfg +# Uncomment and set this to your starting address in Apple ][ memory +# if necessary: +# START_ADDR = 6000 + +# Set the default CPU to assemble for. You can change this in the +# body of a .s file using control commands like ".PC02". Uncomment +# the one you want below (the first one is the default): +# CPU = 6502 +# CPU = 65SC02 +# CPU = 65C02 +# CPU = 65816 +# Note: You can assemble for 65816 in 16-bit mode but the C compiler +# will only produce 8-bit code. +CPU = 65816 + +# Any *.c files in your main project directory will automatically be +# built. But, if you have subdirectories with C files in them, you +# should add them to the list of C_SRCS to build. Do that by +# uncommenting the following line and changing "someSubDir" to match +# the subdirectory you have created. Add multiple lines like this +# for each subdirectory: +# C_SRCS += $(wildcard someSubDir/*.c) + +# Any *.s files in your main project directory will automatically be +# built. But, if you have subdirectories with assembly files in them, +# you should add them to the list of ASM_SRCS to build. Do that by +# uncommenting the following line and changing "someSubDir" to match +# the subdirectory you have created. Add multiple lines like this +# for each subdirectory: +# ASM_SRCS += $(wildcard someSubDir/*.s) + +# If you have a non-standard cc65 install, you may need to change +# some of these. Uncomment the following line and change it to the +# correct path to CC65_HOME if the default is not correct: +# export CC65_HOME := /usr/local/lib/cc65 +# +# If the path to the cc65 binaries is not correct, uncomment this +# line and change it: +# CC65_BIN = /usr/local/bin + +# If you want to add arguments to the compile commandline, add them +# to this variable: +# CFLAGS += -Os + +# If you want to add arguments to the assembly commandline, add them +# to this variable: +# ASMFLAGS += -g + +# If you want to add arguments to the link commandline, add them to +# this variable: +# LDFLAGS += -v -all: $(SYS) - -%.o: %.s - ca65 --cpu 65816 -o $@ $< - -$(SYS): $(ASM_OBJS) $(SRCS) - cl65 -t $(PLATFORM) $(PLATFORM_CFG) --mapfile $(MAPFILE) -o $(SYS) $(SRCS) $(addprefix --obj ,$(ASM_OBJS)) - -clean: - rm -f $(SYS) $(OBJS) $(GEN_ASM) $(MAPFILE) - -install: $(SYS) - cp $(SYS) $(INSTALL_DIR) +# Do not change anything else below here... +include make/tail.mk diff --git a/apple2048.xcodeproj/project.pbxproj b/apple2048.xcodeproj/project.pbxproj new file mode 100644 index 0000000..542ad97 --- /dev/null +++ b/apple2048.xcodeproj/project.pbxproj @@ -0,0 +1,205 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXFileReference section */ + 70E84C2E19B10B3100159159 /* Makefile */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = Makefile; sourceTree = ""; }; + 9D667FA919BFF85D00717163 /* anim.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; path = anim.c; sourceTree = ""; }; + 9D667FAA19BFF85D00717163 /* anim.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = anim.h; sourceTree = ""; }; + 9D667FAB19BFF85D00717163 /* apple2048.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; path = apple2048.c; sourceTree = ""; }; + 9D667FAC19BFF85D00717163 /* game.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; path = game.c; sourceTree = ""; }; + 9D667FAD19BFF85D00717163 /* game.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = game.h; sourceTree = ""; }; + 9D667FAE19BFF85D00717163 /* textpage.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = textpage.h; sourceTree = ""; }; + 9D667FAF19BFF85D00717163 /* textpage.s */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.asm; path = textpage.s; sourceTree = ""; }; + 9D667FB019BFF85D00717163 /* ui.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; path = ui.c; sourceTree = ""; }; + 9D667FB119BFF85D00717163 /* ui.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ui.h; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXGroup section */ + 70E84C2319B10B0500159159 = { + isa = PBXGroup; + children = ( + 70E84C2E19B10B3100159159 /* Makefile */, + 9D667FA919BFF85D00717163 /* anim.c */, + 9D667FAA19BFF85D00717163 /* anim.h */, + 9D667FAB19BFF85D00717163 /* apple2048.c */, + 9D667FAC19BFF85D00717163 /* game.c */, + 9D667FAD19BFF85D00717163 /* game.h */, + 9D667FAE19BFF85D00717163 /* textpage.h */, + 9D667FAF19BFF85D00717163 /* textpage.s */, + 9D667FB019BFF85D00717163 /* ui.c */, + 9D667FB119BFF85D00717163 /* ui.h */, + ); + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXLegacyTarget section */ + 70E84C2819B10B0600159159 /* apple2048 */ = { + isa = PBXLegacyTarget; + buildArgumentsString = "$(ACTION)"; + buildConfigurationList = 70E84C2B19B10B0600159159 /* Build configuration list for PBXLegacyTarget "apple2048" */; + buildPhases = ( + ); + buildToolPath = /usr/bin/make; + dependencies = ( + ); + name = apple2048; + passBuildSettingsInEnvironment = 1; + productName = Apple2BuildPipelineSample; + }; +/* End PBXLegacyTarget section */ + +/* Begin PBXProject section */ + 70E84C2419B10B0500159159 /* Project object */ = { + isa = PBXProject; + attributes = { + LastUpgradeCheck = 0600; + ORGANIZATIONNAME = "One Girl, One Laptop Productions"; + TargetAttributes = { + 70E84C2819B10B0600159159 = { + CreatedOnToolsVersion = 6.0; + }; + }; + }; + buildConfigurationList = 70E84C2719B10B0500159159 /* Build configuration list for PBXProject "apple2048" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + en, + ); + mainGroup = 70E84C2319B10B0500159159; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 70E84C2819B10B0600159159 /* apple2048 */, + ); + }; +/* End PBXProject section */ + +/* Begin XCBuildConfiguration section */ + 70E84C2919B10B0600159159 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + COPY_PHASE_STRIP = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + MACOSX_DEPLOYMENT_TARGET = 10.10; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = macosx; + }; + name = Debug; + }; + 70E84C2A19B10B0600159159 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + MACOSX_DEPLOYMENT_TARGET = 10.10; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = macosx; + }; + name = Release; + }; + 70E84C2C19B10B0600159159 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUGGING_SYMBOLS = YES; + GCC_GENERATE_DEBUGGING_SYMBOLS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + OTHER_CFLAGS = ""; + OTHER_LDFLAGS = ""; + PRODUCT_NAME = apple2048; + }; + name = Debug; + }; + 70E84C2D19B10B0600159159 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + OTHER_CFLAGS = ""; + OTHER_LDFLAGS = ""; + PRODUCT_NAME = apple2048; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 70E84C2719B10B0500159159 /* Build configuration list for PBXProject "apple2048" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 70E84C2919B10B0600159159 /* Debug */, + 70E84C2A19B10B0600159159 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 70E84C2B19B10B0600159159 /* Build configuration list for PBXLegacyTarget "apple2048" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 70E84C2C19B10B0600159159 /* Debug */, + 70E84C2D19B10B0600159159 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 70E84C2419B10B0500159159 /* Project object */; +} diff --git a/apple2048.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/apple2048.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..472c5b6 --- /dev/null +++ b/apple2048.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/apple2048.xcodeproj/project.xcworkspace/xcshareddata/Apple2BuildPipelineSample.xccheckout b/apple2048.xcodeproj/project.xcworkspace/xcshareddata/Apple2BuildPipelineSample.xccheckout new file mode 100644 index 0000000..d74be20 --- /dev/null +++ b/apple2048.xcodeproj/project.xcworkspace/xcshareddata/Apple2BuildPipelineSample.xccheckout @@ -0,0 +1,53 @@ + + + + + IDESourceControlProjectFavoriteDictionaryKey + + IDESourceControlProjectIdentifier + 1FF8E5B6-1315-475A-9CD0-FCCF194EDB92 + IDESourceControlProjectName + Apple2BuildPipelineSample + IDESourceControlProjectOriginsDictionary + + 18A177AA5F1940300C43C3E199A61FB47E277A01 + https://github.com/jeremysrand/apple2048.git + 1DDA97CB96411CB4840C13C24A3B935FA4FF778E + https://github.com/blondie7575/Apple2BuildPipeline + + IDESourceControlProjectPath + Apple2BuildPipelineSample.xcodeproj + IDESourceControlProjectRelativeInstallPathDictionary + + 18A177AA5F1940300C43C3E199A61FB47E277A01 + ../.. + 1DDA97CB96411CB4840C13C24A3B935FA4FF778E + ../../../Apple2BuildPipeline + + IDESourceControlProjectURL + https://github.com/jeremysrand/apple2048.git + IDESourceControlProjectVersion + 111 + IDESourceControlProjectWCCIdentifier + 18A177AA5F1940300C43C3E199A61FB47E277A01 + IDESourceControlProjectWCConfigurations + + + IDESourceControlRepositoryExtensionIdentifierKey + public.vcs.git + IDESourceControlWCCIdentifierKey + 1DDA97CB96411CB4840C13C24A3B935FA4FF778E + IDESourceControlWCCName + Apple2BuildPipeline + + + IDESourceControlRepositoryExtensionIdentifierKey + public.vcs.git + IDESourceControlWCCIdentifierKey + 18A177AA5F1940300C43C3E199A61FB47E277A01 + IDESourceControlWCCName + apple2048 + + + + diff --git a/apple2048.xcodeproj/project.xcworkspace/xcshareddata/apple2048.xccheckout b/apple2048.xcodeproj/project.xcworkspace/xcshareddata/apple2048.xccheckout new file mode 100644 index 0000000..02d25a7 --- /dev/null +++ b/apple2048.xcodeproj/project.xcworkspace/xcshareddata/apple2048.xccheckout @@ -0,0 +1,41 @@ + + + + + IDESourceControlProjectFavoriteDictionaryKey + + IDESourceControlProjectIdentifier + F6D1EEC0-C19C-4638-B0E8-8ED4C76B6DBD + IDESourceControlProjectName + apple2048 + IDESourceControlProjectOriginsDictionary + + 18A177AA5F1940300C43C3E199A61FB47E277A01 + https://github.com/jeremysrand/apple2048.git + + IDESourceControlProjectPath + apple2048.xcodeproj + IDESourceControlProjectRelativeInstallPathDictionary + + 18A177AA5F1940300C43C3E199A61FB47E277A01 + ../.. + + IDESourceControlProjectURL + https://github.com/jeremysrand/apple2048.git + IDESourceControlProjectVersion + 111 + IDESourceControlProjectWCCIdentifier + 18A177AA5F1940300C43C3E199A61FB47E277A01 + IDESourceControlProjectWCConfigurations + + + IDESourceControlRepositoryExtensionIdentifierKey + public.vcs.git + IDESourceControlWCCIdentifierKey + 18A177AA5F1940300C43C3E199A61FB47E277A01 + IDESourceControlWCCName + apple2048 + + + + diff --git a/apple2048.xcodeproj/project.xcworkspace/xcuserdata/jrand.xcuserdatad/UserInterfaceState.xcuserstate b/apple2048.xcodeproj/project.xcworkspace/xcuserdata/jrand.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000..e42a456 Binary files /dev/null and b/apple2048.xcodeproj/project.xcworkspace/xcuserdata/jrand.xcuserdatad/UserInterfaceState.xcuserstate differ diff --git a/apple2048.xcodeproj/project.xcworkspace/xcuserdata/jrand.xcuserdatad/WorkspaceSettings.xcsettings b/apple2048.xcodeproj/project.xcworkspace/xcuserdata/jrand.xcuserdatad/WorkspaceSettings.xcsettings new file mode 100644 index 0000000..bfffcfe --- /dev/null +++ b/apple2048.xcodeproj/project.xcworkspace/xcuserdata/jrand.xcuserdatad/WorkspaceSettings.xcsettings @@ -0,0 +1,10 @@ + + + + + HasAskedToTakeAutomaticSnapshotBeforeSignificantChanges + + SnapshotAutomaticallyBeforeSignificantChanges + + + diff --git a/apple2048.xcodeproj/xcuserdata/jrand.xcuserdatad/xcschemes/Apple2BuildPipelineSample.xcscheme b/apple2048.xcodeproj/xcuserdata/jrand.xcuserdatad/xcschemes/Apple2BuildPipelineSample.xcscheme new file mode 100644 index 0000000..c8532cb --- /dev/null +++ b/apple2048.xcodeproj/xcuserdata/jrand.xcuserdatad/xcschemes/Apple2BuildPipelineSample.xcscheme @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/apple2048.xcodeproj/xcuserdata/jrand.xcuserdatad/xcschemes/xcschememanagement.plist b/apple2048.xcodeproj/xcuserdata/jrand.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 0000000..e9f6188 --- /dev/null +++ b/apple2048.xcodeproj/xcuserdata/jrand.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,22 @@ + + + + + SchemeUserState + + Apple2BuildPipelineSample.xcscheme + + orderHint + 0 + + + SuppressBuildableAutocreation + + 70E84C2819B10B0600159159 + + primary + + + + + diff --git a/make/AppleCommander.jar b/make/AppleCommander.jar new file mode 100644 index 0000000..f74e7cb Binary files /dev/null and b/make/AppleCommander.jar differ diff --git a/make/V2Make.scpt b/make/V2Make.scpt new file mode 100644 index 0000000..26f76a9 Binary files /dev/null and b/make/V2Make.scpt differ diff --git a/make/createDiskImage b/make/createDiskImage new file mode 100755 index 0000000..784212e --- /dev/null +++ b/make/createDiskImage @@ -0,0 +1,158 @@ +#!/bin/sh + +if [ $# -lt 4 ] +then + echo USAGE: $0 ' ' + exit 1 +fi + + +APPLECOMMANDER=$1 +MACHINE=$2 +DISKIMAGE=$3 +PROGRAM=$4 + +if [ ! -f "$PROGRAM" ] +then + echo "Cannot file executable $PROGRAM" + exit 1 +fi + +case "$MACHINE" in + apple2) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=1 + RENAMELOADER=0 + DELETEBASIC=0 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2enh) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=1 + RENAMELOADER=0 + DELETEBASIC=0 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2-dos33) + TEMPLATE="make/dos33_template.dsk" + DELETELOADER=0 + RENAMELOADER=0 + DELETEBASIC=0 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2enh-dos33) + TEMPLATE="make/dos33_template.dsk" + DELETELOADER=0 + RENAMELOADER=0 + DELETEBASIC=0 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2-system) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=1 + RENAMELOADER=0 + DELETEBASIC=1 + HASHEADER=0 + FILETYPE="sys" + TARGETFILE=`basename $PROGRAM`.system + ;; + + apple2enh-system) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=1 + RENAMELOADER=0 + DELETEBASIC=1 + HASHEADER=0 + FILETYPE="sys" + TARGETFILE=`basename $PROGRAM`.system + ;; + + apple2-loader) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=0 + RENAMELOADER=1 + DELETEBASIC=1 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2-reboot) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=0 + RENAMELOADER=1 + DELETEBASIC=1 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2enh-loader) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=0 + RENAMELOADER=1 + DELETEBASIC=1 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + apple2enh-reboot) + TEMPLATE="make/prodos_template.dsk" + DELETELOADER=0 + RENAMELOADER=1 + DELETEBASIC=1 + HASHEADER=1 + FILETYPE="bin" + TARGETFILE=`basename $PROGRAM` + ;; + + *) + echo "Invalid machine type $MACHINE" + exit 1 + ;; +esac + +if [ ! -f "$TEMPLATE" ] +then + echo "Cannot file template disk image $TEMPLATE" + exit 1 +fi + +cp "$TEMPLATE" "$DISKIMAGE" + +if [ $DELETELOADER -eq 1 ] +then + java -jar "$APPLECOMMANDER" -d "$DISKIMAGE" LOADER.SYSTEM +fi + +if [ $RENAMELOADER -eq 1 ] +then + java -jar "$APPLECOMMANDER" -e "$DISKIMAGE" LOADER.SYSTEM | java -jar "$APPLECOMMANDER" -p "$DISKIMAGE" "$TARGETFILE".system sys + java -jar "$APPLECOMMANDER" -d "$DISKIMAGE" LOADER.SYSTEM +fi + +if [ $DELETEBASIC -eq 1 ] +then + java -jar "$APPLECOMMANDER" -d "$DISKIMAGE" BASIC.SYSTEM +fi + +if [ $HASHEADER -eq 1 ] +then + STARTADDR=`od -t x2 -N 2 < "$PROGRAM" | head -1 | awk '{print $2}'` + dd if="$PROGRAM" bs=4 skip=1 | java -jar "$APPLECOMMANDER" -p "$DISKIMAGE" "$TARGETFILE" $FILETYPE 0x$STARTADDR +else + java -jar "$APPLECOMMANDER" -p "$DISKIMAGE" "$TARGETFILE" $FILETYPE < "$PROGRAM" +fi diff --git a/make/dos33_template.dsk b/make/dos33_template.dsk new file mode 100644 index 0000000..ef257aa Binary files /dev/null and b/make/dos33_template.dsk differ diff --git a/make/head.mk b/make/head.mk new file mode 100644 index 0000000..6fc2e73 --- /dev/null +++ b/make/head.mk @@ -0,0 +1,30 @@ +# +# head.mk +# Apple2BuildPipelineSample +# +# Part of a sample build pipeline for Apple ][ software development +# +# Created by Quinn Dunki on 8/15/14. +# One Girl, One Laptop Productions +# http://www.quinndunki.com +# http://www.quinndunki.com/blondihacks +# + +export CC65_HOME := /usr/local/lib/cc65 + +CC65_BIN = /usr/local/bin + +CL65=$(CC65_BIN)/cl65 +CA65=$(CC65_BIN)/ca65 +CC65=$(CC65_BIN)/cc65 + +AC=make/AppleCommander.jar + +C_SRCS=$(wildcard *.c) +ASM_SRCS=$(wildcard *.s) + +MACHINE=apple2 +CPU=6502 +CFLAGS= +ASMFLAGS= +LDFLAGS= \ No newline at end of file diff --git a/make/prodos_template.dsk b/make/prodos_template.dsk new file mode 100644 index 0000000..d5c3b28 Binary files /dev/null and b/make/prodos_template.dsk differ diff --git a/make/tail.mk b/make/tail.mk new file mode 100644 index 0000000..6331f35 --- /dev/null +++ b/make/tail.mk @@ -0,0 +1,80 @@ +# +# tail.mk +# Apple2BuildPipelineSample +# +# Part of a sample build pipeline for Apple ][ software development +# +# Created by Quinn Dunki on 8/15/14. +# One Girl, One Laptop Productions +# http://www.quinndunki.com +# http://www.quinndunki.com/blondihacks +# + +export PATH := $(PATH):$(CC65_BIN) + +C_OBJS=$(C_SRCS:.c=.o) +C_DEPS=$(C_SRCS:.c=.u) +ASM_OBJS=$(ASM_SRCS:.s=.o) +ASM_LSTS=$(ASM_SRCS:.s=.lst) +OBJS=$(C_OBJS) $(ASM_OBJS) + +MAPFILE=$(PGM).map +DISKIMAGE=$(PGM).dsk + +LINK_ARGS= + +EXECCMD= + +ifneq ($(START_ADDR),) +# If the MACHINE is set to an option which does not support a variable start +# address, then error. + ifneq ($(filter $(MACHINE), apple2-system apple2enh-system),) + $(error You cannot change start address with this machine type) + endif + LDFLAGS += --start-addr 0x$(START_ADDR) +endif + +ifneq ($(filter $(MACHINE), apple2 apple2enh apple2-dos33 apple2enh-dos33),) + EXECCMD=$(shell echo brun $(PGM) | tr '[a-z]' '[A-Z]') +endif + +MACHCONFIG= -t apple2 + +ifneq ($(filter $(MACHINE), apple2enh apple2apple2enh-dos33 apple2enh-system apple2enh-loader apple2enh-reboot),) + MACHCONFIG= -t apple2enh +endif + +ifeq ($(filter $(MACHINE), apple2 apple2enh),) + MACHCONFIG += -C $(MACHINE).cfg +endif + +.PHONY: all execute clean + +all: execute + +clean: + rm -f $(PGM) + rm -f $(OBJS) + rm -f $(C_DEPS) + rm -f $(MAPFILE) + rm -f $(ASM_LSTS) + rm -f $(DISKIMAGE) + +$(PGM): $(OBJS) + $(CL65) $(MACHCONFIG) --mapfile $(MAPFILE) $(LDFLAGS) -o $(PGM) $(OBJS) + +$(DISKIMAGE): $(PGM) + make/createDiskImage $(AC) $(MACHINE) $(DISKIMAGE) $(PGM) + +execute: $(DISKIMAGE) + osascript make/V2Make.scpt $(PROJECT_DIR) $(PGM) $(PROJECT_DIR)/DevApple.vii "$(EXECCMD)" + +%.o: %.c + $(CL65) $(MACHCONFIG) $(CFLAGS) --create-dep -c -o $@ $< + sed -i .bak 's/\.s:/.o:/' $(@:.o=.u) + rm -f $(@:.o=.u).bak + +%.o: %.s + $(CL65) $(MACHCONFIG) --cpu $(CPU) $(ASMFLAGS) -l -c -o $@ $< + +-include $(C_DEPS)